



| Message Sequence Charts                   |                           |                                                           | REVIEW                                      |
|-------------------------------------------|---------------------------|-----------------------------------------------------------|---------------------------------------------|
| Communication/<br>local computations      | Shared<br>memory          | Message passing<br>Synchronous   Asynchronou              |                                             |
| Communicating<br>finite state<br>machines | StateCharts,<br>StateFlow |                                                           | SDL, MSCs                                   |
| Data flow model<br>⊂<br>Computational     |                           |                                                           | Kahn process<br>networks, SDF<br>Petri nets |
| graphs                                    |                           |                                                           |                                             |
| Von Neumann<br>model                      | C, C++,<br>Java           | C, C++, Java with libraries<br>CSP, ADA                   |                                             |
| Discrete event (DE)<br>model              | VHDL,<br>Simulink         | Only experimental systems, e.g. distributed DE in Ptolemy |                                             |
| BF - ES                                   |                           |                                                           | - 3-                                        |









| HMSCs                                                                                                                                                                                                                                                                                                                                                                                                                         | REVIEW                                                                                  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
| <ul> <li>HMSC is a finite state automaton whose st<br/>labeled with MSCs over (<i>P</i>, <i>M</i>, <i>Act</i>).</li> <li>Results in finite specifications involving choice, and<br/>iteration operations over a finite set of seed</li> <li>[in general, specification can be hierarchication<br/>of the automaton can be labeled by an HM<br/>an MSC.<br/>Here:<br/>flattened HMSCs, <i>message sequence grap</i></li> </ul> | ates are<br>concatenation<br>MSCs.<br>al, i.e. a state<br>SC instead of<br>ohs (MSGs).] |
| BF - ES                                                                                                                                                                                                                                                                                                                                                                                                                       | - 8-                                                                                    |





| Level     | Mandatory (solid lines)                   | Provisional (dashed lines)                         |
|-----------|-------------------------------------------|----------------------------------------------------|
| Chart     | All runs of the system satisfy the chart  | At least one run of the system satisfies the chart |
| Location  | Instance must move beyond location/time   | Instance run need not move beyond loc/time         |
| Message   | If message is sent, it will be received   | Receipt of message is not guaranteed               |
| Condition | Condition must be met;<br>otherwise abort | If condition is not met,<br>exit subchart          |







| VHDL    |  |       |
|---------|--|-------|
| BF - ES |  | - 15- |

| Communication/                            | Shared                    | Message passing                                           |                               |
|-------------------------------------------|---------------------------|-----------------------------------------------------------|-------------------------------|
| local computations                        | memory                    | Synchronous                                               | Asynchronous                  |
| Communicating<br>finite state<br>machines | StateCharts,<br>StateFlow |                                                           | SDL, MSCs                     |
| Data flow model<br>⊂                      |                           |                                                           | Kahn process<br>networks, SDF |
| Computational graphs                      |                           |                                                           | Petri nets                    |
| Von Neumann<br>model                      | C, C++,<br>Java           | C, C++, Java with libraries<br>CSP, ADA                   |                               |
| Discrete event (DE)<br>model              | VHDL,<br>Simulink         | Only experimental systems, e.g. distributed DE in Ptolemy |                               |



| Goals <ul> <li>Main goal was modeling of digital circuits</li> </ul>                                                                     |
|------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Modelling at various levels of abstraction</li> </ul>                                                                           |
| <ul> <li>I echnology-independent</li> <li>→ Re-Usability of specifications</li> </ul>                                                    |
| <ul> <li>Standard</li> </ul>                                                                                                             |
| $\Rightarrow$ Portability (different synthesis and analysis tools possible)                                                              |
| <ul> <li>Validation of designs based on the same description language for<br/>different levels of abstraction</li> </ul>                 |
| <ul> <li>Powerful description language</li> </ul>                                                                                        |
| <ul> <li>Contains also many aspects of imperative programming languages</li> <li>&gt; VHDL is able to describe software, too.</li> </ul> |
| <ul> <li>Here: Only some aspects of VHDL, not complete language.</li> </ul>                                                              |
| BF - ES - 18 -                                                                                                                           |















| Processes – Examples (1)                                                                                                                                                                                                                                        | $ \geq $ |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| <pre>architecture RTL of NANDXOR is begin     process     begin         if (C='0') then             D &lt;= A nand B after 5 ns;         else             D &lt;= A and B after 10 ns;         end if;         wait on A, B, C;     end process; end RTL;</pre> |          |
| BF - ES                                                                                                                                                                                                                                                         | - 26 -   |



| Proc              | esses – Examples (3) – P Q –<br>CLK – E                                                                                                                                                                 |        |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
|                   | <pre>architecture RTL of DFF is begin     p : process     begin         if (clk'event) and (clk='1') then             Q &lt;= D;         end if;         wait on clk;     end process p; end RTL;</pre> |        |
| CLK<br>D<br>BF-ES |                                                                                                                                                                                                         | - 28 - |























| $t_{corr} = 0$        |
|-----------------------|
|                       |
|                       |
| Transaction Lift      |
|                       |
| (a, 1, 10 us)         |
|                       |
| (6, 0, 10hr)          |
|                       |
| $(c_1, o_1, o_{NS})$  |
|                       |
| (d. A. Ous)           |
|                       |
|                       |
| a be lit:             |
| rocen activation must |
| ( ) A Eus)            |
| ( swap 2)             |
|                       |
|                       |
|                       |



| Example                                                                                                                                                                                                                      | tun = 0                                                                                                                                |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| <pre>architecture behaviour of exampl<br/>signal a : std_logic := `0`;<br/>signal b : std_logic := `1`;<br/>signal c : std_logic := `1`;<br/>signal d : std_logic := `0`;<br/>begin<br/>swap1: process(a, b)<br/>begin</pre> | The is<br>$\begin{aligned} \zeta_{120} \\ \downarrow_{121} \\ (\alpha_1 \Lambda_1 \Lambda_0 u_3) \\ (\zeta_1 0, 10 u_3) \end{aligned}$ |
| a <= b after 10 ns;<br>b <= a after 10 ns;<br>end process;                                                                                                                                                                   | PAL: (swep2, ATues)                                                                                                                    |
| swap2: process<br>begin<br>c <= d;<br>d <= c;<br>wait for 15 ns;<br>end process;                                                                                                                                             |                                                                                                                                        |
| end architecture;                                                                                                                                                                                                            |                                                                                                                                        |
| BF - ES                                                                                                                                                                                                                      | - 42 -                                                                                                                                 |

































