NTU GIEE, MULTIMEDIA SYSTEM-ON-CHIP DESIGN

# Lab 2 - Zynq HLS Design Flow

### **Pin-Hung Kuo**

#### May 18, 2018

#### **1** INTRODUCTION

In Lab 1, we design a system display a value by LEDs. We will have a similar design in this lab, except for that the IP will be produced by high level synthesis (HLS).

## 2 CREATING IP IN HLS

Open Vivado HLS. You can find it in the Start menu: **Start > Programs > Xilinx Design Tools > Vivado 201X.X > Vivado HLS > Vivado HLS 201X.X**. Create a new project by click **Create New Project** as shown in Fig.2.1.

| ado HLS                             |                                                                                                                              | 1000                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | _                                                                                                                                                                                                         |                                                                                                                                                                                     |
|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Edit Project Solution Window        | Help                                                                                                                         |                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                           |                                                                                                                                                                                     |
| 💫 Vivado HLS Welcome Page 😒         |                                                                                                                              |                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                           |                                                                                                                                                                                     |
| VIVADO.                             |                                                                                                                              |                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | EXILINX<br>ALL PROGRAMMABLE.                                                                                                                                                                              |                                                                                                                                                                                     |
| Quick Start                         |                                                                                                                              |                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                           |                                                                                                                                                                                     |
| Create New Project<br>Documentation | Open Project                                                                                                                 | Open Example Project              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                           |                                                                                                                                                                                     |
| Tutorials                           | User Guide                                                                                                                   | Release Notes Guide               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                           |                                                                                                                                                                                     |
|                                     | Edit Project Solution Window<br>Vivado HLS Welcome Page<br>Quick Start<br>Quick Start<br>Create New Project<br>Documentation | Edit Project Solution Window Help | Edit Project Solution Window Help<br>Vivado HLS Welcome Page 23<br>Quick Start<br>Quick Start<br>Create New Project<br>Documentation<br>Quick Start<br>Quick Start | Edit Project Solution Window Help<br>Vivado HLS Welcome Page S<br>Quick Start<br>Quick Start<br>Create New Project<br>Documentation<br>Quick Start<br>Open Project<br>Create New Project<br>Documentation | Edit Project Solution Window Help<br>Vivado HLS Welcome Page 33<br>Quick Start<br>Quick Start<br>Create New Project<br>Documentation<br>Quick Start<br>Documentation<br>Quick Start |

Figure 2.1: Create New Project

A *New Vivado HLS Project* window will appear, type **HLS\_led\_controller** in the *Project name* and change the *Location* to **c:/MSOC** as Fig.2.2.

|          | Project na |
|----------|------------|
|          |            |
| <b>.</b> | Location:  |
|          | Location.  |

Figure 2.2: Project Name

In *Add/Remove Files* dialogue, type **led\_controller** in *Top Function* box. We can add source files here if we have. In this lab, we want to create the source files by our self, so we just click **Next** > here.

| p Function: led_co | ntroller | Broy        |
|--------------------|----------|-------------|
| esign Files        |          |             |
| Name               | CFLAGS   | Add Files   |
|                    |          | New File    |
|                    |          | Edit CFLAGS |
|                    |          | Remove      |
|                    |          |             |
|                    |          |             |
|                    |          |             |
|                    |          |             |
|                    |          |             |
|                    |          |             |
|                    |          |             |

Figure 2.3: Add/Remove Source Files

You should see the dialogue as shown in Fig.2.4. As the hint, we can add testbench files here. We skip this step in this lab, just click **Next** >.

| tBench Files |        |             |
|--------------|--------|-------------|
| lame         | CFLAGS | Add Files   |
|              |        | New File    |
|              |        | Add Folder  |
|              |        | Edit CFLAGS |
|              |        | Remove      |
|              |        |             |
|              |        |             |
|              |        |             |
|              |        |             |

Figure 2.4: Add/Remove Testbench Files

In *Solution Configuration* dialogue, leave *Solution Name* and *Clock* as default. Click ... as shown in Fig.2.5 to select our part.

