# Lab 6: Driver for multiple seven-segment displays



EUROPEAN UNION European Structural and Investment Funds Operational Programme Research, Development and Education



The Study of Modern and Developing Engineering BUT CZ.02.2.69/0.0/0.0/18\_056/0013325

#### Learning objectives

In this laboratory exercise, you will study the creation of a sequential circuit for multiplexing 7-segment displays. This allows you to display four or even eight-digit values, including the decimal point on the display.



Preparation tasks (done before the lab at home)

See schematic or reference manual of the Nexys board, find out the connection of 7-segment displays, and complete the signal timing to display four-digit value 3.142.

Due to the physiological properties of human vision, it is necessary that the time required to display the whole value is a maximum of 16 ms. If we display four digits, then the duration of one of them is 4 ms. If we display eight digits, the time is reduced to 2 ms, etc.



The figure above was created in WaveDrom digital timing diagram online tool. The figure source code is as follows:

```
{
 signal:
    ['Digit position',
      {name: 'Common anode: AN(3)', wave: 'xx01..01..01'},
      {name: 'AN(2)', wave: 'xx1'},
      {name: 'AN(1)', wave: 'xx1'},
      {name: 'AN(0)', wave: 'xx1'},
    ],
    ['Seven-segment data',
      {name: '4-digit value to display', wave: 'xx3333555599', data:
['3', '1', '4', '2', '3', '1', '4', '2', '3', '1']},
      {name: 'Cathod A: CA', wave: 'xx01.0.1.0.1'},
      {name: 'CB', wave: 'xx0'},
      {name: 'CC', wave: 'xx0'},
      {name: 'CD', wave: 'xx0'},
      {name: 'CE', wave: 'xx1'},
      {name: 'CF', wave: 'xx1'},
      {name: 'CG', wave: 'xx0'},
```

```
],
    {name: 'Decimal point: DP', wave: 'xx01..01..01'},
  ],
  head:
    text: '
                                  4ms
                                         4ms
                                                      4ms
                                                                   4ms
                                               4ms
                                                             4ms
                                                                          4ms
             4ms',
4ms
      4ms
  },
}
```

### Part 1: Synchronize repositories and create a new folder

Run Git Bash (Windows) of Terminal (Linux), navigate to your working directory, and update local repository. Create a new working folder Labs/06-display\_driver for this exercise.

### Part 2: VHDL code for display driver

Multiplexer or MUX is a digital switch. It allows to route binary information from several input lines or sources to one output line or channel.

Perform the following steps to model the driver circuit.

- Create a new Vivado RTL project display\_driver in your Labs/06-display\_driver working folder.
- 2. Create a VHDL source file driver\_7seg\_4digits for the driver circuit.
- 3. Choose default board: Nexys A7-50T.
- 4. Open the Driver for 7-segment display example and copy/paste the design.vhd code to your driver\_7seg\_4digits.vhd file. Copy source files of clock enable, binary counter, 7-segment decoder modules from previous labs to
  - display\_driver/display\_driver.srcs/sources\_1/new/ folder and add them to the project.
- 5. Complete the driver code according to the following block diagram.



6. Create a simulation source tb\_driver\_7seg\_4digits, copy/paste the testbench.vhd code from EDA Playground template, complete the code, set conditions to display value 3.142 and run the simulation. Compare simulated timing diagram with yours in Preparation tasks. Verify the meaning of the constant c\_MAX and reset generation process.

## Part 3: Top level VHDL code

Perform the following steps to implement the 4-digit 7-segment display driver on the Nexys A7 board.

- 1. Create a new design source top in your project.
- 2. Use **Define Module** dialog and define I/O ports of entity top as follows.

| Port name | Direction | Туре                                 | Description       |
|-----------|-----------|--------------------------------------|-------------------|
| CLK100MHZ | input     | std_logic                            | Main clock        |
| BTNC      | input     | std_logic                            | Synchronous reset |
| SW        | input     | std_logic_vector(16 - 1<br>downto 0) | Four 4-bit values |
| CA        | output    | std_logic                            | Cathod A          |
| СВ        | output    | std_logic                            | Cathod B          |
| СС        | output    | std_logic                            | Cathod C          |
| CD        | output    | std_logic                            | Cathod D          |

| Port name | Direction | Туре                                | Description                                 |
|-----------|-----------|-------------------------------------|---------------------------------------------|
| CE        | output    | std_logic                           | Cathod E                                    |
| CF        | output    | std_logic                           | Cathod F                                    |
| CG        | output    | std_logic                           | Cathod G                                    |
| DP        | output    | std_logic                           | Decimal point                               |
| AN        | output    | std_logic_vector(8 - 1<br>downto 0) | Common anode signals to individual displays |

3. Use direct instantiation and define an architecture of the top level.

```
-- Architecture body for top level
architecture Behavioral of top is
   -- No internal signals
begin
    -- Instance (copy) of driver_7seg_4digits entity
    driver_seg_4 : entity work.driver_7seg_4digits
        port map(
            clk
                       => CLK100MHZ,
            reset => BTNC,
            data0_i(3) => SW(3),
            data0_i(2) => SW(2),
            data0_i(1) => SW(1),
            data0_i(0) => SW(0),
            --- WRITE YOUR CODE HERE
            dp_i => "0111",
            --- WRITE YOUR CODE HERE
        );
    -- Disconnect the top four digits of the 7-segment display
    AN(7 downto 4) <= b"1111";
end architecture Behavioral;
```

- 4. Create a new constraints XDC file: nexys-a7-50t and uncomment used pins according to the entity.
- 5. Compile the project and download the generated bitstream display\_driver/display\_driver.runs/impl\_1/top.bit into the FPGA chip.
- 6. Test the functionality of the driver by toggling the switches and observing the display.
- 7. Use **IMPLEMENTATION > Open Implemented Design > Schematic** to see the generated structure.
- 8. Use digital oscilloscope or logic analyser and display anode signals via Pmod ports. See schematic or reference manual of the Nexys A7 board and find out to which FPGA pins Pmod ports JA, JB, JC, and JD are connected.

### Synchronize repositories

Use git commands to add, commit, and push all local changes to your remote repository. Check the repository at GitHub web page for changes.

### Experiments on your own

- 1. On your smartphone, set slow motion video recording and observe the seven-segment display behavior:)
- 2. Extend the duration of one symbol on the 7-segment display ie. generic g\_MAX in driver\_7seg\_4digit.vhd file and experimentally determine the maximum value at which switching by the human eye is not yet observable.
- 3. Design the structure of driver\_7seg\_8digits module, which controls all eight 7-segment displays.

### Lab assignment

- 1. Preparation tasks (done before the lab at home). Submit:
  - Timing diagram figure for displaying value 3.142.
- 2. Display driver. Submit:
  - VHDL code listing of the process p\_mux with syntax highlighting,
  - Listing of VHDL testbench processes for reset and stimulus with syntax highlighting and asserts,
  - Screenshot with simulated time waveforms; always display all inputs and outputs. The full functionality of the entity must be verified,
  - Listing of VHDL architecture of the top layer.
- 3. Eight-digit driver. Submit:
  - Image of the driver schematic. The image can be drawn on a computer or by hand.

Prepare all parts of the assignment on a computer (not by hand), insert them in your README file Digital - electronics-1/Labs/06-display\_driver/README.md, export the formated output (not the listing in markdown language) from HTML to PDF, use BUT e-learning web page and submit a single PDF file. The deadline for submitting the task is the day before the next laboratory exercise.