# Creating a custom IP block in Vivado Using ZedBoard: A Tutorial

Embedded Processor Hardware Design February 24<sup>th</sup> 2015.

### Introduction

This tutorial will guide you through the process of using Vivado and IP Integrator to create a custom AXI IP block in Vivado and modify its functionality by integrating custom VHDL code. We will be using the Zync SoC and ZedBoard as a hardware platform. For simplicity, our custom IP will be a multiplier which our processor will be able to access through register reads and writes over an AXI bus.

The multiplier takes in two 16-bit unsigned inputs and then it will output one 32 bit unsigned value. A single 32 bit writes to the IP will contain the two 16-bit inputs, separated by the lower and higher 16 bits. A single 32 bit read from the peripheral will contain the result from the multiplication of the two 16-bit inputs. The design is simple but it is a good example of integrating your own code into an AXI IP block.

### **Objectives**

After completing this tutorial, you will be able to:

- Create an embedded system design using Vivado and SDK flow
- Configure the Processing System (PS)
- Add a custom IP in the Programmable Logic (PL) section
- Use SDK to build a software project and verify the functionality in hardware.

### **Procedure**

This lab is separated into steps that consist of general overview statements that provide information on the detailed instructions that follow. Follow these detailed instructions to progress through the tutorial.

This tutorial comprises three stages (each consisting of steps): You will create a top-level project using Vivado, create the processor system using the IP Integrator, add two instances of the GPIO IP, validate the design, generate the bitstream, export to the SDK, create an application in the SDK, and, test the design in hardware. You will then be able to profile the application and produce statistics that will help you understand the main bottlenecks of your application.

### **Requirements**

The following is needed in order to follow this tutorial:

- Vivado w/ Xilinx SDK (tested, version 2014.4)
- Zedboard (tested, **version D**)

## Part 1: Building a Zynq-7000 Processor Hardware

#### Introduction

In this part of the tutorial you will create a Zynq-7000 processor based design and instantiate IP in the processing logic fabric (PL) to complete your design. Then you take the design through implementation, generate a bitstream, and export the hardware to SDK.

If you are not familiar with the Vivado Integrated Development Environment Vivado (IDE), see the *Vivado Design Suite User Guide: Using the Vivado IDE* (UG893).

### Step 1: Start the Vivado IDE and Create a Project

1. Start the Vivado IDE (**Figure 1**) by clicking the Vivado desktop icon or by typing **vivado** at a terminal command line.



Figure 1: Getting Started Page

- 2. From the Getting Started page, select **Create New Project**. The New Project wizard opens (**Figure 2**).
- 3. Click Next

| 🔈 New Project | Ξ                                                                                                                                                                                                                                                 |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | Create a New Vivado Project                                                                                                                                                                                                                       |
|               | This wizard will guide you through the creation of a new project                                                                                                                                                                                  |
|               | To create a Vivado project you will need to provide a name and a location for your project<br>files. Next, you will specify the type of flow you'll be working with. Finally, you will specify<br>your project sources and choose a default part. |
|               |                                                                                                                                                                                                                                                   |
|               |                                                                                                                                                                                                                                                   |
|               |                                                                                                                                                                                                                                                   |
|               |                                                                                                                                                                                                                                                   |
|               |                                                                                                                                                                                                                                                   |
|               |                                                                                                                                                                                                                                                   |
|               | To continue, click Next.                                                                                                                                                                                                                          |
|               | < Back Next > Finish Cancel                                                                                                                                                                                                                       |

Figure 2: Create New Project Wizard

- 4. In the **Project Name** dialog box, type the project name and location. Ensure that **Create project subdirectory** is checked, and then click **Next**.
- 5. In the **Project Type** dialog box, select **RTL Project**, then click **Next**.
- 6. In the **Add Sources** dialog box, ensure that the **Target language** is set to **VHDL**, then click **Next**.
- 7. In the **Add Existing IP** dialog box, click **Next**.
- 8. In the **Add Constraints** dialog box, click **Next**.
- 9. In the **Default Part** dialog box select **Boards** and choose "ZedBoard Zynq Evaluation and Development Kit". Make sure that you have selected the proper Board Version to match your hardware because multiple versions of hardware are supported in the Vivado IDE. Click **Next**.
- 10. Review the project summary in the **New Project Summary** dialog box before clicking **Finish** to create the project.

### Step 2: Create the Base Processing System

1. In the Flow Navigator, select **Create Block Design**.



Figure 3: Create Block Design from Flow Navigator

2. In the **Create Block Design** popup menu, specify a name for your IP subsystem design as seen in **Figure 4**.

| Create Block De     | sign                                |    |        |
|---------------------|-------------------------------------|----|--------|
| Please specify name | of block design.                    |    |        |
| Design name:        | PSwithMult                          |    | Q      |
| Directory:          | Si <local project="" to=""></local> |    | *      |
| Specify source set: | Design Sources                      |    | *      |
|                     |                                     |    |        |
|                     |                                     | ОК | Cancel |

Figure 4: Create Block Design Dialog Box

