# Verilog - Part II

STUDENTS-HUB.com

### **Presentation Outline**

- Modeling Latches and Flip-Flops
- Blocking versus Non-Blocking Assignments
- Modeling Sequential Circuit Diagrams
- Modeling Mealy and Moore State Diagrams
- Modeling Registers and Counters

### Recall: Sensitivity List of always block

Syntax:

### always @(sensitivity list) begin

procedural statements

end

- Sensitivity list is a list of signals: @(signal1, signal2, ...)
- The sensitivity list triggers the execution of the always block

When there is a *change of value in any listed signal* 

Otherwise, the **always** block does nothing until another change occurs on a signal in the sensitivity list

STUDENTS-HUB.com

### Guidelines for Sensitivity List

For combinational logic, the sensitivity list must include ALL the signals that are read inside the always block

Combinational logic can also use: @(\*) or @\*

- For sequential logic, the sensitivity list may not include all the signals that are read inside the always block
- For edge-triggered sequential logic use:

always @(posedge signal1, negedge signal2, ...)

The positive edge or negative edge of each signal can be specified in the sensitivity list

STUDENTS-HUB.com

### Modeling a D Latch with Enable

- // Modeling a D Latch with Enable and output Q
  // Output Q must be of type reg
  // Notice that the if statement does NOT have else
  // If Enable is 0, then value of Q does not change
  // The D\_latch stores the old value of Q
- module D\_latch (input D, Enable, output reg Q);
   always @(D, Enable)
   if (Enable) Q <= D; // Non-blocking assignment
  endmodule</pre>

## Modeling a D-type Flip-Flop

// Modeling a D Flip-Flop with outputs Q and Qbar module D\_FF (input D, Clk, output reg Q, Qbar); // Q and Qbar change at the positive edge of Clk // Notice that always is NOT sensitive to D always @(posedge Clk) begin

Q <= D; // Non-blocking assignment
Qbar <= ~D; // Non-blocking assignment</pre>

#### end

### endmodule

STUDENTS-HUB.com

## Negative-Edge Triggered D-type Flip-Flop

// Modeling a Negative-Edge Triggered D Flip-Flop
// The only difference is the negative edge of Clk
module D\_FF2 (input D, Clk, output reg Q, Qbar);
// Q and Qbar change at the negative edge of Clk
always @(negedge Clk)

begin

Q <= D; // Non-blocking assignment
Qbar <= ~D; // Non-blocking assignment</pre>

#### end

### endmodule

STUDENTS-HUB.com

## D-type Flip-Flop with Synchronous Reset

// Modeling a D Flip-Flop with Synchronous Reset input module D\_FF3 (input D, Clk, Reset, output reg Q, Qbar); // always block is NOT sensitive to Reset or D // Updates happen only at positive edge of Clk // Reset is Synchronized with Clk always @(posedge Clk) if (Reset) {Q, Qbar} <= 2'b01;

else

{Q, Qbar} <= {D, ~D};

### endmodule

### D-type Flip-Flop with Asynchronous Reset

// Modeling a D Flip-Flop with Asynchronous Reset input module D\_FF4 (input D, Clk, Reset, output reg Q, Qbar); // Q and Qbar change at the positive edge of Clk // Or, at the positive edge of Reset // Reset is NOT synchronized with Clk always @(posedge Clk, posedge Reset) if (Reset) {Q, Qbar} <= 2'b01; else {Q, Qbar} <= {D, ~D};

### endmodule

## JK flip-flop

**module** JK\_FF (**input** J, K, Clk, **output reg** Q, **output** Q\_b); **assign** Bib =  $\sim Q$ ; always @ (posedge Clk) **case** ({J,K}) 2'b00: Q <= Q; 2'b01: Q <= 1'b0; 2'b10: Q <= 1'b1; 2'b11: Q <= !Q; encase; endmodule;

## T flip-flop

```
module T_FF (Q,T,CLK,RST);
output Q;
input T,CLK,RST;
reg Q;
always @ (posedge CLK or negedge RST)
if (~RST) Q = 1'b0;
else Q = Q ^ T;
endmodule
```

### Procedural Assignment

- Procedural assignment is used inside a procedural block only
- Two types of procedural assignments:
- Blocking assignment:

variable = expression; // = operator

Variable is updated **before** executing next statement

Similar to an assignment statement in programming languages

### Non-Blocking assignment:

variable <= expression; // <= operator</pre>

Variable is updated at the end of the procedural block

Does not block the execution of next statements

STUDENTS-HUB.com

## Blocking versus Non-Blocking Assignment

Guideline: Use Non-Blocking Assignment for Sequential Logic



## Blocking versus Non-Blocking Assignment

Guideline: Use Blocking Assignment for Combinational Logic

