

# **Getting to Know Vivado**

## **Course Workbook**

# Table of Contents

|                                  |                                |
|----------------------------------|--------------------------------|
| About this Workbook              | <a href="#"><u>Slide 3</u></a> |
| Pre-Lab: Workshop Pre-requisites | <a href="#"><u>Slide 4</u></a> |
| Lab 1: Understanding Vivado      | <a href="#"><u>Slide 7</u></a> |

# About this Workbook

This workbook is designed to be used in conjunction with the Getting to Know Vivado course.

The contents of this workbook are created by Adiuvo Engineering & Training, Ltd.

If you have any questions about the contents, or need assistance, please contact Adam Taylor at [adam@adiuvoengineering.com](mailto:adam@adiuvoengineering.com).

# **Pre-Lab**

## Workshop Pre-requisites

# Required Hardware

There is no required hardware for this course.

# Downloads and Installations

**Step 1 –** Download and install the following at least one day prior to the workshop. This may take a significant amount of time and drive space.

|                      |                          |
|----------------------|--------------------------|
| Vivado 2020.1        | <a href="#">Download</a> |
| Source Project Files | <a href="#">Download</a> |

# **Lab 1**

## Overview and Introduction to Vivado

# Lab 1: Overview and Introduction to Vivado

**Step 1 – Open Vivado 2020.1.**



# Lab 1: Overview and Introduction to Vivado

**Step 2 – Click on Create Project – This will open the New Project Wizard – Click Next.**



# Lab 1: Overview and Introduction to Vivado

**Step 3 – Enter the project name of “01\_Vivado” and select the location you want to save the project.**



# Lab 1: Overview and Introduction to Vivado

## Step 4 – Select RTL Project.



# Lab 1: Overview and Introduction to Vivado

**Step 5 – Click ADD FILES and select the two files downloaded from Github. For the file average\_tb.vhd, change the HDL source to Simulation Only.**



# Lab 1: Overview and Introduction to Vivado

**Step 6** – At this time we do not want to add any constraints files. Click **Next**.



# Lab 1: Overview and Introduction to Vivado

Step 7 – Select the **ZedBoard** and click **Next**.



# Lab 1: Overview and Introduction to Vivado

**Step 8 – On the project summary tab, select **Finish**.**



# Lab 1: Overview and Introduction to Vivado

**Step 9 – This will open Vivado in the project manager view.**



# Lab 1: Overview and Introduction to Vivado

## Step 10 – Expand the Simulation Sources.



# Lab 1: Overview and Introduction to Vivado

**Step 11** – This will show the test bench and the design source to be simulated.



# Lab 1: Overview and Introduction to Vivado

**Step 12 – Double clicking on the VHDL files will open the source for inspection.**



# Lab 1: Overview and Introduction to Vivado

**Step 13 – To run a simulation, click on Run Simulation and select Run Behavioral Simulation.**



# Lab 1: Overview and Introduction to Vivado

Step 14 – This will open the behavioral simulation view. Note the scope and objects.



# Lab 1: Overview and Introduction to Vivado

**Step 15 – Click on the Untitled\* tab to see the waveform of the simulation. Note this view shows the signals defined within the test bench only, not the Unit Under Test.**



# Lab 1: Overview and Introduction to Vivado

**Step 16 –** At the moment, the results are in hexadecimal but they make more sense in decimal. Select all the signals, right click, and select **unsigned decimal** from the **radix**.



# Lab 1: Overview and Introduction to Vivado

**Step 17** – This will change the results to decimal. Correct operation has result showing 118 then 96. This is the block average of 16 input values.



# Lab 1: Overview and Introduction to Vivado

**Step 18 –** Often we want to be able to see the signals in the UUT. To do this, first let's insert a divider. Right click on the **bottom signal** and select **New Divider**.



# Lab 1: Overview and Introduction to Vivado

**Step 19 – When prompted, enter the name UUT and you will see the new divider in the waveform.**



# Lab 1: Overview and Introduction to Vivado

**Step 20 – To add in the UUT, right click on the **UUT** under the scope and select **Add to Wave Window**.**



# Lab 1: Overview and Introduction to Vivado

**Step 21** – This will add in the UUT signals, however, some information may be missing as it was not saved during the simulation.



# Lab 1: Overview and Introduction to Vivado

**Step 22 –** To add in the missing waveform, we need to restart the simulation. Select **Restart** from menu bar.



# Lab 1: Overview and Introduction to Vivado

**Step 23 – This will clear all waveform data and restart the simulation.**



# Lab 1: Overview and Introduction to Vivado

**Step 24 –** To rerun the simulation, select the **Run button** on the menu. The simulation will stop automatically.



# Lab 1: Overview and Introduction to Vivado

**Step 25 –** When the simulation completes, you will see the highlighted line in the test bench.



