Technische universität dortmund fakultät für informatik informatik 12 Discrete Event Models Jian-Jia Chen (slides are based on Peter Marwedel) TU Dortmund,

Slides:



Advertisements
Similar presentations
Technische universität dortmund fakultät für informatik informatik 12 Models of computation Peter Marwedel TU Dortmund Informatik 12 Graphics: © Alexandra.
Advertisements

Peter Marwedel TU Dortmund, Informatik 12
Fakultät für informatik informatik 12 technische universität dortmund VHDL-based synthesis in XST Peter Marwedel Informatik XII, U. Dortmund.
Fakultät für informatik informatik 12 technische universität dortmund Optimizations - Compilation for Embedded Processors - Peter Marwedel TU Dortmund.
FSMs & message passing: SDL
Fakultät für informatik informatik 12 technische universität dortmund Imperative model of computation Peter Marwedel TU Dortmund, Informatik 12 Graphics:
Technische universität dortmund fakultät für informatik informatik 12 Specifications and Modeling Peter Marwedel TU Dortmund, Informatik 12 Graphics: ©
fakultät für informatik informatik 12 technische universität dortmund Additional compiler optimizations Peter Marwedel TU Dortmund Informatik 12 Germany.
Fakultät für informatik informatik 12 technische universität dortmund Petri Nets Peter Marwedel TU Dortmund, Informatik 12 Graphics: © Alexandra Nolte,
Fakultät für informatik informatik 12 technische universität dortmund Petri Nets Peter Marwedel TU Dortmund, Informatik 12 Graphics: © Alexandra Nolte,
Evaluation and Validation
Fakult ä t f ü r informatik informatik 12 technische universit ä t dortmund Data flow models Peter Marwedel TU Dortmund, Informatik 12 Graphics: © Alexandra.
Fakultät für informatik informatik 12 technische universität dortmund Specifications and Modeling Peter Marwedel TU Dortmund, Informatik 12 Graphics: ©
Fakultät für informatik informatik 12 technische universität dortmund Standard Optimization Techniques Peter Marwedel Informatik 12 TU Dortmund Germany.
Fakultät für informatik informatik 12 technische universität dortmund SDL Peter Marwedel TU Dortmund, Informatik 12 Graphics: © Alexandra Nolte, Gesine.
Technische universität dortmund fakultät für informatik informatik 12 Discrete Event Models Peter Marwedel TU Dortmund, Informatik 12 Germany
Communicating finite state machines
Technische universität dortmund fakultät für informatik informatik 12 Specifications and Modeling Peter Marwedel TU Dortmund, Informatik
Embedded Systems & Parallel Programming P. Marwedel, Univ. Dortmund/Informatik 12 + ICD/ES, 2007 Universität Dortmund A view on embedded systems.
Digital System Design Subject Name : Digital System Design Course Code : IT-314.
Embedded System, A Brief Introduction
fakultät für informatik informatik 12 technische universität dortmund Optimizations - Compilation for Embedded Processors - Peter Marwedel TU Dortmund.
Fakultät für informatik informatik 12 technische universität dortmund Classical scheduling algorithms for periodic systems Peter Marwedel TU Dortmund,
Fakultät für informatik informatik 12 technische universität dortmund Finite state machines + message passing: SDL Peter Marwedel TU Dortmund, Informatik.
Technische universität dortmund fakultät für informatik informatik 12 Embedded System Design: Embedded Systems Foundations of Cyber-Physical Systems Jian-Jia.
Fakultät für informatik informatik 12 technische universität dortmund Lab 3: Scheduling Solution - Session 10 - Heiko Falk TU Dortmund Informatik 12 Germany.
Technische universität dortmund fakultät für informatik informatik 12 Embedded Systems Jian-Jia Chen (slides are based on Peter Marwedel) TU Dortmund,
Petri Nets Jian-Jia Chen (slides are based on Peter Marwedel)
Technische universität dortmund fakultät für informatik informatik 12 Specifications, Modeling, and Model of Computation Jian-Jia Chen (slides are based.
(slides are based on Peter Marwedel)
technische universität dortmund fakultät für informatik informatik 12 Early design phases Jian-Jia Chen (slides are based on Peter Marwedel) TU Dortmund,
Technische universität dortmund fakultät für informatik informatik 12 Limits of von-Neumann (thread-based) computing Jian-Jia Chen (Slides are based on.
ENEL111 Digital Electronics
Hardware/ Software Partitioning 2011 年 12 月 09 日 Peter Marwedel TU Dortmund, Informatik 12 Germany Graphics: © Alexandra Nolte, Gesine Marwedel, 2003 These.
OBJECTIVES Learn the history of HDL Development. Learn how the HDL module is structured. Learn the use of operators in HDL module. Learn the different.
fakultät für informatik informatik 12 technische universität dortmund Test Peter Marwedel TU Dortmund Informatik 12 Germany Graphics: © Alexandra Nolte,
Digital Design with VHDL Presented by: Amir Masoud Gharehbaghi
Fakultät für informatik informatik 12 technische universität dortmund Lab 4: Exploiting the memory hierarchy - Session 14 - Peter Marwedel Heiko Falk TU.
Fakultät für informatik informatik 12 technische universität dortmund Specifications - Session 5 - Peter Marwedel TU Dortmund Informatik 12 Germany Slides.
fakultät für informatik informatik 12 technische universität dortmund Early design phases Peter Marwedel TU Dortmund, Informatik 12 Graphics: © Alexandra.
Evolution and History of Programming Languages Software/Hardware/System.
System Software (2) Peter Marwedel TU Dortmund, Informatik 12 Germany 2013 年 11 月 26 日 These slides use Microsoft clip arts. Microsoft copyright restrictions.
PTIDES: Programming Temporally Integrated Distributed Embedded Systems Yang Zhao, EECS, UC Berkeley Edward A. Lee, EECS, UC Berkeley Jie Liu, Microsoft.
1 Hardware description languages: introduction intellectual property (IP) introduction to VHDL and Verilog entities and architectural bodies behavioral,
Models of Computation for Embedded System Design Alvise Bonivento.
fakultät für informatik informatik 12 technische universität dortmund Specifications - sessions Peter Marwedel TU Dortmund Informatik 12 Germany.
Fakultät für informatik informatik 12 technische universität dortmund Modeling levels Peter Marwedel TU Dortmund, Informatik 12 Graphics: © Alexandra Nolte,
- 1 -  P. Marwedel, Univ. Dortmund, Informatik 12, 2003 Universität Dortmund Actual design flows and tools.
(1) Introduction © Sudhakar Yalamanchili, Georgia Institute of Technology, 2006.
Course Outline DayContents Day 1 Introduction Motivation, definitions, properties of embedded systems, outline of the current course How to specify embedded.
- 1 -  P. Marwedel, Univ. Dortmund, Informatik 12, 2005/6 Universität Dortmund Specifications.
CSET 4650 Field Programmable Logic Devices
Studio Session 1: Introduction to VHDL and related Tools EE19D – 25/01/2005.
Languages for HW and SW Development Ondrej Cevan.
Fall 2004EE 3563 Digital Systems Design EE 3563 VHSIC Hardware Description Language  Required Reading: –These Slides –VHDL Tutorial  Very High Speed.
Reconfigurable Computing - VHDL John Morris Computer Science/ Electrical and Computer Engineering The University of Auckland Iolanthe racing off Fremantle,
Ch.2 Part E: VHDL, SystemC EECE **** Embedded System Design.
Universität Dortmund System Software (2) Peter Marwedel TU Dortmund, Informatik 12 Germany 2012 年 11 月 28 日 These slides use Microsoft clip arts. Microsoft.
1 Hardware Description Languages: a Comparison of AHPL and VHDL By Tamas Kasza AHPL&VHDL Digital System Design 1 (ECE 5571) Spring 2003 A presentation.
1 Hardware description languages: introduction intellectual property (IP) introduction to VHDL and Verilog entities and architectural bodies behavioral,
technische universität dortmund fakultät für informatik informatik 12 Early design phases Jian-Jia Chen (slides are based on Peter Marwedel) TU Dortmund,
Technische universität dortmund fakultät für informatik informatik 12 Imperative model of computation Peter Marwedel Informatik 12 TU Dortmund Germany.
Technische universität dortmund fakultät für informatik informatik 12 Finite state machines & message passing: SDL Peter Marwedel TU Dortmund, Informatik.
Fakultät für informatik informatik 12 technische universität dortmund Prepass Optimizations - Session 11 - Heiko Falk TU Dortmund Informatik 12 Germany.
2. Specification and Modeling
Embedded System Design Specifications and Modeling
CS341 Digital Logic and Computer Organization F2003
Programming Languages
VHDL Introduction.
Specifications and Modeling
Presentation transcript:

technische universität dortmund fakultät für informatik informatik 12 Discrete Event Models Jian-Jia Chen (slides are based on Peter Marwedel) TU Dortmund, Informatik 12 Germany 2014 年 10 月 28 日 These slides use Microsoft clip arts. Microsoft copyright restrictions apply. © Springer, 2010

- 2 - technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 Models of computation considered in this course Communication/ local computations Shared memory Message passing Synchronous | Asynchronous Undefined components Plain text, use cases | (Message) sequence charts Communicating finite state machines StateChartsSDL 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 modelC, C++, JavaC, C++, Java with libraries CSP, ADA | * Classification is based on implementation of VHDL, Verilog, SystemC with central queue

- 3 - technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 Discrete event semantics Basic discrete event (DE) semantics  Queue of future actions, sorted by time  Loop: Fetch next entry from queue Perform function as listed in entry May include generation of new entries  Until termination criterion = true abcabc time action a:=5 b:=7 c:=8 a:=6 a:=9 queue

- 4 - technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 HDLs using discrete event (DE) semantics Used in hardware description languages (HDLs): Description of concurrency is a must for HW description languages!  Many HW components are operating concurrently  Typically mapped to “processes“  These processes communicate via “signals“  Examples: MIMOLA [Zimmermann/Marwedel], ~1975 … …. VHDL (very prominent example in DE modeling) One of the 3 most important HDLs: VHDL, Verilog, SystemC

- 5 - technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 VHDL VHDL = VHSIC hardware description language VHSIC = very high speed integrated circuit 1980: Def. started by US Dept. of Defense (DoD) in : first version of the language defined, based on ADA (which in turn is based on PASCAL) 1987: revised version became IEEE standard : revised IEEE standard 1999: VHDL-AMS: includes analog modeling 2006: Major extensions

- 6 - technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 Simple example (VHDL notation) Processes will wait for changes on their input ports. If they arrive, processes will wake up, compute their code and deposit changes of output signals in the event queue and wait for the next event. If all processes wait, the next entry will be taken from the event queue. gate1: process (a,b) begin c <= a nor b; end; gate2: process (a,b) begin c <= a nor b; end; S a b c c a R b

- 7 - technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 VHDL processes Delays allowed: process (a,b) begin c <= a nor b after 10 ns; end; Equivalent to process begin c <= a nor b after 10 ns; wait on a,b; end;  <=: signal assignment operator  Each executed signal assignment will result in adding entries in the projected waveform, as indicated by the (optional) delay time  Implicit loop around the code in the body  Sensitivity lists are a shorthand for a single wait on-statement at the end of the process body

- 8 - technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 The full adder as an example entity full_adder is port(a, b, carry_in: in Bit; -- input ports sum,carry_out: out Bit); --output ports end full_adder; architecture behavior of full_adder is begin sum <= (a xor b) xor carry_in after 10 ns; carry_out <= (a and b) or (a and carry_in) or (b and carry_in) after 10 ns; end behavior;

- 9 - technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 The full adder as an example - Simulation results -

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 VHDL semantics: global control According to the original VHDL standards document:  The execution of a model consists of an initialization phase followed by the repetitive execution of process statements in the description of that model.  Initialization phase executes each process once.

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 VHDL semantics: initialization At the beginning of initialization, the current time, T c is 0 ns.  The … effective value of each explicitly declared signal are computed, and the current value of the signal is set to the effective value. …  Each... process … is executed until it suspends.  The time of the next simulation cycle (… in this case … the 1st cycle), T n is calculated according to the rules of step f of the simulation cycle, below.

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 VHDL semantics: The simulation cycle (1) According to the standard, the simulation cycle is as follows: a)Stop if T n = time‘high and “nothing else is to be done” at T n. The current time, T c is set to T n. ?

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 VHDL semantics: The simulation cycle (2) a)Each active explicit signal in the model is updated. (Events may occur as a result.) Previously computed entries in the queue are now assigned if their time corresponds to the current time T c. New values of signals are not assigned before the next simulation cycle, at the earliest. Signal value changes result in events  enable the execution of processes that are sensitive to that signal. b)..

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 VHDL semantics: The simulation cycle (3) d e e a)  P sensitive to s : if event on s in current cycle: P resumes. b)Each... process that has resumed in the current simulation cycle is executed until it suspends*. * Generates future values for signal drivers.

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 VHDL semantics: The simulation cycle (4) a)Time T n of the next simulation cycle = earliest of 1.time‘high (end of simulation time). 2.The next time at which a driver becomes active 3.The next time at which a process resumes (determined by wait for statements). Next simulation cycle (if any) will be a delta cycle if T n = T c. f

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014  -simulation cycles … Next simulation cycle (if any) will be a delta cycle if T n = T c. Delta cycles are generated for delay-less models. There is an arbitrary number of  cycles between any 2 physical time instants: In fact, simulation of delay-less hardware loops might not terminate (don’t even advance T c ).

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014  -simulation cycles Simulation of an RS-Flipflop 0ns 0ns+  0ns+2  0ns+3  R S Q nQ ns 0ns+  0ns+2  0ns+3  R S Q nQ st  2nd   cycles reflect the fact that no real gate comes with zero delay.  should delay-less signal assignments be allowed at all? 3rd  gate1: process (S,Q) begin nQ <= S nor Q; end; gate2: process (R,nQ) begin Q <= R nor nQ; end;

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014  -simulation cycles and determinate simulation semantics Semantics of a <= b; b <= a; ? Separation into 2 simulation phases results in determinate semantics (  StateMate).

