9/30/2016 Distributed System Exploration Mirabilis Design Inc.

Slides:



Advertisements
Similar presentations
Network II.5 simulator ..
Advertisements

Interconnection Networks: Flow Control and Microarchitecture.
INPUT-OUTPUT ORGANIZATION
Packet Switching COM1337/3501 Textbook: Computer Networks: A Systems Approach, L. Peterson, B. Davie, Morgan Kaufmann Chapter 3.
1 Agenda TMA2 Feedback TMA3 T821 Bock 2. 2 Packet Switching.
CSCI 465 D ata Communications and Networks Lecture 20 Martin van Bommel CSCI 465 Data Communications & Networks 1.
Abhijit Davare 1, Qi Zhu 1, Marco Di Natale 2, Claudio Pinello 3, Sri Kanajan 2, Alberto Sangiovanni-Vincentelli 1 1 University of California, Berkeley.
Reference: Message Passing Fundamentals.
6/14/2015 How to measure Multi- Instruction, Multi-Core Processor Performance using Simulation Deepak Shankar Darryl Koivisto Mirabilis Design Inc.
1 25\10\2010 Unit-V Connecting LANs Unit – 5 Connecting DevicesConnecting Devices Backbone NetworksBackbone Networks Virtual LANsVirtual LANs.
COMPUTER NETWORKS.
INPUT-OUTPUT ORGANIZATION
 Network Segments  NICs  Repeaters  Hubs  Bridges  Switches  Routers and Brouters  Gateways 2.
CHAPTER 3 TOP LEVEL VIEW OF COMPUTER FUNCTION AND INTERCONNECTION
Data and Computer Communications Chapter 10 – Circuit Switching and Packet Switching (Wide Area Networks)
Sami Al-wakeel 1 Data Transmission and Computer Networks The Switching Networks.
 Circuit Switching  Packet Switching  Message Switching WCB/McGraw-Hill  The McGraw-Hill Companies, Inc., 1998.
Multiplexing FDM & TDM. Multiplexing When two communicating nodes are connected through a media, it generally happens that bandwidth of media is several.
15.1 Chapter 15 Connecting LANs, Backbone Networks, and Virtual LANs Copyright © The McGraw-Hill Companies, Inc. Permission required for reproduction or.
Packet switching network Data is divided into packets. Transfer of information as payload in data packets Packets undergo random delays & possible loss.
Internet Protocols (chapter 18) CSE 3213 Fall 2011.
Internet Protocol: Routing IP Datagrams Chapter 8.
Gedae, Inc. Gedae: Auto Coding to a Virtual Machine Authors: William I. Lundgren, Kerry B. Barnes, James W. Steed HPEC 2004.
Group 1 chapter 3 Alex Francisco Mario Palomino Mohammed Ur-Rehman Maria Lopez.
Techniques for List Creation (2) Data formatting and control level processing Basics for Interactive Lists Detail lists The Program Interface Interactive.
Virtual-Channel Flow Control William J. Dally
1 Packet Switching Outline Switching and Forwarding Bridges and Extended LANs.
A computer consists of five functionally independent main parts.
Data and Computer Communications Eighth Edition by William Stallings Lecture slides by Lawrie Brown Chapter 10 – Circuit Switching and Packet Switching.
Chapter 3 Part 3 Switching and Bridging
Architecture Review 10/11/2004
Behrouz A. Forouzan TCP/IP Protocol Suite, 3rd Ed.
Basic Computer Organization and Design
Instructor Materials Chapter 5: Dynamic Routing
Overview Parallel Processing Pipelining
Distributed Systems.
Advanced Computer Networks
Dynamic connection system
Packet Switching Outline Store-and-Forward Switches
CHAPTER 4 TOP LEVEL VIEW OF COMPUTER FUNCTION AND INTERCONNECTION
Chapter 6 Delivery & Forwarding of IP Packets
1 Input-Output Organization Computer Organization Computer Architectures Lab Peripheral Devices Input-Output Interface Asynchronous Data Transfer Modes.
Chapter 3 Top Level View of Computer Function and Interconnection
Chapter 3 Part 3 Switching and Bridging
THE NETWORK LAYER.
Chapter 5: Dynamic Routing
ECE 544 Protocol Design Project 2016
Interfacing Memory Interfacing.
Chapter 3: Open Systems Interconnection (OSI) Model
Multiprocessor Introduction and Characteristics of Multiprocessor
Parallel communication interface 8255
Vidur Nayyar Xueting Wang Weicong Zhao
ECEG-3202 Computer Architecture and Organization
Control Unit Introduction Types Comparison Control Memory
ECE 544 Project3 Team member: BIAO LI, BO QU, XIAO ZHANG 1 1.
Overview of Computer Architecture and Organization
Data and Computer Communications
Data Communication Networks
Viet Nguyen Jianqing Liu Yaqin Tang
Networked Real-Time Systems: Routing and Scheduling
Network Layer The network layer is responsible for the source-to-destination delivery of a packet, possibly across multiple networks (links). Whereas the.
Chapter 3 Part 3 Switching and Bridging
Delivery, Forwarding, and Routing of IP Packets
Optical communications & networking - an Overview
Software Architecture
Packet Switching Outline Store-and-Forward Switches
Chapter 5 Architectural Design.
William Stallings Computer Organization and Architecture
Multiprocessors and Multi-computers
Presentation transcript:

