**Peter Anthony** 

Michael Cavins

Andres Colon

ECE 4304 - 01

Lab 4: Seven-Segment BCD counter

## **Architecture:**

The objective of this lab was to display a counter where it counts from 00,000,000 to 99,999,999 and then resets based on the direction in which to count in. The speed at which the counter counts at can be varied based on 2 switches which gives a total of 4 counter options. The reset for the ssegs and for the counter are independent to each other.



## Tricks of the code:

The main trick to this counter is that the clock speed can be changed if desired by making use of the pll. The outputs of each of the pll are used along lock to create a stable clock. The clocks are then multiplexed which can be changed by two switches on the board.

```
PLL_CLK_COMP: clk_wiz_0
port map(
   i clk sys => i sel clk,
                                   -- Map the top clock with the input for the pll
                                   -- Map the top reset with the input for the pll
             => i sel rst,
   reset
   o_pll_10 => temp_pll_clk_10, -- Output the 10MHz clock
    o_pl1_50 => temp_pl1_clk_50, -- Output the 50MHz clock
    o_pll_100 => temp_pll_clk_100, -- Output the 100MHz clock
   o_pl1_200 => temp_pl1_clk_200, -- Output the 200MHz clock
                                  -- Output the current locked value
             => temp_pll_lock
   locked
   utilizes lock from pll clock to make sure only stable clocks are being used
stable_clk_10 <= temp_pll_clk_10 and temp_pll_lock;
stable_clk_50 <= temp_pll_clk_50 and temp_pll_lock;
stable_clk_100 <= temp_pll_clk_100 and temp_pll_lock;
stable_clk_200 <= temp_pll_clk_200 and temp_pll_lock;
 - Concatenate all stable clocks so it can be formatted for the multiplexer
temp_clk_in <= stable_clk_10 & stable_clk_50 & stable_clk_100 & stable_clk_200;
 - Creates a 4x1 multiplexer with each data set size of 1 bit
MUX 4x1: generic mux Nx1
   generic map(g_WIDTH_MUX_DATA => 1, g_MUX_INPUTS => 4)
       i_mux_sel => i_sel_SW,
                                      -- Map the top select switches for the multiplexer
       i_mux_data => temp_clk_in,
                                     -- Input the newly formatted clock data
       o_mux_data => temp_current_clk -- output the selected clock
```

## Testbench:



Counter is set to count up.



Counter is set to count down.



Corner case for when BCD counter counts backwards from 0.

## Area/Resources:

