

ENGR 210 / CSCI B441  
“Digital Design”

Test 2

# Flip-Flops

Andrew Lukefahr

# Announcements

- P7 Saturating Counter is out
- P8 – Elevator Controller is out
  - This one is hard.

# UPDATE: ‘wire’ vs ‘logic’

SystemVerilog (NEW) Rules:  
Just use ‘logic’\*

\* **EXCEPT**

logic foo = a & b; **(BAD - Initial values of a & b only)**

wire foo = a & b; **(OK)**

logic foo;  
assign foo = a & b; **(OK)**

Always specify  
defaults for  
always\_comb!

**BLOCKING (=) FOR**

**always\_comb**

**NON-BLOCKING (<=) for**

**always\_ff**

# Last Time: SR Latch



| <u>Set</u> | <u>reset</u> | $Q$ | $\bar{Q}$ |
|------------|--------------|-----|-----------|
| 0          | 1            | 0   | 1         |
| 0          | 0            | 0   | 1         |
| 1          | 0            | 1   | 0         |
| 0          | 0            | 1   | 0         |

Same inputs, different output!  
⇒ Internal state!

# D-Latch



"Q follows D  
~~when~~ when  
 $\text{en} = 1$ ,  
otherwise  
doesn't  
change"

# Inputs to D Latches

Output Follows Input when Enable=1



# Glitches

→ unintended, short, errors in  
boolean logic

→ caused by gate delays

- Assume 10ps / gate.
- $A=1$ ,  $C=1$ ,  $B$  falls
- What is  $F$ ? ↗

$$A=1 \quad B=1 \quad C=1$$

$\downarrow \qquad \downarrow$   
 $10\text{ps}$



# Glitches on D-Latches



# Inferred Latches

```
wire x, y, z;  
reg foo, bar ;
```

→ always\_comb begin  
    if x [foo = y & z;] //bad:  
    if (x) bar = y | z; // what if ~x?  
end

What if  $x == 0$ ?



↑  
guess  
latch?

# Defaults

```
wire x, y, z;  
reg foo, bar ;
```

```
always_comb begin  
    foo = x; bar = x; //good: defaults  
    if (x) foo = y & z; //
```

```
    if (x) bar = y | z; //
```

```
end
```

x foo



$x=0$



What if  $x == 0$ ?  $foo = bar = x!$

Always specify defaults for always\_comb!

Always specify  
defaults for  
always\_comb!

# D Flip-Flop



\* no gate delays

D latch:  
 $Q$  follows D when  $en=1$



# Levels vs. Edges

D-latch

Q follows D when  
 $en = 1$



D Flip-Flop

Q follows D only on the  
rising edge of en



# D Flip-Flop vs. D Latch



# D Flip-Flop in Verilog

```
module d_ff (
    input d,                      //data
    input en,                     //enable
    output logic q                //reg-isters hold state
);

    always_ff@(posedge en) //positive edge of enable
begin
    q <= d; //non-blocking assign
    qn <= ~d; //optional
end

endmodule
```

# D Flip-Flop w/ Clock

```
module d_ff (
    input d,           //data
    input clk,        //clock
    output reg q       //reg-isters hold state
);

    always_ff@(posedge clk)
    begin
        q <= d; //non-blocking assign
        qn <= ~d; //optional
    end

endmodule
```



# Blocking vs. NonBlocking Assignments

- Blocking Assignments (`=` in Verilog)
  - Execute in the order they are listed in a sequential block;
  - Upon execution, they immediately update the result of the assignment before the next statement can be executed.

$x = 3$   
 $x = 2$

→ —————→  $x = 2$

LHS      RHS  
 $x \Leftarrow 2$

# Blocking vs. NonBlocking Assignments

- Non-blocking assignments ( $\Leftarrow$  in Verilog):

- Execute concurrently



- Evaluate the expression of all right-hand sides of each statement in the list of statements before assigning the left-hand sides.

- Consequently, there is no interaction between the result of any assignment and the evaluation of an expression affecting another assignment.

- Nonblocking procedural assignments be used for all variables that are assigned a value within an edge-sensitive cyclic behavior.





## Blocking vs. NonBlocking

```
always_comb
begin
    x = a + 1;
    y = x + 1;
    z = z + 1;
end
```



```
always_ff @ (posedge clk)
begin
    x <= a + 1; = 1
    y <= x + 1; = 2
    z <= z + 1; = 2
end
```

