



# DIGITAL DESIGN

LAB1 USING VIVADO + FPGA DEVELOPMENT BOARD(MINISYS/EGO1)

2022 FALL TERM

A faint, light blue watermark-like pattern of a printed circuit board (PCB) is visible across the entire slide, showing various tracks, vias, and component pads.

# DIGITAL DESIGN

LAB1 USING VIVADO + FPGA DEVELOPMENT BOARD(MINISYS/EGO1)

2022 FALL TERM



# DIGITAL DESIGN

LAB1 USING VIVADO + FPGA DEVELOPMENT BOARD(MINISYS/EGO1)

2022 FALL TERM

# TOPICS

- Experimental Platform  
EDA tool (Vivado 2017.4) + FPGA Development Board(EGO1/Minisys)
  - Vivado installation tips
  - FPGA Development Board(EGO1/Minisys) introduction
- 1st Lab on Digital Logic course
  - Build a Vivado project, add circuit design file and constraint file
  - Connect Vivado with FPGA Development Board and program the FPGA chip
  - Test the circuit which runs on the FPGA chip
- Questions and Exercises

It is an acronym for field programmable gate array. It is a semiconductor IC where a large majority of the electrical functionality inside the device can be changed; changed by the design engineer, changed during the PCB assembly process, or even changed after the equipment has been shipped to customers out in the 'field'.

# EXPERIMENTAL PLATFORM: EDA + FPGA DEVELOPMENT BOARD

Electronic Design Automation, or EDA, is a market segment consisting of software, hardware, and services with the collective goal of assisting in the definition, planning, design, implementation, verification, and subsequent manufacturing of semiconductor devices, or chips. Regarding the manufacturing of these devices, the primary providers of this service are semiconductor foundries, or fabs. These highly complex and costly facilities are either owned and operated by large, vertically integrated semiconductor companies or operated as independent, "pure-play" manufacturing service providers. This latter category has become the dominate business model.

- Vivado (a type of EDA tools)
  - Vivado is a design environment for FPGA products from Xilinx, and is tightly-coupled to the architecture of such chips, and cannot be used with FPGA products from other vendors.
  - Vivado enables developers to synthesize (compile) their designs, perform timing analysis, examine RTL diagrams, simulate a design's reaction to different stimuli, and configure the target device with the programmer.
  - The version we choose is Vivado 2017.4
- Installation of Vivado (20 G free hard disk space is suggested)
  - Attention: the name of the directory which includes installation package MUST NOT containing Chinese and space characters.



# FPGA DEVELOPMENT BOARD(MINISYS)



- Power Interface (17)
- USB-JTAG Interface (21)
- **Artix 7 FPGA chip** (10)
- SRAM (9)
- **Seven-Segment Digital Tube** (1)
- **Mini Keyboard** (3)
- **Dial Switch \*24** (5)
- **LED \*24** (4)

# FPGA DEVELOPMENT BOARD(EGO1)



MINI SY

- Power Switch (1)
- Potentiometer (2)
- Button \* 5 (3)
- Dial switch \* 16 (4)
- **Reset Button (5)**
- **Seven-Segment Digital Tube \* 8 (6)**
- **Artix 7 FPGA chip (7)**



# VIVADO(2017.4) INSTALLATION (TIPS1)

<ftp://10.20.118.226/>

account: **ftp-d-logic**

password: **ggsddu**

**Download** two files from FTP site to your PC:

**Attention:** Before coping, make sure there is enough free space in the destination disk.

- 1) Installation package:  
“Xilinx\_Vivado\_SDK\_2017.4\_1216\_1.rar”
- 2) Licence file: “xilinx\_ise\_vivado\_2017.lic”



**Decompress** the compressed package “Xilinx\_Vivado\_SDK\_2017.4\_1216\_1.rar”, find the file “xsetup.exe”, **double click** it to start the installation.



## ATTENTION:

The FTP site is only valid for the user who are in Sustech compus.

