

# [T]EE2026 DIGITAL DESIGN

## LAB4: SEQUENTIAL CIRCUITS IN VERILOG (2/2)

---

*Gu Jing  
E4-03-10  
eleguji@nus.edu.sg*

# REVISION FOR LAB 3

*clock divider*

## Sequential Circuits :

- Outputs depend on the current AND past values of inputs or outputs
- Sequential logic: `always @ (posedge/negedge CLOCK) begin.... end`
- Within sequential block, use non-blocking assignment (`<=`) to make sure values are updated in the next clock cycle

```
module example_for_non_blocking (
    input clk,
    input [1:0] para_in,
    output reg [1:0] A = 2'b00,
    output reg [1:0] B = 2'b00
);

    always @ (posedge clk) begin
        A <= para_in;
        B <= A + 1;
        .... para_in
    end
endmodule
```



# REVISION FOR LAB 3

Clock Divider to achieve  $f_{new}$ :



An internal n-bit counter: allow us to count how many cycles of clk will cause new\_clk to flip.

always @

```
counter <= counter + 1;
newclk <= (counter==0) ~ newclk : newclk;
```

## OUTLINE FOR LAB 4

### Precise Frequency Generation (continue from lab 3)

- Generate an Accurate Frequency from 100MHz

### Single Pulse Circuit & Counter

- D-Flip-Flop (DFF)

- Single Pulse Circuit by two DFF (for simulation)

- Single Pulse and Counter (for simulation)

- Single Pulse Debounced Circuit (for Hardware)

- Single Pulse Debounced Circuit and Counter (for Hardware)

DFF

Applications

# PRECISE CLOCK GENERATION



# PRECISE CLOCK GENERATION

Clock Divider to achieve exactly 1Hz from 100MHz:



Step 1: Determine exactly how many cycles of fundamental clock CLOCK,  $R$ , should cause new\_clk to flip?

$$R = \frac{\frac{T_{new}}{2}}{T_o} = \frac{f_o}{2 f_{new}}$$

Count    0 →  $R-1$

Step 2: create a counter with Maximum bit number (32 bits) that to be able to count up to  $(R-1)$ , an exact cycle number:

```
reg [31:0] counter = 32'b0; // counter counting from 0 to R-1
```

Step 3: create the sequential logic when there is a CLOCK:

```
always @(posedge CLOCK) begin
    if (counter <= (R-1)) begin
        counter <= (counter+1);
        new_clk <= (counter==0) ? ~new_clk : new_clk;
    end
end
```

# PRECISE CLOCK GENERATION



```
module test_my_precise_clk();
    reg CLOCK; //Inputs and Outputs of DUT
    reg [31:0]flip_count;
    wire new_clk;
    my_precise_clk DUT (CLOCK,
                        flip_count,
                        new_clk); //Instantiation

    initial begin //Stimuli
        CLOCK = 0; //Provide an initial value for the inputs
        R = 32'd4; //To generate 10MHz slow clock, R=100/(2*10)-1
    end

    always begin
        #5 CLOCK = ~CLOCK; // Generating a 100MHz CLOCK
    end
endmodule
```

**Simulation**

**Design File**

```
module my_precise_clk(
    //100MHz Fundamental Clock
    input CLOCK,
    //Precisely no. of count R to flip new_clk
    //Pre-calculated by flip_count=(f_100M)/(2*f_new)-1
    input [31:0] flip_count, R-1
    //New clock with frequency f_new
    output reg new_clk = 0
);
    //Define a counter with largest size 32bits
    reg [31:0] count = 32'b0;
    //Sequential logic when there is a fundamental CLOCK
    always @ (posedge CLOCK) begin
        count <= (count == flip_count)? 0 : count+1;
        new_clk <= (count == flip_count)? ~new_clk : new_clk;
    end
endmodule
```

// Structural modeling to create  $f_{new}$

