**Laboratory 3 Counters**

**Prelab**

1. Complete block diagram of the top modules
2. complete all Verilog files
3. compile your designs
4. simulations(optional)

**Objectives**

1. Design counter using flip-flops.
2. Design counter using behavior statements.
3. Design a timer using clock frequency-division

**Part1 8-bit synchronous counter using T flip-flops and AND gates**

**Circuit description**

Consider the circuit in Figure 1. It is a 4-bit (**Q0 Q1 Q2 Q3**) synchronous counter which uses four T-type flip-flops. The counter increases its value on each positive edge of the clock if the Enable signal is asserted. The counter is reset to 0 by setting the Clear signal low. You are to implement an 8-bit counter of this type.

![](data:image/png;base64,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)

3

2

1

0

Figure 1. 4-bit synchronous counter (but you need to implement 8-bit counter in this lab)

Specific notes:

1. You should build a T flip-flop module tfliplfop (tff is a reserved key word, so it cannot be used as module name) first, and then instantiate **8 times** to create 8-bit counter with module name conter8.
2. Modify the 4 bit bcd to 7 segment display module BCD2LEDS from lab 2 to display 0 to F (instead of 0 to 9 for BCD numbers) with module name hex2seg7. Create two instances of hex2seg7 to display the 8-bit counter state Q7 Q6 … Q0 in double hex digits. One hex for Q7-4, and another for Q3-0
3. Use SW[1] for Enable, SW[0] for Clear, KEY[0] for clock.
4. The output of left TFF is Q[0] (LSB).
5. Counter state Q[7:0] also goes to red led display LEDR [7:0]
6. Q[7:0] should go through two 7-seg display so that the output of the 8-bit counter can be display on HEX1 and HEX0 as 00 to FF.

**prelab: complete the following Verilog files**

**Submodules**

1. T-flipflop: tflipflop.v

module tflipflop(resetn, t, clk, q); // available from lecture notes and textbook

// resetn: asynchronous low active reset control input

…

always @ (posedge clk, negedge resetn)

if (~resetn)

q<=0;

else

q<=t?~q: q;

…

endmodule

1. 8-bit counter: counter8.v

module counter8 (en, clear, clk, Q);

input en, clear, clk;

output [7:0] Q; // state of the 8 bit counter

…

// tflipflop x 8 instances

tflipflop u0(clear, T[0], clk, Q[0]); // TFF#0

…

// excitations

assign T[0]=en;

…

endmodule

1. HEX to 7-seg design: hex2seg7.v

to be modified from BCD to 7 segment display module available from Lab 2 (to display 0 to F instead of 0 to 9 only)

module hex2seg7(hex, seg7);

input [3:0] bin; // 4 bit binary input as one hex number

output reg [6:0] seg 7; // low active 7 seg LED output for 0 to F

always @ (\*)

case (bin)

4’b0000: seg7=?; // to display ‘0’

…

4’b1111: seg7=?; // to display ‘F’

endcase

endmodule

**Top Module**

module lab3part1(SW, KEY, LEDR, HEX1, HEX0);

input [1:0] SW; // SW[1] as enable input, SW[0] as asynchronous reset

input [0] KEY; // clock

output [7:0] LEDR; // binary counter state on LEDR

output [6:0] HEX1, HEX0; // two hex display of the counter state

wire [7:0] Q; // internal signals for stateQ7 Q6…Q0

// display 8 bit counter on LEDR directly

assign LEDR=Q;

// create instances of counter8 the 8 bit counter

//module counter8 (en, clear, clk, Q);

counter8(…);

// create 2 instances of display module

hex2seg7 H1(…); // display a hex # for bit 3-0 on HEX0

hex2seg7 H2(…); // bit 7-4 on HEX1

endmodule

**Implementation (put a check mark when you finish the step)**

1. \_\_\_\_\_\_Create a new project.
2. \_\_\_\_\_\_Write Verilog files (*lab3part1.v, counter8.v, tflipflop.v, hex2seg7.v*) required by the above description and notes and add them to the project.
3. \_\_\_\_\_\_Download *DE2\_pin\_assignments.qsf* from altera website.
4. In Quartus II, select **assignments 🡪 import assignments**, choose *DE2\_pin\_assignments.qsf* in the file box.
5. \_\_\_\_\_\_Compile your design.
6. **\_\_\_\_\_\_\_Tools🡪 programmer**, download the circuit into FPGA, and test the functionality.
7. \_\_\_\_\_\_\_Using Quartus II, find out how many logic elements (LEs) are used to implement your circuit.
8. \_\_\_\_\_\_\_Using Quartus II RTL viewer, find out how quartus II software synthesized your circuit.
9. Test the design a few times by changing SW[1], SW[0], KEY[0] (you are not expected to test 8 bit counter from 00 to FF manually) to observe the correct counting sequence on LEDR[7:0], and HEX1, HEX0.

**Trouble shooting tips:** you may need to test each submodule first (by creating a simple top module for testing purpose) before put everything together.

**Part2 8-bit synchronous counter using Q <=Q+1**

**Circuit description**

The functionality of the circuit is the same as part 1. The counter is accomplished using the statement: Q <= Q+1;

**prelab: complete the following Verilog code)]**

Design a submodule 8 bit counter

module counter8new(resetn, clk,en, Q);

input resetn, clk, en;

output reg [7:0] Q;