9/30/2016 Distributed System Exploration Mirabilis Design Inc.

Slide 2 I have added a description of the model below: The model is used to study the operation of a distributed computing system This distributed computing system contains networks connected via bridges with multiple computing nodes on each network. Each computing node contains multiple software applications or tasks. The tasks execute at an independent rate irrespective of whether data is available or not. The data for each task is in the form of either sensor input or a message from another task. Each task can have any number of message or sensors as input. After the task is complete, it can generate any number of output messages to the same or different tasks. If the message or sensor data does not arrive, as required, the task will operate with the persistent data. Model Attributes Each sensor, message and task have a task rate. Each task and message has a load processing time. Each task has a priority Number of Processors and Buses Routing Table Assignment of tasks to Processors Analysis Response time for the complete sequence of tasks Optimal allocation of tasks to processors Selection of the best priority when multiple tasks are assigned to a Processor Range of possible task/message rates and task times If you look at the pdf presentation, the following slides are important Slide 2 shows the distributed system block diagram Slide 3 shows the connection between tasks and the messages between the tasks. Slide 4 shows the computation of latency. Here you will notice that the S1 sensor writes data to a shared memory and is the data for T1 to execute. Now, T1 reads the data from the shared memory, executes and writes the data to another shared location. Message M1 reads the data from the shared location, transfers it across the network to the shared data for T2. The communication path can be within the same computing node or across the network from node to another. 9/30/2016 Mirabilis Design  Inc  Confidential

Slide 3 9/30/2016 Mirabilis Design  Inc  Confidential Design Analysis 2: Distributed System System details Multi-independent processing computers Software tasks distributed across these computers Connectivity across multiple shared networks Analysis Optimal Routing Table configuration Capacity planning Software tasks and thread distribution Resource allocation

Slide 4 9/30/2016 Mirabilis Design  Inc  Confidential Example 2: Distributed System Logical Task Flow T1T4 T3 T2 M1M2 M3 M4 Initial Assignment List of Tasks: T1, T2, T3, T4 T1, T2 -> ECU_1 T3 -> ECU_2 T4 -> ECU_3 Messages: M1, M2, M3, M4

Slide 5 9/30/2016 Mirabilis Design  Inc  Confidential Example 2: Distributed System uP-Computer/Bus Physical Mapping CAN_1 ECU_1ECU_2 Bridge_1 Bridge_2 Bridge_4 ECU_3 CAN_2 CAN_4 CAN_3 Message Assignment Messages: M1, M2, M3, M4 Internal to ECU, if Source ECU == Destination ECU CAN_N bus segments selection based on Source:Destination of Task, Routing is selected for shortest hops Dynamic allocation based on topology selection An ECU is the equivalent of a core, processor or computer.

Slide 6 9/30/2016 Mirabilis Design  Inc  Confidential End-to-End Latency T1 writes latest S1(time) when task executes. M1 reads T1(time) via Middleware Buffer when it periodically executes, sends packet through Bus structure. T2 reads M1(time) from buffer when it fires via Middleware Buffer, and if the last node, outputs end-to-end latency. T1T2 M1 SSSS Wr Rd Signals SS WrRd

Slide 7 9/30/2016 Mirabilis Design  Inc  Confidential