# Lab 1: Overview and Introduction to Vivado

**Step 26 – Selecting the waveform tab again will show all the signals for the UUT.**



# Lab 1: Overview and Introduction to Vivado

**Step 27 –** If you make changes to the source code, you need to relaunch the simulation. This can be achieved using the relaunch button on the menu.



# Lab 1: Overview and Introduction to Vivado

**Step 28 –** With the simulation complete, we are now ready to implement the design. Close the simulation view.



# Lab 1: Overview and Introduction to Vivado

**Step 29** – When asked to confirm, click **OK**. If a save waveform dialog pops up, select **Discard**.



# Lab 1: Overview and Introduction to Vivado

**Step 30 – To synthesize the design, click the green run arrow and select Run Synthesis.**



# Lab 1: Overview and Introduction to Vivado

**Step 31 –** On the Launch Runs dialog, select the number of jobs you want to run on your system and click **OK**.



# Lab 1: Overview and Introduction to Vivado

**Step 32 –** When synthesis is complete, you will see a dialog box appear.



# Lab 1: Overview and Introduction to Vivado

**Step 33 – Select Open Synthesized Design.**



# Lab 1: Overview and Introduction to Vivado

**Step 34 –** This will open the synthesis view. From the menu layout, select I/O Planning.



# Lab 1: Overview and Introduction to Vivado

**Step 35 – Expand the Data\_In, Result and Scalar Ports and assign them to pins. All EXCEPT the clock pin can be assigned to any pin.**



# Lab 1: Overview and Introduction to Vivado

**Step 36 – Assign the clock pin to Y9.** Clocks have to be assigned to clock capable pins.



# Lab 1: Overview and Introduction to Vivado

**Step 37 – Ensure the **IO Standard** is set to **LVC MOS18**. Do not leave it as default because this will lead to a failure to implement and generate a bitstream.**



# Lab 1: Overview and Introduction to Vivado

Step 38 – Save the Constraints we just edited.



# Lab 1: Overview and Introduction to Vivado

**Step 39** – This will present two new dialogs. Click **OK** on the first and enter a **file name** for the second.



# Lab 1: Overview and Introduction to Vivado

## Step 40 – Close the Synthesis View.



# Lab 1: Overview and Introduction to Vivado

**Step 41** – Confirm the decision to close by clicking **OK**. This will take us back to the project manager view.



# Lab 1: Overview and Introduction to Vivado

**Step 42 – We are now ready to Run Implementation.**



# Lab 1: Overview and Introduction to Vivado

**Step 43 – Click Yes when the Synthesis Out-of-Date dialog pops up.**



# Lab 1: Overview and Introduction to Vivado

**Step 44 – Select OK on the Launch Runs dialog.**



# Lab 1: Overview and Introduction to Vivado

**Step 45 – When the implementation completes, you will see a dialog appear. Select **Generate Bitstream**.**



# Lab 1: Overview and Introduction to Vivado

**Step 46** – A dialog box will appear when the bitstream generates. Congratulations you have completed your first Vivado FPGA implementation.



# **Lab 2**

## Intermediate Vivado

# Lab 2: Intermediate Vivado

**Step 1 – Open the project created in part one.**



# Lab 2: Intermediate Vivado

Step 2 – This will open in project management view. Click on **Create Block Diagram**.



# Lab 2: Intermediate Vivado

**Step 3 – Leave the predefined name and locations unchanged and click **OK**.**



# Lab 2: Intermediate Vivado

**Step 4 – Undock the block diagram window and maximize it.**



# Lab 2: Intermediate Vivado

**Step 5 – We are going to add in new IP. Click on the **+** button.**



# Lab 2: Intermediate Vivado

**Step 6 – Select the FIFO Generator.** This will add a FIFO to the block diagram.



# Lab 2: Intermediate Vivado

**Step 7 – Double click on the FIFO Generator to customize it.**



# Lab 2: Intermediate Vivado

**Step 8 – Leave the first page unchanged.**



# Lab 2: Intermediate Vivado

**Step 9 – Change the Write and Read Width to be 8 bits.**



# Lab 2: Intermediate Vivado

**Step 10 – Leave the third page unchanged.**



# Lab 2: Intermediate Vivado

**Step 11 – Leave the fourth page unchanged.**



# Lab 2: Intermediate Vivado

**Step 12 –** Leave the final page unchanged. Note that the FIFO OP are unregistered. Click **OK**.



# Lab 2: Intermediate Vivado

**Step 13 – Click back on the Vivado Project Management view you will see the block diagram under the design sources.**



# Lab 2: Intermediate Vivado

**Step 14 – Right click on the average RTL block and select Add Module to Block Design.**



# Lab 2: Intermediate Vivado

**Step 15** – This will add the average block to the block diagram.



# Lab 2: Intermediate Vivado