// always block for 8 bit counter with asynchronous low active reset

// and synchronous high active enable

always @ (posedge clk, negedge resetn)

if (!resetn) // low active

… // reset

else if (en)

… // count up by 1

else

… // no change

endmodule

Design the top module

module lab3part2(SW, KEY, LEDR,HEX1, HEX0);

input [1:0] SW; // SW[1] as enable, SW[0] as asynchronous reset

input [0:0] KEY; // KEY[0] as clock

output reg [6:0] HEX1, HEX0; // to display 8 bits

// (2 hex numbers) on two 7-seg display

output [7:0] LEDR; // to display counter state on LEDR

wire [7:0] Q; // internal signals for counter state

assign LEDR=Q; // optional: to have counter state on LEDR directly

// instantiate 8 bit counter

couner8new U0(…);

// instantiate display module twice

hex2seg7 U1(…);

hex2seg7 U2(…);

endmodule

// always block for 8 bit counter with asynchronous low active reset

// and synchronous high active enable

**Implementation**

1. \_\_\_\_\_\_\_Create a new project.
2. \_\_\_\_\_\_\_Write Verilog files (*lab3\_part2.v, counter8new.v )* required by the above description. Use *hex2seg7.v* from previous work.
3. \_\_\_\_\_\_\_Download *DE2\_pin\_assignments.qsf* from altera website.
4. \_\_\_\_\_\_\_In Quartus II, select **assignments 🡪 import assignments**, choose *DE2\_pin\_assignments.qsf* in the file box.
5. \_\_\_\_\_\_\_Compile your design.
6. **Tools🡪 programmer**, download the circuit into FPGA, and test the functionality.
7. \_\_\_\_\_\_\_Using Quartus II, find out how many logic elements (LEs) are used to implement your circuit.
8. \_\_\_\_\_\_\_Using Quartus II RTL viewer, find out how quartus II software synthesized your circuit.
9. Test the design a few times by changing SW[1], SW[0], and KEY[0] (you are not expected to test 8 bit counter from 00 to FF manually) to observe the correct counting sequence.

**Part3 a simple timer of 8-bit counter updated every second**

**Circuit Description**

The circuit, driven by a 50MHz clock (CLOCK\_50) (on-board), will display two-digit hexadecimal numbers from 00 to FF on two 7-seg displays HEX1 and HEX0 at a refreshing rate of 1Hz. The circuit consists of 3 parts: 1) 1 Hz clock signal generator; 2) 8-bit binary counter with reset (SW[0]) and enable (SW[1]); and 3) binary-seg decoder for the display (seg7.v in lab2).

The Verilog code for a frequency divider is provided as follows:

module clock\_div(input clk\_in, input[31:0] clkscale, output reg clk\_out);

// output clk\_out frequency = input cclk\_in frequency / (2\* clkscale)

reg[31:0] clkq=0; // 2^32-1>25M

always@(posedge clk\_in)

begin

clkq=clkq+1;// add 1, every cycle of clk\_in

if(clkq==clkscale)

begin; // toggle every clckscale cycles

clk\_out=~clk\_out

clkq=0; // reset counter

end

end

endmodule

The frequency of output clk is equal to the frequency of input cclk divided by (2\*clkscale). For example, if cclk frequency is 50MHz, clkscale should be 25,000,000 to generate 1Hz clk.

Your Verilog top module will instantiate the module clock\_div with clk1Hz as output and hex2seg7 (see part 1), and also instantiate counter8 (see part 2) with reset SW[0], enable SW[1] and clk11Hz as inputs.

**[prelab: complete the following Verilog code]**

module lab3part3(SW, CLOCK\_50, LEDR, HEX1, HEX0);

//SW[1]: enable (high active)

//SW[0]: resetn (low active)

input [1:0] SW;

input CLOCK\_50; // DE2 50MHz clock

wire clk1Hz; // user derived 1Hz clock

wire [7:0] Q; // internal state for the coutner

output …

…

// instantiate module clock to generate 1 Hz clock

clock\_div U0 (CLOCK\_50, 25000000,clk1Hz); // 50MHz input, 25M scale,

//1Hz output

// instantiate 8 bit counter with clk1Hz as clock

// SW[0] as low active reset, SW[1] as high active enable

…counter8…

// instantiate display module twice

…hex2seg7…

…hex2seg7…

endmodule

**Implementation**

1. \_\_\_\_\_\_\_Create a new project.
2. \_\_\_\_\_\_\_Write Verilog files (*lab3part3.v, clock\_div.v,)* required by the above description.Use files *counter8.v hex2seg7.v* from previous work.
3. \_\_\_\_\_\_\_Download *DE2\_pin\_assignments.qsf* from altera website.
4. \_\_\_\_\_\_\_In Quartus II, select **assignments 🡪 import assignments**, choose *DE2\_pin\_assignments.qsf* in the file box.
5. \_\_\_\_\_\_\_Compile your design.
6. **Tools🡪 programmer**, download the circuit into FPGA, and test the functionality by change SW[1] and SW[0] values.

1. Test your design fully as you see the counter changes its display from 00 to FF (it will take over 4 minutes for the whole counting sequence. So yo may do two things: 1. Veryify the accuracy of the 1 Hz freq or 1sec period using an external digital watch; 2. Increase clock frequency by changing the frequency divider scale constant so that you may see the whole counting sequence within a more reasonable time say 1 min)