## Mechtron 3TB4: Embedded Systems Design II Tutorial Lab 2

Building a Hardware Interface using an FPGA

## Goals

In this tutorial lab session, you will create a project to implement a stopwatch using the FPGA on the DE1-SOC board. Some modules developed here can be used in Lab 2 (some may require modifications). The objective of Lab 2 is to create a reaction time contest device.

To implement a stopwatch, you will design a clock divider, a counter, a hexidecimal (or binary) to binary-coded decimal (BCD) translator, a seven-segment display handler, and a top-level module interfacing the submodules. You will describe your circuits using Verilog Hardware Description Language (HDL) and implement them on the FPGA on the DE1-SoC board. This lab requires knowledge of basic Verilog.

# System Description

The system we are building is shown in Figure 1. The diagram is intended only for guidance.

You will use the clock divider to slow down the signal from the 50 MHz oscillator crystal on the DE1-SoC to 1 KHz. The slower signal can then be used as the input for a counter so the counter can increment every 1 millisecond. The count from the counter module is fed into the hex(or binary)-to-BCD converter. Once the count is translated to BCD, it is fed into the seven-segment display handler to output the counter value on the seven-segment HEX LEDs on the DE1-SoC board.

Your system has three user buttons: reset, start/resume, stop. The system should work in the following way:

- After your design is downloaded to the FPGA, or after the reset button is pressed, the HEX LEDs on the DE1-SoC display 0s.
- When the start/resume button is pressed, the stopwatch starts to run, and the HEX LEDs on the DE1-SoC board display time in milliseconds.
- Pressing the stop button will halt the stopwatch.
- Pressing the start/resume button after the stopwatch is halted will resume the stopwatch.

#### Clock Divider

The clock divider is a special circuit that can limit the rate of a given clock signal. The DE1-SoC board carries 50 MHz clocks that you will be using. However, this is too fast for our application. You will create a clock divider to slow down the signal from 50 MHz to 1 KHz. The slower signal is then fed into a counter so the counter can increment every millisecond.



Figure 1: System Block Diagram

#### Binary to BCD converter

BCD (Binary-Coded Decimal) is a digital encoding method for decimal numbers, in which each decimal digit is represented by its own binary sequence. For example, a binary number 1100, which is 12 in decimal, is 0001 0010 when represented in BCD.

Converting a binary or a decimal number to its BCD format makes it easy to display the decimal number on the seven-segment displays.

One algorithm to convert a binary represented decimal number to its BCD is "Shift-Add-3". The algorithm works in the following way:

1. According to the bit number of the binary or the value of the decimal number, declare a register for BCD. The register for the BCD should have enough tetrads (each tetrad corresponds to one decimal digit). Initiate the BCD register to 0.

For example: The largest value for an 8 bit unsigned binary number is 255, so the register for its BCD should have 3 tetrads, that is 12 bits.

- 2. Check the value of each BCD tetrad. If a tetrad's value is greater than or equal to 5, then add 3 to that tetrad.
- 3. Shift the BCD register one bit left. Shift the binary one bit left into the BCD register, i.e., shift the most significant bit of the binary number into the BCD register as the least significant bit.
- 4. Repeat step 2 and step 3 until all of the binary bits are shifted into the BCD resgister. (NOTE that after the last time shift, the tetrad values are checked).

### Activities

## Pre-lab [10]

The following activities must be completed by each student **independently** and shown to one of the TAs at the start of your Lab 2 Tutorial session.

1. Write Verilog code that implements the clock divider circuit and try to simulate it to verify its functionality. Use the following skeleton code for your module:

```
module clock_divider (input Clock, Reset_n, output reg clk_ms);
/* fill in your code here */
endmodule
```

To simulate a clock divider that slows the clock signal from 50 MHz to 1KHz will take a long time. You can simulate your clock divider using a much slower output clock. You may write this module as a parameterized module to allow the slow-down rate to be changed easily and for easy simulation.

2. Write Verilog counter logic to reset the counter, to stop the counter without resetting the current value, and to resume counting after being paused. Try to simulate the module to make sure it functions as expected.

```
module hex_counter(input Clock, Reset_n, Start_n, Stop_n, output reg [19:0] Q);
/* fill in your code here */
endmodule
```

3. Create a top level module that takes the 50MHz clock and three of the four KEYs of the DE1-SoC board as inputs, and outputs signals to the six HEX LED displays of the DE1-SoC board. Use KEY[0] for the "Reset\_n" signal, KEY[1] for the "Start\_n" signal, and KEY[2] for the "Stop\_n" signal.

Please note that pressing any of these KEYs results in a logic low signal. Use the following module declaration for the top level module:

## In the lab [20]

You will have different solutions from your pre-lab (pre-labs should be completed individually). In the lab you need to demonstrate only one working program/circuit per group.

1. Simulate your clock divider and your counter. Show the simulation results to one of your TAs.

- 2. Create a new Quartus project and name this project "lab2tut". Use your code from the pre-lab and Lab1. Create a top level module named lab2tut that binds all of the components together. Write code for all other necessary modules. Import pin assignments from the DE1-SoC.qsf file provided on the course web page. Before compiling, make sure that all unused pins are reserved as Input tri-stated. This option is available under Assignments | Device > Device and Pin Options > Unused Pins. Compile your design and debug your code if necessary.
- 3. Download your design to the FPGA and test the behavior of your circuit. Demonstrate your working project to one of the TAs.