technische universität dortmund fakultät für informatik informatik 12 Multi-valued logic and standard IEEE 1164 Peter Marwedel TU Dortmund, Informatik 12 These slides use Microsoft clip arts. Microsoft copyright restrictions apply. © Springer, 年 11 月 06 日

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 Abstraction of electrical signals  Complete analog simulation at the circuit level would be time-consuming  We try to use digital values and DE simulation as long as possible  However, using just 2 digital values would be too restrictive (as we will see)

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 How many logic values for modeling ? Two ('0' and '1') or more? If real circuits have to be described, some abstraction of the driving strength is required.  We introduce the distinction between:  the logic level (as an abstraction of the voltage) and  the strength (as an abstraction of the current drive capability) of a signal. The two are encoded in logic values.  CSA (connector, switch, attenuator) - theory [Hayes]

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, signal strength Logic values '0' and '1'. Both of the same strength. Encoding false and true, respectively.

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, signal strengths Many subcircuits can effectively disconnect themselves from the rest of the circuit (they provide “high impedance“ values to the rest of the circuit). Example: subcircuits with open collector or tri-state outputs.

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 TriState circuits nMOS-Tristate CMOS-Tristate Source: ~phys532/lecture3.pdf  We introduce signal value 'Z', meaning “high impedance“

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, signal strengths (cont’ed) We introduce an operation #, which generates the effective signal value whenever two signals are connected by a wire. #('0','Z')='0'; #('1','Z')='1'; '0' and '1' are “stronger“ than 'Z' 1 strength According to the partial order in the diagram, # returns the smallest element at least as large as the two arguments (“Sup”). In order to define #('0','1'), we introduce 'X', denoting an undefined signal level. 'X' has the same strength as '0' and '1'. Hasse diagram

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 Application example signal value on bus = #(value from left subcircuit, value from right subcircuit) #('Z', value from right subcircuit) value from right subcircuit “as if left circuit were not there“.

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 IEEE 1164 VHDL allows user-defined value sets.  Each model could use different value sets (unpractical)  Definition of standard value set according to standard IEEE 1164: {'0', '1', 'Z', 'X', 'H', 'L', 'W', 'U', '-'} First seven values as discussed previously.  : Everything said about 7-valued logic applies.  : Combination of pre-charging and depletion transistors cannot be described in IEEE 'U': un-initialized signal; used by simulator to initialize all not explicitly initialized signals.

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 Input don‘t care '-' denotes input don't care. Suppose: except for a = b = c ='0' where f is undefined Then, we could like specifying this in VHDL as f <= select a & b & c '1' when "10-" -- first term '1' when "-11" -- second term 'X' when "000" -- 'X' ≙ ('0' or '1') here (output don't care) '0' otherwise; Simulator would check if a & b & c = "10-", i.e. if c='-'. Since c is never assigned a value of '-', this test would always fail. Simulator does not know that '-' means either '1' or '0', since it does not include any special handling for '-', (at least not for pre-VHDL’2006).

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 Function std_match Special meaning of '-' can be used in special function std_match. if std_match(a&b&c,"10-") is true for any value of c, but this does not enable the use of the compact select statement.  The flexibility of VHDL comes at the price of less convenient specifications of Boolean functions. VHDL’2006 has changed this: '-' can be used in the “intended” way in case selectors

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 Outputs tied together In hardware, connected outputs can be used: bus 'Z' 'h''0' Modeling in VHDL: resolution functions type std_ulogic is ('U', 'X','0', '1', 'Z', 'W', 'l', 'h', '-'); subtype std_logic is resolved std_ulogic; -- involve function resolved for assignments to std_logic outputs Resolution function used for assignments to bus, if bus is declared as std_logic.

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 Resolution function for IEEE 1164 type std_ulogic_vector is array(natural range<>)of std_ulogic; function resolved (s:std_ulogic_vector) return … variable result: std_ulogic:='Z'; --weakest value is default begin if (s'length=1) then return s(s'low) --no resolution else for i in s'range loop result:=resolution_table(result,s(i)) end loop end if; return result; end resolved;

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 Using # (=sup) in resolution functions constant resolution_table : stdlogic_table := ( --U X 0 1 Z W L H – ('U', 'U', 'U','U', 'U', 'U','U', 'U', 'U'), --| U | ('U', 'X', 'X','X', 'X', 'X', 'X', 'X', 'X'), --| X | ('U', 'X', '0','X', '0', '0', '0', '0', 'X'), --| 0 | ('U', 'X', 'X','1', '1', '1', '1', '1', 'X'), --| 1 | ('U', 'X', '0','1', 'Z', 'W', 'L', 'H', 'X'), --| Z | ('U', 'X', '0','1', 'W', 'W', 'W', 'H', 'X'), --| W | ('U', 'X', '0','1', 'L', 'W', 'L', 'W', 'X'), --| L | ('U', 'X', '0','1', 'H', 'W', 'W', 'H', 'X'), --| H | ('U', 'X', 'X','X', 'X', 'X', 'X', 'X', 'X') --| - | ); This table would be difficult to understand without the partial order

technische universität dortmund fakultät für informatik  JJ Chen and P.Marwedel, Informatik 12, 2014 Summary Discrete event models  Queue of future events, fetch and execute cycle, commonly used in HDLs  processes model HW concurrency  signals model communication  wait, sensitivity lists  the VHDL simulation cycle  cycles, determinate simulation Multiple-valued logic General CSA approach Application to IEEE 1164