Slide 8 9/30/2016 Mirabilis Design  Inc  Confidential Signal Table Note: Destinations can be Tasks, or Messages

Slide 9 9/30/2016 Mirabilis Design  Inc  Confidential Task/Message Table Note: Read_Buffer, Write_Buffer columns can designate Tasks or Messages

Slide 10 9/30/2016 Mirabilis Design  Inc  Confidential Routing Table Note: Simple Source, Destination, Hop format

Slide 11 9/30/2016 Mirabilis Design  Inc  Confidential Discovery Process Discover Logical Path: M1 Source: T1 Destination: T2 Discover Physical Path: M1 Source: ECU_1 Destination: ECU_1 First Hop Array: {"NONE"} No Further Processing Required... Discover Logical Path: M2 Source: T2 Destination: T4 Discover Physical Path: M2 Source: ECU_1 Destination: ECU_3 First Hop Array: {"CAN_1"} Second Hop Array: {"CAN_2", "CAN_4"} Third Hop Array: {"CAN_3"} Fourth Hop Array: {"NONE"} Final Hop Array: {{"CAN_1", "CAN_2", "CAN_3"}, {"CAN_1", "CAN_4", "CAN_3"} } Discover Logical Path: M3 Source: T1 Destination: T3 Discover Physical Path: M3 Source: ECU_1 Destination: ECU_2 First Hop Array: {"CAN_1"} No Further Processing Required... Final Hop Array: {{"CAN_1"} } Discover Logical Path: M4 Source: T2 Destination: T3 Discover Physical Path: M4 Source: ECU_1 Destination: ECU_2 First Hop Array: {"CAN_1"} No Further Processing Required... Final Hop Array: {{"CAN_1"} }

Slide 12 9/30/2016 Mirabilis Design  Inc  Confidential End-to-End Delay End-to-End Delay is composed of the following elements: Task – Signal or Message (Signal) Middleware Buffer, Periodic Task time, ECU Execution time Message – Task Middleware Buffer, Periodic Message time, Bus(n) Transfer time ECU Execution time: Time due to arbitration/queueing, due to processing Bus Transfer time: Time due to arbitration/queueing, due to transfer for each Bus segment in a path. Note: Receive Interrupt, or Polling can be added

Slide 13 9/30/2016 Mirabilis Design  Inc  Confidential End-to-End Delay Equation

Slide 14 9/30/2016 Mirabilis Design  Inc  Confidential End-to-End Delay Histogram

Slide 15 9/30/2016 Mirabilis Design  Inc  Confidential Task, Message Execution

Slide 16 9/30/2016 Mirabilis Design  Inc  Confidential Model Assumptions Each Task will execute periodically for a specified time on an ECU, read from Middleware Buffers, or write a Signals from a prior Task from Middleware Buffers, desinated in a Table. Columns: Read_Buffer Write_Buffer Each Message will execute periodically for a specified time, read from Middleware Buffers and send via Buses to a distant Middleware Buffer. Same Columns: Read_Buffer Write_Buffer If a Task accepts two Middleware Buffers, each will be retained in an array to maintain proper end-to-end latency, or follow-on processing.

Slide 17 9/30/2016 Mirabilis Design  Inc  Confidential Model Assumptions (cont) Deployment of Tasks to ECUs and Messages to Buses Discovery process is flexible enough to allow the specification of the mapping of tasks (t1, t2, t3, t4) to ECUs and the automatic determination of the mapping of messages (m1, m2, m3, m4) to buses. User can map Tasks to ECUs in a table format. After Task completes, it will pass the transmit message, or receive message, through bus segments to continue the process, unless destination is “NONE”. Model will select M1, M2, M3… paths during initialization of model and insert the shortest path into database memory for each Task.

Slide 18 9/30/2016 Mirabilis Design  Inc  Confidential Model Advantages A Table-Driven model should scale simply by modifying the table entries. A Table-Driven model should allow entry of physical mapping, or routing, from existing sources, some pre-processing to get into source, destination, hop format. User can allocate Signals, Messages, Tasks, to perform What-If scenarios. A single Script-based block can support 32 independent periodic signals, tasks, or messages currently, and Mirabilis can provide 64 or 128 per block. One Table might be created and allocated to different tables in a model. Additional Task logic could be added, either in script form, block style, or C code. Data structure fields can capture the internal flow with variable length arrays containing physical names in one array and timestamps in a double array.