3. Right-click in the Vivado IP integrator diagram window, and select Add IP.



4. Alternatively, you can click the **Add IP** link in the IP integrator diagram area.



Figure 6: Add IP Link in IP Integrator Canvas

The IP Catalog opens.

5. In the search field, type **zynq** to find the ZYNQ7 Processing System IP (not the Zynq7 processing system BFM), and then press **Enter** on the keyboard.

| 🗵 (2 m    | natches)          |                                       |                                                                                                |                                                                                                                                 |                                                                                                                                                                     |
|-----------|-------------------|---------------------------------------|------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Version 2 | AXI4              | Status                                | License                                                                                        | Vendor                                                                                                                          | Ī                                                                                                                                                                   |
| 5.2       | AXI4-Stream, AXI4 | Production                            | Included                                                                                       | Xilinx, Inc.                                                                                                                    |                                                                                                                                                                     |
| 1.0       | AXI4              | Pre-produ                             | Purchase                                                                                       | Xilinx, Inc.                                                                                                                    |                                                                                                                                                                     |
| III       |                   |                                       |                                                                                                | 4                                                                                                                               |                                                                                                                                                                     |
|           | Version<br>5.2    | Version AXI4<br>5.2 AXI4-Stream, AXI4 | Version         AXI4         Status           5.2         AXI4-Stream, AXI4         Production | Version         AXI4         Status         License           5.2         AXI4-Stream, AXI4         Production         Included | Version         AXI4         Status         License         Vendor           5.2         AXI4-Stream, AXI4         Production         Included         Xilinx, Inc. |

Figure 7: The IP Integrator IP Catalog

Because you selected the ZedBoard when you created the project, the Vivado IP integrator configures the design appropriately.

*In the Tcl Console, you will see the following message:* 

"create\_bd\_cell -type ip -vlnv xilinx.com:ip:processing\_system7:5.5 processing\_system7\_0"

There is a corresponding Tcl command for all actions performed in the IP integrator block diagram. Those commands are not shown in this document. See the Tcl Console for information on those commands.

6. In the IP integrator diagram header, click **Run Block Automation**.

| ŀ  | Diag | jram ×    | 🔣 Address Editor  | ×                 |                                   |
|----|------|-----------|-------------------|-------------------|-----------------------------------|
| ₹  | 🎄 z  | ynq_desig | jn_1              |                   |                                   |
| 4  | -    | Designer  | Assistance availa | ole. <u>Run B</u> | lock Automation                   |
| ٩- |      |           |                   |                   | <pre>/processing_system7_1 </pre> |
|    |      |           |                   |                   |                                   |

Figure 8: Run Block Automation on Zync

The **Run Block Automation** dialog box opens, stating that the FIXED\_IO and DDR interfaces will be created for the Zynq core.

7. Click **OK**.

After running block automation on the Zynq processor, the IP integrator diagram should look as shown in **Figure 9**.



Figure 9: Zynq Processing System after Running Block Automation

- 8. We will now reconfigure the ZYNQ7 Processing System. **Double click** on the ZYNC block diagram.
- 9. The Re-customize IP window will open as seen in **Figure 10**.



Figure 9: Re-customizing the ZYNQ Processing System

- 10. **Click** on the MIO Configuration panel to open its configuration form.
- 11. **Expand** the IO Peripherals on the right.
- 12. Uncheck ENET 0, USB 0, and SD 0, GPIO (GPIO MIO), leaving UART1 selected.
- 13. In the MIO Configuration panel, **expand** the Application Processing Unit and **uncheck** the Timer 0.
- 14. From the Page Navigator, **select** "Clock Configuration" and open the "PL Fabric Clocks" tree as seen in **Figure 11**.

|                       | - H      | ocation 🍈 Import XPS Settings           |              |                    |                       |                       |               |
|-----------------------|----------|-----------------------------------------|--------------|--------------------|-----------------------|-----------------------|---------------|
| Page Navigator «      | Clock    | Configuration                           |              |                    |                       |                       | Summary Repor |
| yng Block Design      | В        | asic Clocking Advanced Clocki           | ng           |                    |                       |                       |               |
| S-PL Configuration    | 👍 Ir     | nput Frequency (MHz) 33.3333            | 33 💿 CPU C   | ock Ratio 6:2:1    | *                     |                       |               |
| eripheral I/O Pins    | 9        | Search: Q-                              |              |                    |                       |                       |               |
|                       | <b>2</b> | New York Control and State              | 1            | 121 2022           | 100.00                | 1                     |               |
| 1IO Configuration     | <b>(</b> | Component<br>Processor/Memory Clocks    | Clock Source | Requested Frequenc | Actual Frequency(MHz) | Range(MHz)            |               |
| Clock Configuration   |          |                                         |              |                    |                       |                       |               |
| DDR Configuration     |          | PL Fabric Clocks                        |              |                    |                       |                       |               |
| OR Configuration      |          | FCLK_CLK0                               | IO PLL 💌     | 100.000000 📀       | 100.000000            | 0.100000:250.000000   |               |
| MC Timing Calculation |          | - FCLK_CLK1                             | IO PLL       | 150.000000         | 150.000000            | 0.100000:250.000000   |               |
| nterrupts             |          | FCLK_CLK2                               | IO PLL       | 50                 | 50.000000             | 0.100000:250.000000   |               |
|                       |          |                                         | IO PLL       | 50                 | 50.000000             | 0.100000 : 250.000000 |               |
|                       | Ē        | <ul> <li>System Debug Clocks</li> </ul> |              |                    |                       |                       |               |
|                       | Œ        | ] Timers                                |              |                    |                       |                       |               |
|                       |          |                                         |              |                    |                       |                       |               |
|                       |          |                                         |              |                    |                       |                       |               |
|                       |          |                                         |              |                    |                       |                       |               |
|                       |          |                                         |              |                    |                       |                       |               |
|                       |          |                                         |              |                    |                       |                       |               |
|                       |          |                                         |              |                    |                       |                       |               |
|                       |          |                                         |              |                    |                       |                       |               |
|                       |          |                                         |              |                    |                       |                       |               |

