CS373 LM8: Introduction to FPGA’s and VHDL using   
Xilinx Vivado® and the BASYS 3 Board

Name(s) Stephen Haugland

|  |  |  |
| --- | --- | --- |
| **CATEGORY** | **POINTS** |  |
| Majority4 |  | 50 |
| TOTAL |  | 50 |

## Learning Goals for This Study Guide

* Understand where to locate additional information about FPGA design with the Basys 3
* Gain an introductory understanding of how and FPGA works and how they are programmed.
* Learn the key features of the Bassys 3 board.
* Understand how to test and verify that the Basys 3 board is working correctly.
* Learn beginning VHDL.
* Learn how to simulate a design.
* Challenge critical thinking skills by implementing a new project.

## Instructions for This Project

* You may work by yourself or with another person. You must **both** submit the code to whitgit along with your changes to this document. You must each answer the questions in this document by yourself, but you may consult each other on your answers.
* Answer the questions on the last page of this document and submit this document (with your answers in it) to Blackboard.
* Follow the instructions given in class to install Vivado on your machine (or use the machines in the lab – if you use lab machines which already have Vivado installed, you will need to install the board files for the BASYS 3)
* Create the majority project using the TCL/Bash scripts provided in class. You will need to configure the TCL script so that it builds your majority project.

# Majority4 Project

Now it’s time to put your newly learned skills to use. For this project you will design and implement the logic for a **Majority Circuit** that has four input bits.

## Marjority4 Project Specifications

* **Pull the LM8\_Majority starter project from whitgit using vscode**
* Create a **Majority** VHDL module that has:
  + Four STD\_LOGIC inputs, a, b, c and d.
  + One STD\_LOGIC output m :
    - This output will be high if 3 or 4 of the a,b,c,d inputs are active.
    - This output will be low if 0, 1, or 2 of the a, b, c, d inputs are active.
* **Create a testbench vhdl file to test all combinations of a, b, c, d of your Majority component**.
  + You could do this using nested simulation code loops for loops in a test bench, but this is not required for this lab. We will cover how to write more complex test bench code in class.
  + Make sure to configure the setup TCL script so that this simulation will be generated.
* Create a **Majority\_top** VHDL module that interfaces to the BASYS 3 board.
  + This should include the Majority component and map the board inputs/outputs to this component.
  + Setup the project so that SW(3), SW(2) … SW(0) map to the inputs of your majority circuit **a**, **b, c**, and **d** respectively.
  + Setup the project so that LED(0) is mapped to the output **m** of your majority circuit.
* **You must program the FPGA board and verify the majority circuit works: if any 3 of the four switches are high the LED should turn on. It should also turn on if all four switches are set to high.**
  + Modify the setup TCL script so that it will generate both the simulation and the bitstream

## Majority Circuit Design

1. Create a Karnaugh map for the Majority circuit include the k-map and the resulting Boolean equation for the Majority circuit here:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| CD/AB | 00 | 01 | 11 | 10 |
| 00 | 0 | 0 | 0 | 0 |
| 01 | 0 | 0 | 1 | 0 |
| 11 | 0 | 1 | 1 | 1 |
| 10 | 0 | 0 | 1 | 0 |

M = BCD + ACD + ABC + ABD

1. Include a copy of your Majority VHDL module code here. Make sure it is commented well!

------------------------------------------------

-- Module Name: majority4

------------------------------------------------

library IEEE;

use IEEE.STD\_LOGIC\_1164.ALL;

entity majority4 is

-- complete the port statement for this module

-- defining inputs and output

    Port (  a : in STD\_LOGIC;

            b : in STD\_LOGIC;

            c : in STD\_LOGIC;

            d : in STD\_LOGIC;

            m : out STD\_LOGIC

        );

end majority4;

architecture majority4 of majority4 is

begin

-- complete the behavioral code for this module

-- Boolean logic equation derived from k-map simplification

    m <= (b and c and d) or (a and c and d) or (a and b and c) or (a and b and d);

end majority4;

1. Include a copy of your Majority\_top level VHDL module code here. Make sure you comment it well!

library IEEE;

use IEEE.STD\_LOGIC\_1164.ALL;