**Step 16 – Expand the FIFO Write and Read Interfaces.**



# Lab 2: Intermediate Vivado

**Step 17 –** Make the Clk, Reset, Result, Valid and FIFO Write interfaces external by right-clicking on each pin and selecting **Make External**. Connect the remaining interfaces as below.



# Lab 2: Intermediate Vivado

**Step 18 – Click on Validate Design.**



## Lab 2: Intermediate Vivado

**Step 19 –** The validated design should result in no error or critical warnings. Click **OK**.



# Lab 2: Intermediate Vivado

**Step 20 – Re-dock the block diagram window into the Vivado Project Manager.**



# Lab 2: Intermediate Vivado

**Step 21 – Click on the Zoom Fit button to fit the design to the window.**



# Lab 2: Intermediate Vivado

**Step 22 – Right click on the block diagram design under the Design Sources tab and select Create HDL Wrapper.**



# Lab 2: Intermediate Vivado

**Step 23 – Allow Vivado to manage the wrapper and click **OK**.**



# Lab 2: Intermediate Vivado

**Step 24 – Expand the newly created wrapper and you will see the entire design.**



# Lab 2: Intermediate Vivado

## Step 25 – Run the Synthesis.



# Lab 2: Intermediate Vivado

**Step 26** – On both resultant dialogs click **OK** and wait for synthesis to complete.



# Lab 2: Intermediate Vivado

**Step 27 – When synthesis completes, Open the Synthesized Design.**



# Lab 2: Intermediate Vivado

**Step 28 –** If any critical warnings pop up, select **OK**. This is due to out of data constraints which we are about to address.



# Lab 2: Intermediate Vivado

**Step 29 – Change the I/O standard from default to LVCMOS18.**



# Lab 2: Intermediate Vivado

**Step 30 – Assign the clock input to pin Y9. Assign all other IO to pins of your choice.**



# Lab 2: Intermediate Vivado

Step 31 – Click on Save Constraints.



# Lab 2: Intermediate Vivado

**Step 32 – If an out-of-date warning appears, click OK.**



# Lab 2: Intermediate Vivado

**Step 33 –** From the sources tab, open the **IO constraints**. You will see the old pin out for the previous project and your new project. This is because we have evolved the original project.



# Lab 2: Intermediate Vivado

**Step 34 – Select the old constraints (at the top of the file) and delete them. Save the file.**



# Lab 2: Intermediate Vivado

## Step 35 – Run the Implementation.



# Lab 2: Intermediate Vivado

**Step 36 – Click OK to run the implementation.**



# Lab 2: Intermediate Vivado

**Step 37 – When the implementation completes, click **View Reports**.**



# Lab 2: Intermediate Vivado

## Step 38 – Select Constraints under Design Sources.



# Lab 2: Intermediate Vivado

Step 39 – Click on the Add Source button.



# Lab 2: Intermediate Vivado

**Step 40 – Select Add or Create Constraints. Then Create File, enter the name “timing” for the file, and click Finish.**



# Lab 2: Intermediate Vivado

**Step 41 – Right click on the newly created constraint file and select Set as Target Constraints File.**



# Lab 2: Intermediate Vivado

**Step 42 – Open the implemented design. If you see the warning below click **OK**.**



# Lab 2: Intermediate Vivado

Step 43 – From the Tools menu, select Timing -> Constraints Wizard.



# Lab 2: Intermediate Vivado

**Step 44 –** On the welcome screen, click **Next** and then enter **200 MHz** for the clock frequency. Once done, select **Skip to Finish**.



# Lab 2: Intermediate Vivado

**Step 45 –** On the final page, check that only one constraints is being created, check the **View Timing Constraints**, and click **Finish**.



# Lab 2: Intermediate Vivado

**Step 46 – Close the implementation view and **rerun the implementation**. Click **OK** on any dialogs which pop up prior to implementation starting.**



# Lab 2: Intermediate Vivado

**Step 47 – Once the implementation completes, Timing will fail. Open the Implemented Design.**



# Lab 2: Intermediate Vivado

**Step 48 – In the implemented design, select the failing Intra-Clock Paths.**



# Lab 2: Intermediate Vivado

**Step 49 – Select Path 1 and zoom in.** You will see that the FIFO output data passes through LUTs before finally being registered. This path is too long for timing at 200 MHz.



# Lab 2: Intermediate Vivado

**Step 50 –** To fix this, we need to register the output of the FIFO. Close the implementation view and reopen the block diagram. Double click on the **FIFO** to customize.



# Lab 2: Intermediate Vivado

**Step 51** – Note the latency has changed from 1 to 2 clocks. We would need to correct for this in the average block, however, we proceed assuming that we have.



# Lab 2: Intermediate Vivado

**Step 52 – Reimplement the design.** When the timing is completed, you should see that the implementation is correct and the timing is met.