| 👠 New Vivado HLS Project                          |                 | _      |        |
|---------------------------------------------------|-----------------|--------|--------|
| Solution Configuration<br>Part must be specified. |                 |        | Es     |
| Solution Name: solution1<br>Clock<br>Period: 10   | l la contrônt a |        |        |
|                                                   | Uncertainty:    |        |        |
| Part Selection                                    |                 |        |        |
| Part: [Please select part]                        |                 |        |        |
|                                                   |                 |        | $\sim$ |
|                                                   |                 |        |        |
|                                                   |                 |        |        |
|                                                   |                 |        |        |
|                                                   |                 |        |        |
|                                                   |                 |        |        |
|                                                   |                 |        |        |
|                                                   |                 |        |        |
|                                                   |                 |        |        |
|                                                   |                 |        |        |
|                                                   |                 |        |        |
| < Bac                                             | <b>k</b>        | Finish | Cancel |

Figure 2.5: Solution Configuration

Similar to the part selection in Lab 1, we choose **ZedBoard Zynq Evaluation and Development Kit** in the *Device Selection Dialogue*.

| Device Selection     Select:      Part |              | ]                        |                | ×            |  |  |  |  |
|----------------------------------------|--------------|--------------------------|----------------|--------------|--|--|--|--|
| Filter                                 |              |                          |                |              |  |  |  |  |
| Vendor:                                | All          |                          |                |              |  |  |  |  |
| Display Name:                          | All          |                          |                |              |  |  |  |  |
| Search: 🔻                              |              | Res                      | et All Filters |              |  |  |  |  |
| Display Name                           |              | Part                     | Family         | Vendor       |  |  |  |  |
| Zynq ZC706 E                           | valuation Bo | xc7z045ffg900-2          | zynq           | xilinx.com   |  |  |  |  |
| Zynq ZC702 E                           | valuation Bo | xc7z020clg484-1          | zynq           | xilinx.com   |  |  |  |  |
| ZedBoard Zyr                           | q Evaluation | xc7z020clg484-1          | zynq           | em.avnet.com |  |  |  |  |
| ZYNQ UltraSc                           | ale+ ZCU102  | xczu9eg-ffvb1156-1-i-es1 | zynquplus      | xilinx.com   |  |  |  |  |
| Virtex-7 VC70                          | 9 Evaluation | xc7vx690tffg1761-2       | virtex7        | xilinx.com   |  |  |  |  |
| Virtex-7 VC70                          | 7 Evaluation | xc7vx485tffg1761-2       | virtex7        | xilinx.com   |  |  |  |  |
| Virtex UltraSc                         | ale VCU110 E | xcvu190-flgc2104-2-e     | virtexu        | xilinx.com   |  |  |  |  |
| Virtex UltraSc                         | ale VCU108 E | xcvu095-ffva2104-2-e     | virtexu        | xilinx.com   |  |  |  |  |
| Virtex 6 ML60                          | 5 Evaluation | xc6vlx240tff1156-1       | virtex6        | xilinx.com   |  |  |  |  |
| MI Virtov E MI E1                      | 0 Evaluation | v~5vfv120+ff1720_0       | virtav5        | viliny com   |  |  |  |  |
|                                        |              |                          |                | OK Cancel    |  |  |  |  |

Figure 2.6: Device Selection Dialogue

Click **OK** and **Finish** to enter to our Vivado HLS project.

In Lab 1, our IP is simply pass the value from AXI slave port to output **LEDs\_out**. In this lab, we will design a similar IP in C++.

Right-click the **Source** in the left-handed *Explorer* pane, and click **New Files...** to create a new source file as . You should be asked to save a file. Type **led\_controller.cpp** as the file name.



Figure 2.7: New File

An empty cpp file should be opened now in *Workspace*. Type the following code:

```
#include <ap_int.h>
void led_controller(int input, ap_uint<8>* LEDs_out){
*LEDs_out = input;
}
```

or you can find it in the lab file. Save the file by **Ctrl+s**. The data type of **LEDs\_out** is **ap\_uint<8>**, which is defined by Vivado HLS. This data type allow you to define a arbitrary length data

type. In our case, we just defined an 8-bits unsigned integer. You can realize this data type in detail by reading **ap\_uint.h**, which can be opened by holding **Ctrl** and hovering you mouse on the **ap\_uint.h**. The **ap\_uint.h** will become a link, click on it to open the corresponding file. This operation can also be used in Vivado SDK, which is very useful to find the corresponding declarations, defines and so on.