endmodu



(input a,b,c, output reg x,y);

x = a & b; // update x

y = x | c; // y = a&b | c;

always @ (a, b, c) begin

module blocking



end

#### endmodule

Uploaded By: Malak Dar Obaid

### Verilog Coding Guidelines

- 1. When modeling **combinational** logic, use **blocking** assignments
- 2. When modeling **sequential** logic, use **non-blocking** assignments
- 3. When modeling **both sequential** and **combinational logic** within the same always block, use **non-blocking** assignments
- 4. Do **NOT** mix blocking with non-blocking assignments in the same always block
- 5. Do **NOT** make assignments to the same variable from more than one always block

### Structural Modeling of Sequential Circuits



// Mixed Structural and Dataflow module Seq\_Circuit\_Structure (input x, Clock, output y); wire DA, DB, A, Ab, B, Bb; // Instantiate two D Flip-Flops D\_FF FFA(DA, Clock, A, Ab); D\_FF FFB(DB, Clock, B, Bb); // Modeling logic assign DA = (A & x) | (B & x);assign DB = Ab & x;assign  $y = (A \mid B) \& \sim x;$ 

#### endmodule

STUDENTS-HUB.com

### Modeling a State Diagram

- ✤ A state diagram can be modeled directly in Verilog
- Without the need of having the circuit implementation
- An example of a Mealy state diagram is shown below
- This is the state diagram of the 111 sequence detector
- ↔ State assignment:  $S_0 = 00$ ,  $S_1 = 01$ , and  $S_2 = 10$



STUDENTS-HUB.com

### Modeling a Mealy State Diagram

```
module Mealy_111_detector (input x, clock, reset, output z);
  reg [1:0] state; // present state
  always @(posedge clock, posedge reset)
    if (reset) state <= 'b00;</pre>
    else case(state)
      'b00: if (x) state <= 'b01; else state <= 'b00;</pre>
      'b01: if (x) state <= 'b10; else state <= 'b00;</pre>
      'b10: if (x) state <= 'b10; else state <= 'b00;</pre>
    endcase
  // output depends on present state and input x
  assign z = (state == 'b10) \& x;
endmodule
```



STUDENTS-HUB.com

### Modeling a Moore State Diagram

module Moore\_Comparator (input A, B, clk, rst, output GT, LT, EQ);

```
reg [1:0] state; // present state
assign GT = state[1];
assign LT = state[0];
assign EQ = ~(GT | LT);
always @(posedge clk, posedge rst)
 if (rst) state <= 'b00;</pre>
 else case (state)
 'b00: state <= ({A,B}=='b01)?'b01:</pre>
                 ({A,B}=='b10)?'b10:'b00;
 'b01: state <= ({A,B}=='b10)?'b10:'b01;</pre>
 'b10: state <= ({A,B}=='b01)?'b01:'b10;</pre>
 endcase
```

#### endmodule

STUDENTS-HUB.com



### Modeling a Register with Parallel Load

```
module Register #(parameter n = 4)
  (input [n-1:0] Data_in, input load, clock, reset,
     output reg [n-1:0] Data_out);
```

always @(posedge clock, posedge reset) // Asynchronous reset if (reset) Data\_out <= 0; else if (load) Data\_out <= Data\_in;</pre>



STUDENTS-HUB.com

### Modeling a Shift Register

```
module Shift_Register #(parameter n = 4)
  (input Data_in, clock, reset, output Data_out);
  reg [n-1:0] Q;
 assign Data_out = Q[0];
  always @(posedge clock, negedge reset) // Asynchronous reset
    if (!reset) Q <= 0;</pre>
                                          // Active Low reset
    else Q <= {Data_in, Q[n-1:1]}; // Shifts to the right</pre>
```

endmodule



### Modeling a Counter with Parallel Load

module Counter\_with\_Load #(parameter n = 4) // n-bit counter
 ( input [n-1:0] D, input Load, EN, clock,
 output reg [n-1:0] Q, output Cout);



STUDENTS-HUB.com

### Modeling a Generic Up-Down Counter

module Up\_Down\_Counter #(parameter n = 16) // n-bit counter

```
( input [n-1:0] Data_in,
  input [1:0] f, input reset, clock,
  output reg [n-1:0] Count );
```

// Asynchronous reset
always @(posedge clock, posedge reset)
if (reset) Count <= 0;
else if (f == 1) Count <= Count + 1;
else if (f == 2) Count <= Count - 1;
else if (f == 3) Count <= Data\_in;</pre>

#### endmodule

STUDENTS-HUB.com



$$f = 1 \rightarrow Count up$$

= 2 
$$\rightarrow$$
 Count down

$$f = 3 \rightarrow Load counter$$