If you are not in the compus, get all the files used for Vivado installation from the Baidu disk  
(webpage : <https://pan.baidu.com/s/1MfeMCk2igcsf1WEQA49ObA> key: **fhr4**)

# VIVADO(2017.4) INSTALLATION (TIPS2)

Following the steps below



# VIVADO(2017.4) INSTALLATION (TIPS3)



It's suggested to install the "Vivado HL System Edition" because of its "complete device support" and "Documentation Navigator".

下该版本  
IP包. FTP  
芯片号  
8

# VIVADO(2017.4) INSTALLING (TIPS4)



The size of “Vivado HL system Edition” is huge.  
It is strongly recommended to select **ONLY WHAT IS NEEDED TO INSTALL!!**

The options in the left figure are enough for both the Digital Logic course and Computer Organization course.

# VIVADO INSTALLING (TIPS4)



At the end of the installing,  
load license as shown in  
the left figure.

## ATTENTION:

The license file(with ".lic" as its suffix) could be in  
**ANYWHERE** of your  
computer which is now  
doing the Vivado  
installation.

"□□□□□□□" here is just  
a demo on my computer, **NOT**  
**MUST**.

# USING VIVADO + FPGA DEVELOPMENT BOARD

Follow the Following steps to make your designed circuit implement on the FPGA chip, test the circuit on the board which is embeded with the FPGA chip and other input/output device(s).



# USING VIVADO + FPGA DEVELOPMENT BOARD(1)

**STEP1-1. Create project, select “rtl type” as its type, determin the project’s name and location(the name and location of the project MUST NOT containing Chinese characters), select the corresponding **FPGA chip name**.**



**Attention:**

the value of project name and location in the middle figure is just a demo, all of them should be upto you to decide.

# USING VIVADO + FPGA DEVELOPMENT BOARD(2)

STEP1-2. select the corresponding **FPGA chip**. The version of **FPGA chip** in EGO1 is different from which in Minisys board.

The version of **FPGA Chip** in **Minisys** board:

Artix 7 xc7a100t fgg484-1



Blue one

The version of **FPGA Chip** in **EGO1** board:

Artix 7 xc7a35t CSG324-1



Red one

an 12

# USING VIVADO + FPGA DEVELOPMENT BOARD(3)

**STEP2.** Adding source file(s), including **design** file(s), **simulation** file(s) and **constraints** file(s). There are **two ways** to add file(s):

- 1) Adding file(s) **while creating project**(as shown in the left figure below).

TIPS: If there's NO file, you can **creat** file(s) or just skip the adding files while creating the project.

- 2) Adding file(s) **after the project is created**(as shown in the right figure below).

**Attention:** In both ways, You should first select the file type then add or creat a file.



# USING VIVADO + FPGA DEVELOPMENT BOARD(4)



**STEP3.** Following the steps to **verify the function** of your designed circuit(**step1** in the left figure) by simulation and generate bitstream file which is used to program FPGA chip(**step4** in the left figure)

- Do the **simulation**(**step1** in the left figure) to verify the function of the designed Circuit
  - After simulation, there will be a waveform which records the states of circuit's input and output signals.
    - If the function of the circuit is NOT ok, you should **modify the design file(s)**, then do the simulation(**step1** in the left figure) again to verify the function of circuit. Subsequent steps can ONLY be started after the function verification is passed
    - If the function of the circuit is ok , "**run synthesis**"(**step2** in the left figure) ,then "**run implementation**"(**step3** in the left figure)
  - After the implementation is finished, do the "**Generate Bitstream**"(**Step4** in the left figure) to generate a **bitstream file**(with ".bit" as its suffix) .

- synthesis : mixture or combination of ideas and styles  
综合

# Where to find the bitstream file



# USING VIVADO + FPGA DEVELOPMENT BOARD(5)

**STEP4. First Connect EGO1/Minisys board with PC which runs the Vivado project, then turn on the EGO1/Minisys board.**



for vivado & bit流  
之類

**TIPS:**  
Here is a demo of connection between EGO1 board and the PC which runs the vivado projet.

- USB **TypeC** interface for EGO1/Minisys(new version) board
- USB **JTAG** interface for Minisys(old version) board

# USING VIVADO + FPGA DEVELOPMENT BOARD(6)

**STEP5.** First Click “Open Hardware Manager”, then click“**open Target** ” (as shown in the left figure below) to **connect the Vivado project with FPGA chip** which is embeded in the EGO1/Minisys board.

**Attention:** If the FPGA chip is found by the Vivado project, the chip type could be found in the “**Hardware**” window(as shown in the right figure below, the chip type is xc7a100t), if there is no info about the chip in the “**Hardware**” window, you should redo the STEP4 on last page and the STEP5 on this page untile the FPGA chip is found.