entity majority4\_top is

  Port ( sw : in STD\_LOGIC\_VECTOR (15 downto 0);  -- 16 switch inputs

        LED : out STD\_LOGIC\_VECTOR (15 downto 0);  -- 4 leds above switches

        an  : out STD\_LOGIC\_VECTOR (3 downto 0);  -- Controls four 7-seg displays

        seg : out STD\_LOGIC\_VECTOR(6 downto 0);   -- 6 leds per display

        dp  : out STD\_LOGIC                       -- 1 decimal point per display

  );

end majority4\_top;

architecture majority4\_top of majority4\_top is

-- add the component statement here for the majority4 entity

component majority4 is

  -- defining 4 single bit inputs and 1 single bit output

  Port( a : in STD\_LOGIC;

  b : in STD\_LOGIC;

  c : in STD\_LOGIC;

  d : in STD\_LOGIC;

  m : out STD\_LOGIC );

end component;

begin

-- map the the wires from the board to the majority 4 compoment as described in the lab instructions

-- hooking up inputs to board switches, and output to board led

m1 : majority4 port map (

  a <= SW(3),

  b <= SW(2),

  c <= SW(1),

  d <= SW(0),

  m <= LED(0)

);

----------------------Leave this untouched------------------------------

-- Turn off the 7-segment LEDs

an <= "1111";     -- wires supplying power to 4 7-seg displays

seg <= "1111111"; -- wires connecting each of 7 \* 4 segments to ground

dp <= '1';        -- wire connects decimal point to ground

end majority4\_top;

1. Include a screen snip of your Majority circuit simulation testbench running here:

![Chart, treemap chart

Description automatically generated](data:image/png;base64,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8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzoMd9llxONHG2c6DHfaQ8jzWxtnOgx32WXE40cbZzoMd9pDyPNbG2c6DHfZZcTjRxtnOgx32kPI81sbZzvu+2L/60MCHaOBuZ/gQX6cvUgNf56dBExrQgAY0oAENaEADGtCABjSgAQ1oQAMa0IAGNKABDWhAAxrQgAY0oAENaEADGtCABjSgAQ1oQAMa0IAGNKABDWhAAxrQgAY0oAENaEADGtCABjSgAQ1oQAMa0IAGNKABDWhAAxrQgAY0oAENaEADGtCABjSgAQ1oQAMa0IAGNKABDWhAAxrQgAY0oAENaEADGtCABjSggdc34FcGauCjNPDTv31o4IM0APsHWWhf5r///f9Y2012rMSudgAAAABJRU5ErkJggg==)

1. Describe the design process, what issues you faced, and how it works.

First, we started with defining our majority4 component by describing the combinational logic for our output. In order to create this behavioral code, we had to first make a k-map to deduce the simplest Boolean expression for the output m. Once we had that, we could code that logic into our majority4 component. This file acted as a template or object that we could create an instance of later on in our simulation testbench and our top-level file to program the board. Next, we tested this majority 4 component to make sure our logic was correctly defined by feeding it different inputs and assuring the correct outputs were given through assert statements. In addition to looking for fail reports in our logs from failed assertions, we also were able to view the trace diagram (see question 4) to confirm our logic was correct. After we confirmed that our component was designed correctly, we edited the majority4\_top file in order to connect our majority4 component up to the input switches and output LED on the board. Then we generated a bitstream which was loaded onto our board and finally we tested our program on our board. To our surprise, once we had worked out all of the compilation errors and loaded the program to our board, it worked as expected and when 3 or 4 switches were high, the led turned on.

Overall our design process started by determining the combinational logic for our output using “and” and “or” gates and we slowly abstracted these details away until we had an instance of a majority\_4 module that we had tested, and then connected and programmed to our board.

Some of the main issues we had was with the syntax and getting used to how VHDL code works. At first we defined our inputs a,b,c,d to be STD\_INPUT\_VECTOR(0 downto 0) because we were following the example from the slides that had an input with multiple bits. This did not work however because we were trying to assign a vector to a single integer. Besides this, one main conceptual issue I had was with not realizing that the simulation test bench was not at all related to programming our boards. I was a little confused as to why we were defining our majority4 component in multiple files but we needed to in order to first run a simulation on it and second, connect it to the board.