Project 1.1: Introduction to Digital Engineering and FPGA Boards

by Commanderfranz in Circuits > Electronics

12693 Views, 42 Favorites, 0 Comments

Project 1.1: Introduction to Digital Engineering and FPGA Boards

53bc463bec8d838e960001c9.jpg

This is the first in a series of projects using Digilent materials that are created for EE214 at Washington State University . However, we decided that we wanted to make them more accessible to the general public, so I am creating them here. For more of Digilent's educational materials, see the Learn Site.

This project sets up your FPGA board for use and shows you the steps in starting project files. It also gives you some basic background knowledge on electrical engineering and digital circuits. This is a starter project with very little hands-on work with your board, but it is a good reference if you ever forget how to start your projects.

What you need:

- A Digilent FPGA board, This series will focus on the Nexys 4 and Basys 3.

- A PC with Internet access

- Time to set up the board and download tools

What you will gain:

- Xilinx Vivado Webpack installed

- A basic understanding of digital engineering

- Knowledge of setting up a Verilog project for your FPGA Board

I will not cover all the basic circuit theory necessary in this tutorial, but If you are interested you can follow these links:

- Electronic Charge, Voltage and Current

- Resistance and Ohm's Law

- Electric Vs. Electronic

- Electronic Components

- Physical Vs Model

Basic Theory

The use of the word circuit in this context comes from the idea that electric power must flow from the positive terminal of a power source through one or more electronic devices and back to the negative terminal of a power source, thereby forming a circuit. If the connections between an electronic device and either the positive or negative terminals of a power supply are interrupted, the circuit will be broken and the device will not function.

A digital circuit consists of a power supply, devices, and conduction nets. Some nets provide circuit inputs from the “outside world”; in a schematic, these input nets are generally shown entering the left side of component and/or the overall circuit. Other nets present circuit outputs to the outside world; these nets are generally shown exiting the schematic on the right side. Circuit components are shown as arbitrary shapes, nets are shown as lines, and inputs and outputs are denoted by connector symbols. In a digital circuit, power supply voltage levels are constrained to two distinct values – “logic high voltage” (called LHV or Vdd) and “logic low voltage” (called LLV or GND). The GND node in any circuit is the universal reference voltage against which all other voltages are measured (in modern digital circuits, GND is typically the lowest voltage in the circuit). In a schematic, it is often difficult to show lines connecting all GND nodes; rather, any nodes labeled GND are assumed to be connected into the same node. The Vdd node in a digital circuit is typically the highest voltage, and all nodes labeled Vdd are tied together into the same node. Vdd may be thought of as the “source” of positive charges in a circuit, and GND may be thought of as the “source” of negative charges in a circuit. In modern digital systems, Vdd and GND are separated by anywhere from 1 to 5 volts. Older or inexpensive circuits typically use 5 volts, while newer circuits use 1-3 volts. In digital circuits, the Vdd and GND voltages are used not only to supply electric power to circuit devices; they are used to represent information as well. The most basic digital devices are called gates. The function of gates, or“gating,” is to allow or halt the flow of digital information. In general, a gate has one or more inputs and produces an output (more on that later). Now that you have a basic understanding of what digital engineering is and how the circuits function, let’s move on to setting up your FPGA board and getting started.

Download the Vivado Tools and License

You will need to have a computer connected to the internet and some time for this step.

1. Install Xilinx Vivado WebPACK tools. All projects require a Xilinx Vivado Design Suite WebPACK Edition.

2. Open the Hardware Manager and request a license.

Create a Vivado Project

1 - vivado.PNG
2- create new project.PNG
3- name new project.PNG
53bad67326ece2fc01000029.jpg

Open Vivado:

Linux (See screenshot for reference):

First source the settings* with the following line;

source /(Filepath of Vivado setting you prefer)

Then open Vivado with the following line;

vivado & or vivado /(.xpr filepath**)

**To open a specific project replace the & with the filepath of the .xpr file.

*Note: There are four settings files available in the Vivado toolset: settings64.sh for use on 64-bit machines with bash; settings32.sh for use on 32-bit machines with bash; settings32.csh for use on 32-bit machines with C Shell; and settings64.csh for use on 64-bit machines with C Shell.

Windows:

Although Vivado is now compatible with Windows 8, I would highly recommend using Vivado on Linux as it runs much faster. For Windows installations, simply click on the icon.

Name the Project:

Name the project something helpful for when you have to find it and open it again. I usually name mine with the project number and a short title of what the project should be. That way you can find it whether you know what it is or what project number it is.

Choose Sources

4 - add sources.PNG

Next, Vivado will prompt you to choose sources for your project. If you already had source files you could add them here. However, you can also add them later.

Project Type

4 - rtl project.PNG

Next, you will choose the appropriate project types. We will choose RTL Project. Vivado provides short descriptions beneath each project type.

Add IP and Add Constraints

5 - addip.PNG
6 - add constraints.PNG

Next it will prompt you for IPs or constraints. Again, you can add these here or later, if you prefer. The constraints file is the .xdc file (.ucf in ISE.)

Select Part

7 - select part.PNG
53baf0de26ece2e13d000035.jpg
8 - next.PNG

Next, Vivado will prompt you to select the part that you will be programming. You can find all the information you need on the chip itself, or if it is too difficult to read, in the reference manual. The image of the chip is from the Basys 3. I've labeled the information you need from it to select the part.

Hit next, then hit finish to finish creating the project.

Finish Creating the Project

8 - next.PNG
9-window.PNG

Hit finish and the empty project manager should open up.

Add Sources

10-add sources.PNG

Download the appropriate demo files for your board.

Double-click on the constraints file and right-click on the folder inside. Then select add sources. This is where you will put the appropriate .xdc file.

Right click on design sources and add the appropriate .v file.

Run Synthesis

11 - before running.PNG

Now that you have the correct Verilog and XDC files, you can build the project. Under flow navigator, click run synthesis.

Run Implementation

12- Synthesis done.PNG

After the synthesis is done, this window should appear. Select Run Implementation and click ok.

Generate Bitstream

13 - implementation done.PNG

After the implementation is done, this window should appear. Select Generate Bitstream and click ok.

Open Hardware Manager

14 - bitstream done.PNG

After the Bitfile is generated, this window will appear. Select open hardware manager and click ok.

Open New Hardware Target

15 - open hardware target.PNG

Now that the Bitstream has completed, you can program the board. When the hardware manager opens, select Open a New Hardware Target, which is in blue text on the green bar.

Select Server

16 server.PNG

Select the Server that the board is connected to. Generally that will be the local server.

Select Target

17 - select target.PNG
18 - summary.PNG

Select the correct hardware target, hit next, and then finish.

Program Device

19 - program device.PNG
20 - select device.PNG

In the Hardware Manager, select program device that will be in blue text on the green bar. Then select your board from the drop-down menu.

Select Bitfile

21 - bitfile.PNG

The correct bitfile should already be selected, but double-check just to be sure. Then click program. You will see the demo operating and showing the green LEDs on except for one LED that is off, and moving across the LEDs. The seven-segment display will change through the different segments. When this is complete you have finished this project!