













| Structural mod                   | lel                                                                                                                   |   |
|----------------------------------|-----------------------------------------------------------------------------------------------------------------------|---|
| input<br>output                  |                                                                                                                       |   |
| inverter<br>and_gate<br>and_gate | <pre>invA (abar, a);<br/>invB (bbar, b);<br/>and1 (t1, a, bbar);<br/>and2 (t2, b, abar);<br/>or1 (out, t1, t2);</pre> |   |
| endmodule                        |                                                                                                                       |   |
| Autumn 2010                      | CSE370 - IX - Hardware Description Languages                                                                          | 8 |



| Simple behavioral model                                                                                           |                                                                                                                                                                                 |
|-------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>always block</li> <li>module xor_gate (out, a, b<br/>input a, b;<br/>output out;<br/>reg out;</li> </ul> | ));                                                                                                                                                                             |
| always @(a or b) begin<br>#6 out = a ^ b;<br>end<br>endmodule                                                     | specifies when block is executed<br>ie. triggered by which signals<br>NOTE: this "or" is not a Boolean OR,<br>it just says: re-evaluate this<br>expression whever a or b change |
| Autumn 2010 CSE370 - IX - Hardware De                                                                             | escription Languages 10                                                                                                                                                         |













| Verilog<br>Operator | Name                                                          | Functional Group                              | >=            | greater than<br>greater than or equal to | Relational<br>Relational         |
|---------------------|---------------------------------------------------------------|-----------------------------------------------|---------------|------------------------------------------|----------------------------------|
| 0                   | bit-select or part-select                                     |                                               | < <=          | less than<br>less than or equal to       | Relational<br>Relational         |
| ()                  | parenthesis                                                   |                                               | ==            | logical equality<br>logical inequality   | Equality<br>Equality             |
| !<br>~<br>          | logical negation<br>negation<br>reduction AND<br>reduction OR | Logical<br>Bit-wise<br>Reduction<br>Reduction |               | case equality<br>case inequality         | Equality<br>Equality<br>Equality |
| ~&<br>~             | reduction NAND<br>reduction NOR                               | Reduction<br>Reduction                        | &             | bit-wise AND                             | Bit-wise                         |
| ^ `<br>~^ or ^~     | reduction XOR<br>reduction XNOR                               | Reduction<br>Reduction                        | ^<br>^~ or ~^ | bit-wise XOR<br>bit-wise XNOR            | Bit-wise<br>Bit-wise             |
| +                   | unary (sign) plus<br>unary (sign) minus                       | Arithmetic<br>Arithmetic                      | 1             | bit-wise OR                              | Bit-wise                         |
| {}                  | concatenation                                                 | Concatenation                                 | &&            | logical AND                              | Logical                          |
| {{ }}               | replication                                                   | Replication                                   | 11            | logical OR                               | Logical                          |
| *<br>/<br>%         | multiply<br>divide<br>modulus                                 | Arithmetic<br>Arithmetic<br>Arithmetic        | ?:            | conditional                              | Conditional                      |
| + -                 | binary plus<br>binary minus                                   | Arithmetic<br>Arithmetic                      | Similar       | to C operators                           |                                  |
| ~~                  | shift left<br>shift right                                     | Shift<br>Shift                                |               |                                          |                                  |























```
Functions
   Use functions for complex combinational logic
 module and_gate (out, in1, in2);
                   in1, in2;
    input
    output
                    out;
    assign out = myfunction(in1, in2);
    function myfunction;
     input in1, in2;
                                          Benefit:
     begin
                                          Compiler will fail if function
       myfunction = in1 & in2;
     end
                                          does not generate a result
    endfunction
 endmodule
Autumn 2010
                    CSE370 - IX - Hardware Description Languages
                                                                   29
```