Figure 10: Clock Configuration

- 15. Make sure that the FCLK\_CLK0 is enabled (ticked) and that it is set for a frequency of **100 MHZ**. This will be our AXI clock.
- 16. Now from the Page Navigator, **select** "PS-PL Configuration" and **open** the "GP Master AXI Interface" tree.
- 17. **Tick** the "M AXI GP0 interface" checkbox and enable it as seen in **Figure 12**.

| Documentation 🔞 Preset | s 🛅 IP Lo                             | ocation 🏠 Import XPS Settings                                                     |          |                                                       |                |
|------------------------|---------------------------------------|-----------------------------------------------------------------------------------|----------|-------------------------------------------------------|----------------|
| Page Navigator «       | PS-PL                                 | Configuration                                                                     |          |                                                       | Summary Report |
| Zyng Block Design      | 🗲 s                                   | earch: 🔍                                                                          |          |                                                       |                |
| PS-PL Configuration    |                                       | Name                                                                              | Select   | Description                                           | ĺ              |
| Peripheral I/O Pins    | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | Name           General           DMA Controller           GP Master AXI Interface |          | 9<br>                                                 |                |
| 4IO Configuration      |                                       | M AXI GP0 interface                                                               | <b>v</b> | Enables General purpose AXI master interface 0        |                |
| Clock Configuration    |                                       | M AXI GP1 interface                                                               |          | Enables General purpose AXI master interface 1        |                |
| DDR Configuration      | Ū.                                    | GP Slave AXI Interface<br>HP Slave AXI Interface<br>ACP Slave AXI Interface       |          |                                                       |                |
| nterrupts              |                                       | PS-PL Cross Trigger interface                                                     |          | Enables PL cross trigger signals to PS and vice-versa |                |

Figure 11: PS-PL Configuration

- 18. Now **click** "OK" to close the Re-customize IP window.
- 19. We must now **connect** the FCLK\_CLK0 output to the AXI clock input. To do this, **click** on the FCLK\_CLK0 output and then **click** on the M\_AXI\_GP0\_ACLK input. This will trace a wire between the pins and make the connection as seen in **Figure 13**.



Figure 12: processing\_system7\_0 connection

## Part 2: Create the Custom IP

#### Introduction

In this part of the tutorial you will create a custom IP by using the "Create and Package IP" facility in Vivado.

1. With the base Vivado project opened, from the menu select **Tools→ Create and package IP.** A new window will appear as seen in **Figure 14**.

| 🝌 Create and Package New II | P.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | × |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
|                             | Create and Package IP<br>This wizard can be used to accomplish two tasks:<br>Package a new IP for the Vivado IP Catalog<br>This wizard will guide you through the process of creating a new Vivado IP using source files and<br>information from your current project or specified directory.<br>Create a new AXI4 Peripheral<br>This wizard will guide you through the process of creating a new AXI4 peripheral which includes<br>HDL, driver, software test application, IP Integrator BFM simulation and debug demonstration<br>design. |   |
| VIVADO.                     | Click Next to continue                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |
|                             | < Back Next > Einish Cancel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |

Figure 13: Create and Package New IP

- 2. When the "Create and Package IP" wizard opens. Click "Next".
- 3. On the next page (**Figure 15**), **select** "Create a new AXI4 Peripheral. **Click** "Next".



Figure 14: Create a new AXI4 Peripheral

4. Now you can give the peripheral an appropriate name, description and location as seen in **Figure 16**. Click "Next".