| Name                            | Status     |
|---------------------------------|------------|
| localhost (1)                   | Connected  |
| xilinx_tcf/Xilinx/1234-tulA (1) | Open       |
| xc7a100t_0 (1)                  | Programmed |
| XADC (System Monitor)           |            |

# USING VIVADO + FPGA DEVELOPMENT BOARD(7)

STEP6. right click “Program Device”, then choose the device name(as shown in the left figure below), select the bitstream file(with “.bit” as its suffix) , click “Program” button(as shown in the right figure below).



while the led of “Done” on Minisys/EGO1 is on, it means the bit file is written into the device, it means your circuit is implemented on the FPGA chip, Congratulations!!

Is your circuit functioning properly ? Testing it on the EGO1/Minisys.

# A 8-INPUTS-8-OUTPUTS CIRCUIT ON EGO1

lab1\_sw\_led\_8.v

```
module lab1_sw_led_8(
    input [7:0] sw,
    output [7:0] led
);
    assign led=sw;
endmodule
```

lab1\_sw\_led\_8\_sim.v

```
`timescale 1ns / 1ps

module lab1_sw_led_8_sim();
reg [7:0] tb_sw=24'h000000;
wire [7:0] tb_led;

lab1_sw_led_8 usrc1(
    .sw(tb_sw),
    .led(tb_led)
);

always #10 tb_sw=tb_sw+1;
endmodule
```

lab1\_ego1.xd  
c

```
set_property IOSTANDARD LVCMOS33 [get_ports {led[7]}]
...
set_property IOSTANDARD LVCMOS33 [get_ports {led[0]}]
set_property IOSTANDARD LVCMOS33 [get_ports {sw[7]}]
...
set_property IOSTANDARD LVCMOS33 [get_ports {sw[0]}]
set_property PACKAGE_PIN F6 [get_ports {led[7]}]
...
set_property PACKAGE_PIN K2 [get_ports {led[0]}]
set_property PACKAGE_PIN P5 [get_ports {sw[7]}]
...
set_property PACKAGE_PIN R1 [get_ports {sw[0]}]
```

Q: If “lab1\_sw\_led\_8\_sim.v” is removed from the Vivado project, will the circuit on the FPGA chip work or not?

# PRACTICE1

- If you have NOT got the board(with FPGA chip embeded), do practice1, following the steps shown in the top figure on the right side.
- A waveform would be generated to show the logic relationship between the input and output of the designed circuit.
- Is the logic relationship shown in the waveform same with your design?



Screenshot of the Vivado IDE interface:

- Top menu: File, Edit, Flow, Tools, Reports, Window, Layout, View, Run, Help.
- Time scale: 10 us.
- Flow Navigator: IP INTEGRATOR, SIMULATION (selected), RTL ANALYSIS.
- SIMULATION - Behavioral Simulation - Functional - sim\_1 - lab1\_sw\_led\_8\_sim.
- Protocol Instances: lab1\_sw\_led\_8.v, Untitled 3.
- Waveform viewer showing tb\_sw[7:0] and tb\_led[7:0] over time.
- Source code editor (lab1\_sw\_led\_8\_sim.v):

```
timescale 1ns / 1ps
module lab1_sw_led_8_sim();
    //connect to input
    reg [7:0] tb_sw=24'h000000;
    //connect to output
    wire [7:0] tb_led;
    //instantiate the unit
    lab1_sw_led_8 usrc1(
        .sw(tb_sw),
        .led(tb_led)
    );
    always #10 tb_sw=tb_sw+1;
endmodule
```

# PRACTICE2

- If you HAVE got the board(with FPGA chip embeded), do practice2, following the steps shown in the top figure on the right side.
- Test the designed circuit on the board, change the input(here is the dail switch of EGO1) to assert to state of output(here is the led of EGO1).
- Is the logic relationship between the input and the output same with your design?



# A 24-INPUTS-24-OUTPUTS CIRCUIT ON MINISYS



lab1\_sw\_led\_  
24.v



lab1\_sw\_led\_  
24\_sim.v



lab1\_minisys.  
xdc

Q: If a 12-inputs-12-outputs circuit is designed to work on Minisys board, which of the above files need to be modified to make the circuit work on the Minsys board?

## TIPS:

while using **Minisys(new version)** board/**EGO1** board, connect its **typeC** interface to the computer which run Vivado project by typeC USB wire.

while using **Minisys(old version)** board, connect its **USB-Jtag** interface to the computer which run Vivado project by typeB USB wire.