

# Introduction to Verilog

# Review on Digital Logic Design



Figure 2.8: Gate network corresponding to  $E(x_2, x_1, x_0) = \sum m(1, 2, 6)$ .

$x_2'x_1'x_0 + +$



Figure 8.12: D flip-flop and its state diagram.





Figure 8.12: D flip-flop and its state diagram.



Input:  $x(t) \in \{a, b, c\}$   
 Output:  $z(t) \in \{0, 1\}$   
 State:  $s(t) \in \{A, B, C, D\}$   
 Initial state:  $s(0) = A$

Coding:

Functions: The state-transition and output functions

| PS | Input   |         |         |
|----|---------|---------|---------|
|    | $x = a$ | $x = b$ | $x = c$ |
| A  | C,0     | B,1     | B,0     |
| B  | D,0     | B,0     | A,1     |
| C  | A,0     | D,1     | D,0     |
| D  | B,0     | A,0     | D,1     |
|    | $NS, z$ |         |         |

| Input code |       |       | State code |       |       |
|------------|-------|-------|------------|-------|-------|
| $x$        | $x_1$ | $x_0$ | $s$        | $y_1$ | $y_0$ |
| a          | 0     | 1     | A          | 0     | 0     |
| b          | 1     | 0     | B          | 1     | 0     |
| c          | 1     | 1     | C          | 0     | 1     |
|            |       |       | D          | 1     | 1     |

- State-transition and output functions

| $PS$     | $x_1x_0$    |      |      |
|----------|-------------|------|------|
| $y_1y_0$ | 01          | 10   | 11   |
| 00       | 01,0        | 10,1 | 10,0 |
| 10       | 11,0        | 10,0 | 00,1 |
| 01       | 00,0        | 11,1 | 11,0 |
| 11       | 10,0        | 00,0 | 11,1 |
|          | $Y_1Y_0, z$ |      |      |
|          | NS, Output  |      |      |



- State-transition and output functions

| $PS$     | $x_1x_0$    |      |      |
|----------|-------------|------|------|
| $y_1y_0$ | 01          | 10   | 11   |
| 00       | 01,0        | 10,1 | 10,0 |
| 10       | 11,0        | 10,0 | 00,1 |
| 01       | 00,0        | 11,1 | 11,0 |
| 11       | 10,0        | 00,0 | 11,1 |
|          | $Y_1Y_0, z$ |      |      |
|          | NS, Output  |      |      |

$$Y_1: \begin{array}{c} x_0 \\ \hline - & 0 & 1 & 1 \\ - & 0 & 1 & 1 \\ - & 1 & 1 & 0 \\ - & 1 & 0 & 1 \\ \hline x_1 \end{array} \quad y_0$$

$(y_1, y_0) \setminus (x_1, x_0)$ : 00 01 11 10  
 00 : - , 1 , 0, 0  
 01 : - , 0, 1, 1  
 11: -  
 10 : -

- State-transition and output functions

| $PS$     | $x_1x_0$    |      |      |
|----------|-------------|------|------|
| $y_1y_0$ | 01          | 10   | 11   |
| 00       | 01,0        | 10,1 | 10,0 |
| 10       | 11,0        | 10,0 | 00,1 |
| 01       | 00,0        | 11,1 | 11,0 |
| 11       | 10,0        | 00,0 | 11,1 |
|          | $Y_1Y_0, z$ |      |      |
|          | NS, Output  |      |      |

$$Y_1: \begin{array}{c} \overline{x_0} \\ \begin{array}{|c|c|c|} \hline - & 0 & 1 & 1 \\ \hline - & 0 & 1 & 1 \\ \hline - & 1 & 1 & 0 \\ \hline - & 1 & 0 & 1 \\ \hline \end{array} \end{array} | y_0$$

$$y_1 \left| \begin{array}{|c|c|c|} \hline - & 1 & 1 & 0 \\ \hline - & 1 & 0 & 1 \\ \hline \end{array} \right. | \overline{x_1}$$

$$Y_1 = y'_1x_1 + y_1x'_1 + y'_0x'_0 + y_0x_1x_0$$

- State-transition and output functions

| $PS$     | $x_1x_0$    |      |      |
|----------|-------------|------|------|
| $y_1y_0$ | 01          | 10   | 11   |
| 00       | 01,0        | 10,1 | 10,0 |
| 10       | 11,0        | 10,0 | 00,1 |
| 01       | 00,0        | 11,1 | 11,0 |
| 11       | 10,0        | 00,0 | 11,1 |
|          | $Y_1Y_0, z$ |      |      |
|          | NS, Output  |      |      |