Now, we have finished our source code. But how can we know if it works well? The testbench is used for this purpose. If you are familiar with HDL, you may be know about testbench. If you are not, it is OK. Testbench is also a code to include our design and test it if it works as our expectation. In HLS, we also have to integrate such testbench to examine our design. Right-click on the **Test Bench** in the **Explorer** pane and select **New File...** to create the testbench. Let the name of testbench be **led\_controller\_tb.cpp**. You should have an empty cpp file opened in the *Workspace*, type the following code

```
#include <stdio.h>
#include <ap_int.h>
void led_controller(int input, ap_uint<8>* LEDs_out);
int main(){
ap_uint<8> LEDs_out;
int error=0;
for(int i=0;i<256;++i){</pre>
led_controller(i,&LEDs_out);
if(LEDs_out!=i)
error++;
}
if(error)
printf("There are %d errors\n",error);
else
printf("Test Pass! Congratulation!!\n");
return 0;
}
```

or find it in lab file. Our IP passes an 8-bits number between 0 and 255, so we test our IP with these 256 values. As you can see, the **main** function in HLS is used for testbench.

Click 🔎 and just click **OK** to simulate the source file. You should see the message as Fig.2.8.

| 🔄 Console 🕱 🧕 Errors 🙆 Warnings                                                                                               |
|-------------------------------------------------------------------------------------------------------------------------------|
| Vivado HLS Console                                                                                                            |
| Starting C simulation                                                                                                         |
| C:/Xilinx/Vivado_HLS/2016.1/bin/vivado_hls.bat C:/MSOC/HLS_led_controller/solution1/csim.tcl                                  |
| <pre>INFO: [HLS 200-10] Running 'C:/Xilinx/Vivado_HLS/2016.1/bin/unwrapped/win64.o/vivado_hls.exe'</pre>                      |
| INFO: [HLS 200-10] For user 'setsunil' on host 'setsunil-pc' (Windows NT_amd64 version 6.1) on Fri May 06 16:56:08 +0800 2016 |
| INFO: [HLS 200-10] In directory 'C:/MSOC'                                                                                     |
| INFO: [HLS 200-10] Opening project 'C:/MSOC/HLS_led_controller'.                                                              |
| <pre>INFO: [HLS 200-10] Opening solution 'C:/MSOC/HLS_led_controller/solution1'.</pre>                                        |
| INFO: [SYN 201-201] Setting up clock 'default' with a period of 10ns.                                                         |
| INFO: [HLS 200-10] Setting target device to 'xc7z020clg484-1'                                                                 |
| Compiling//led_controller_tb.cpp in debug mode                                                                                |
| Compiling///led_controller.cpp in debug mode                                                                                  |
| Generating csim.exe                                                                                                           |
| Test Pass! Congratulation!!                                                                                                   |
| INFO: [SIM 211-1] CSim done with 0 errors.                                                                                    |
| Finished C simulation.                                                                                                        |
|                                                                                                                               |
|                                                                                                                               |
|                                                                                                                               |

#### Figure 2.8: Simulation result

The simulation is to verify if your code is valid to be synthesized. Once we finish the simula-

tion, we can now click the licon to synthesize the HDL code from our cpp file. Once the synthesis is finished, a synthesis report should be opened in the *Workspace*. You can check the synthesis results here. Expand the **solution1** in the **Explorer** pane, you can find that the *systemc, vhdl and verilog* code of our IP have already been generated (under **syn** and **impl**). In RTL design flow, we usually take advantage of wave form for debugging. Vivado HLS provides

this feature too. Click  $\checkmark$  to run the co-simulation. In co-simulation dialogue, selection your HDL language, where we choose verilog, and set the *Dump Trace* as **all** as shown in Fig.2.9.

| 💫 Co-simulation Dialog                 | ×                                  |
|----------------------------------------|------------------------------------|
| C/RTL Co-simulation                    |                                    |
| Verilog/VHDL Simulator Selection       |                                    |
| RTL Selection<br>Verilog   VHDL        |                                    |
| Options <ul> <li>Setup Only</li> </ul> |                                    |
| Dump Trace all                         |                                    |
| Reduce Diskspace                       |                                    |
| Compiled Library Location              | Browse                             |
| Input Arguments                        |                                    |
|                                        |                                    |
|                                        | Do not show this dialog box again. |
|                                        | OK Cancel                          |

Figure 2.9: Co-simulation dialogue

The co-simulation tests the synthesized HDL code by our testbench cpp. After the co-simulation,

