# Digital Systems Design and Laboratory [Lab 1. Combinational Circuit Design]

CSIE Department
National Taiwan University

#### Outline

- **□** Introduction
- ☐ Verilog Syntax
- Simulator Installation
- ☐ Assignment

# Hardware Description Language (HDL)

- ☐ A HDL language is used to **describe** the structure and behavior of electronics circuit
- Popular languages
  - ➤ Verilog, VHDL, SystemVerilog
- Simulation
  - Use a test bench to check if the behavior meets your requirements
- Synthesis
  - > First convert HDL code into a netlist
  - ➤ Then place and route them to generate a set of masks (for IC) or a list of mapping and interconnections (for FPGA/CPLD)



#### Outline

- Introduction
- **☐** Verilog Syntax
- Simulator Installation
- ☐ Assignment

#### Module

☐ Basic functional unit, can be instantiated in other modules

```
> module <name>(<signal0>, <signal1>, <signal2>);
   output <signal0>;
   input <signal1>, <signal2>;
   // implementation
endmodule
```



#### Data Types

- ☐ wire
  - > Driven outside a process block, becomes a net after synthesis
  - > Type of input and output is wire unless specified
- ☐ reg (register)
  - > Driven in a process block, may become a net or a register after synthesis
- ☐ integer
  - > Default to be 32 bit signed, usually used in test bench
- ☐ time
  - Equivalent to reg[63:0]
- More details
  - https://en.wikibooks.org/wiki/Programmable\_Logic/Verilog\_Data\_Types

## Number Representation

通知教育者的 时

4'b1011 马胡那挺注流流 b: binary, h: hex, o: octa( 4'013 ☐ Binary (2):

☐ Octal (8):

☐ Hexadecimal (16): 4'hb

■ Decimal (10): 4'd11 == -4'd5

 $\Box$  Concatenation: {2'b10, 2'b11} == 4'b1011

More details

http://web.engr.oregonstate.edu/~traylor/ece474/beamer\_lectures/ver ilog number literals.pdf

```
Arrays([] 从代码)
                                Eff2 ar/ay 73.112 1 bit 6 } register
    Unpacked array (array) (3的数数)
           reg an_unpacked_array[2:0];
    ☐ Packed array (vector)
uming 大利人 reg[5:0] a_packed_array; ビ川板側数なる個がで
reg[0:5] a_packed_array;
   → 😚 reg[3:5] a_packed_array; // it's legal syntax!
    Example
           integer [7:0] A [3:0]; // 4 8-bit integer
           reg B [3:0][7:0] // 4*8 1-bit register
    Icarus Verilog only supports 1-dimensional arrays
           reg[5:0][4:0] two_dimensional_array[3:0][2:0]
           // syntax error in Icarus Verilog
    ■ More details
       https://verificationacademy.com/forums/ovm/difference-between-packed-
         and-unpacked-arrays
```

### Level of Description

- ☐ Verilog is to describe the structure and behavior of circuit
- Describe the operations of a circuit at various level
  - > Behavior Level 7 R1L
  - Dataflow Level
  - ➢ Gate Level
  - Switch Level
- Behavior level and dataflow level are collectively referred to as RTL (Register Transfer Level)
- ☐ Verilog only touch the first three levels in most of cases

### Verilog: Switch Level Modeling

- More details
  - https://www.slideshare.net/pradeepdevip/switch-level-modeling



```
module inv(in, out);
   output out;
   input in;
   supply0 a;
   supply1 b;
   nmos(out, a, in);
   pmos(out, b, in);
endmodule
```

### Verilog: Gate Level Modeling

- More details
  - http://access.ee.ntu.edu.tw/course/logic\_design\_94first/941%20Verilog %20HDL(Gate%20Level%20design).pdf



# Verilog: Behavioral Level Modeling

☐ Register-Transfer Level (RTL)