$$Y_1: \begin{array}{c} \frac{x_0}{\boxed{\begin{array}{|ccc|} \hline - & 0 & 1 & 1 \\ - & 0 & 1 & 1 \\ - & 1 & 1 & 0 \\ - & 1 & 0 & 1 \\ \hline x_1 \end{array}}} \\ y_1 \boxed{\begin{array}{|ccc|} \hline - & 1 & 1 & 0 \\ - & 0 & 1 & 0 \\ - & 1 & 0 & 0 \\ \hline x_1 \end{array}} \end{array} | y_0$$

$$Y_0: \begin{array}{c} \frac{x_0}{\boxed{\begin{array}{|ccc|} \hline - & 1 & 0 & 0 \\ - & 0 & 1 & 1 \\ - & 0 & 1 & 0 \\ - & 1 & 0 & 0 \\ \hline x_1 \end{array}}} \\ y_1 \boxed{\begin{array}{|ccc|} \hline - & 1 & 0 & 0 \\ - & 0 & 1 & 0 \\ - & 1 & 0 & 0 \\ \hline x_1 \end{array}} \end{array} | y_0$$

$$z: \begin{array}{c} \frac{x_0}{\boxed{\begin{array}{|ccc|} \hline - & 0 & 0 & 1 \\ - & 0 & 0 & 1 \\ - & 0 & 1 & 0 \\ - & 0 & 1 & 0 \\ \hline x_1 \end{array}}} \\ y_1 \boxed{\begin{array}{|ccc|} \hline - & 1 & 0 & 0 \\ - & 0 & 1 & 0 \\ - & 1 & 0 & 0 \\ \hline x_1 \end{array}} \end{array} | y_0$$

$$Y_1 = y'_1 x_1 + y_1 x'_1 + y'_0 x'_0 + y_0 x_1 x_0$$

$$Y_0 = y'_0 x'_1 + y'_1 y_0 x_1 + y_0 x_1 x_0$$

$$z = y'_1 x'_0 + y_1 x_1 x_0$$



Figure 8.19: Sequential network in Example 8.4.



# Verilog

Figure 8.19: Sequential network in Example 8.4.

# Introduction to Verilog

# Overview of Verilog

1. Resemblance to C: case sensitive, same style comments, operators, etc.
2. Two standards: Verilog-1995, Verilog-2001, both supported by ISE
3. VHDL is the other widely used HDL.

# Behavioral vs Synthesizable code

Historically Verilog has always served two functions:

1. Describe your digital logic design in a high-level way instead of using schematics (synthesizable code).
2. Model elements that interact with your design (behavioral models/testbenches)

You should **always** have a clear conscience of whether you are writing behavioral or synthesizable code.

Better yet, know what your synthesizable code translates to in **physical hardware**.

# Behavioral vs Synthesizable code



Which part corresponds to behavioral / synthesizable code?

# Data types: wire, reg

Variables must be declared before used; wire/reg are the most common data types.

wire:

- models basic wire that holds transient values

reg:

- anything that stores a value

# Data Values

**Values:** 1, 0, x/X (unknown), z/Z (high impedance)

**Radices:** d(decimal), h(hex), o(octal), b(binary)

**Format:** <size>'<radix><value>

```
123      // default: decimal radix, unspecified width  
'd123    // 'd = decimal radix  
8'h7B    // 'h = hex radix  
'o173    // 'o = octal radix  
'b111_1011 // 'b = binary radix, "_" are for readability
```

Signed number (rarely used):

8'shFF (8-bit twos-complement representation of -1)

# Operators

Bitwise:  $\sim a$ ,  $a \& b$ ,  $a | b$ ,  $a ^ b$ ,  $a \sim \wedge b$

Reduction: bitwise operation on a **single** operand and produces one bit result.

$\&a$ ,  $\sim \&a$ ,  $|a$ ,  $\sim |a$ ,  $^a$ ,  $\sim ^a$

Example:  ${}^4'b1001 = 1'b0$

Logical: output one bit result

$!a$ ,  $a \& \&b$ ,  $a | | b$ ,  $==/!=$ ,  $===/!=$  (also compares x/z)

$x1x \& 1xx = x1x$   
5  $\&\&$  3 = 1  
5  $\&\&$  0 = 0  
 $xxx == x11 : x$   
 $x11 == x11 : x$   
 $x11 === x11 : 1$   
4  $!= 5 : 1$   
 $x1x !== x1x : 0$

Arithmetic:  $+, -, *, /, \%$  (mod, takes the sign of operand 1)

# Operators, ctd.

Can you tell the difference between the following expressions? What are the sizes of each expression and what do they mean?

Declaration: wire [31:0] a,b