$$x=0, a=0, y=0, z=0$$

$$x=1, y=2, z=1$$

$$x=1, y=2, z=2$$

$$x=1, y=2, z=3$$

$$a=0 \quad x=0 \quad y=0 \quad z=0$$

$$\underline{x=1} \quad y=1 \quad \underline{z=1}$$

$$x=1 \quad y=2 \quad z=2$$

# Blocking vs. Non-Blocking Assignments

- **ONLY USE BLOCKING (=) FOR COMBINATIONAL LOGIC**
  - `always_comb`
- **ONLY USE NON-BLOCKING (<=) FOR SEQUENTIAL LOGIC**
  - `always_ff`
- Disregard what you see/find on the Internet!

BLOCKING (=) FOR

always\_comb

NON-BLOCKING (<=) for

always\_ff

# D-FlipFlop w/Clock

```
module d_ff (
    input d,          //data
    input clk,        //clock
    output logic q    //registers hold state
) ;  
  
    always_ff @ (posedge clk)
begin
    q <= d; //non-blocking assign
end  
endmodule
```



What is q before posedge clk?

# D-FF's with Reset

- Two different ways to build in a reset
  - Synchronous
  - Asynchronous



# Sync Reset in Verilog

```
module d_ff (
    input clk,
    input rst,
    input D,
    output logic Q);
```

```
begin
    always_ff @ (posedge clk)
        if (rst) begin
            Q <= 1h0;
        end
        else begin
            Q <= D;
        end
    end
end module
```

# Registers



# 4-bit Register in Verilog

```
module d_ff (
    input [3:0]      d,      //data
    input             clk,    //clock
    output logic [3:0] q      //output register
);

    always_ff @(posedge clk)
    begin
        q <= d; //non-blocking assign
    end

endmodule
```

# 4-bit Register in Verilog

```
module d_ff (
    input      [3:0]  d,    //data
    input                  clk,   //clock
    output logic [3:0] q    //output register
) ;

    always_ff @(posedge clk)
    begin
        q <= d; //non-blocking assign
    end

endmodule
```

# D Flip-Flops as Shift Registers



# Shift Register



# Shift-Register in Verilog

```
module shift_register (  
    input clk, rst, D,  
    output [3:0] Q );
```

```
    logic [3:0] DFF;  
    logic [3:0] next_DFF;
```

```
    always_ff @(posedge clk)  
        if (rst) DFF <= 'h0;  
        else      DFF <= next_DFF;  
    end
```

```
    always_comb  
        next_DFF = { DFF[2], DFF[1], DFF[0], D };
```

```
endmodule
```

assign Q = DFF;



# Shift-Register in Verilog

```
module shift_register (
    input clk, rst, D,
    output [3:0] Q );

    logic [3:0] dff;
    logic [3:0] next_dff;

    always_ff (@posedge clk) begin
        if (rst) dff <= 4'h0;
        else      dff <= next_dff;
    end

    always_comb
        next_dff = { dff[2:0], D };

    assign Q = dff;

endmodule
```



# Shift-Register in Verilog

```
module shift_register (
    input clk, rst, D,
    output [3:0] Q );

    logic [3:0] dff;
    logic [3:0] next_dff;

    always_ff (@posedge clk) begin
        if (rst) dff <= 4'h0;
        else      dff <= next_dff;
    end

    always_comb
        next_dff = { dff[2:0], D };

    assign Q = dff;

endmodule
```



# What does this module do?

```
module mystery(
    input clk,           //clock
    input rst,           //reset
    output logic out    //output
);
    logic [3:0] D;
    wire [4:0] sum;

    always_ff @( posedge clk ) // <- sequential logic
    begin
        if (rst) D <= 4'h0;
        else     D <= sum;      //non-blocking
    end

    always_comb // <- combinational logic
    {out,sum} = {0,D} + 5'h1; //blocking

endmodule
```

# What does this module do?

```
module counter(  
    input clk,           //clock  
    input rst,           //reset  
    output logic out    //output  
);  
    logic [3:0] D;  
    wire [4:0] sum;
```

```
always_ff @ ( posedge clk ) // <- sequential logic  
begin  
    if (rst) D <= 4'h0;  
    else      D <= sum;    //non-blocking  
end
```

```
always_comb // <- combinational logic  
{out,sum} = {0,D} + 5'h1; //blocking
```

```
endmodule
```



uses FF's

uses AND, OR, NOT  
Gates

# Next Time

- State machines