| Version: 1.0                                                                                                                                                                                                                                                  | Create and    | Package New IP                                                                               | ×       |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|----------------------------------------------------------------------------------------------|---------|
| Version:       1.0         Display name:       my_multiplier_v1.0         Description:       My new AXI IP         IP location:       D:/a0-PersonalFiles-D/z0-FPGA_Projects/ENG3050-xilinxprojects/Vivado2014ZyncCustomIP/ip_repo         Overwrite existing |               |                                                                                              | ~       |
| Display name: my_multiplier_v1.0                                                                                                                                                                                                                              | Name:         | my_multiplier                                                                                | 8       |
| Description: My new AXI IP IP location: D:/a0-PersonalFiles-D/20-FPGA_Projects/ENG3050-xilinxprojects/Vivado2014ZyncCustomIP/lp_repo                                                                                                                          | Version:      | 1.0                                                                                          | 0       |
| IP location: D:/a0-PersonalFiles-D/z0-FPGA_Projects/ENG3050-xilinxprojects/Vivado2014ZyncCustomIP/ip_repo                                                                                                                                                     | Display name: | my_multiplier_v1.0                                                                           | 0       |
| Coverwrite existing                                                                                                                                                                                                                                           | Description:  | My new AXI IP                                                                                | 8       |
|                                                                                                                                                                                                                                                               | IP location:  | D:/a0-PersonalFiles-D/z0-FPGA_Projects/ENG3050-xilinxprojects/Vivado2014ZyncCustomIP/ip_repo | <u></u> |
|                                                                                                                                                                                                                                                               |               |                                                                                              |         |
| Li < Back II Next > Enist Cancel                                                                                                                                                                                                                              |               | Sext > Einish                                                                                | Cancel  |

Figure 15: Peripheral Details

5. On the next screen we can configure the AXI bus interface. For the multiplier we will use AXI lite, and it will be a slave to the PS, so we will stick to the default values shown on **Figure 17**.

| Create and Package New IP       |                     |                        |                 |
|---------------------------------|---------------------|------------------------|-----------------|
| Add Interfaces                  |                     |                        |                 |
| Add AXI4 interfaces supported b | y your peripheral   |                        | s               |
| Enable Interrupt Support        | + ×<br>→ Interfaces | Name S0                | 0_AXI           |
|                                 | S00_AXI             | Interface Mode Sla     | ave 👻           |
|                                 |                     | Data Width (Bits) 32   | 2 👻             |
|                                 |                     | Memory Size (Bytes) 64 | ۰<br>۲          |
|                                 |                     | Number of Registers    | 4 🛨 [4512]      |
| my_multiplier_v1.0              |                     |                        |                 |
|                                 |                     | < Back                 | t> Enish Cancel |

Figure 16: Add Interface

6. On the last page, select "Edit IP" and click "Finish" as seen in **Figure 18**.

| 🝌 Create and Package New IP |                                                                                      | × |
|-----------------------------|--------------------------------------------------------------------------------------|---|
|                             | Create Peripheral                                                                    |   |
|                             | Peripheral Generation Summary                                                        |   |
|                             | 1. IP (uoguelph.ca:user:my_multiplier: 1.0) with <u>1 interface(s)</u>               |   |
|                             | 2. Driver(v1_00_a) and testapp more info                                             |   |
|                             | 3. AXI4 BFM Simulation demonstration design more info                                |   |
|                             | 4. AXI4 Debug Hardware Simulation demonstration design more info                     |   |
|                             | Peripheral created will be available in the catalog :                                |   |
|                             | D:/a0-PersonalFiles-D/z0-FPGA_Projects/ENG3050-xilinxprojects/Vivado2014ZyncCustomIF | 2 |
|                             | Next Steps:                                                                          |   |
|                             | C Add IP to the repository                                                           |   |
|                             | € Edt IP                                                                             |   |
|                             | C Verify peripheral IP using AXI4 BFM Simulation interface                           |   |
|                             | C Verify peripheral IP using JTAG interface                                          |   |
| <b>A</b>                    |                                                                                      |   |
| VIVADO.                     | 4                                                                                    | 1 |
| VIVADO.                     | Click Finish to continue                                                             |   |
|                             |                                                                                      |   |
|                             | < <u>Back</u> <u>Next</u> > <u>Finish</u> Cancel                                     | 8 |

Figure 17: Create & Edit IP

7. At this point, the peripheral that has been generated by Vivado is an AXI Lite Slave that contains 4 x 32 bit read/write registers (as seen in **Figure 19**). We want to add our multiplier code to the IP and modify it so that one of the registers connects to the multiplier inputs and another to the output.



Figure 19: Summary of IP

### Add the multiplier code to the peripheral

You can find the multiplier code on the web site of ENG3050. Download the "multiplier.vhd" file and save it somewhere, the location is not important for now. Note that these steps must be done in the Vivado window that contains the peripheral we just created (not the base project that contains the PS).

1. From the Flow navigator, click "Add Sources". In the window that appears (**Figure 20**) **select** "Add or Create Design Sources" and **click** "Next".

| Add Sources |                                                                                     | ×   |
|-------------|-------------------------------------------------------------------------------------|-----|
|             | Add Sources                                                                         |     |
|             | This guides you through the process of adding and creating sources for your project |     |
|             | C Add or greate constraints                                                         |     |
|             | <u>A</u> dd or create design sources                                                |     |
|             | C Add or create simulation sources                                                  |     |
|             | C Add or create DSP sources                                                         |     |
|             | C Add existing block design sources                                                 |     |
|             | C Add existing IP                                                                   |     |
|             |                                                                                     |     |
|             |                                                                                     |     |
|             |                                                                                     |     |
|             |                                                                                     |     |
| VIVADO.     |                                                                                     |     |
| VIVADO.     | To continue, click Next                                                             |     |
|             | TO CONDINCE, CITCK TYEAL                                                            |     |
|             | < Back Next> Enish Can                                                              | cel |