you can observe that the si is activated. Click this icon to observe the waveform. A *Wave Viewer* window will be opened. Select the module you want to observed in the *Name* pane at the left-hand, and select the ports you want to observe in *Objects* pane in the middle of the window. Right-click the selected ports and click **Add To Wave Window** to observe the waveform as Fig.2.10. This *Wave Viewer* is very similar to the Synopsis Verdi/nWave, which is commonly used for RTL debugging.

| idit Flow Icols <u>M</u> indow Ley |                                       |                       |                                                |                       |                            |                               |                              |                               |                             |                             | Q+ Search o                | cumends      |
|------------------------------------|---------------------------------------|-----------------------|------------------------------------------------|-----------------------|----------------------------|-------------------------------|------------------------------|-------------------------------|-----------------------------|-----------------------------|----------------------------|--------------|
| n 🖉 🗎 🛍 🗙 🐝 🗔 🗄                    | 🛯 Defenit Leyout                      | 🖃 🗶 🖗 🏋 🕪             | 10                                             | 02 <b>*</b> 43        | G   🖏                      |                               |                              |                               |                             |                             |                            |              |
| ation Result - led_controller.wib  |                                       |                       |                                                |                       |                            |                               |                              |                               |                             |                             |                            |              |
|                                    | _ 🗆 🖻 ×                               | Objects               |                                                | * × _                 | led_controller.vcfg* ×     |                               |                              |                               |                             |                             |                            |              |
| : # 🔲 @ 🗅 🖓 🗎 9 1                  |                                       |                       |                                                | 킌                     |                            |                               |                              |                               |                             |                             |                            | 2,795.000 vi |
|                                    |                                       | Nome                  |                                                |                       | Name                       | Value                         | 10 roi                       | 500 rs.                       | 1,000 ya                    | 1,500 mi                    | 2,000 ys                   | 2,500 ye     |
| g AEE_Jackie consister             | oph M.con. Yei                        |                       | Lag<br>Bang<br>Lag<br>Lag<br>Lag<br>Lag<br>Lag | 4<br>2<br>4<br>1<br>2 |                            | 0<br>0<br>1<br>25<br>235<br>0 |                              |                               |                             |                             |                            |              |
| m                                  | ,                                     |                       |                                                |                       |                            |                               |                              |                               |                             |                             |                            |              |
| Scope 👗 Sources                    |                                       | * [                   |                                                | - 1 v                 |                            | *                             | • K                          |                               | 17                          |                             |                            |              |
|                                    | mtroller.mdb<br>S_led_controller/solu | tion1/sim/verilog/led | _controller.wofg                               | ontroller_top         | /AESL_inst_led_controller/ | op_done}] [[/apatb_led        | controller_tog/AEXL_inst_led | _controller/ag_idle]} {[/apet | _led_controller_top/ABSL_ir | st_led_controller/sp_ready] | } {[/epetb_led_controller_ | ? - D        |
| × [                                |                                       |                       |                                                |                       |                            |                               |                              |                               |                             |                             |                            |              |
| vec a Tel command here             |                                       |                       |                                                |                       |                            |                               |                              |                               |                             |                             |                            |              |

Figure 2.10: Waveform

Close the *Wave Viewer* and discard the waveform. Although we finished the synthesis few minutes ago, we have not added constraints/directives to our design. We are going to back to do this now.

Double click the **led\_controller.cpp** in the *Explorer* pane to open the source file. Then select the **Directive** tab at the right-handed pane as shown in Fig.2.11

| ed_controller_csim.log 🗐 Synthesis(solution1) 👘 Simulation(solution1) 🕼 led_controller.cpp 🛛  | 🖳 🗖 📴 Outline 💓 Directive 🛛 | $\leftarrow \rightarrow$ |
|-----------------------------------------------------------------------------------------------|-----------------------------|--------------------------|
| <pre>#include <ap_int.h></ap_int.h></pre>                                                     | ▲ ● led_controller          |                          |
| unid lad controllon/int input on uint(8)\$ (EDs out)/                                         | e input                     |                          |
| <pre>void led_controller(int input, ap_uint&lt;8&gt;* LEDs_out){     *LEDs_out = input;</pre> | LEDs_out                    |                          |
|                                                                                               |                             |                          |
| }                                                                                             |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               |                             |                          |
|                                                                                               | -                           |                          |
| 4                                                                                             | P                           |                          |

Figure 2.11: Directive

Right click on the **led\_controller** in *Directive* pane and select **Insert Directive**. A **Vivado HLS Directive Editor** dialogue will show up. Select *Directive* as **INTERFACE** in the drop-down menu and set **mode(optional)** as **s\_axilite**. The directive should be as that of Fig.2.12.

| Directive                          |           |   |
|------------------------------------|-----------|---|
| INTERFACE                          |           | • |
| Destination                        |           |   |
| Source File                        |           |   |
| Oirective File                     |           |   |
| Options                            |           |   |
| mode (optional):                   | s_axilite | • |
| register (optional):               |           |   |
| depth (optional):                  |           |   |
| offset (optional):                 |           |   |
| bundle (optional):                 |           |   |
| clock name (optional):             |           |   |
| num_read_outstanding (optional):   |           |   |
| num_write_outstanding (optional):  |           |   |
| max_read_burst_length (optional):  |           |   |
| max_write_burst_length (optional): |           |   |
| Help Cancel                        | OK        |   |

Figure 2.12: HLS Directive Editor

Click **OK**. We have to define our IP as having a **ap\_ctrl\_none** interface to remove unneeded control signals. Right-click on **led\_controller** in *Directive* pane, and select **Insert Directive**. As before, select **INTERFACE** again. This time, we set the mode as **ap\_ctrl\_none** and click **OK**.

By the similar way, we set the **input** as **s\_axilite** and the **LEDs\_out** as **ap\_none**. Check your *Directive* pane if it is same as Fig.2.13



Figure 2.13: All Directives

With directives, we can now generate an IP. Although we did that few minutes ago, that is for co-simulation. This time we will generate the IP can be used in Vivado. It is worth noting that once we add the directives, the co-simulation will fail.

Now we run synthesis again by clicking **P**. After the synthesis, now we can package our

Now we just finish the HLS IP creation. We will integrate this IP into our system.

#### **3** INTEGRATE HLS IP

Because it is very close to Lab 1, we will roughly go through the steps which we did once in the last lab.

Create a new Vivado project **Lab2**. **Create Block Design**. Now we have to integrate the HLS IP into our system. Click **Settings** in the tool bar as shown in Fig.3.1



Figure 3.1: IP Settings

In IP defaults, click + under IP Catalog to add our IP as Fig. 3.2. Select **c:/MSOC/HLS\_led\_controller** and click **OK**.

🝌 Settings



Figure 3.2: IP Repository

Click **OK** to return to our design.

Add our IP by the same method as Lab 1.

Our IP will be added to the diagram as Fig.3.3.

NOTE! Unfortunately, there is a bug in the newest Vivado 2018.1. If you cannot find the **led\_controller** in IP Catalog as Fig.3.3, you can fix it by following steps:

- 1. Close your project.
- 2. Delete your project folder, e.g. c:/MSOC/Lab2/
- 3. Create a Lab2 project again
- 4. Now you can find the IP, Magic!

Х

| Search: | Q- led       |                   | 🛞 (1 match)       |
|---------|--------------|-------------------|-------------------|
| 📭 Led_  | controller   |                   |                   |
|         |              |                   |                   |
|         |              |                   |                   |
|         |              |                   |                   |
|         |              |                   |                   |
|         |              |                   |                   |
|         |              |                   |                   |
|         |              |                   |                   |
|         |              |                   |                   |
|         |              |                   |                   |
|         |              |                   |                   |
|         |              |                   |                   |
| ENTER t | o select, ES | C to cancel, Ctrl | +Q for IP details |

Figure 3.3: HLS\_led\_controller

Now, follow the steps as Lab 1.

**Note** that the port name of our HLS IP is a little different from that of Lab 1, therefore you should modify port name from **LEDs\_out\_0** into **LEDs\_out\_V\_0** in the constraints file. Or you can find it in the lab2 zip file. Observe the difference between wrapper.v files of these two labs.

After the bitsream being generated, launch SDK.

Please create a new project Lab2. All files you need can be found in the lab zip file.

Find the difference between the source file of Lab 1 and that of Lab 2. In the **Xilinx Tools > Repositories** step, please choose **C:/MSOC/HLS\_led\_controller** folder.

Run the application, and you should have the same result as Lab 1.