```
nodule mux(out, sel, in1, in2);
   output out;
   input sel, in1, in2;
   reg out;
   always @(sel, in1, in2)
       if(sel==1)
            out = in1;
       else
            out = in2;
endmodule
module mux(out, sel, in1, in2);
   output out;
   input sel, in1, in2;
   assign out = sel&in1
        | ~sel&in2;
endmodule
module mux(out, sel, in1, in2);
   output out;
   input sel, in1, in2;
   assign out = sel?in1:in2;
endmodule
```

### Concurrent and Sequential Statements

#### Concurrent statement

- "Executed" at the same time
  wire a, b, c; assign b = a; assign c = b;
- > Connect wire b to wire a and then connect wire c to wire b
  - If a changes from 0 to 1, b and c will change at the same instant

#### ■ Sequential statement

- "Executed" one by one like programming languages
  - But actually converted into equivalent concurrent statements

reg a, b, c; 
$$b = a$$
;  $c = b$ ;

- $\triangleright$  [reg a]  $\rightarrow$  [reg b]  $\rightarrow$  [reg c]
  - If output of register a changes, b changes before c
- > Sequential statements are only allowed in a process block

#### Assignment

Continuous assignment

```
Outside a process block

assign x = y & z; // continuous assignment

// same as and a0(x, y, z) // x cannot be a reg
```

- ☐ Blocking and non-blocking assignment
  - Inside a process block

```
x = y; // blocking assignment
a <= b; // non-blocking assignment
b <= a; // a and b exchanges their values</pre>
```

## Process Block (1/3)

- ☐ always and initial
  - > Statements in **always** will be executed from time 0 and repeated forever
  - > initial is the same as always except that it only executes once
- Example

```
always begin
     <statements>
end
```

# Process Block (2/3)

- Sensitivity list
- > If **always** is followed by a @, the process will be executed once whenever the expressions in the list changes, instead of repeating from
- - > always @(a or b) //old syntax
  - $\triangleright$  always @(a, b)
  - > always @(a, posedge clk, negedge enable)
  - ➤ always @a
  - ➤ always @\*



# Process Block (3/3)

☐ Flow control Example ➤ if(condition) begin <statements> end else begin <statements> end > while, case, for, repeat are also supported

#### Operators

| Verilog Operator | Name                      | Functional Group |  |
|------------------|---------------------------|------------------|--|
| []               | bit-select or part-select |                  |  |
| ()               | parenthesis               |                  |  |
| !                | logical negation          | logical          |  |
| ~                | negation                  | bit-wise         |  |
| &                | reduction AND             | reduction        |  |
|                  | reduction OR              | reduction        |  |
| ~&               | reduction NAND            | reduction        |  |
| ~                | reduction NOR             | reduction        |  |
| ^                | reduction XOR             | reduction        |  |
| ~^ or ^~         | reduction XNOR            | reduction        |  |
| +                | unary (sign) plus         | arithmetic       |  |
| -                | unary (sign) minus        | arithmetic       |  |
| {}               | concatenation             | concatenation    |  |
| {{ }}            | replication               | replication      |  |
| *                | multiply                  | arithmetic       |  |
| /                | divide                    | arithmetic       |  |
| %                | modulus                   | arithmetic       |  |

|  | Note: | no | a++ | and | a+=1 |
|--|-------|----|-----|-----|------|
|--|-------|----|-----|-----|------|

> Use a=a+1 instead

➤ More details: <a href="https://class.ece.uw.edu/cadta/verilog/operators.html">https://class.ece.uw.edu/cadta/verilog/operators.html</a>