Figure 20: Add Sources

2. On the next window (Figure 21), click "Add Files"



Figure 21: Add Files

- 3. **Browse to** the "multiplier.vhd" file, select it and **click** "OK".
- 4. Make sure you **tick** "Copy sources into IP directory" and the **click** "Finish" as seen in **Figure 22**.

| Ad  | and the second second | eate Design      | Courcos          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|-----|-----------------------|------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|
|     |                       |                  |                  | and a second review of the star floor as adding the second s |                                         |
|     | our proj              |                  | nies, or direct  | ories containing HDL and netlist files, to add to your project. Create                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | a new source file on disk and add it to |
| 1   | our proj              |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
| 1   | Index                 | Name             | Library          | Location                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                         |
| 0 1 | 1                     | multiplier.vhd   | xil_defaultlib   | D:/a0-PersonalFiles-D/z0-FPGA_Projects/ENG3050-xilinxprojects                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|     |                       |                  |                  | Add Files                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
| S   | can and               | add RTL includ   | e files into pro |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
|     |                       |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
| С   | opy <u>s</u> ou       | rces into IP Dir | ectory           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
| С   | opy <u>s</u> ou       | rces into IP Dir | ectory           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
| С   | opy <u>s</u> ou       |                  | ectory           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
| С   | opy <u>s</u> ou       | rces into IP Dir | ectory           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |
| С   | opy <u>s</u> ou       | rces into IP Dir | ectory           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                         |

Figure 22: Choosing the VHDL Code

5. The multiplier code is now added to the peripheral; however **we still have to** instantiate it and connect it to the registers.

# Modify the Peripheral

At this point, your Project Manager Sources window should like the following **Figure 23**.



Figure 23: Project Manager

- 1. **Open** the branch "my\_multiplier\_v1\_0-arch\_imp"
- 2. **Double click** on the "my\_multiplier\_v1\_0\_S00\_AXI\_INST" file to open it.
- 3. The source file should be open in Vivado. **Find** the line with the "begin" keyword and add the following code just above it to declare the multiplier and output signal:

```
signal multiplier_out : std_logic_vector(31 downto 0);
component multiplier
port (
   clk: in std_logic;
   a: in std_logic_VECTOR(15 downto 0);
   b: in std_logic_VECTOR(15 downto 0);
   p: out std_logic_VECTOR(31 downto 0));
end component;
```

4. Now **find** the line that says " – Add user logic here" and **add** the following code below it to instantiate the multiplier:

```
390
       -- Add user logic here
391
       multiplier 0 : multiplier
392
       port map (
393
         clk => S AXI ACLK,
394
         a => slv reg0(31 downto 16),
395
         b => slv reg0(15 downto 0),
396
         p => multiplier out);
        -- User logic ends
397
```

- 5. **Find** this line of code "reg\_data\_out <= slv\_reg1"; and **replace** it with "reg\_data\_out <= multiplier\_out".
- 6. In the process statement just a few lines above, **replace** "slv\_reg1" with "multiplier\_out".
- 7. Save the file
- 8. You should notice that the multiplier.vhd" file has been integrated into the hierarchy (as seen in **Figure 24**) because we have instantiated it from within the peripheral.



Figure 24: Sources Hierarchy

9. **Click** on "IP File Groups" in the Package IP tab of the Project Manager.

