Top Banner
technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 年 10 年 30 年 These slides use Microsoft clip arts. Microsoft copyright restrictions © Springer, 2010
48

Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

Mar 26, 2015

Download

Documents

Steven Donahue
Welcome message from author
This document is posted to help you gain knowledge. Please leave a comment to let me know what you think about it! Share it to your friends and learn new things together.
Transcript
Page 1: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

technische universität dortmund

fakultät für informatikinformatik 12

FSMs & message passing: SDL

Peter MarwedelTU Dortmund,Informatik 12

2012 年 10 月 30 日These slides use Microsoft clip arts. Microsoft copyright restrictions apply.

© S

prin

ger,

201

0

Page 2: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 2 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Models of computation considered in this course

Communication/local computations

Shared memory

Message passingSynchronous | Asynchronous

Undefined components

Plain text, use cases | (Message) sequence charts

Communicating finite state machines

StateCharts SDL

Data flow Scoreboarding + Tomasulo Algorithm ( Comp.Archict.)

Kahn networks, SDF

Petri nets C/E nets, P/T nets, …

Discrete event (DE) model

VHDL*, Verilog*, SystemC*, …

Only experimental systems, e.g. distributed DE in Ptolemy

Von Neumann model C, C++, Java C, C++, Java with librariesCSP, ADA |

* Based on implementation of VHDL, Verilog..

Page 3: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 3 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

SDL

SDL used here as a (prominent) example of a model of computation based on asynchronous message passing communication.

SDL is appropriate also for distributed systems.

Just like StateCharts, it is based on the CFSM model of computation; each FSM is called a process.

Provides textual and graphical formats to please all users.

Page 4: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 4 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

SDL-representation of FSMs/processes

output

input

state

Page 5: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 5 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Communication among SDL-FSMs

Communication is based on message-passing of signals (=inputs+outputs), assuming a potentially indefinitely large FIFO-queue. Each process fetches next

signal from FIFO,

checks if signal enables transition,

if yes: transition takes place,

if no: signal is ignored (exception: SAVE-mechanism).

Implementation requires bound for the maximum length of FIFOs

Page 6: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 6 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Determinate?

Let signals be arriving at FIFO at the same time:Order in which they are stored, is unknown:

All orders are legal: simulators can show different behaviors for the same input, all of which are correct.

Page 7: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 7 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Operations on data

Variables can be declared locally for processes.Their type can be predefined or defined in SDL itself.SDL supports abstract data types (ADTs). Examples:

Page 8: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 8 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Process interaction diagrams

Interaction between processes can be described in process interaction diagrams (special case of block diagrams).In addition to processes, these diagrams contain channels and declarations of local signals. Example:

,B

Page 9: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 9 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Hierarchy in SDL

Process interaction diagrams can be included in blocks. The root block is called system.

Processes cannot contain other processes, unlike in StateCharts.

Page 10: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 10 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Timers

Timers can be declared locally. Elapsed timers put signal into queue. RESET removes timer (also from FIFO-queue).

Not necessarily processed immediately.

Page 11: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 11 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Additional language elements

SDL includes a number of additional language elements, like

procedures

creation and termination of processes

advanced description of data

More features added for SDL-2000

Page 12: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 12 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Application: description of network protocols

Page 13: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 13 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Larger example: vending machine

Machine° selling pretzels, (potato) chips, cookies, and doughnuts:

accepts nickels, dime, quarters, and half-dollar coins.

Not a distributed application.

° [J.M. Bergé, O. Levia, J. Roullard: High-Level System Modeling, Kluwer Academic Publishers, 1995]

Page 14: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 14 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Overall view of vending machine

Page 15: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 15 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Decode Requests

p

Page 16: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 16 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

ChipHandler

no

yes

yes

no

Page 17: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 17 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

History

Dates back to early 1970s,

Formal semantics defined in the late 1980s,

Defined by ITU (International Telecommunication Union): Z.100 recommendation in 1980Updates in 1984, 1988, 1992, 1996 and 1999

SDL-2000 a significant update (not well accepted)

Becoming less popular

Page 18: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 18 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Evaluation & summary

FSM model for the components, Non-blocking message passing for communication, Implementation requires bound for the maximum length of