| +        | binary plus              | arithmetic  |
|----------|--------------------------|-------------|
| '        | 1                        | arithmetic  |
| -        | binary minus             | aritimetic  |
| <<       | shift left               | shift       |
| >>       | shift right              | shift       |
| >        | greater than             | relational  |
| >=       | greater than or equal to | relational  |
| <        | less than                | relational  |
| <=       | less than or equal to    | relational  |
| ==       | logical equality         | equality    |
| !=       | logical inequality       | equality    |
| ===      | case equality            | equality    |
| !==      | case inequality          | equality    |
| &        | bit-wise AND             | bit-wise    |
| ^        | bit-wise XOR             | bit-wise    |
| ^~ or ~^ | bit-wise XNOR            | bit-wise    |
|          | bit-wise OR              | bit-wise    |
| &&       | logical AND              | logical     |
|          | logical OR               | logical     |
| ?:       | conditional              | conditional |

### Delay

- Outside a process block
  - > assign #10 a = b + c;
    - The adder has 10 time units of propagation delay
- ☐ Inside a process block
  - > #10;
    - Delay 10 units
  - > #10 a = b + c;
    - Delay 10 units of time and evaluate b+c, assign it to a
  - > a = #10 b + c;
    - Evaluate b+c and execute the next statement, assign 10 time units later
- More details
  - http://content.inflibnet.ac.in/data-server/eacharyadocuments/53e0c6cbe413016f23443704\_INFIEP\_33/7/LM/33-7-LM-V1-S1\_\_delay\_modeling.pdf

#### Test Bench

■ Macros and system tasks > include <module> `define <parameter> <value> > `timescale <unit>/<precision> > \$dumpfile("some\_file.vcd"); > \$dumpvars(<level>, <module>); Level = 0: variables in all levels • Level = 1: variables in only Level = 2: variables in and one level below it > \$display(), \$write(), \$monitor() 数似print, dubuy 用.

#### References

- ☐ Summary of Synthesizable Verilog 2001 (2 pages)
  - https://www.cl.cam.ac.uk/teaching/0910/ECAD+Arch/files/verilogcheat sheet.pdf
- ☐ Quick Reference for Verilog HDL (25 pages)
  - http://ece.eng.umanitoba.ca/undergraduate/ECE3610/Verilog%20Notes/ /VerilogQuickRef.pdf
- ☐ Language reference
  - http://verilog.renerta.com/

#### Outline

- ☐ Introduction
- ☐ Verilog Syntax
- **☐** Simulator Installation
- Assignment

#### Icarus Verilog and GTKWave

- What is Icarus Verilog?
  - http://iverilog.icarus.com/
- For Windows users
  - https://bleyer.org/icarus/
  - http://bleyer.org/icarus/iverilog-0.9.7\_setup.exe (recommended)
    - Reminder: Run the installer as administrator!
- ☐ For Linux-like OS users
  - > sudo apt-get update
  - > sudo apt-get install iverilog
  - > sudo apt-get install gtkwave
- ☐ For Mac users
  - > Use **brew install** instead

# After Downloading Successfully

#### 📆 命令提示字元

#### Commands and File Extensions

- Compile
  - > iverilog [-o compiled\_file.vvp] source\_file.v
    - If no -o option provided, a.out will be generated
- Simulate
  - >> vvp compiled\_file.vvp
    - A dump file will be generated if \$dumpfile("dump\_file.vcd") is called

各种直接着

- vcd stands for Value Change Dump
- View waveform
  - Open a new cmd window
  - >> gtkwave \_
  - Open dump\_file.vcd in GUI
  - > You can also use **gtkwave dump\_file.vcd** in the same line

新用.

# After Opening dump\_file.vcd



#### Hello World

☐ Save as wow.v

> iverilog -o wow.vvp wow.v && vvp wow.vvp

```
module wow();
   wire out;
   reg in;
   not #3 n0 (out, in);
   integer i;
   initial begin
       $display("time / in out");
       $monitor("%4d / %b %b", $time, in, out);
       for(i=0; i<5; i=i+1) begin
           $display("----");
           in <= i; // high bits will be truncated
           #10;
       end
   end
 ndmodule
```

### **Trouble Shooting**

#### ☐ For Windows users