- $a \& b$
- $a \&& b$
- $(\&a) \& (\&b)$
- $(\&a) \&& (\&b)$
- $\&(a \&& b)$
- $a \&& (\&b)$

# Operators, ctd.

Shift: <<, >>(logical)

<<<, >>> (arithmetic)

Conditional: sel ? a : b

Concatenation: {a, b}

Replication: {n{m}}

Assignment: =(blocking), <= (non-blocking)

$4'b1100 \gg 1 = 4'b 0110$

—

001 > 1's comp

: 110 >+1 = 111: 111

reg signed [7:0]a;

a = {4'd15, 4'd5}= 1111\_0101

{3{3'b101}}= 101\_101\_101

# Blocking/Non-blocking assignments

Blocking assignments (=):

assignment immediate, happens first

at the posedge of the  
clock:

```
out1 <= input1  
out2 <= out1;
```

Non-blocking assignment(<=):

assignments deferred until all right hand sides has been evaluated, closer to actual hardware register behavior.

# Assignment operator guidelines

1. Sequential logic: use nonblocking ( $<=$ )
2. Pure combinational logic in “always” block: use blocking ( $=$ )
3. Do not mix blocking/non-blocking in the same “always” block
4. Both sequential and “combinational” logic in the same “always” block: use non-blocking ( $<=$ )

```
y <= a ^ b;
```

Recommendation: in complex sequential circuit, use two always blocks, one for combinational circuit, one for state update.

# Basic building block: modules

1. port: input / output / inout
2. Signal declarations: wire [3:0]  
a;  
a. Rule-of-thumb: stick to [MSB:LSB]
3. Concurrent logic blocks, one of the following:
  - a. continuous assignments
  - b. always blocks (either sequential or combinatorial)
  - c. initial blocks (only used in behavioral modeling)
  - d. forever blocks (only used in behavioral modeling)
4. Instantiations of sub-modules

```
module top(a, b, ci, s, co
);
    input a, b, ci;
    output s, co;

    wire s;
    reg g, p, co;

    assign s = a ^ b ^ ci;
    // combinatorial always
    // block using begin/end
    always @* begin
        g = a & b;
        p = a | b;
        co = g | (p & ci);
    end

endmodule
```



# Basic building block: modules

1. port: input / output / inout
2. Signal declarations: wire [3:0]  
a;  
a. Rule-of-thumb: stick to [MSB:LSB]
3. Concurrent logic blocks, one of the following:
  - a. continuous assignments
  - b. always blocks (either sequential or combinatorial)
  - c. initial blocks (only used in behavioral modeling)
  - d. forever blocks (only used in behavioral modeling)
4. Instantiations of sub-modules

```
module top(a, b, ci, s, co
);
    input a, b, ci;
    output s, co;

    wire s;
    reg g, p, co;

    assign s = a ^ b ^ ci; // combinatorial always
    // block using begin/end
    always @* begin
        g = a & b;
        p = a | b;
        co = g | (p & ci);
    end
endmodule
```

# Always Block

```
// combinatorial always
// block using begin/end
always @* begin
    g = a & b;
    p = a | b;
    co = q | (p & ci);
end
```

Sensitivity list

Code that describes the real  
“function”

# Always Block: Sensitivity list

1. Level sensitive: changes to any signals on the sensitivity list will invoke the always block. Used in combinational circuits.

always @ (a or b) / always @\* (verilog-2001, recommended)

1. Edge sensitive: invoke always block on specified signal edges. Used in sequential circuits.

always @ (posedge clk or posedge reset)

# Always Block: case, if/else

```
case (sel)
    val0: statements
    val1: statements
    ...
    default: statements
endcase

if (condition)
    statements
else if (condition)
    statements
...
else
    statements
```

# Aways Blocks: case, if/else ctd.

```
module ALU(a, b, f, z
);
input [3:0] a, b;
input [1:0] f;
output reg [3:0] z;

always @(*)
z = 4'bx; (#1)
case (f)
  0: z = a + b;
  1: z = a * b;
  2: z = a & b;
  3: z = a | b;
default: z = 4'bx; (#2)
endcase
endmodule
```

if/else or case statement fails to cover all cases → **inferred latch**

Example:

```
if (x == 2'b00)
  z = a;
else if (x == 2'b01)
  z = b;
```

What about other cases? The circuit will hold previous value

To avoid: add #1 or #2

# Always Block: Looping (mostly for testing)

`while (condition)  
statements`

`for (initialization; condition; increment)  
statements`

`repeat (n)  
statements`

# Data types: wire, reg

Variables must be declared before used; wire/reg are the most common data types.

wire:

- models basic wire that holds transient values
- **only wires can be used on the LHS of continuous assign statement**
- input/output port signals default to wire

reg:

- anything that stores a value
- can appear in both combinational and sequential circuits
- **only regs can be used on the LHS of non-continuous assign statement**

# Wire vs. reg

When to use wire:

Left hand side of “assign”

```
wire s;
```

```
assign s = a ^ b ^ ci;
```

When to use reg:

Left hand side of “=” or “<=” in  
“always” blocks

```
reg g, p, co;  
always @* begin  
    g = a & b;  
    p = a | b;  
    co = g | (p & ci);  
end
```

# Sequential circuit example: modulo 64 counter

```
module counter(clk, rst, out
);
  input clk, rst;
  output [5:0] out;

  reg [5:0] out;
  always @ (posedge clk or posedge rst)
begin
  if (rst)
    out <= 6'b000000;
  else
    out <= out + 1;
end

endmodule
```

# Module instantiation

```
counter counter1 (.clk(test_clk), .rst(test_rst), .out(out));
```

Achieve hierarchical design by using other modules inside one module.

Recommended format:

```
type name (.port1(w1),.port2(w2).....);
```

1. Port order doesn't matter
2. Unused output port allowed
3. Name must be unique within module

# Example

```
module half_adder(a, b, x, y
);
    input a, b;
    output x, y;
    assign x = a & b;
    assign y = a ^ b;
endmodule
```

```
module full_adder(a, b, ci, s, co
);
    input a, b, ci;
    output s, co;
    wire g, p, pc;
    half_adder h1(.a(a), .b(b),
                  .x(g), .y(p));
    half_adder h2(.a(p), .b(ci),
                  .x(pc), .y(s));
    assign co = pc | g;
endmodule
```

# Schematics output



# Testbench

Procedures for creating testbench:

1. Instantiate unit under test (uut)

```
reg clk, rst;  
wire out;  
counter uut(.clk(clk), .rst(rst),  
.out(out));
```

2. Provide input for uut: clk, rst,  
other ports...

```
initial begin  
    // Assign different inputs  
    ...  
end  
always begin  
    // Alternatively  
    initial+forever  
        #5 clk = ~clk;  
end
```

3. Simulate and verify behavior



# Testbench

```
initial begin
    // Initialize Inputs
    clk = 0;
    rst = 0;
    // Wait 100 ns for global reset
    // to finish
    #100;
    // Add stimulus here
    rst = 1;
    #20 rst = 0;
    // add verification routine here
    #1000 $finish;
end
```

**Initial block starts execution at time 0.**

**#n : wait n time units**  
**\$finish: stop simulation**

# Parameter

```
module ALU #(parameter W=4) (a, b, f, z);
input [W-1:0] a, b;
input [1:0] f;
output reg [W-1:0] z;

always @(*)
  case (f)
    0: z = a + b;
    1: z = a * b;
    2: z = a & b;
    3: z = a | b;
    default: z = { (W) {1'bX} };
  endcase
endmodule
```

# Parameters

Default parameter W=4. Instantiate a 16-bit ALU:

Format:

```
type #(params) name (ports);
```

Example:

```
ALU #(W(16)) alu16 (.a(a), .b(b), .f(f), .z(z));
```

# Recap

- = for combinational, <= for sequential
- register for always blocks, wire for others
  - output of a submodule should be register
- edge sensitive always blocks only allow 2 types:
  - always @ (posedge clk)
  - always @ (posedge clk or posedge rst)
- switch / if else should be complete, no latches allowed

# Preparation Tasks

- Read *An Old Tutorial* on the course web
  - *Ignore the device parameters for Spartan-3*
  - *Ignore contents beyond Create Timing Constraints*
- Create projects, write code and simulate:
  - 2:1 mux
  - mux2( input din0, din1, sel, output out);
  - 8 bit counter
  - counter( output [7:0] out, input clk, ena, rst);
  - 16-4 encoder
  - encoder ( input [15:0] in, input enable, output [3:0] out);

# References

1. MIT 6.111 course notes,

<http://web.mit.edu/6.111/www/f2013/index.html>

2. Verilog in one day,

[http://www.asic-world.com/verilog/verilog\\_one\\_day.html](http://www.asic-world.com/verilog/verilog_one_day.html)

3. Wire vs. Reg,

<http://inst.eecs.berkeley.edu/~cs150/Documents/Nets.pdf>

4. Sunburst Design (Read on assignment operators)

<http://www.sunburst-design.com/papers/>

5. ISE Quick Start Guide

<http://cseweb.ucsd.edu/classes/wi11/cse141L/Media/Quick-Tutorial-11.pdf>