FIFOs; may be very difficult to compute, Excellent for distributed applications (used for ISDN), Commercial tools available (see http://www.sdl-forum.org) Not necessarily determinate Timer concept adequate just for soft deadlines, Limited way of using hierarchies, Limited programming language support, No description of non-functional properties, Examples: small network + vending machine

Page 19: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

technische universität dortmund

fakultät für informatikinformatik 12

Data flow models

Peter MarwedelTU Dortmund,Informatik 12

2012 年 10 月 22 日These slides use Microsoft clip arts. Microsoft copyright restrictions apply.

© S

prin

ger,

201

0

Page 20: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 20 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Models of computation considered in this course

Communication/local computations

Shared memory

Message passingSynchronous | Asynchronous

Undefined components

Plain text, use cases | (Message) sequence charts

Communicating finite state machines

StateCharts SDL

Data flow Scoreboarding + Tomasulo Algor. ( Comp.Archict.)

Kahn networks, SDF

Petri nets C/E nets, P/T nets, …

Discrete event (DE) model

VHDL, Verilog, SystemC, …

Only experimental systems, e.g. distributed DE in Ptolemy

Von Neumann model C, C++, Java C, C++, Java with librariesCSP, ADA |

Page 21: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 21 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Data flow as a “natural” model of applications

Example: Video on demand system

www.ece.ubc.ca/~irenek/techpaps/vod/vod.html

Page 22: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 22 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Data flow modeling

Definition: Data flow modeling is … “the processof identifying, modeling and documenting how data moves around an information system.Data flow modeling examines processes (activities that transform data from one form to

another), data stores (the holding areas for data), external entities (what sends data into a system or receives

data from a system, and data flows (routes by which data can flow)”.

[Wikipedia: Structured systems analysis and design method. http://en.wikipedia.org/wiki/Structured Systems Analysis and Design Methodology, 2010 (formatting added)].

Page 23: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 23 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Kahn process networks (KPN)

Each component is modeled as a program/task/process, (underlying FSM is inconvenient: possibly many states)

Communication is by FIFOs; no overflow considered writes never have to wait, reads wait if FIFO is empty.

Only one sender and one receiver per FIFO no SDL-like conflicts at FIFOs

Page 24: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 24 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Example

© R. Gupta (UCSD), W. Wolf (Princeton), 2003

levi animation

Process f(in int u, in int v, out int w){ int i; bool b = true; for (;;) { i= b ? read(u) : read(v); //read returns next token in FIFO, waits if empty send (i,w); //writes a token into a FIFO w/o blocking b = !b; }

Page 25: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 25 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Properties of Kahn process networks

Communication is only via channels(no shared variables)

Mapping from 1 input channelto 1 output channel possible;

Channels transmit information within an unpredictable but finite amount of time;

In general, execution times are unknown.

Page 26: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 26 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Key beauty of KPNs (1)

A process cannot check for available data before attempting a read (wait).

A process cannot wait for data for >1 port at a time.

if nonempty(p1) then read(p1)else if nonempty(p2) then read(p2); p1 p2

read(p1|p2);

Processes have to commit to wait for data from a particular port;

Page 27: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 27 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Key beauty of KPNs (2)

Therefore, the order of reads does not depend on the arrival time (but may depend on data).

Therefore, Kahn process networks are determinate (!); for a given input, the result will always the same, regardless of the speed of the nodes.

Many applications in embedded system design:Any combination of fast and slow simulation & hardware prototypes always gives the same result.

p1 p2

Page 28: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 28 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Computational power and analyzability

It is a challenge to schedule KPNs without accumulating tokens

KPNs are Turing-complete (anything which can be computed can be computed by a KPN)

KPNs are computationally powerful, but difficult to analyze (e.g. what’s the maximum buffer size?)

Number of processes is static (cannot change)

Page 29: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 29 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

More information about KPNs

http://ls12-www.cs.tu-dortmund.de/teaching/download/ levi/index.html: Animation

http://en.wikipedia.org/wiki/Kahn_process_networks

See also S. Edwards: http://www.cs.columbia.edu/~sedwards/classes/2001/w4995-02/presentations/dataflow.ppt

Page 30: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 30 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

SDF

Less computationally powerful, but easier to analyze:

Synchronous data flow (SDF).

Synchronous= global clock controlling “firing” of nodes

Again using asynchronous message passing = tasks do not have to wait until output is accepted.

Page 31: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 31 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

(Homogeneous-)Synchronous data flow (SDF)

Nodes are called actors. Actors are ready, if the necessary number of input tokens

exists and if enough buffer space at the output exists Ready actors can fire (be executed).

Execution takes a fixed, known time.Actually, this is a case of homogeneous synchronous data flow models (HSDF): # of tokens per firing the same.

1

1

Page 32: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 32 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

(Non-homogeneous-)Synchronous data flow (SDF) (1)

In the general case, a number of tokens can be produced/ consumed per firing

2

A ready, can fire (does not have to)

3

Page 33: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 33 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

(Non-homogeneous-)Synchronous data flow (SDF) (2)

In the general case, a number of tokens can be produced/ consumed per firing

2

B ready, can fire

3

Page 34: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 34 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

(Non-homogeneous-)Synchronous data flow (SDF) (3)

In the general case, a number of tokens can be produced/ consumed per firing

2

A ready, can fire

3

Page 35: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 35 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

(Non-homogeneous-)Synchronous data flow (SDF) (4)

In the general case, a number of tokens can be produced/ consumed per firing

2

B ready, can fire

3

Page 36: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 36 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

(Non-homogeneous-)Synchronous data flow (SDF) (5)

In the general case, a number of tokens can be produced/ consumed per firing

2

B ready, can fire

3

Page 37: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 37 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

(Non-homogeneous-)Synchronous data flow (SDF) (6)

In the general case, a number of tokens can be produced/ consumed per firing

2

1 period complete, A ready, can fire

Replace FIFO by back-edge

3

Page 38: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 38 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Actual modeling of buffer capacity

The capacity of buffers can be modeled easier: as a backward edge where (initial number of tokens = buffer capacity).

323

Firing rate depends on # of tokens …

Page 39: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 39 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Multi-rate models & balance equations(one for each channel)

MfNf BA number of tokens consumed

number of firings per “iteration”number of tokens produced

Adopted from: ptolemy.eecs.berkeley.edu/presentations/03/streamingEAL.ppt

Decidable: buffer memory requirements deadlock

Schedulable statically

fire B { … consume M …}

fire A { … produce N …}

channel

N MFIFO

Page 40: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 40 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Parallel Scheduling of SDF Models

A

C

D

B

Sequential Parallel

SDF is suitable for automated mapping onto parallel processors and synthesis of parallel circuits.

Many scheduling optimization problems can be formulated.

Source: ptolemy.eecs.berkeley.edu/presentations/03/streamingEAL.ppt

Page 41: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 41 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Expressiveness of data flow MoCs

CSDF=Cyclo static data flow (rates vary in a cyclic way)

Turing-complete

Not Turing-complete

[S. Stuijk, 2007]

Page 42: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 42 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

The expressiveness/analyzability conflict

[S. Stuijk, 2007]

Page 43: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 43 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Similar MoC: Simulink- example -

Semantics? “Simulink uses an idealized timing model for block execution and communication. Both happen infinitely fast at exact points in simulated time. Thereafter, simulated time is advanced by exact time steps. All values on edges are constant in between time steps.” [Nicolae Marian, Yue Ma][mathworks

]

[mathworks]

Page 44: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 44 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Page 45: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 45 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Code automatically generated

© MathWorks, http://www.mathworks.de/ cmsimages/rt_forloop_code_wl_7430.gif

Starting point for“model-based design”

Page 46: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 46 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Page 47: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 47 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Actor languages

© E. Lee, Berkeley

Page 48: Technische universität dortmund fakultät für informatik informatik 12 FSMs & message passing: SDL Peter Marwedel TU Dortmund, Informatik 12 2012 10 30.

- 48 -technische universitätdortmund

fakultät für informatik

P.Marwedel, Informatik 12, 2012

Summary

Data flow model of computation

Motivation, definition

Kahn process networks (KPNs)

(H/C)SDF

Visual programming languages

• Simulink, Real Time Workshop, LabVIEW