- ➤ If you cannot run iverilog on command line, uninstall and run the installer as administrator
- ➤ If an error message pop up saying that some dll is missing, or the compiler executed but didn't generate any output file, try the latest version:
  - http://bleyer.org/icarus/iverilog-v11-20190327-x64\_setup.exe

#### Outline

- ☐ Introduction
- ☐ Verilog Syntax
- Simulator Installation
- **☐** Assignment

#### Half Adder and Full Adder

```
half adder

HA

> assign {C, S} = A + B;

In the odder

FA
```

- > assign {Cout, S} = A + B + Cin;
- More details
  - https://www.electronics-tutorials.ws/combination/comb\_7.html



#### Ripple-Carry Adder

- Notice that carry<sub>n</sub> depends on carry<sub>n-1</sub>
  - Where is the longest propagation path?



- More details
  - https://en.wikipedia.org/wiki/Adder\_(electronics)

## Carry-Lookahead Adder (1/2)



# Carry-Lookahead Adder (2/2)

#### Carry lookahead method

$$\triangleright$$
  $G_i = A_i \cdot B_i$ 

 $\triangleright$  P<sub>i</sub> can be either:

$$P_i = A_i \oplus B_i$$

$$P_i = A_i + B_i$$

#### ☐ Implementation details

$$\triangleright$$
 C<sub>1</sub> = G<sub>0</sub> + P<sub>0</sub> · C<sub>0</sub>

$$\triangleright$$
 C<sub>2</sub> = G<sub>1</sub> + G<sub>0</sub> · P<sub>1</sub> + C<sub>0</sub> · P<sub>0</sub> · P<sub>1</sub>

$$ightharpoonup C_3 = G_2 + G_1 \cdot P_2 + G_0 \cdot P_1 \cdot P_2 + C_0 \cdot P_0 \cdot P_1 \cdot P_2$$

$$\triangleright$$
 C<sub>4</sub> = G<sub>3</sub> + G<sub>2</sub> · P<sub>3</sub> + G<sub>1</sub> · P<sub>2</sub> · P<sub>3</sub> + G<sub>0</sub> · P<sub>1</sub> · P<sub>2</sub> · P<sub>3</sub> + C<sub>0</sub> · P<sub>0</sub> · P<sub>1</sub> · P<sub>2</sub> · P<sub>3</sub>

#### Reference

https://en.wikipedia.org/wiki/Carry-lookahead\_adder

# Requirements (1/2)

- ☐ Implement a 3-bit ripple-carry adder rca\_gl
  - Use gate-level modeling
  - Follow the architecture in page 31
  - Only the gates provided in gates.v (with delays) and FA, HA module in adders.v are allowed to use
- ☐ Implement a 3-bit carry-lookahead adder cla\_gl
  - Use gate-level modeling
  - > P has two ways to implement, try and choose one that have less delay
  - ➤ Only the gates provided in **gates.v** (with delays) and FA, HA module in adders.v are allowed to use

# Requirements (2/2)

- ☐ Attach your source codes to your Homework 3
- Show the waveform of **cla\_gl** on input transition from 000 + 000 + 0 to 000 + 111 + 1.
  - > You should select all the input and output signals of cla\_gl module
- ☐ Find the maximum propagation delay of rca\_gl and cla\_gl
  - > And find one of the corresponding input transitions 過差層別質級人
- □ Assume that only 2-input gates are used, derive the number of levels needed in an n-bit carry-lookahead adder as a function of n
- ☐ Hand in along with Homework 3

#### Hints

- ☐ The outputs of adder\_rtl and cla\_gl should be the same at steady state
  - ➤ If they are different, there are some mistakes in **cla\_gl** since it is more complicated
- ☐ Implement your adders in adders.v
  - > The output and input signals are given
- ☐ Do not modify gates.v and HA/FA module
- Only minor changes should be done to lab1.v
- ☐ Use system tasks and GTKWave to debug

# Waveform Screenshot example



# Q&A