

| <b>Simulation</b>                                                                                                                        |           |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------|-----------|--|--|--|
| <ul> <li>Simulation replace the prototype with a software<br/>model</li> <li>Simulate the circuit behavior before realization</li> </ul> |           |  |  |  |
| Sons/div         IIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIII                                                                                    | 5.5us Kus |  |  |  |
|                                                                                                                                          | 2.0       |  |  |  |





































| Resolution Function                                                                                  |                                                                                                                |                                                                                                        |                                                                                             |                                                                   |                                                                   |                                                                           |                                                                   |                                                                                                   |
|------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|-------------------------------------------------------------------|-------------------------------------------------------------------|---------------------------------------------------------------------------|-------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|
| Table 8-4 Resolu                                                                                     | Table 8-4 Resolution Function Table for IEEE 9-valued Logic<br>CONSTANT resolution_table : stdlogic_table := ( |                                                                                                        |                                                                                             |                                                                   |                                                                   |                                                                           |                                                                   |                                                                                                   |
| <br> <br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>( | U X<br>'U', 'U',<br>'U', 'X',<br>'U', 'X',<br>'U', 'X',<br>'U', 'X',<br>'U', 'X',<br>'U', 'X',<br>'U', 'X',    | 0 1<br>'U', 'U<br>'X', 'X<br>'0', 'X<br>'X', '1<br>'0', '1<br>'0', '1<br>'0', '1<br>'0', '1<br>'X', 'X | Z<br>, 'U',<br>, 'X',<br>, '0',<br>, '1',<br>, 'Z',<br>, 'W',<br>, 'L',<br>, 'H',<br>, 'X', | W<br>'U',<br>'X',<br>'0',<br>'1',<br>'W',<br>'W',<br>'W',<br>'X', | L<br>'U',<br>'X',<br>'0',<br>'L',<br>'W',<br>'L',<br>'W',<br>'X', | H<br>'U',<br>'X',<br>'0',<br>'1',<br>'H',<br>'W',<br>'W',<br>'H',<br>'X', | -<br>'U')<br>'X')<br>'X')<br>'X')<br>'X')<br>'X')<br>'X')<br>'X') | <br>,   U  <br>,   X  <br>,   0  <br>,   1  <br>,   Z  <br>,   W  <br>,   L  <br>,   H  <br>,   - |
|                                                                                                      |                                                                                                                |                                                                                                        |                                                                                             |                                                                   |                                                                   |                                                                           |                                                                   | 3-21                                                                                              |

































| The veriuser.c File                                                                                                                                                                                        |  |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| <pre>#include "veriuser.h" #include "vxl_veriuser.h"</pre>                                                                                                                                                 |  |  |  |  |  |
| extern int hello();  function declaration                                                                                                                                                                  |  |  |  |  |  |
| <pre>s_tfcell veriusertfs[TF_MAXARRAY] = { /*** Template for an entry:     { usertask userfunction, data, checktf(), sizetf(), calltf(),     misctf(), "\$tfname", forwref?, Vtool?, ErrMsg? }, ***/</pre> |  |  |  |  |  |
| /*** add user entries here ***/<br>{ usertask, 0, 0, 0, hello, 0, "\$hello", 1},<br>task type<br>(0) /*** final entry must be 0 ***/                                                                       |  |  |  |  |  |
| <pre>{0} /*** final entry must be 0 ***/ }; function name 3-38</pre>                                                                                                                                       |  |  |  |  |  |























| <u>A FSM Example</u>                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                       |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| <pre>module fsm ( found, serial, clk, reset ) ; output found ; input serial, clk, reset ; reg found ; reg [1:0] current_state, next_state ; parameter [1:0]     S0 = 0,     S1 = 1,     S2 = 2 ; always @ ( reset or serial or current_state ) begin     if ( reset ) begin         next_state = S0 ;         found = 0 ; end</pre> | S0 : begin<br>if ( serial == 1 ) next_state = S2 ;<br>end<br>S2 : begin<br>if ( serial == 0 ) next_state = S1 ;<br>else next_state = S2 ;<br>end<br>S1 : begin<br>next_state = S0 ;<br>if ( serial == 1 ) found = 1 ;<br>end<br>endcase<br>end<br>end |  |  |  |  |  |
| end<br>else begin<br>next_state = current_state ;<br>found = 0 ;<br>case ( current_state )                                                                                                                                                                                                                                          | always @(posedge clk)<br>current_state = next_state ;                                                                                                                                                                                                 |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                     | endmodule 3-50                                                                                                                                                                                                                                        |  |  |  |  |  |

| Instrumented Code                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |      |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--|--|--|
| <pre>always @ ( reset or serial or current_state )     begin     if ( reset ) begin         next_state = S0 ;         found = 0 ;         \$count_block(0);         end         else begin         next_state = current_state ;         found = 0 ;         case ( current_state )         S0 : begin         if ( serial == 1 ) begin             next_state = S2 ;         \$count_block(1);         end         \$count_block(2);         end         S2 : begin         if ( serial == 0 ) begin             next_state = S1 ;         \$count_block(3);         end</pre> | <pre>else begin<br/>next_state = S2 ;<br/>\$count_block(4);<br/>end<br/>\$count_block(5);<br/>end<br/>S1 : begin<br/>next_state = S0 ;<br/>if (serial == 1) begin<br/>found = 1 ;<br/>\$count_block(6);<br/>end<br/>\$count_block(7);<br/>end<br/>endcase<br/>\$count_block(7);<br/>end<br/>endcase<br/>\$count_block(8);<br/>end<br/>\$count_block(8);<br/>end<br/>\$count_block(9);<br/>end<br/>always @ ( posedge clk ) begin<br/>current_state = next_state ;<br/>\$count_block(10);<br/>end</pre> | 2.51 |  |  |  |

| ·······                                                                                                                                                                 |                                                                                                                                                                                                                                      |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Test Patterns                                                                                                                                                           |                                                                                                                                                                                                                                      |  |  |  |  |
| original                                                                                                                                                                | instrumented                                                                                                                                                                                                                         |  |  |  |  |
| module test;<br>reg serial, clk, reset ;<br>wire found ;                                                                                                                | module test;<br>reg_serial, clk, reset ;<br>wire found ;                                                                                                                                                                             |  |  |  |  |
| fsm u1 ( found, serial, clk, reset ) ;                                                                                                                                  | fsm u1 ( found, serial, clk, reset );                                                                                                                                                                                                |  |  |  |  |
| always #5 clk=~clk;<br>initial begin<br>clk=0; reset=0; serial=0;<br>#2 reset=1;<br>#10 reset=0;<br>#20 serial=1;<br>#10 serial=0;<br>#30 \$finish;<br>end<br>endmodule | <pre>always #5 clk=~clk;<br/>initial begin<br/>clk=0; reset=0; serial=0;<br/>#2 reset=1;<br/>#10 reset=0;<br/>#20 serial=1;<br/>#10 serial=0; Add this line<br/>#30 \$finish;<br/>end<br/>initial \$setup_count;<br/>endmodule</pre> |  |  |  |  |
|                                                                                                                                                                         | 3-52                                                                                                                                                                                                                                 |  |  |  |  |

| []                 |           |                     |          |  |  |
|--------------------|-----------|---------------------|----------|--|--|
| Temporary Files    |           |                     |          |  |  |
| _jimmy_blockno.dat |           | _jimmy_execount.dat |          |  |  |
| 11 <b></b> tota    | l number  | b0 2                |          |  |  |
| b0 32 of           | blocks    | b1 1                |          |  |  |
| b1 41              |           | b2 3                |          |  |  |
| b2 40              |           | b3 1                |          |  |  |
| b3 44              |           | b4 1                |          |  |  |
| b4 45              |           | b5 2                |          |  |  |
| b5 43              |           | b6 0                |          |  |  |
| b6 49              |           | b7 1                |          |  |  |
| b7 47              |           | b8 7                |          |  |  |
| b8 36              |           | b9 9                |          |  |  |
| b9 31              |           | b10 7               |          |  |  |
| b10 55             |           |                     | unt      |  |  |
| start              | ting line | block of this block | um<br>1- |  |  |
| block of th        | uis block | block of this bloc  | К        |  |  |
| number             | iii oloek | number              |          |  |  |
| numou              |           |                     | 3-53     |  |  |

| Output Results                   |                                                                                                      |        |                                  |                                                                          |  |  |  |
|----------------------------------|------------------------------------------------------------------------------------------------------|--------|----------------------------------|--------------------------------------------------------------------------|--|--|--|
| statemer<br>count #li            | nt coverage information<br>ne text                                                                   | 1      | 40<br>41<br>41                   | S0 : begin<br>if ( serial == 1 )<br>next_state = S2 :                    |  |  |  |
| 21                               | module fsm ( found, serial, clk, reset );<br>output found;<br>input serial, cllk, reset;             |        | 42<br>43<br>44                   | end<br>S2 : begin<br>if ( serial == 0 )                                  |  |  |  |
|                                  | reg found;<br>reg [1:0] current_state;<br>reg [1:0] next_state;                                      | 1<br>1 | 44<br>45<br>45                   | next_state = S1 ;<br>else<br>next_state = S2 ;                           |  |  |  |
|                                  | parameter S0 = 0 ;<br>parameter S1 = 1 ;<br>parameter S2 = 2 ;                                       | 1      | 46<br>47<br>48                   | end<br>S1 : begin<br>next_state = S0 ;<br>if ( corial == 1 )             |  |  |  |
| 31<br>31<br>31<br>32<br>2 33     | always<br>@ ( reset or serial or current_state )<br>begin<br>if ( reset ) begin<br>next_state = S0 ; | **0**  | 49<br>49<br>50<br>51<br>52<br>53 | end<br>end<br>end<br>end                                                 |  |  |  |
| 2 34<br>35<br>36<br>7 37<br>7 38 | found = 0 ;<br>end<br>else begin<br>next_state = current_state ;<br>found = 0 :                      | 7      | 55<br>55<br>55<br>56             | always<br>@ ( posedge clk )<br>current_state = next_state ;<br>endmodule |  |  |  |
| 39                               | 39 case (current_state)                                                                              |        |                                  | statement coverage = 9 / 10 = 90% 3-54                                   |  |  |  |