| Package IP - my_multiplier                                                                                                                                                                                                      |                                       |                                                                                |              |      |            |                 | - [                                                  | <u> </u> |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|--------------------------------------------------------------------------------|--------------|------|------------|-----------------|------------------------------------------------------|----------|
| Packaging Steps 《                                                                                                                                                                                                               | Construction and the state            |                                                                                |              |      |            |                 |                                                      |          |
| Identification                                                                                                                                                                                                                  | Merge chang                           | es from File Groups Wizard                                                     |              |      |            |                 |                                                      |          |
| <ul> <li>Identification</li> <li>Compatibility</li> <li>File Groups</li> <li>Customization Parameters</li> <li>Ports and Interfaces</li> <li>Addressing and Memory</li> <li>Customization GUI<br/>Review and Package</li> </ul> | C C C C C C C C C C C C C C C C C C C | Name<br>rd<br>DL Synthesis (2)<br>DL Simulation (2)<br>ced<br>tware Driver (6) | Library Name | Туре | Is Include | File Group Name | Model Name<br>my_multplier_v1_0<br>my_multplier_v1_0 |          |
|                                                                                                                                                                                                                                 |                                       |                                                                                |              |      |            |                 |                                                      |          |

Figure 25: IP Groups

10. **Click** the "Merge changes from IP File Group Wizard" link. 11. The "IP File Groups" should now have a tick.

| ackage IP - my_multiplier |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      |            |                 | - 0                                      | 1 2 |
|---------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------|------------|-----------------|------------------------------------------|-----|
| ackaging Steps            | « Fi | le Groups                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |              |      |            |                 |                                          |     |
| Identification            | Q    | Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Library Name | Туре | Is Include | File Group Name | Model Name                               |     |
| • Identification          | X    | Content     C |              |      |            |                 |                                          |     |
| Compatibility             |      | G VHDL Synthesis (3)     VHDL Simulation (3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |              |      |            |                 | my_multiplier_v1_0<br>my_multiplier_v1_0 |     |
| 🗸 File Groups             |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      | Ē          |                 | my_mataples_v1_o                         |     |
|                           |      | E C Advanced                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |              |      |            |                 |                                          |     |
| Customization Parameters  | 8    | 🕀 🐻 UI Layout (1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |              |      | Г          |                 |                                          |     |
| Ports and Interfaces      |      | E Block Diagram (1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |      |            |                 |                                          |     |
|                           |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      |            |                 |                                          |     |
| Addressing and Memory     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      |            |                 |                                          |     |
| Customization GUI         |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      |            |                 |                                          |     |
|                           |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      |            |                 |                                          |     |
| Review and Package        |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      |            |                 |                                          |     |
|                           |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      |            |                 |                                          |     |
|                           | 1    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      |            |                 |                                          |     |
|                           |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      |            |                 |                                          |     |
|                           |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      |            |                 |                                          |     |
|                           |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      |            |                 |                                          |     |
|                           |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      |            |                 |                                          |     |
|                           |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      |            |                 |                                          |     |
|                           |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      |            |                 |                                          |     |
|                           |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      |            |                 |                                          |     |
|                           |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      |            |                 |                                          |     |
|                           |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      |            |                 |                                          |     |
|                           |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      |            |                 |                                          |     |
|                           |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      |            |                 |                                          |     |
|                           |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |      |            |                 |                                          |     |



12. Now **Click** "Review and Package IP" as seen in **Figure 27** and then **click** RePackage IP.



Figure 27: Review and Package IP

13. A final window will appear as seen in Figure 28. Press "OK"

| Close | e Project                                                                                                                                                                                                     | × |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| ?     | Finished packaging successfully. Do you want to close the project?<br>Package IP Location: d:/a0-personalfiles-d/z0-fpga_projects/eng3050-xilinxprojects/<br>vivado2014zynccustomip/ip_repo/my_multiplier_1.0 |   |

Figure 28: Close the Project

The peripheral will be packaged and the Vivado window for the peripheral should be automatically closed. We should now be able to find our IP in the IP catalog. Now the rest of this tutorial will be done from the original Vivado window.

# Add the IP to the Design

- 1. Click the "Add IP" icon
- 2. Find the "my\_multiplier" IP as seen in Figure 29 and double click it.

| earch: Q- my               |    |                              | (1 match) |  |  |
|----------------------------|----|------------------------------|-----------|--|--|
| Name                       | /1 | VLNV                         |           |  |  |
| my_multiplier_v1.0         |    | uoguelph.ca                  |           |  |  |
|                            |    |                              |           |  |  |
|                            |    | olat-Aster indicate          |           |  |  |
| 1- 1-                      |    | alat-kalati dilikina         |           |  |  |
|                            |    | alat Jakot di Kaland         |           |  |  |
|                            |    | nder E. Johov I. ald Schwart |           |  |  |
| ect and press ENTER or dra |    |                              |           |  |  |

Figure 29: Search for my\_multiplier

**3.** The block should appear in the block diagram (**Figure 30**) and you should see the message "Designer Assistance available". **Click** on "Run Connection Automation".

| Diagram                                                       | ₽ ×        |
|---------------------------------------------------------------|------------|
| →] <u>▲</u> PSwithMult                                        |            |
| Ce G Designer Assistance available. Run Connection Automation |            |
|                                                               | <u></u>    |
| 월 <b>↔</b> 500_AXI<br>— \$00_axi_adk                          |            |
| -s00_axi_aresetn                                              |            |
|                                                               |            |
| my_multiplier_v1.0 (Pre-Production) processing_system7_0      |            |
|                                                               | DDR        |
| FIXED_IO4                                                     |            |
|                                                               |            |
| PLANCE FOLK_CLK                                               |            |
|                                                               | ·-         |
| IX ZYNQ7 Processing System                                    | °          |
| C.                                                            |            |
|                                                               |            |
| ණ<br>ම<br>ජ<br>්                                              |            |
|                                                               |            |
|                                                               |            |
|                                                               |            |
|                                                               |            |
|                                                               |            |
|                                                               |            |
|                                                               | <u>N</u> K |

Figure 30: Run Connection Automation

4. In the window that appears (**Figure 31**), **set** Clock connection to "Auto" and **click** "OK".



Figure 31: Run Connection Automation (Auto)

5. The new block diagram should like **Figure 32**.



Figure 32: The Final Block Diagram

- 6. Validate the design (**choose "Tools** → **Validate Design**").
- 7. If all goes well, your design will be validated and you will get a message that says "validation successful".

### **Generate HDL Design Files**

You now generate the HDL files for the design.

1. In the Source window, **right-click** the top-level subsystem design and **select** "Generate Output Products" (**Figure 33**). This generates the source files for the IP used in the block diagram and the relevant constraints file.



**Figure 33: Sources Window** 

2. The **Generate Output Products** dialog box opens (Figure 34). **Click** "Generate".



**Figure 34: Generate Output Products Option** 

- 3. In the Sources window, select the top-level subsystem source, and select **Create HDL Wrapper** to create an example top-level HDL file (**Figure 35**).
- 4. Click **OK** when the **Create HDL Wrapper** dialog box opens.



#### **Implement Design and Generate Bitstream**

1. In Flow Navigator, **click** "Generate Bitstream" to implement the design and generate a BIT file.

*Note:* If the system requests to re-synthesize the design before implementing, click **No**. The previous step of saving the constraints caused the flow to mark synthesis out-of-date. Ordinarily, you might want to re-synthesize the design if you manually changed the constraints, but for this tutorial, it is safe to ignore this condition (**Figure 36**).



Figure 36: Generate Bitstream

You might see a dialog box stating no implementation results are available.

2. Click "Yes".



Figure 37: No Implementation Results Available Dialog Box

3. After the design implementation, **click** "Open Implemented Design", (**Figure 38**). **Press** "ok"



**Figure 38: Bitstream Generation Completed** 

4. You might get a warning that the implementation is out of date. Click "Yes".



Figure 39: Implementation Is Out-of-Date Dialog Box

## **Export Hardware to SDK**

In this step, you export the hardware description to SDK. You use this in Part 2. The IP integrator block diagram, and the Implemented design, must be open to export the design to SDK.

#### **Export to SDK**

1. In the Flow Navigator, **click** "Open Block" to invoke the IP integrator design (**Figure 40**).



Figure 40: IP Integrator - Open Block Design

Now you are ready to export your design to SDK.

 From the main Vivado File menu, select "Export → Export Hardware" (Figure 41).

| 8 | Add Sources       | Alt+A  |   | Туре:       | Block Designs |
|---|-------------------|--------|---|-------------|---------------|
|   | Open Source File  | Ctrl+N |   | Size:       | 55.5 KB       |
|   | Export            | ×      |   | Export Har  | dware for SDK |
|   | Open Log File     |        |   | Export Blog | •0            |
|   | Open Journal File |        | 1 | Export Bits | tream File    |

Figure 41: Export Hardware for SDK

The Export Hardware for SDK dialog box opens, **ensure** that Export Hardware, Include Bitstream, is checked (**Figure 42**).

| 👃 Export Hardware for SDK                          | × |
|----------------------------------------------------|---|
| Export hardware platform for SDK.                  |   |
| Options                                            |   |
| Source: 📥 zynq_design_1.bd 🔻                       |   |
| Export to: 💿 <local project="" to=""> 👻</local>    |   |
| Workspace: 💿 <local project="" to=""> 👻</local>    |   |
| ✓ Export Hardware                                  |   |
| ▼ Include bitstream (Note: an implemented design m |   |
| Launch SDK                                         |   |
|                                                    |   |
| OK Cance                                           |   |

Figure 42: Export Hardware for SDK

**3**. From the main Vivado File Menu, **select** "Launch SDK". The SDK will Launch in a new window.

## Part 3: Build Zynq-7000 Processor Software

In this portion of the tutorial you will test the multiplier by printing results to the terminal via the UART (serial port).

### **Step 1**: Start SDK and Create a Software Application

- 1. If you are doing this lab as a continuation of Part 2 then SDK should have launched in a separate window.
- 2. From the SDK window **Select** "File > New > Application Project" (**Figure 43**).



A "New Project" dialog box opens. Here you will enter the name of the project

In the Project Name field, type "TestMultiplier", and click "Next" (Figure 44).

| K New Project                                  |                                                 |        |
|------------------------------------------------|-------------------------------------------------|--------|
| pplication Project<br>Create a managed make as | polication project.                             | G      |
|                                                |                                                 |        |
| Project name: TestMultip                       | lior                                            |        |
| an a       |                                                 |        |
| Use default location                           |                                                 |        |
| Location: D:\a0-Personal                       | Files-D/20-FPGA_Projects\ENG3050-xilinxprojects | Browse |
| Choose file systematics                        | em; default 💌                                   |        |
| Target Hardware                                |                                                 |        |
|                                                | D Custom IP wrapper hw platform 0               | ▼ New  |
|                                                | 7_cortexa9_0                                    |        |
| 100003007. [p3                                 |                                                 |        |
|                                                |                                                 |        |
| Target Software                                |                                                 |        |
| Language:                                      | • c • c++                                       |        |
|                                                |                                                 | 2428.0 |
| OS Platform:                                   | standalone                                      |        |
|                                                | Create New TestMultiplier_bsp                   |        |
|                                                |                                                 |        |

**Figure 44: SDK Application Project** 

4. From the Available Templates, **select** "Hello World" as seen in (**Figure 45**) and **click** "Finish".

| emplates<br>Create one of the available templat<br>application project.                                           | tes to generate a fully-functioning | G     |
|-------------------------------------------------------------------------------------------------------------------|-------------------------------------|-------|
| Available Templates:                                                                                              |                                     |       |
| Dhrystone<br>Empty Application<br>Hello World<br>WIP Echo Server<br>Memory Tests<br>Peripheral Tests<br>Zyng FSBL | Let's say 'Hello World' in C.       |       |
| ? <u>Sack</u>                                                                                                     | Next > Finish Ca                    | ancel |

When the program finishes compiling, you will see the following message on

the console (Figure 46).

| Overview Source                                                                                                                                                                                                            |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 😰 Problems ⁄ Tasks 📮 Console 🖾 🖉 Properties 🖉 Terminal                                                                                                                                                                     |
| CDT Build Console [Zynq_Design]                                                                                                                                                                                            |
| Invoking: ARM Print Size<br>arm-xilinx-eabi-size Zynq_Design.elf  tee "Zynq_Design.elf.size"<br>text data bss dec hex filename<br>74740 2024 33700 110464 1af80 Zynq_Design.elf<br>Finished building: Zynq_Design.elf.size |
| 16:53:10 Build Finished (took 4s.976ms)                                                                                                                                                                                    |
| Figure 46: SDK Message                                                                                                                                                                                                     |

### **Step 2: Modify the Software Application**

Now, you can either run the hello world application on the ZedBoard or test the multiplier!!. If you want to test the multiplier then you need to modify the software application.

- 1. From the Project Explorer, open the "TestMultiplier/src" folder. Open the "helloworld.c" source file.
- 2. Replace all the code in this file with the following code shown in Figure 47 (available on the webpage)



Figure 47: SDK Message

### Step 3: Run the code on the FPGA

1. Download the bitstream into the FPGA by **selecting** "Xilinx Tools > Program FPGA" (FIGURE 48).



This opens the Program FPGA dialog box.

2. A new window will appear (Figure 49)

| ok Program FPGA                       |                                                |         | ×        |
|---------------------------------------|------------------------------------------------|---------|----------|
| Program FPGA<br>Specify the bitstrear | n and the ELF files that reside in BRAM memory |         |          |
| Hardware Configura                    |                                                | ন       |          |
| Connection:                           | Local                                          | New     |          |
| Device:                               | Auto Detect                                    | Select  |          |
| Bitstream:                            | PSwithMultIP_wrapper.bit                       | Search  | Browse,  |
| BMM/MMI File:                         |                                                | Search  | Browse., |
| Software Configural                   | ELF File to Initialize in Block RAM            | 1       |          |
| •                                     |                                                | Program | Cancel   |



3. Ensure that the path to the bitstream that you created is correct and then **click** "Program".

**Note**: The DONE LED on the board turns blue if the programming is successful.

- 4. **Connect** a terminal to see the results (check previous tutorials of how to connect a terminal).
- 5. **Select** "Run → Run Configurations". A new window will appear as seen in **Figure 50**.

| <ul> <li>Run Configurations</li> <li>Create, manage, and run configurations</li> <li>[Application]: Application path is empty.</li> </ul>                                                                                                     |                               |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|
| Type filter text         C/C++ Application         C/C++ Remote Application         Launch Group         Remote ARN Linux Application         Target Communication Framework         Stilnx C/C++ application (CDB)         New_configuration | Name:       New_configuration |
| Filter matched 7 of 10 items                                                                                                                                                                                                                  | Apply Revert Run Close        |

Figure 50: Run Configuration

6. **Double Click** on Xilinx C/C++ application (GDB) and a new configuration will be created "New Configuration" along with its setting menu as seen in **Figure 50**.

7. Make sure you have an application associated with your run configuration as seen in **Figure 51**.

| 🔯 Run Configurations 🔀                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                         |                                               |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
| Create, manage, and run configurations                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                         |                                               |
| Type filter text         C       C/C++ Application         Launch Group       A Remote APPlication         Target Communication Framework         Target Communication Framework         Torget New_configuration | Name:       New_configuration         Image:       Target Setup         Application       Image:         Image:       TestMultiplier         Application:       Debug/TestMultiplier.elf         Image:       Do not download program to memory         Image:       TestMultiplier         Image:       Address         Image:       Address         Image:       Address         Image:       Address | Browse<br>Browse<br>Add<br>Remove<br>Relative |
| Filter matched 7 of 10 items                                                                                                                                                                                      | Apply                                                                                                                                                                                                                                                                                                                                                                                                   | Revert                                        |
| (?)                                                                                                                                                                                                               | Run                                                                                                                                                                                                                                                                                                                                                                                                     | Close                                         |

Figure 51: Application associated with your run configuration

- 8. Click on Run.
- 9. You will see the following results on the terminal (Figure 52)



Figure 52: Results of Run Configuration