







| High-level view of Verilog                                                                                                                 |                                                                    |                                               |                     |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|-----------------------------------------------|---------------------|--|--|--|--|
| Verilog descriptions look like programs:                                                                                                   |                                                                    |                                               |                     |  |  |  |  |
|                                                                                                                                            | C/C++                                                              | Verilog                                       |                     |  |  |  |  |
|                                                                                                                                            | Function                                                           | Module                                        |                     |  |  |  |  |
|                                                                                                                                            | Procedure<br>Parameters                                            | Ports                                         |                     |  |  |  |  |
|                                                                                                                                            | Variables                                                          | Wires/Regs                                    |                     |  |  |  |  |
| <ul><li>Modules reand use (in</li><li>Block struct</li></ul>                                                                               | esemble subroutin<br>nstantiate) it in mul<br>cture is a key princ | es in that you can wr<br>tiple places<br>iple | ite one description |  |  |  |  |
| <ul> <li>Use hie</li> </ul>                                                                                                                | <ul> <li>Use hierarchy/modularity to manage complexity</li> </ul>  |                                               |                     |  |  |  |  |
| <ul> <li>But they aren't 'normal' programs</li> <li>Module evaluation is concurrent (every block has its own "program counter")</li> </ul> |                                                                    |                                               |                     |  |  |  |  |
| EECS 427 F08                                                                                                                               |                                                                    | Discussion 6                                  | 5                   |  |  |  |  |









| Reserved Keywords                                                                                          |                                                                                                                                  |                                                                                                                          |                                                                                                                       |                                                                                                                |  |  |  |  |
|------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|--|--|--|--|
| The following is a list of the Verilog reserved keywords:                                                  |                                                                                                                                  |                                                                                                                          |                                                                                                                       |                                                                                                                |  |  |  |  |
| always<br>and<br>assign<br>attribute<br>begin<br>buf<br>bufif0<br>bufif1<br>case<br>casex<br>casez<br>cmos | endmodule<br>endprimitive<br>endspecify<br>endtable<br>endtask<br>event<br>for<br>force<br>forever<br>fork<br>function<br>highz0 | medium<br>module<br>nand<br>negedge<br>nmos<br>nor<br>not<br>not<br>not<br>f0<br>not<br>if1<br>or<br>output<br>parameter | reg<br>release<br>repeat<br>rnmos<br>rpmos<br>rtran<br>rtranif0<br>rtranif1<br>scalared<br>signed<br>small<br>specify | tranif0<br>tranif1<br>tri<br>tri0<br>tri1<br>triand<br>trior<br>trireg<br>unsigned<br>vectored<br>wait<br>wand |  |  |  |  |
| EECS 427 F08                                                                                               |                                                                                                                                  | Discussion 6                                                                                                             |                                                                                                                       | 10                                                                                                             |  |  |  |  |

| leassign     | highzlpmos  | param     | spec     | weak0 |
|--------------|-------------|-----------|----------|-------|
| default      | if          | posedge   | strength | weak1 |
| defparam     | ifnone      | primitive | strong0  | while |
| disable      | initial     | pull0     | strong1  | wire  |
| edge         | inout       | pull1     | supply0  | wor   |
| else         | input       | pulldown  | supply1  | xnor  |
| end          | integer     | pullup    | table    | xor   |
| endattribute | join        | remos     | task     |       |
| endcase      | large       | real      | time     |       |
| endfunction  | macromodule | realtime  | tran     |       |
|              |             |           |          |       |
|              |             |           |          |       |
|              |             |           |          |       |
|              |             |           |          |       |
|              |             |           |          | 11    |

| Numbers                                                                                                                                                       |                                                                                                 |    |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|----|
| <ul> <li>Number notation:</li> <li><size> ' <base formation<="" li=""/> </size></li></ul>                                                                     | t> <number></number>                                                                            |    |
| <ul> <li>Examples:         <ul> <li>4'b1111 // 4 bit</li> <li>12'habc //12 bit</li> <li>16'd255 //16 bit</li> </ul> </li> <li>Z is high impedance,</li> </ul> | : binary number<br>: hexadecimal number<br>: decimal number<br>X is don't care, ? = 0 or 1 or X |    |
| EECS 427 F08                                                                                                                                                  | Discussion 6                                                                                    | 12 |





































## Positive edge-triggered registers with resets

```
module ff1(d,clk,reset,q)
input d, clk, reset;
output q;
reg q;
always @(posedge clk)
if (reset == 1)
    q <= 0;
else
    q <= d;
    OR
always @(posedge clk or posedge reset)
if (reset) q <= 0;
else
    q <= d;
    q <= d;
</pre>
```

endmodule EECS 427 F08

Discussion 6

31