*my\_precise\_clk*.dev(CLOCK,32'd*R*,new\_clk);

$$R = \frac{f_0}{2f_{new}} = \frac{10\text{MHz}}{2 \times 4} = 12.5\text{M} = 12500000$$

$$12499999$$

Note: DO NOT run simulate for low frequencies (may take infinite amount of time!)



**D-FLIP-FLOP**

## D-FLIP-FLOP: SINGLE DFF

- D-Flip Flop (DFF): “hold the input”

```
module my_dff(input DFF_CLOCK, D, output reg Q = 0);

    always @ (posedge DFF_CLOCK) begin
        Q <= D;
    end

endmodule
```



For sequential circuit, inside “always @ .... end” section, all the LHS signals must be reg



Observation of Q: “hold” the input D even there is a short duration of “bouncing”.



# **SINGLE PULSE CIRCUIT AND COUNTER**

## **FOR SOFTWARE SIMULATION**

# SINGLE PULSE CIRCUIT

- Two DFFs in series:

create single pulse from pushbutton, which lasts for only 1 clock cycle.



# SINGLE PULSE CIRCUIT

- Design file: using structural modeling to create single\_pulse\_circuit.v
- Create a corresponding simulation file to test the output



```

23 ⊕ module my_dff(
24   input CLOCK,
25   input D,
26   output reg Q
27 );
28
29 ⊕   always @ (posedge CLOCK) begin
30     Q <= D;
31   end
32 ⊕ endmodule
33 : 
```

```

23 ⊕ module single_pulse_circuit(
24   input clock,
25   input PB,
26   output single_pulse_out
27 );
28
29 ⊕   wire Q1;
30   wire Q2;
31
32   // instantiate two DFF
33   my_dff DFF1 (clock,PB,Q1);
34   my_dff DFF2 (clock,Q1,Q2);
35
36   assign single_pulse_out = Q1 & (~Q2);
37
38 ⊕ endmodule 
```

```

23 ⊕ module sim_single_pulse_circuit(
24
25 );
26
27   // 1. inputs and outputs
28   reg sim_clock;
29   reg sim_PB;
30   wire sim_pb_pulse_out;
31
32   // 2. instantiate the design module you want to test
33   single_pulse_circuit DUT (sim_clock, sim_PB, sim_pb_pulse_out);
34
35   // 3. describe your inputs
36   initial begin
37     sim_clock = 0;
38     sim_PB = 0; #15;
39     sim_PB = 1; #100;
40     sim_PB = 0; #15;
41   end
42
43
44   always begin
45     sim_clock = ~sim_clock; #10;
46   end
47
48
49 ⊕ endmodule 
```

# SINGLE PULSE CIRCUIT

- Design file: using structural modeling to create single\_pulse\_circuit.v
- Create a corresponding simulation file to test the output



## SINGLE PULSE CIRCUIT FOR COUNTER

Simulation Practice: 8-bit Counter Counting number of Presses of Pushbutton

- Increase a counter when there is a button press



\*\*\* Clock used for single\_pulse\_circuit and pulse\_to\_count must be the same clock! \*\*\*

# SINGLE PULSE CIRCUIT FOR COUNTER

## Simulation Practice: 8-bit Counter Counting number of Presses of Pushbutton



```
// Method 1 for Count
reg [7:0] counter = 8'b0;
always @ (posedge single_pulse_in) begin
    counter <= counter + 1;
end
```

// Method 2 for Count (\*\*SUGGESTED\*\*)

```
reg [7:0] counter = 8'b0;
always @ (posedge clk) begin
    counter <= single_pulse_in? counter + 1 : counter;
end
```

*should be a proper clock*

```
23 module pulse_to_count(
24     input clk,
25     input single_pulse_in,
26     output reg [7:0] counter = 8'b0
27 );
28
29
30 always @ (posedge clk) begin
31
32 if (single_pulse_in == 1)
33 begin
34     counter <= counter + 1;
35 end
36
37 end
38 endmodule
39
```

```
23 module TOP_single_pulse_count(
24     input PB,
25     input CLOCK,
26     output [7:0] COUNT
27 );
28
29 wire single_pulse;
30
31 // COMPONENTS INSTANTIATION
32 single_pulse_circuit DUT1 (CLOCK,PB,single_pulse);
33 pulse_to_count DUT2 (CLOCK,single_pulse, COUNT);
34
35 endmodule
36
```

```
23 module sim_TOP(
24
25 );
26
27 // 1. inputs and outputs
28 reg PB;
29 reg CLOCK;
30 wire [7:0] COUNT;
31
32 // instantiation
33 TOP_single_pulse_count DUT (PB,CLOCK,COUNT);
34
35 // 3. describe your inputs
36 initial begin
37     CLOCK = 0;
38     PB = 0; #15;
39     PB = 1; #100;
40     PB = 0; #15;
41
42     PB = 0; #10;
43     PB = 1; #50;
44     PB = 0; #10;
45
46     PB = 0; #10;
47     PB = 1; #50;
48     PB = 0; #10;
49
50     always begin
51         CLOCK = ~CLOCK; #10;
52     end
53 endmodule
54
```

\*\*\* Clock used for single\_pulse\_circuit and pulse\_to\_count must be the same clock! \*\*\*

# SINGLE PULSE CIRCUIT FOR COUNTER

Simulation Practice: 8-bit Counter Counting number of Presses of Pushbutton



\*\*\* Clock used for single\_pulse\_circuit and pulse\_to\_count must be the same clock \*\*\*

# SINGLE PULSE CIRCUIT AND COUNTER

FOR HARDWARE IMPLEMENTATION

# SINGLE PULSE CIRCUIT FOR REAL CASE (HARDWARE)

In the real case, pushbutton takes some time to stabilize.



\*\*\* PB\_clock needs to be much slower than the Pushbutton's bouncing \*\*\*

# SINGLE PULSE CIRCUIT FOR REAL CASE (HARDWARE)

Reason why PB\_clock needs to be much slower than the Pushbutton's bouncing:

If the  
PB\_clock  
is too fast:



## SINGLE PULSE CIRCUIT FOR REAL CASE (HARDWARE)

Reason why PB\_clock needs to be much slower than the Pushbutton's bouncing:

If the  
PB\_clock is  
too slow:



# SINGLE PULSE CIRCUIT FOR COUNTER (REAL CASE / HARDWARE)

Hardware Practice 1: [7:0]LED as a Counter Counting number of Presses of BTNC

- Overview block diagram to implement on Basys3



- Clock for counter must be exactly the same clock that was used to create the single pulse output.
- **SLOWCLOCK:** determines the “sensitivity” of Pushbutton (try 3Hz, 12Hz and 25MHz).

# SINGLE PULSE CIRCUIT FOR COUNTER (REAL CASE / HARDWARE)

Hardware Practice 2: LED shifts to left (between LED0 to LED15) when BTNC is pressed

- Shifter operator can be used to multiply / devide a counter by  $2^n$

```
// Application of Shift Operator
```

```
reg [15:0] counter = 16'b0;
```

```
always @ (posedge SLOWCLOCK) begin
```

```
// double the counter, because shift to left by 1 position
counter <= PB_pulse? (counter <<1) : counter;
```

```
// counter value increase by 4 times, because shift to left by 2 positions
counter <= PB_pulse? (counter <<2) : counter;
```

```
// counter value is half-ed, because shift to right by 1 position
counter <= PB_pulse? (counter >>1) : counter;
end
```



# SINGLE PULSE CIRCUIT FOR COUNTER (REAL CASE / HARDWARE)

➤ List of operators:

| Bitwise Operators                                                     |                  |                                                            |
|-----------------------------------------------------------------------|------------------|------------------------------------------------------------|
| $\sim$                                                                | $\sim m$         | invert each bit of m                                       |
| $\&$                                                                  | $m \& n$         | AND each bit of m with each bit of n                       |
| $ $                                                                   | $m   n$          | OR each bit of m with each bit of n                        |
| $\wedge$                                                              | $m \wedge n$     | exclusive-OR each bit of m with n                          |
| $\sim\wedge$                                                          | $m \sim\wedge n$ | exclusive-NOR each bit of m with n                         |
| $<<$                                                                  | $m << n$         | shift m left n-times and fill with zeros                   |
| $>>$                                                                  | $m >> n$         | shift m right n-times and fill with zeros                  |
| Unary Reduction Operators                                             |                  |                                                            |
| $\&$                                                                  | $\&m$            | AND all bits in m together (1-bit result)                  |
| $\sim\&$                                                              | $\sim\&m$        | NAND all bits in m together (1-bit result)                 |
| $ $                                                                   | $ m$             | OR all bits in m together (1-bit result)                   |
| $\sim $                                                               | $\sim m$         | NOR all bits in m together (1-bit result)                  |
| $\wedge$                                                              | $\wedge m$       | exclusive-OR all bits in m (1-bit result)                  |
| $\sim\wedge$                                                          | $\sim\wedge m$   | exclusive-NOR all bits in m (1-bit result)                 |
| Logical Operators                                                     |                  |                                                            |
| !                                                                     | $!m$             | is m not true? (1-bit True/False result)                   |
| $\&\&$                                                                | $m \&\& n$       | are both m and n true? (1-bit True/False result)           |
| $\ $                                                                  | $m \  n$         | are either m or n true? (1-bit True/False result)          |
| Equality and Relational Operators (return X if an operand has X or Z) |                  |                                                            |
| $==$                                                                  | $m == n$         | is m equal to n? (1-bit True/False result)                 |
| $!=$                                                                  | $m != n$         | is m not equal to n? (1-bit True/False result)             |
| $<$                                                                   | $m < n$          | is m less than n? (1-bit True/False result)                |
| $>$                                                                   | $m > n$          | is m greater than n? (1-bit True/False result)             |
| $<=$                                                                  | $m <= n$         | is m less than or equal to n? (1-bit True/False result)    |
| $>=$                                                                  | $m >= n$         | is m greater than or equal to n? (1-bit True/False result) |

| Identity Operators (compare logic values 0, 1, X, and Z) |            |                                                                                                                  |
|----------------------------------------------------------|------------|------------------------------------------------------------------------------------------------------------------|
| $==$                                                     | $m == n$   | is m identical to n? (1-bit True/False results)                                                                  |
| $!=$                                                     | $m != n$   | is m not identical to n? (1-bit True/False result)                                                               |
| Miscellaneous Operators                                  |            |                                                                                                                  |
| $:$                                                      | $sel?m:n$  | conditional operator; if sel is true, return m: else return n                                                    |
| {}                                                       | $\{m, n\}$ | concatenate m to n, creating a larger vector                                                                     |
| {}                                                       | $\{n\}$    | replicate inner concatenation n-times                                                                            |
| $\rightarrow$                                            | $-> m$     | trigger an event on an event data type                                                                           |
| Arithmetic Operators                                     |            |                                                                                                                  |
| $+$                                                      | $m + n$    | add n to m                                                                                                       |
| $-$                                                      | $m - n$    | subtract n from m                                                                                                |
| $-$                                                      | $-m$       | negate m (2's complement)                                                                                        |
| $*$                                                      | $m * n$    | multiply m by n                                                                                                  |
| $/$                                                      | $m / n$    | divide m by n                                                                                                    |
| $\%$                                                     | $m \% n$   | modulus of m / n                                                                                                 |
| $**$                                                     | $m ** n$   | m to the power n (new in Verilog-2001)                                                                           |
| $<<<$                                                    | $m <<< n$  | shift m left n-times, filling with 0 (new in Verilog-2001)                                                       |
| $>>>$                                                    | $m >>> n$  | shift m right n-times; fill with value of sign bit if expression is signed, otherwise fill with 0 (Verilog-2001) |

# ASSIGNMENT 4

# ASSIGNMENT 4: DISPLAY LOA

## Sub-Task A: Four 7-SEG Multiplexing with Different $f_m$

- Display specific character on specific 7-SEG at specific time step
- 'Multiplexing' among the steps 01 to 04, with frequency  $f_{m\_slow}$  and  $f_{m\_fast}$
- Observation: when  $f_m$  is large, it seems displaying 4 different characters on four 7-SEG statically

$f_m$

|                                                                                        | AN3 | AN2 | AN1 | ANO |
|----------------------------------------------------------------------------------------|-----|-----|-----|-----|
| Time Step 01                                                                           | S   |     |     |     |
| Time Step 02                                                                           |     | R   |     |     |
| Time Step 03                                                                           |     |     | F   |     |
| Time Step 04                                                                           |     |     |     | E   |
| Each time step is 1.342 seconds long<br>(An error of $\pm 0.005$ second is acceptable) |     |     |     |     |

  

|                                                                                                                      | AN3 | AN2 | AN1 | ANO |
|----------------------------------------------------------------------------------------------------------------------|-----|-----|-----|-----|
| Observation                                                                                                          | S   | R   | F   | E   |
| Hint: Repeat Time Step 01 to 04 at a frequency of 381 Hz<br>(Maximum error of $\pm 1\%$ for frequency is acceptable) |     |     |     |     |

when  $f_m$  is fast, e.g. 381Hz

## ASSIGNMENT 4:



# ASSIGNMENT 4: DURING LOA AND QUAR MODE

## Sub-Task A & B: Changing 7-Segments Display using Pushbuttons

- Pushbuttons have to be debounced first
- Sense the buttons by using the same PB\_clock, to guarantee that each press will be only recognized as 1 press.



b7K C  
debouncing circuit

b7K U  
single pulse

Similar as  
"button\_to\_count.v"  
created during the lab

# ASSIGNMENT 4: DURING LOA AND QUAR MODE

## Sub-Task A: Changing 7-Segments Display using Pushbuttons

- To sense if BTNC is held for LEDs to light up from LD0 to LD15, better not create sequential logic based on the edges of BTNC, but still the edge of Clock.

```
// Method 1 for Count
reg [7:0] counter = 8'b0;
always @ (posedge single_pulse_in) begin
    counter <= counter + 1;
end
```

```
// Method 2 for Count (**Much Better Solution**)
reg [7:0] counter = 8'b0;
always @ (posedge clk) begin
    counter <= single_pulse_in? counter + 1 : counter;
end
```

\*\*\* Some general rules for Verilog programming:

1. In sequential modules `always @(posedge/negedge xxx) begin .... end`, `xxx` should be a **proper clock signals** to prevent hardware limitations.
2. In one system, try to use the same clock for all sequential modules, so that hardware synchronization can be well retained.

*proper clock.*

## ASSIGNMENT 4:

---



END

[T]EE2026 Wiki: [tiny.cc/ee2026wiki](http://tiny.cc/ee2026wiki)

Email: [eleguji@nus.edu.sg](mailto:eleguji@nus.edu.sg)