## **Vivado Design Suite Tutorial**

## **Programming and Debugging**

UG936 (v2018.2) June 6, 2018





## **Revision History**

The following table shows the revision history for this document.

| Section                                                            | Revision Summary |  |  |  |
|--------------------------------------------------------------------|------------------|--|--|--|
| 06/06/2018 Version 2018.2                                          |                  |  |  |  |
| General updates Editorial updates only. No technical content updat |                  |  |  |  |
| 04/27/2018 Version 2018.1                                          |                  |  |  |  |
| General updates                                                    | General updates  |  |  |  |





## **Table of Contents**

| Revision History                                                           | 2  |
|----------------------------------------------------------------------------|----|
| Debugging in Vivado Tutorial                                               | 6  |
| Introduction                                                               | 6  |
| Objectives                                                                 | 6  |
| Getting Started                                                            | 7  |
| Lab 1: Using the Netlist Insertion Method for Debugging a Design           | 13 |
| Introduction                                                               | 13 |
| Step 1: Creating a Project with the Vivado New Project Wizard              | 13 |
| Step 2: Synthesizing the Design                                            | 14 |
| Step 3: Probing and Adding Debug IP                                        | 15 |
| Step 4: Implementing and Generating Bitstream.                             | 24 |
| Lab 2: Using the HDL Instantiation Method for Debugging a Design in Vivado | 25 |
| Introduction                                                               | 25 |
| Step 1: Creating a Project with the Vivado New Project Wizard              | 25 |
| Step 2: Synthesize Implement and Generate Bitstream                        | 27 |
| Lab 3: Using a VIO Core for Debugging a Design in Vivado                   | 28 |
| Introduction                                                               | 28 |
| Step 1: Creating a Project with the Vivado New Project Wizard              | 29 |
| Step 2: Synthesize, Implement, and Generate Bitstream                      | 34 |
| Lab 4: Using Synplify Pro Synthesis Tool and Vivado for Debugging a Design | 35 |
| Introduction                                                               | 35 |
| Step 1: Create a Synplify Pro Project                                      | 35 |
| Step 2: Synthesize the Synplify Project                                    | 43 |
| Step 3: Create DCPs for the Black Box Created in Synplify Pro              | 44 |
| Step 4: Create a Post Synthesis Project in Vivado IDE                      | 44 |
| Step 5: Add More Debug Nets to the Project                                 | 46 |
| Step 6: Implementing the Design and Generating the Bitstream               | 48 |

www.xilinx.com



| Lab 5: Using Vivado Logic Analyzer to Debug Hardware                                                   | 49 |
|--------------------------------------------------------------------------------------------------------|----|
| Introduction                                                                                           | 49 |
| Step 1: Verifying Operation of the Sine Wave Generator                                                 | 49 |
| Step 2: Debugging the Sine Wave Sequencer State Machine (Optional)                                     | 61 |
| Lab 6: Using ECO Flow to Replace Debug Probes Post Implementation                                      |    |
| Lab 7: Debugging Designs Using Incremental Compile Flow                                                | 97 |
| Introduction                                                                                           | 97 |
| Procedure                                                                                              | 97 |
| Step 1: Opening the Example Design and Adding a Debug Core                                             | 97 |
| Step 2: Compiling the Reference Design                                                                 |    |
| Step 3: Create New Runs                                                                                |    |
| Step 4: Making Incremental Debug Changes                                                               |    |
| Step 5: Running Incremental Compile                                                                    |    |
| Conclusion                                                                                             |    |
| Lab 8: Using Vivado Serial Analyzer to Debug Serial Links                                              |    |
| Introduction                                                                                           |    |
| Design Description                                                                                     |    |
| Step 1: Creating, Customizing, and Generating an IBERT Design                                          |    |
| Step 2: Adding an IBERT core to the Vivado Project                                                     |    |
| Step 3: Synthesize, Implement and Generate Bitstream for the IBERT design                              |    |
| Step 4: Interact with the IBERT core using Serial I/O Analyzer                                         |    |
| Lab 9: Using Vivado ILA Core to Debug JTAG-AXI Transactions                                            |    |
| Introduction                                                                                           |    |
| Design Description                                                                                     |    |
| Step 1: Opening the JTAG to AXI Master IP Example Design and Configuring the AXI Interf<br>Connections | -  |
| Step 2: Program the KC705 Board and Interact with the JTAG to AXI Master Core                          |    |
| Step 3: Using ILA Advanced Trigger Feature to Trigger on an AXI Read Transaction                       |    |
| Lab 10: Using Vivado Serial Analyzer to Debug GTR Serial Links                                         |    |
| Introduction                                                                                           |    |
| Step 1: Generating Zynq UltraScale + MPSoC PS Hardware Definition File (HDF)                           |    |



| Step 2: Using XSCT flow to generate FSBL by using HDF     |  |
|-----------------------------------------------------------|--|
| Step 3: ZCU102 Board Settings                             |  |
| Using FSBL with Serial I/O Analyzer to bring up IBERT GTR |  |
| Troubleshooting                                           |  |
| Using SDK Flow or XSCT Flow to Generate FSBL by Using HDF |  |
| Legal Notices                                             |  |
| Please Read: Important Legal Notices                      |  |





### Introduction

This document contains a set of tutorials designed to help you debug complex FPGA designs. The first four labs explain different kinds of debug flows that you can chose to use during the course of debug. These labs introduce the Vivado® debug methodology recommended to debug your FPGA designs. The labs describe the steps involved in taking a small RTL design and the multiple ways of inserting the Integrated Logic Analyzer (ILA) core to help debug the design. The fifth lab is for debugging high-speed serial I/O links in Vivado. The sixth lab is for debugging JTAG-AXI transactions in Vivado. The first four labs converge at the same point when connected to a target hardware board.

Example RTL designs are used to illustrate overall integration flows between Vivado logic analyzer, ILA, and Vivado Integrated Design Environment (IDE). In order to be successful using this tutorial, you should have some basic knowledge of Vivado Design Suite tool flow.

**TRAINING:** Xilinx provides training courses that can help you learn more about the concepts presented in this document. Use these links to explore related courses:

- <u>Vivado Design Suite Hands-on Introductory Workshop Training Course</u>
- <u>Vivado Design Suite Tool Flow Training Course</u>
- <u>Essentials of FPGA Design Training Course</u>
- Designing FPGAs Using the Vivado Design Suite 1
- Designing FPGAs Using the Vivado Design Suite 2
- Designing FPGAs Using the Vivado Design Suite 3
- Designing FPGAs Using the Vivado Design Suite 4
- Vivado Design Suite User Guide: Programming and Debugging (UG908)

## **Objectives**

These tutorials:

• Show you how to take advantage of integrated Vivado logic analyzer features in the Vivado design environment that make the debug process faster and simpler.





- Provide specifics on how to use the Vivado IDE and the Vivado logic analyzer to debug common problems in FPGA logic designs.
- Provide specifics on how to use the Vivado Serial I/O Analyzer to debug high-speed serial links.

After completing this tutorial, you will be able to:

- Validate and debug your design using the Vivado Integrated Design Environment (IDE) and the Integrated Logic Analyzer (ILA) core.
- Understand how to create an RTL project, probe your design, insert an ILA core, and implement the design in the Vivado IDE.
- Generate and customize an IP core netlist in the Vivado IDE.
- Debug the design using Vivado logic analyzer in real-time, and iterate the design using the Vivado IDE and a KC705 Evaluation Kit Base Board that incorporates a Kintex®-7 device.
- Analyze high-speed serial links using the Serial I/O Analyzer.

## **Getting Started**

#### Setup Requirements

Before you start this tutorial, make sure you have and understand the hardware and software components needed to perform the labs included in this tutorial as listed below.

#### Software

• Vivado Design Suite 2018.1

#### Hardware

- Kintex-7 FPGA KC705 Evaluation Kit Base Board
- Digilent Cable
- Two SMA (Sub-miniature version A) cables









X14686

Figure 1: KC705 Board Showing Key Components

#### **Tutorial Design Components**

Labs 1 through 4 include:

- A simple control state machine
- Three sine wave generators using AXI-Streaming interface, native DDS Compiler
- Common push buttons (GPIO\_BUTTON)
- DIP switches (GPIO\_SWITCH)
- LED displays (GPIO\_LED) VIO Core (Lab 3 only)

**Push Button Switches**: Serve as inputs to the de-bounce and control state machine circuits. Pushing a button generates a high-to-low transition pulse. Each generated output pulse is used as an input into the state machine.

DIP Switch: Enables or disables a de-bounce circuit.

**De-bounce Circuit**: In this example, when enabled, provides a clean pulse or transition from high to low. Eliminates a series of spikes or glitches when a button is pressed and released.

**Sine Wave Sequencer State Machine**: Captures and decodes input from the two push buttons. Provides sine wave selection and indicator circuits, sequencing among 00, 01, 10, and 11 (zero to three).

**LED Displays**: GPIO\_LED\_0 and GPIO\_LED\_1 display selection status from the state machine outputs, each of which represents a different sine wave frequency: high, medium, and low.







Lab 5 includes:

- An IBERT core
- A top-level wrapper that instantiates the IBERT core.

#### **Board Support and Pinout Information**

Table 1: Pinout Information for the KC705 Board

| Pin Name        | Pin Location | Description                |
|-----------------|--------------|----------------------------|
| CLK_N           | AD11         | Clock                      |
| CLK_P           | AD12         | Clock                      |
| GPIO_BUTTONS[0] | AA12         | Reset                      |
| GPIO_BUTTONS[1] | AG5          | Sine Wave Sequencer        |
| GPIO_SWITCH     | Y28          | De-bounce Circuit Selector |
| LEDS_n[0]       | AB8          | Sine Wave Selection[0]     |
| LEDS_n[1]       | AA8          | Sine Wave Selection[1]     |
| LEDS_n[2]       | AC9          | Reserved                   |
| LEDS_n[3]       | AB9          | Reserved                   |

#### **Design Files**

- 1. In your C: drive, create a folder called /Vivado\_Debug.
- 2. Download the <u>Reference Design Files</u> from the Xilinx website.



**CAUTION!** The tutorial and design files may be updated or modified between software releases. You can download the latest version of the material from the Xilinx website.

3. Unzip the tutorial source file to the /Vivado\_Debug folder. There are six labs that use different methodologies for debugging your design. Select the appropriate lab and follow the steps to complete them





**Lab 1**: This lab walks you through the steps of marking nets for debug in HDL as well as the postsynthesis netlist (Netlist Insertion Method). Following are the required files:

- debounce.vhd
- fsm.vhd
- sinegen.vhd
- sinegen\_demo.vhd
- sine\_high/sine\_high.xci
- sine\_low/sine\_low.xci
- sine\_mid/sine\_mid.xci
- sinegen\_demo\_kc705.xdc

**Lab 2**: This lab goes over the details of marking nets for debug in the source HDL (HDL instantiation method) as well as instantiating an ILA core in the HDL. Following are the required files:

- debounce.vhd
- fsm.vhd
- sinegen.vhd
- sinegen\_demo\_inst.vhd
- ila\_0/ila\_0.xci
- sine\_high/sine\_high.xci
- sine\_low/sine\_low.xci
- sine\_mid/sine\_mid.xci
- sinegen\_demo\_kc705.xdc

**Lab 3:** You can test your design even if the hardware is not physically accessible, using a VIO core. This lab walks you through the steps of instantiating and customizing a VIO core that you will hook to the I/Os of the design. Following are the required files:

- debounce.vhd
- fsm.vhd
- sinegen.vhd
- sinegen\_demo\_inst\_vio.vhd
- sine\_high/sine\_high.xci
- sine\_low/sine\_low.xci
- sine\_mid/sine\_mid.xci
- ila\_0/ila\_0.xci
- sinegen\_demo\_kc705.xdc





**Lab 4:** Nets can also be marked for debug in a third-party synthesis tool using directives for the synthesis tool. This lab walks you through the steps of marking nets for debug in the Synplify tool and then using Vivado to perform the rest of the debug. Following are the required files:

- debounce.vhd
- fsm.vhd
- sign\_high.dcp
- sign\_low.dcp
- sine\_mid.dcp
- sine\_high.xci
- sine\_low.xci
- sine\_mid.xci
- sinegen.edn
- sinegen\_synplify.vhd
- synplify\_1.sdc
- synplify\_1.fdc
- sinegen\_demo\_kc705.xdc

Lab 5: Take designs created from Lab 1, Lab 2, Lab 3, and Lab 4 and load them onto the KC705 board.

Lab 6: Enhance post implementation debugging by using the ECO flow to replace debug probes.

**Lab 7:** Use the Incremental Compile flow to enable faster debugging flows. Using the results from a previous implementation run, this flow allows you to make debug modifications and rerun implementation.

**Lab 8:** Debug high-speed serial I/O links using the Vivado Serial I/O Analyzer. This lab uses the Vivado IP example design.

**Lab 9:** Use Vivado ILA core to debug JTAG-to-AXI transactions. This lab uses the Vivado IP example design.

**Lab 10:** Evaluate and Monitor IBERT UltraScale+<sup>™</sup> GTR (IBERT GTR) transceivers in Zynq<sup>®</sup> UltraScale+ MPSoC<sup>™</sup> devices. This lab takes you through the steps of configuring the GTR, generating the FSBL (First Stage Boot Loader file) and using the Vivado Serial Analyzer tool to debug the links.





#### Connecting the Boards and Cables

- 1. Connect the Digilent cable from the Digilent cable connector to a USB port on your computer.
- 2. Connect the two SMA cables (for lab 5 only) as follows:
  - a. Connect one SMA cable from J19 (TXP) to J17 (RXP).
  - b. Connect the other SMA cable from J20 (TXN) to J66 (RXN).

The relative locations of SMA cables on the board are shown in Figure 1: KC705 Board Showing Key Components.





## Lab 1: Using the Netlist Insertion Method for Debugging a Design

### Introduction

In this lab, you will mark signals for debug in the source HDL as well as the post synthesis netlist. Then you will create an ILA core and take the design through implementation. Finally, you will use Vivado® to connect to the KC705 target board and debug your design using Vivado Integrated Logic Analyzer.

# Step 1: Creating a Project with the Vivado New Project Wizard

To create a project, use the New Project wizard to name the project, to add RTL source files and constraints, and to specify the target device.

- 1. Invoke the Vivado IDE.
- 2. In the **Getting Started** page, click **Create Project** to start the New Project wizard. Click **Next**.
- 3. In the **Project Name** page, name the new project **proj\_netlist** and provide the project location (C:/Vivado\_Debug). Ensure that **Create Project Subdirectory** is selected and click **Next**.
- 4. In the **Project Type** page, specify the type of project to create as **RTL Project**. Click **Next**.
- 5. In the **Add Sources** page:
  - a. Set Target Language to VHDL.
  - b. Click the green "+" sign, and then click Add Files.
  - c. In the **Add Source Files** dialog box, navigate to the /src/lab1 directory.
  - d. Select all VHD source files, and click **OK**.
  - e. Verify that the files are added, and Copy Sources into project is selected.
- 6. Click Add.
- 7. In the Add Directories dialog box, navigate to the /src/lab1 directory.
- 8. Select sine\_high, sine\_low, and sine\_mid directories and click **Select**.
- 9. Verify that the directories are added. Click **Next**.
- 10. In the **Add Constraints** dialog box, click the "+" sign, and then click **Add Files**.
- 11. Navigate to /src/lab1 directory and select sinegen\_demo\_kc705.xdc. Click Next.





- 12. In the **Default Part** dialog box, specify the **xc7k325tffg900-2** part for the KC705 platform. You can also select **Boards** and then select **Kintex-7 KC705 Evaluation Platform**. Click **Next**.
- 13. Review the **New Project Summary** page. Verify that the data appears as expected, per the steps above, and click **Finish**.

*Note:* It could take a moment for the project to initialize.

## Step 2: Synthesizing the Design

1. In the Project Manager, click **Settings** as shown in the following figure.

| 🍌 proj_netlist - [C:/Vivado_D          | )ebug/2 | 2017.1/proj_netlist/p        | roj_n  | etlist.xpr] - Vivado 2                     | 2017.1      |             |                                                     |                |
|----------------------------------------|---------|------------------------------|--------|--------------------------------------------|-------------|-------------|-----------------------------------------------------|----------------|
| File Edit Flow Tools                   | Window  | v Layout View                | Help   | Q- Quick Access                            |             |             |                                                     |                |
|                                        | < 🕨     | 👫 🌣 Σ 🖄                      | . Q    | 5 18                                       |             |             |                                                     |                |
| Flow Navigator 😤 🌲                     | ? _     | PROJECT MANAGER -            | proj_n | etlist                                     |             |             |                                                     |                |
| ✓ PROJECT MANAGER                      |         | Sources                      |        |                                            | ? _ [       | ЦЦХ         | Project Summary                                     |                |
| Settings                               |         | Q 素 ♦ +                      | L I P  | 2 0                                        |             | ø           |                                                     |                |
| Add Sources                            |         | V Design Source              |        |                                            |             |             | Settings Edit                                       |                |
| Language Templates                     |         | -                            |        | (Mixed) (sinegen_dem                       | o.vhd) (4)  |             | Project name: proj_netlist                          |                |
| ₽ IP Catalog                           |         | ****                         |        |                                            |             |             | Desis d'Issertions Ochémica Debus                   |                |
| ✓ IP INTEGRATOR                        | / Se    | ttings                       |        |                                            |             |             |                                                     | 32             |
| Create Block Design                    | Q       | *                            |        | General                                    |             |             |                                                     | 52             |
| Open Block Design                      | Pro     | oject Settings               |        | Specify values for var<br>current project. | ious settir | igs used th | throughout the design flow. These settings apply to | othe 🙏         |
| Generate Block Design                  |         | General<br>Simulation        |        |                                            |             |             |                                                     |                |
| -                                      |         | Elaboration                  |        | Name:                                      | proj_netli  | st          |                                                     |                |
|                                        |         | Synthesis                    |        | Project device:                            | 📕 Kinte     | -7 KC705    | 5 Evaluation Platform (xc7k325tffg900-2)            |                |
| Run Simulation                         |         | Implementation<br>Bitstream  |        | Target language:                           | VHDL        |             |                                                     | ~              |
| ✓ RTL ANALYSIS                         | >       | IP                           |        | Default library:                           | xil_defai   | ultlib      |                                                     | 8              |
| > Open Elaborated Design               | То      | ol Settings                  | -11    | Top <u>m</u> odule name:                   | sinegen     | _demo       |                                                     | 🛛 ile          |
|                                        |         | Project Language Options     |        |                                            |             |             |                                                     |                |
| ✓ SYNTHESIS                            |         | IP Defaults<br>Source File   |        | Language Options                           |             |             |                                                     |                |
| Run Synthesis                          |         | Display                      |        | Verilog option                             | B:          | verilog_v   | version=Verilog 2001                                |                |
| > Open Synthesized Design              |         | WebTalk                      |        | Generics/Para                              | meters:     |             |                                                     |                |
|                                        | >       | Help<br>Text Editor          |        | Loop count:                                |             |             |                                                     | 1,000 🌲        |
| <ul> <li>Run Implementation</li> </ul> |         | 3rd Party Simulators         |        |                                            |             |             |                                                     |                |
| > Open Implemented Design              | >       | Colors                       |        |                                            |             |             |                                                     |                |
|                                        |         | Selection Rules<br>Shortcuts |        |                                            |             |             |                                                     |                |
| ✓ PROGRAM AND DEBUG                    |         | Strategies                   |        |                                            |             |             |                                                     |                |
| 👫 Generate Bitstream                   | >       | Window Behavior              |        |                                            |             |             |                                                     |                |
| > Open Hardware Manager                | ?       |                              |        |                                            |             |             | OK Cancel Apply                                     | Restore        |
|                                        | •       |                              |        |                                            |             |             | Cancer Apply                                        | <u>Testore</u> |
| l                                      | 1       | 1                            |        | 1 1 1                                      |             |             |                                                     |                |

Figure 2: Configuring the Settings







**IMPORTANT:** As an optional step, in the **Settings** dialog box, select Synthesis from the left and change **flatten hierarchy** to **none**. The reason for changing this setting to **none** is to prevent the synthesis tool from performing any boundary optimizations for this tutorial.

2. In the Vivado Flow Navigator, expand the Synthesis drop-down list, and click Run Synthesis. In the Launch Runs dialog box, accept all of the default settings (Launch runs on local host), and click OK.

**Note:** When synthesis runs, a progress indicator appears, showing that synthesis is occurring. This could take a few minutes.

3. In the **Synthesis Completed** dialog box, click **Cancel** as shown in the following figure. You will implement the design later.



Figure 3: Synthesis Completed Dialog Box

## **Step 3: Probing and Adding Debug IP**

To add a Vivado ILA core to the design, take advantage of the integrated flows between the Vivado IDE and Vivado logic analyzer.

In this step, you will accomplish the following tasks:

- Add debug nets to the project.
- Run the Set Up Debug wizard.
- Implement and open the design.
- Generate the bitstream.





#### Adding Debug Nets to the Project

Following are some ways to add debug nets using the Vivado IDE:

• Add MARK\_DEBUG attribute to HDL files.

#### VHDL

```
attribute mark_debug : string;
attribute mark_debug of sine : signal is "true";
attribute mark_debug of sineSel : signal is "true";
```

#### Verilog

(\* mark\_debug = "true" \*) wire sine; (\* mark\_debug = "true" \*) wire sineSel;

This method lets you probe signals at the HDL design level. This can prevent optimization that might otherwise occur to that signal. It also lets you pick up the signal tagged for post synthesis, so you can insert these signals into a debug core and observe the values on this signal during FPGA operation. This method gives you the highest probability of preserving HDL signal names after synthesis.

• Right-click and select Mark Debug or Unmark Debug on a synthesized netlist.

This method is flexible since it allows probing the synthesized netlist in the Vivado IDE and allows you to add/remove MARK\_DEBUG attributes at any hierarchy in the design. In addition, this method does not require HDL source modification. However, there may be situations where synthesis may not preserve the signals due to netlist optimization involving absorption or merging of design structures.

• Use a Tcl prompt to set the MARK\_DEBUG attribute on a synthesized netlist.

```
set_property mark_debug true [get_nets -hier [list {sine[*]}]]
```

This applies the MARK\_DEBUG on the current, open netlist.

This method is flexible since you can turn MARK\_DEBUG on and off by modifying the Tcl command. In addition, this method does not require HDL source modification. However, there may be situations where synthesis does not preserve the signals due to netlist optimization involving absorption or merging of design structures.

In the following steps, you learn how to add debug nets to HDL files and the synthesized design using Vivado IDE.



**TIP:** Before proceeding, make sure that the **Flow Navigator** on the left panel is enabled. Use **Ctrl-Q** to toggle it off and on.





61

1. In the **Flow Navigator** under the **Synthesis** drop-down list, click **Open Synthesized Design** as shown in the following figure.

ī.

| ✓ SYNTHESIS               | Properties | ? _ 🗆 🖒 ×                                       |
|---------------------------|------------|-------------------------------------------------|
| Run Synthesis             |            | $\leftarrow \mid \Rightarrow \mid \diamondsuit$ |
| > Open Synthesized Design |            |                                                 |

Figure 4: Open Synthesized Design

- 2. In the main toolbar drop-down menu, select **Debug**. When the **Debug** window opens. Click the window if it is not already selected.
- 3. Expand the **Unassigned Debug Nets** folder. The following figure shows those debug nets that were tagged with MARK\_DEBUG attributes in sinegen demo.vhd.

| 01 j |                                                                         |
|------|-------------------------------------------------------------------------|
| 62   | Add mark_debug attributes to show debug nets in the synthesized netlist |
| 63   | attribute mark_debug : string;                                          |
| 64   | attribute mark_debug of GPIO_BUTTONS_db : signal is "true";             |
| 65   | attribute mark_debug of GPIO_BUTTONS_dly : signal is "true";            |
| 66   | attribute mark_debug of GPIO_BUTTONS_re : signal is "true";             |
| 67   | attribute mark_debug of DONT_EAT : signal is "true";                    |
| 68   |                                                                         |
| 69   |                                                                         |
| 70 Ę | component sinegen                                                       |
| 71   | port                                                                    |
| 72   | (                                                                       |
| 73   | clk : in std_logic;                                                     |
| 74   | reset : in std_logic;                                                   |
| 75   | <pre>sel : in std_logic_vector(1 downto 0);</pre>                       |
| 76   | <pre>sine : out std_logic_vector(19 downto 0)</pre>                     |
| 77   | );                                                                      |
| 78   |                                                                         |
| 79 É | end component;                                                          |
| 80   |                                                                         |

Figure 5: VHDL Example Using MARK\_DEBUG Attributes





#### Lab 1: Using the Netlist Insertion Method for Debugging a Design

| Tcl Console Messages Log Repo         | orts Design Ru | ns Debug × |
|---------------------------------------|----------------|------------|
| Q   素   ≑   兼   <b>+</b>   ≓          |                |            |
| Name                                  | Driver Cell    | Driver Pin |
| 👻 🖨 Unassigned Debug Nets (7)         |                |            |
| ✓ 小窓 GPIO_BUTTONS_db (2)              | FDRE           | Q          |
| _ I ಔ GPIO_BUTTONS_db[0]              | FDRE           | Q          |
| _ □ III GPIO_BUTTONS_db[1]            | FDRE           | Q          |
| ✓ 小☆ GPIO_BUTTONS_dly (2)             | FDRE           | Q          |
| _ I III GPIO_BUTTONS_dly[0]           | FDRE           | Q          |
| _ SPIO_BUTTONS_dly[1]                 | FDRE           | Q          |
| ✓ √f <sup>™</sup> GPIO_BUTTONS_re (2) | FDRE           | Q          |
| _ □ CPIO_BUTTONS_re[0]                | FDRE           | Q          |
| _ □ GPIO_BUTTONS_re[1]                | FDRE           | Q          |
| _f ∞ DONT_EAT                         | FDRE           | Q          |
|                                       |                |            |
| Debug Cores Debug Nets                |                |            |

Figure 6: Unassigned Debug Nets Post-Synthesis

- 4. In the **Netlist** window, elect the **Netlist** tab and expand **Nets**. Select the following nets for debugging as shown in the following figure.
  - GPIO\_BUTTONS\_IBUF[0] and GPIO\_BUTTONS\_IBUF[1] Nets folder under the toplevel hierarchy
  - o sel(2) Nets folder under the U\_SINEGEN hierarchy
  - o sine (20) Nets folder under the U\_SINEGEN hierarchy



Figure 7: Add Nets for Debug from the Synthesized Netlist





**Note**: These signals represent the significant behavior of this design and are used to verify and debug the design in subsequent steps.

5. Right-click the selected nets and select Mark Debug as shown in the following figure.



Figure 8: Adding Nets from the Netlist Tab

6. Next, mark nets for debug in the Tcl console. Mark nets "sine (20) " under the U\_SINEGEN hierarchy for debug by executing the following Tcl command.

```
set_property mark_debug true [get_nets -hier [list {sine[*]}]]
```

**TIP:** In the **Debug** window, you can see the unassigned nets you just selected. In the **Netlist** window, you can also see the green bug icon next to each scalar or bus, which indicates that a net has the attribute mark\_debug = true as shown the following two figures.





#### Lab 1: Using the Netlist Insertion Method for Debugging a Design

| Tcl Console Messages Log Repo                      | rts Design Ru | ns Debug × |
|----------------------------------------------------|---------------|------------|
| Q   素   ≑   兼   <b>∔</b>   ≓                       |               |            |
| Name                                               | Driver Cell   | Driver Pin |
| 🕆 📮 Unassigned Debug Nets (29)                     |               |            |
| ✓ Jr <sup>™</sup> GPIO_BUTTONS_db (2)              | FDRE          | Q          |
| _ ☐ ☎ GPIO_BUTTONS_db[0]                           | FDRE          | Q          |
| _ SPIO_BUTTONS_db[1]                               | FDRE          | Q          |
| ✓ Jr <sup>™</sup> GPIO_BUTTONS_dly (2)             | FDRE          | Q          |
| _ SPIO_BUTTONS_dly[0]                              | FDRE          | Q          |
| _ SPIO_BUTTONS_dly[1]                              | FDRE          | Q          |
| ✓ J <sup>™</sup> GPIO_BUTTONS_IBUF (2)             | IBUF          | 0          |
| _ SPIO_BUTTONS_IBUF[0]                             | IBUF          | 0          |
| _ SPIO_BUTTONS_IBUF[1]                             | IBUF          | 0          |
| ✓ Jr <sup>™</sup> GPIO_BUTTONS_re (2)              | FDRE          | Q          |
| Γ\$\$_GPIΩ_BUTTΩNS_rel01<br>Debug Cores Debug Nets | FDRF          | Q          |

Figure 9: Newly Added Nets for Debug from the Synthesized Netlist



Figure 10: Netlist View of Nets Marked for Debug

#### Running the Set Up Debug Wizard

1. From the **Debug** window tool bar or **Tools** drop-down menu, select **Set Up Debug**. The **Set up Debug** wizard opens.





#### Lab 1: Using the Netlist Insertion Method for Debugging a Design

| Tcl Console Messa          | ges Log Repo   | rts Design Rur | ns Debug × |
|----------------------------|----------------|----------------|------------|
| Q 🛨 🌲 🕷                    | <b>↓ →</b>     |                |            |
| Name                       | Set Up Debug   | Driver Cell    | Driver Pin |
| 👻 🖨 Unassigned Deb         | oug Nets (29)  |                |            |
| ✓ - J t GPIO_BUTT          | ONS_db (2)     | FDRE           | Q          |
| _∫¤ GPIO_BU                | JTTONS_db[0]   | FDRE           | Q          |
| _∫≋ GPIO_BU                | JTTONS_db[1]   | FDRE           | Q          |
| ✓ J <sup>™</sup> GPIO_BUTT | ONS_dly (2)    | FDRE           | Q          |
| _∫≅ GPIO_BU                | ITTONS_dly[0]  | FDRE           | Q          |
| _∫≅ GPIO_BU                | ITTONS_dly[1]  | FDRE           | Q          |
| ✓ 小☆ GPIO_BUTT             | ONS_IBUF (2)   | IBUF           | 0          |
| _∫≅ GPIO_BU                | ITTONS_IBUF[0] | IBUF           | 0          |
| _∫≅ GPIO_BU                | ITTONS_IBUF[1] | IBUF           | 0          |
| ✓ 小☆ GPIO_BUTT             | ONS_re (2)     | FDRE           | Q          |
| Γ.C. GPIΩ .BI              | ITTONS, relol  | FDRF           | Ω          |
| Debug Cores Debu           | ig Nets        |                |            |

#### Figure 11: Launching the Set up Debug Wizard

2. When the **Set up Debug** wizard opens, click **Next.** 

| 🍌 Set Up Debug                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| HLx Editions                  | Set Up Debug This wizard will guide you through the process of <ol> <li>Choosing nets and connecting them to debug cores.</li> <li>Associating a clock domain with each of the nets chosen for debug.</li> <li>Choosing additional features on the debug cores like Data Depth, Advanced Trigger mode and Capture control.</li> </ol> Note: This setup wizard does not apply to the VIO, IBERT or JTAG-to-AXI-Master debug cores. Please refer to Vivado Design Suite User Guide. Programming and Debugging (UG908) for further instructions on how to use these IPs. |  |
| E XILINX<br>ALL PROGRAMMABLE. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| <ul> <li>?</li> </ul>         | < <u>Back</u> <u>Einish</u> Cancel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |

Figure 12: Set up Debug Wizard





3. In the **Nets to Debug** page, shown in the following figure, ensure that all the nets have been added for debug and click **Next**.

| dows, then drag them to the list or cli | ck "Add Selected Ne | ets".       |                      |                |
|-----------------------------------------|---------------------|-------------|----------------------|----------------|
| Q   ¥   ≑   ㎡   Ⅲ   +                   | -                   |             |                      | 0              |
| Name                                    | Clock Domain        | Driver Cell | Probe Type           |                |
| > Jrt≋ GPIO_BUTTONS_db (2)              | clk                 | FDRE        | Data and Trigger 🛛 👻 |                |
| > Jac GPIO_BUTTONS_dly (2)              | clk                 | FDRE        | Data and Trigger 🛛 🗸 |                |
| > Jata GPIO_BUTTONS_IBUF (2)            | clk                 | IBUF        | Data and Trigger 🛛 🗸 |                |
| > Jac GPIO_BUTTONS_re (2)               | clk                 | FDRE        | Data and Trigger 🛛 🗸 |                |
| > √ft≋ U_SINEGEN/sel (2)                | clk                 | FDRE        | Data and Trigger 🛛 🗸 |                |
| ✓ Jata U_SINEGEN/sine (20)              | clk                 | FDRE        | Data and Trigger 👒   |                |
| _f¤ sine[0]                             | clk                 | FDRE        | Data and Trigger     |                |
| _f¤ sine[1]                             | clk                 | FDRE        | Data and Trigger     |                |
| _f¤ sine[2]                             | clk                 | FDRE        | Data and Trigger     |                |
| ∫¤ sine[3]                              | clk                 | FDRE        | Data and Trigger     |                |
| _∫¤ sine[4]                             | clk                 | FDRE        | Data and Trigger     | ]              |
| Find Nets to Add                        |                     |             |                      | Nets to debug: |

Figure 13: Specify Nets to Debug

4. In the **ILA Core Options** page, go to **Trigger and Storage Settings** section and select both **Capture Control** and **Advanced Trigger**. Click **Next**.





5. In the **Setup Debug Summary** page, make sure that all the information is correct and as expected. Click **Finish**.

| 🅕 Set Up Debug    |                                          |               |                | ×      |
|-------------------|------------------------------------------|---------------|----------------|--------|
|                   | Set up Debug Summary                     |               |                |        |
| HLx Editions      | 0 debug cores will be removed            |               |                |        |
|                   | 1 debug core will be created             |               |                |        |
|                   | Found 1 clock                            |               |                |        |
|                   |                                          |               |                |        |
|                   |                                          |               |                |        |
|                   |                                          |               |                |        |
|                   |                                          |               |                |        |
|                   |                                          |               |                |        |
|                   |                                          |               |                |        |
|                   |                                          |               |                |        |
|                   |                                          |               |                |        |
| <b>E</b> XILINX   | 🖌 Open in Debug layout                   |               |                |        |
| ALL PROGRAMMABLE» | To apply the above changes, click Finish |               |                |        |
| •                 |                                          | < Back Next > | <u>F</u> inish | Cancel |

Figure 14: Set up Debug Summary

Upon clicking **Finish**, the relevant XDC commands that insert the ILA core(s) are generated.





## **Step 4: Implementing and Generating Bitstream.**

1. In the Flow Navigator, under Program and Debug, click Generate Bitstream.



Figure 15: Implement Design and Generate Bitstream

- 2. In the **Save Project** dialog box click **Save**. This applies the MARK\_DEBUG attributes on the newly marked nets. You can see those constraints by inspecting the sinegen\_demo\_kc705.xdc file.
- 3. When the **No Implementation Results Available** dialog box pops up, click **Yes**. In the **Launch Runs** dialog box, accept all of the default settings (Launch runs on local host) and click **OK**.
- 4. When the bitstream generation completes, the **Bitstream Generation Completed** dialog box pops up. Click **OK**.
- 5. In the dialog box asking to close synthesized design before opening implemented design. Click Yes.
- 6. Examine the **Timing Summary** report to ensure that all the specified timing constraints are met.

| Tcl Console Messages Log R            | eports Design Runs Power          | DRC Met      | thodology | Timing $\times$    |            |          |                                          | ? _ 🗆 🖸  |
|---------------------------------------|-----------------------------------|--------------|-----------|--------------------|------------|----------|------------------------------------------|----------|
| Q ≚ ♦ ●                               | Design Timing Summary             |              |           |                    |            |          |                                          |          |
| General Information<br>Timer Settings | Setup                             |              | Hold      |                    |            |          | Pulse Width                              |          |
| Design Timing Summary                 | Worst Negative Slack (WNS):       | 0.491 ns     | Wors      | t Hold Slack (WH   | IS): (     | 0.052 ns | Worst Pulse Width Slack (WPWS):          | 1.732 ns |
| Clock Summary (4)                     | Total Negative Slack (TNS):       | 0.000 ns     | Total     | Hold Slack (THS    | s): (      | 0.000 ns | Total Pulse Width Negative Slack (TPWS): | 0.000 ns |
| > 🗁 Check Timing (0)                  | Number of Failing Endpoints       | 0            | Num       | ber of Failing End | dpoints: ( | D        | Number of Failing Endpoints:             | 0        |
| > 🗁 Intra-Clock Paths                 | Total Number of Endpoints:        | 12755        | Total     | Number of Endp     | ooints: 1  | 12755    | Total Number of Endpoints:               | 6938     |
| Inter-Clock Paths                     | All user specified timing constra | ints are met | t.        |                    |            |          |                                          |          |
| > 🗁 Other Path Groups                 |                                   |              |           |                    |            |          |                                          |          |
| User Ignored Paths                    |                                   |              |           |                    |            |          |                                          |          |
| Unconstrained Paths                   |                                   |              |           |                    |            |          |                                          |          |
|                                       |                                   |              |           |                    |            |          |                                          |          |
| Timing Summary - impl_1 (saved)       |                                   |              |           |                    |            |          |                                          |          |

Figure 16: View the Timing Summary Report

Proceed to Lab 5: Using Vivado Logic Analyzer to Debug Hardware to complete the rest of the steps for debugging the design.





## Lab 2: Using the HDL Instantiation Method for Debugging a Design in Vivado

## Introduction

The HDL Instantiation method is one of the two methods supported in Vivado® Debug Probing. For this flow, you will generate an ILA IP using the Vivado IP Catalog and instantiate the core in a design manually as you would with any other IP.

# Step 1: Creating a Project with the Vivado New Project Wizard

To create a project, use the New Project wizard to name the project, to add RTL source files and constraints, and to specify the target device.

- 1. Invoke the Vivado IDE.
- 2. In the Quick Start tab, click Create Project to start the New Project wizard. Click Next.
- 3. In the **Project Name** page, name the new project **proj\_hdl** and provide the project location (C:/Vivado\_Debug). Ensure that **Create project subdirectory** is selected. Click **Next**.
- 4. In the **Project Type** page, specify the **Type of Project** to create as **RTL Project**. Click **Next**.
- 5. In the **Add Sources** page:
  - a. Set Target Language to VHDL.
  - b. Click the "+" sign, and then click Add Files.
  - c. In the Add Source Files dialog box, navigate to the /src/lab2 directory, and choose the sine\_high, sine\_low, sine\_mid, and ila\_0 directories. Click Select.
  - d. Select all VHD source files, and click **OK**.
  - e. Verify that the files are added, and Copy Sources into Project is selected.
- 6. Click the "+" sign, and then click Add Files.
- 7. Navigate to the /src/lab2/sine\_high directory.
- 8. Verify that the directories are added, and **Copy Sources into Project** is selected. Click **Next**.
- 9. In the Add Constraints dialog box, click the green "+" sign, and then click Add Files.
- 10. Navigate to /src/lab1 directory and select sinegen\_demo\_kc705.xdc. Click Next.





- 11. In the **Default Part** page, specify the **xc7k325tffg900-2** part for the KC705 platform. You can also select **Boards** and then select **Kintex-7 KC705 Evaluation Platform**. Click **Next**.
- 12. Review the **New Project Summary** page. Verify that the data appears as expected, per the steps above. Click **Finish**.
- 13. In the **Sources** window in Vivado IDE, expand **sinegen\_demo\_inst** to see the source files for this lab. Note that **ila\_0** core has been added to the project.



Figure 17: ILA Instantiation in HDL

14. Double-click the **sinegen\_demo\_inst.vhd** file, shown in the following figure to open it and inspect the instantiation and port mapping of the ILA core in the HDL code.

| ILA                         |
|-----------------------------|
|                             |
| U_ILA : ila_0 .             |
| port map                    |
| (                           |
| CLK => clk,                 |
| PROBE0 => sineSel,          |
| PROBE1 => sine,             |
| PROBE2 => GPIO_BUTTONS_db,  |
| PROBE3 => GPIO_BUTTONS_re,  |
| PROBE4 => GPIO_BUTTONS_dly, |
| PROBE5 => GPIO_BUTTONS      |
| );                          |
|                             |

Figure 18: Hook Signals that Require Debugging in the ILA



## Step 2: Synthesize Implement and Generate Bitstream

1. From the **Program and Debug** drop-down list, in **Flow Navigator**, click **Generate Bitstream**. This will synthesize, implement and generate a bitstream for the design.

|                             | Size:        |
|-----------------------------|--------------|
| ✓ PROGRAM AND DEBUG         | Modified:    |
| Generate Bitstream          | Copied to:   |
| لک<br>Open Hardware Manager | Copied from: |
|                             | Copied on:   |
|                             | <            |
|                             | General Pro  |
|                             |              |

Figure 19: Generate Bitstream

- **2.** The **No Implementation Results Available** dialog box appears. Click **Yes**. In the **Launch Runs** dialog box, accept all of the default settings (Launch runs on local host) and click **OK**.
- 3. After bitstream generation completes, the **Bitstream Generation Completed** dialog box appears. **Open Implemented Design** is selected by default. Click **OK**.
- 4. In the **Design Timing Summary** window, ensure that all timing constraints are met.

| Tcl Console Messages Log R            | Reports Design Runs IP Status     | Power         | DRC  | Methodology        | Timing    | ×        |                                          | ? _ 🗆 🛛  |
|---------------------------------------|-----------------------------------|---------------|------|--------------------|-----------|----------|------------------------------------------|----------|
| Q ∓ ≑ ●                               | Design Timing Summary             |               |      |                    |           |          |                                          |          |
| General Information<br>Timer Settings | Setup                             |               | Hold |                    |           |          | Pulse Width                              |          |
| Design Timing Summary                 | Worst Negative Slack (WNS):       | 0.511 ns      | Wor  | st Hold Slack (W   | HS):      | 0.044 ns | Worst Pulse Width Slack (WPWS):          | 1.732 ns |
| Clock Summary (4)                     | Total Negative Slack (TNS):       | 0.000 ns      | Tota | I Hold Slack (TH   | S):       | 0.000 ns | Total Pulse Width Negative Slack (TPWS): | 0.000 ns |
| Check Timing (0)                      | Number of Failing Endpoints       | : 0           | Nun  | nber of Failing Er | ndpoints: | 0        | Number of Failing Endpoints:             | 0        |
| Intra-Clock Paths                     | Total Number of Endpoints:        | 4437          | Tota | I Number of End    | lpoints:  | 4437     | Total Number of Endpoints:               | 2478     |
| Inter-Clock Paths                     | All user specified timing constra | aints are met |      |                    |           |          |                                          |          |
| Other Path Groups                     |                                   |               |      |                    |           |          |                                          |          |
| User Ignored Paths                    |                                   |               |      |                    |           |          |                                          |          |
| Unconstrained Paths                   |                                   |               |      |                    |           |          |                                          |          |
| Timing Summary - impl_1 (saved)       |                                   |               |      |                    |           |          |                                          |          |

#### Figure 20: Review Design Timing Summary

5. Proceed to Lab 5: Using Vivado Logic Analyzer to Debug Hardware chapter to complete the rest of this lab.





## Lab 3: Using a VIO Core for Debugging a Design in Vivado

## Introduction

The Virtual Input/Output (VIO) core is a customizable core that can both monitor and drive internal FPGA signals in real time. The number and width of the input and output ports are customizable in size to interface with the FPGA design. Because the VIO core is synchronous to the design being monitored and/or driven, all design clock constraints that are applied to your design are also applied to the components inside the VIO core. Run time interaction with this core requires the use of the Vivado® logic analyzer feature. The following figure is a block diagram of the new VIO core.



Figure 21: VIO Block Diagram

This lab walks you through the steps of instantiating and configuring the VIO core. It walks you through the steps of connecting the I/Os of the design to the VIO core. This way, you can debug your design when you do not have access to the hardware or the hardware is remotely located.

The following ports are created:

- One 4-bit PROBE\_IN0 port. This has two bits to monitor the 2-bit Sine Wave selector outputs from the finite state machine (FSM) and other two bits to mimic the state of the other two LEDs on the board. We will configure these 4-bit signals as LEDs during run time to mimic the LEDs displayed on the KC705 board.
- One 2-bit PROBE\_OUT0 port to drive the input buttons on the FSM. We will configure it so one bit can be used as a toggle switch during run time to mimic the "PUSH\_BUTTON", SW3, and second bit will be used as the "PUSH\_BUTTON", SW6.





## Step 1: Creating a Project with the Vivado New Project Wizard

To create a project, use the New Project wizard to name the project, to add RTL source files and constraints, and to specify the target device.

- 1. Invoke Vivado IDE.
- 2. In the Quick Start tab, click Create Project to start the New Project wizard. Click Next.
- 3. In the **Project Name** page, name the new project **proj\_hdl\_vio** and provide the project location (C:/Vivado Debug). Ensure that **Create project subdirectory** is selected. Click **Next**.
- 4. In the Project Type page, specify the Type of Project to create as RTL Project. Click Next.
- 5. In the **Add Sources** page:
  - a. Set Target Language to VHDL.
  - b. Click Add Files.
  - c. In the Add Source Files dialog box, navigate to the /src/lab3 directory.
  - d. Select all VHD source files, and click **OK**.
  - e. Verify that the files are added, and Copy Sources into Project is selected. Click Next.
- 6. Click the green "+" sign, and then click **Add Files**.
- 7. In the Add Source Directories dialog box, navigate to the /src/lab3 directory and choose the sine\_high, sine\_low, sine\_mid, and ila\_0 directories. Click Select.
- 8. Verify that the files are added and Copy sources into project is selected. Click Next.
- 9. In the Add Constraints dialog box, click the "+" sign, and then click Add Files.
- 10. Navigate to /src/lab3 directory and select sinegen\_demo\_kc705.xdc. Click Next.
- 11. In the **Default Part** page, specify the **xc7k325tffg900-2** part for the KC705 platform. You can also select **Boards** and then select **Kintex-7 KC705 Evaluation Platform**. Click **Next**.
- 12. Review the **New Project Summary** page. Verify that the data appears as expected, per the steps above. Click **Finish**.

*Note*: It might take a moment for the project to initialize.





13. In the **Sources** window in Vivado IDE, expand sinegen\_demo\_inst\_vio to see the source files for this lab. Note that ila\_0 core has been added to the project. However, vio\_0 (the VIO core) is missing.



Figure 22: Missing Source for VIO Core

- In this step, you will instantiate and configure this VIO core. From the Flow Navigator, click IP Catalog, expand Debug & Verification, then expand Debug, and double-click VIO. The Customize IP dialog box opens.
- 15. On the **General Options** tab, leave the **Component Name** to its default value of **vio\_0**, **set Input Probe Count** to **1**, **Output Probe Count** to **1**, and select the **Enable Input Probe Activity Detectors** check box.





| i Customize IP                      |                                                                                                                                                                                                                                                                 | <b>×</b>  |
|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| VIO (Virtual Input/Output) (3.0)    |                                                                                                                                                                                                                                                                 | A         |
| Documentation 📄 IP Location C Swite | th to Defaults                                                                                                                                                                                                                                                  |           |
| Show disabled ports                 | Component Name<br>To configure more than 64 probe ports use Vivado Tcl Conso                                                                                                                                                                                    | vio_0     |
| cik probe_in0[0:0]                  | General Options     PROBE_IN Ports(00)     PROBE_OUT       Input Probe Count     1     0     [0 - 256]       Output Probe Count     1     0     [0 - 256]       Image: Count Count     1     0     [0 - 256]       Image: Count Count     1     0     [0 - 256] |           |
|                                     |                                                                                                                                                                                                                                                                 | OK Cancel |

Figure 23: Configure General Options of the VIO Core

16. On the **PROBE\_IN Ports** tab, set **Probe Width** to **4** bits wide.

| 🏄 Customize IP                   |                     |                           |                        |           | × |
|----------------------------------|---------------------|---------------------------|------------------------|-----------|---|
| VIO (Virtual Input/Output) (3.0) |                     |                           |                        |           | 4 |
| Documentation PLocation C Swite  | h to Defaults       |                           |                        |           |   |
| Show disabled ports              | Component Name      |                           | vio_0                  |           | 0 |
|                                  | To configure more t | han 64 probe ports use Vi | vado Tcl Console       |           |   |
|                                  | General Options     | PROBE_IN Ports(00)        | PROBE_OUT Ports(00)    |           |   |
|                                  | Probe Port          |                           | Probe Width [1 - 256 ] |           |   |
|                                  | PROBE_IN0           |                           | 4                      | e         | 3 |
| clk probe_in0[0:0]               |                     |                           |                        |           |   |
|                                  |                     |                           |                        | OK Cancel | I |

Figure 24: Configure PROBE\_IN Ports of the VIO Core

17. On the PROBE \_OUT Ports, set Probe Width to 2 bits wide with an initial value of 0 in hex format.





| 🍐 Customize IP                          |                                                          |                        |             |                        | ×      |
|-----------------------------------------|----------------------------------------------------------|------------------------|-------------|------------------------|--------|
| VIO (Virtual Input/Output) (3.0)        |                                                          |                        |             |                        | 4      |
| 1) Documentation 📄 IP Location C Switch | to Defaults                                              |                        |             |                        |        |
| Show disabled ports                     | Component Name                                           |                        | vio         | _0                     | 8      |
|                                         | To configure more than 64 pro<br>General Options PROBE_I |                        | OUT Ports(0 | 0)                     |        |
|                                         | Probe Port                                               | Probe Width [1 - 256 ] |             | Initial Value (in hex) |        |
| olk<br>probe_in0[3:0] probe_out0[1:0]   | PROBE_OUT0                                               | 2                      |             | 0x0                    | •      |
|                                         |                                                          |                        |             | ОК                     | Cancel |

Figure 25: Configure the PROBE\_OUT Ports of the VIO Core

18. Click **OK** to generate the IP. The **Generate Output Products** dialog box will appear. Click **Generate**.

| 🚴 Generate Output Products 🛛 🔀                                                                                                       |
|--------------------------------------------------------------------------------------------------------------------------------------|
| The following output products will be generated.                                                                                     |
| Preview                                                                                                                              |
| <ul> <li>Instantiation Template</li> <li>Synthesized Checkpoint (.dcp)</li> <li>Behavioral Simulation</li> <li>Change Log</li> </ul> |
| Synthesis Options ?                                                                                                                  |
| © <u>G</u> lobal                                                                                                                     |
| Out of context per IP                                                                                                                |
| Run Settings                                                                                                                         |
| Number of jobs: 8 👻                                                                                                                  |
| Apply Generate Skip                                                                                                                  |

Figure 26: Generate Output Products for the VIO Core





Output product generation should take less than a minute. At this point, you have finished customizing the VIO. This core has already been instantiated in the top level design as shown in the following figure.

| VIO                                     |
|-----------------------------------------|
| U_VIO : vio_0                           |
| port map                                |
| (                                       |
| CLK => clk,                             |
| <pre>PROBE_IN0(3) =&gt; DONT_EAT,</pre> |
| PROBE INO(2) => GPIO BUTTONS re(1),     |
| PROBE INO(1 downto 0) => sineSel,       |
| PROBE OUTO(1) => push button reset,     |
| PROBE OUTO(0) => push button vio        |
| );                                      |

#### Figure 27: VIO Instantiation in the Top Level Design

At this point, the **Sources** window should look as shown in the following figure.



Figure 28: Instantiated VIO Core in the Sources Window





19. Double-click **sinegen\_demo\_inst.vhd** in the **Sources** window, to open it and inspect the instantiation and port mapping of the ILA core in the HDL code.

```
-- ILA
U_ILA : ila_0
port map
(
    CLK => clk,
    PROBE0 => sineSel,
    PROBE1 => sine,
    PROBE2 => GPI0_BUTTONS_db,
    PROBE3 => GPI0_BUTTONS_re,
    PROBE4 => GPI0_BUTTONS_dly,
    PROBE5 => GPI0_BUTTONS
);
```

Figure 29: Hook signals that need to be debugged in the ILA

## Step 2: Synthesize, Implement, and Generate Bitstream

- 1. From the **Program and Debug** drop-down list, in **Flow Navigator**, click **Generate Bitstream**. This synthesizes, implements, and generates a bitstream for the design.
- 2. The Missing Implementation Results dialog box appears. Click OK.
- 3. After bitstream generation completes, the **Bitstream Generation Completed** dialog box appears. **Open Implemented Design** is selected by default. Click **OK**.
- 4. Inspect the Timing Summary report and make sure that all timing constraints have been met.



Figure 30: Report Timing Summary Dialog Box

 Proceed to Lab 5: Using Vivado Logic Analyzer to Debug Hardware chapter to complete the rest of the steps for debugging the design. Skip forward to Verifying the VIO Core Activity (Only applicable to Lab 3) section to complete the rest of this lab.





## Lab 4: Using Synplify Pro Synthesis Tool and Vivado for Debugging a Design

## Introduction

This simple tutorial shows how to do the following:

- Create a Synplify Pro project for the wave generator design.
- Mark nets for debug in the Synplify Pro constraints file as well as VHDL source files.
- Synthesize the Synplify Pro project to create an EDIF netlist.
- Create a Vivado® project based on the Synplify Pro netlist.
- Use the Vivado IDE to setup and debug the design from the synthesized design using Synplify Pro.

## Step 1: Create a Synplify Pro Project

- 1. Launch Synplify Pro and select **File > New**.
- 2. Set File Type to Project File (Project) as highlighted in the following figure.
- 3. In the New File Name box, enter synplify\_1.
- 4. Click **OK**.



Figure 31: Synplify Pro New Project Dialog Box



**XILINX** Lab 4: Using Synplify Pro Synthesis Tool and Vivado for Debugging a Design

5. If you get a dialog box asking you to create a non-existing directory, click **OK**.



Figure 32: Synplify Pro project Confirmation Dialog Box



**XILINX** Lab 4: Using Synplify Pro Synthesis Tool and Vivado for Debugging a Design

6. In the left panel of the **Synplify Pro** window, click **Add File** as shown in the following figure.



Figure 33: Adding Files to a Synplify Pro Project

- 7. In the Add Files to Project dialog box, change the Files of Type to HDL File. Navigate to C:\Vivado\_Debug\src\lab4, which shows all the VHDL source files needed for this lab. Select the following three files by pressing the Ctrl key and clicking on them.
  - debounce.vhd
  - fsm.vhd
  - sinegen\_demo.vhd
- 8. Click Add.



## **XILINX** Lab 4: Using Synplify Pro Synthesis Tool and Vivado for Debugging a Design

| S Add Files to Project                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ×                                                   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|
| Look in: C:\Vivado_Debug\src\Lab4  C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_D |                                                     |
| File name:       "debounce.vhd" "fsm.vhd" "sinegen_demo.vhd"         Files of type:       HDL Files (*.vhd *.vhdl *.v *.sv *.vma)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                     |
| VHDL/Verilog lib:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                     |
| Files to add to project: (3 file(s) selected) 🗹 Use relative paths 🗹 Add files to Folders Folder Options                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                     |
| \\src\Lab4\debounce.vhd<br>\\src\Lab4\fsm.vhd<br>\\src\Lab4\sinegen_demo.vhd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | <- Add All <- Add Remove All -> Remove -> OK Cancel |

Figure 34: Adding VHDL Source Files to the Synplify Pro Project





10. In the same dialog box set **Files of type** to **Constraints Files**. This shows the synplify\_1.sdc file. Select the file and click **Add** as shown in the following figure.

| Look in: C:\Vivado_Debug\src\Lab4  C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_Debug\src\Lab4 C:\Vivado_D | S Add Files to P                                                                                                 | Project                  | ×                                          |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|--------------------------|--------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 鰔 My Compu                                                                                                       |                          |                                            |
| File name: synplify_1.sdc   Files of type: Constraint Files (*.sdc)   VHDL/Verilog lib: •   Files to add to project: (4 file(s) selected)  Use relative paths  Add files to Folders Folder Options   .\src\Lab4\debounce.vhd   .\src\Lab4\sinegen_demo.vhd   .\src\Lab4\synplify_1.sdc     Cancel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Files of type:<br>VHDL/Verilog lib:<br>Files to add to pro<br>\src\Lab4\debu<br>\src\Lab4\fsm.<br>\src\Lab4\sine | Constraint Files (*.sdc) | <- Add<br>Remove All -><br>Remove -><br>OK |

Figure 35: Adding SDC Constraints File to the Synplify Pro Project



## **XILINX**. Lab 4: Using Synplify Pro Synthesis Tool and Vivado for Debugging a Design

11. In the same dialog box, set **Files of type** to **FPGA Constraint Files**. This shows the

synplify\_1.fdc file. Select the file and click Add as shown in the following figure. Click OK.

| S                  | Add                                          | Files to I | Project      |           |                   |         | ×             |
|--------------------|----------------------------------------------|------------|--------------|-----------|-------------------|---------|---------------|
| Look in:           | proj/xcoswmktg/smitha/vivado_del             | bug/lab4   | -            | 💠 🔿       | ♠ 🖴               | :       |               |
| 💻 Comp             | Name                                         | Size       | Туре         | Date Mo   | dified $	riangle$ |         |               |
| 🚞 smitha           | 📄 synplify_1.fdc                             | 468 bytes  | s fdc File   | 5/6/16 9: | 18 AM             |         |               |
|                    |                                              | -          |              |           |                   |         |               |
| File <u>n</u> ame: | synplify_1.fdc                               |            |              |           |                   |         |               |
| Files of type:     | FPGA Constraint Files (*.fdc)                |            |              |           |                   | •       |               |
| VHDL/Verilog lib   | :                                            |            |              |           |                   | •       |               |
| Files to add to p  | oroject: (1 file(s) selected) 🗹 Use relative | paths 🖌    | Add files to | Folders   | Folder            | Options | ]             |
| ./lab4/synplify_   | 1.fdc                                        |            |              |           |                   |         | <- Add All    |
|                    |                                              |            |              |           |                   |         | <- Add        |
|                    |                                              |            |              |           |                   |         | Remove All -> |
|                    |                                              |            |              |           |                   |         | Remove ->     |
|                    |                                              |            |              |           |                   |         | ОК            |
|                    |                                              |            |              |           |                   |         | Cancel        |

Figure 36: Adding FPGA Constraints File to the Synplify Pro Project



**XILINX**<sub>• Lab</sub> 4: Using Synplify Pro Synthesis Tool and Vivado for Debugging a Design

- 12. Now, you need to set the implementation options.
- 13. Click **Implementation Options** in the **Synplify Pro** window as shown in the following figure.

| Import Run Analysis HDL-Analys                                              |  |  |  |  |
|-----------------------------------------------------------------------------|--|--|--|--|
| a maalmia almit                                                             |  |  |  |  |
| : ■ ⊕ ⊛ & ∞ @ 0 0 0 0                                                       |  |  |  |  |
| Synplify Pro®<br>Ready                                                      |  |  |  |  |
| Project Files Design Hierarchy<br>ynplify_1 : rev_1 - Xilinx Kintex7 : XC7K |  |  |  |  |
| i isynplify_1] - C:\Vivado_Debu<br>i i i i i i i i i i i i i i i i i i i    |  |  |  |  |
| VHDL     Goic Constraints (SDC)                                             |  |  |  |  |
| <ul> <li>Compiler Directive</li> <li>rev_1</li> </ul>                       |  |  |  |  |
| F                                                                           |  |  |  |  |

Figure 37: Opening Implementation Options in Synplify Pro

14. This brings up the **Implementation Options** dialog box as shown in the following figure. In the **Device** tab, set **Technology** to **Xilinx Kintex7**, **Part** to **XC7K325T**, **Package** to **FFG900** and **Speed** to **-2**. Leave all the other options at their default values. Click **OK**.

| evice Options Constraints Im                                     | plementation Results | Timing Report | High Reliability | VHD I | Implementations: |
|------------------------------------------------------------------|----------------------|---------------|------------------|-------|------------------|
| echnology:                                                       | Part                 | Package:      | Speed:           |       | rev_1            |
| ülinx Kintex7                                                    | ▼ XC7K325T           | ▼ FFG900      | ▼ -2             | -     |                  |
| Device Mapping Options                                           |                      |               |                  |       |                  |
| Option                                                           |                      |               | Value            |       |                  |
| Fanout Guide                                                     |                      |               | 10000            |       |                  |
| Disable I/O Insertion                                            |                      |               |                  |       |                  |
| Disable Sequential Optimizations                                 |                      |               |                  |       | L                |
| Update Compile Point Timing Data                                 |                      |               |                  | ▲     |                  |
| Click on an option for description<br>System Designer Board File |                      |               |                  |       |                  |
| [                                                                |                      |               |                  |       |                  |
|                                                                  |                      |               |                  |       | SYNOPSY:         |

Figure 38: Specifying Implementation Options in Synplify Pro



**XILINX** Lab 4: Using Synplify Pro Synthesis Tool and Vivado for Debugging a Design

15. You need to preserve the net names that you want to debug by putting attributes in the HDL files. These attributes are already placed in the sinegen\_demo.vhd, file of this tutorial. Open the sinegen\_demo.vhd file and inspect the lines shown.

```
-- Attributes for Synplify Pro
attribute syn_keep : boolean;
attribute syn_keep of GPIO_BUTTONS_db : signal is true;
attribute syn_keep of GPIO_BUTTONS_dly : signal is true;
attribute syn_keep of GPIO_BUTTONS_re : signal is true;
```

Figure 39: Specifying Attributes to Preserve Net Names in Synplify

16. You also can specify the MARK\_DEBUG attributes in the source HDL files to mark the signals for debug, as shown in the code snippet from singen\_demo.vhd file.

```
-- Add mark_debug attributes to show debug nets in the synthesized netlist
attribute mark_debug : string;
attribute mark_debug of GPIO_BUTTONS_db : signal is "true";
attribute mark_debug of GPIO_BUTTONS_re : signal is "true";
```

Figure 40: Add MARK\_DEBUG Attribute in HDL File

17. The symplify\_1.sdc file contains various kinds of constraints such as pin location, I/O standard, and clock definition. The symplify\_1.fdc file contains directives for the compiler. Here is where the nets of interest to us that are marked for debug are located. The attribute and the nets selected for debug are shown in the following figure.

| # Attributes that                    | are needed to mark_debug the nets that are needed to be viewed in ILA                                                                                                                                                                                                                                                   |
|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| define_attribute<br>define_attribute | <pre>-comment {Mark sinegen as black box} {v:work.sinegen} {syn_black_box} {1} -comment {Set no_prune on sinegen} {v:work.sinegen} {syn_noprune} {1} -comment {Mark entire bus for debug} {i:sinegen.sine[*]} {mark_debug} {"true"} -comment {Mark entire bus for debug} {i:sinegen.sel[*]} {mark_debug} {"true"}</pre> |

#### Figure 41: Synplify Pro Constraints in FDC Files

In the above constraints, sinegen has been defined as a black box by using the syn\_black\_box attribute. Second, the syn\_no\_prune attribute has been used so that the I/Os of this block are not optimized away. Finally, two nets, sine[20:0] and sel[1:0], have been assigned the MARK\_DEBUG attribute such that these two nets should show up in the synthesized design in Vivado IDE for further debugging. For further information on these attributes, please refer to the Synplify Pro User Manual and Synplify Pro Reference Manual.



**XILINX** Lab 4: Using Synplify Pro Synthesis Tool and Vivado for Debugging a Design

## **Step 2: Synthesize the Synplify Project**

1. Before implementing the project, you need to set the name for the output netlist file. By default, the name of the output netlist file is synplify\_1.edf. To change the name of the output file, type the following command at the Tcl command prompt:

%project -result\_file "./rev\_1/sinegen\_demo.edf"

You will use this file in Vivado IDE.

2. With all the settings in place, click the **Run** button in the left panel of the **Synplify Pro** window to start synthesizing the design.



Figure 42: Synthesize the Design in Synplify

- 3. During synthesis, status messages appear in the **Tcl Script** tab. Warning messages are expected, but there should not be any Error messages. To see detailed messages, click the **Messages** tab in the bottom left-hand corner of the Synplify Pro console.
- When synthesis completes, the output netlist is written to the file: rev\_1/sinegen\_demo.edf
   [Optional] To view the netlist select View > View Result File.
- 5. Click **File > Save All** to save the project, then click **File > Exit**.



## Step 3: Create DCPs for the Black Box Created in Synplify Pro

The black box, sinegen, created in the Synplify Pro project, contains the Direct Digital Synthesizer IP. You need to create a synthesized design for this block. To do this, create an RTL type project in Vivado IDE by following the steps outlined below.

- 1. Launch Vivado IDE.
- 2. Click Create Project. This opens up the New Project wizard. Click Next.
- 3. Under Project Name, set the project name to proj\_synplify\_netlist. Click Next.
- 4. Under Project Type, select RTL Project. Click Next.
- 5. Under Add Sources, click Add Files, navigate to the Vivado\_Debug/src/lab4 folder and select the sinegen.vhd file. Set Target Language to VHDL. Ensure that Copy sources into project box is selected. Click Next.
- 6. Click Add Files, navigate to the Vivado\_Debug/src/lab4 folder and select the sine\_high.xci, sine\_low.xci, and sine\_mid.xci files. Click Next.
- 7. Under **Default Parts**, select **Boards** and then select the **Kintex-7 KC705 Evaluation Platform** and correct version for your hardware. Click **Next**.
- 8. Under New Project Summary, ensure that all the settings are correct. Click Finish.
- 9. Once the project has been created, in Vivado Flow Navigator, under the Project Manager folder, click Settings. In the dialog box, in the left panel, click Synthesis. From the pull-down menu on the right panel, set -flatten\_hierarchy to none. Click OK.
- 10. In Vivado IDE Flow Navigator, under Synthesis Folder, click Run Synthesis.
- 11. When synthesis completes the **Synthesis Completed** dialog box appears. Select **Open Synthesized Design** and click **OK**.
- 12. Click File > Exit in Vivado IDE. When the OK to exit dialog box pops up, click OK.

## Step 4: Create a Post Synthesis Project in Vivado IDE

- 1. Launch Vivado IDE.
- 2. Click Create Project. This opens up the New Project wizard. Click Next.
- 3. Set the Project Name to proj\_synplify. Click Next.
- 4. Under Project Type, select Post-synthesis Project. Click Next.
- 5. Under Add Netlist Sources, click Add Files, navigate to the Vivado\_Debug/synopsys/rev\_1 folder, and select sinegen\_demo.edf. Click OK.



**XILINX** Lab 4: Using Synplify Pro Synthesis Tool and Vivado for Debugging a Design

- 6. Add the netlist file created in the previous section. Click **Add Files** again, navigate to the proj\_synplify\_netlist/proj\_synplify\_netlist.runs/synth1 folder and select the following file:
  - o sinegen.dcp

Add the DCP files created for the sub-module IPs in the previous section. Click **Add Directories** again, navigate to the

proj\_synplify\_netlist/proj\_synplify\_netlist.srcs/sources\_1/ip folder and select the following:

- o sine\_high
- o sine\_mid
- o sine\_low

Click **OK** in the **Add Source Files** dialog box. In the **Add Netlist Sources** dialog box ensure that **Copy Sources into Project** is selected. Click **Next**.

- 7. Click Add Files, navigate to the Vivado\_Debug/src folder, and select the sinegen\_demo\_kc705.xdc file. This file has the appropriate constraints needed for this Vivado project. Click OK in the Add Constraints File dialog box. In the Add Constraints (optional) dialog box ensure that Copy Constraints into Project is selected. Click Next.
- 8. Under **Default Part**, select **Boards** and then select **Kintex-7 KC705 Evaluation Platform** and the right version number for your hardware. Click **Next**.
- 9. Under New Project Summary, ensure that all the settings are correct and click Finish.
- 10. In the **Sources** window, ensure **sinegen\_demo.edf** is selected as the top module.



**XILINX** Lab 4: Using Synplify Pro Synthesis Tool and Vivado for Debugging a Design

## **Step 5: Add More Debug Nets to the Project**

- 1. In Vivado IDE, in the Flow Navigator, select **Open Synthesized Design** from the **Netlist Analysis** folder.
- 2. Select the **Netlist** tab in the **Netlist** window to expand Nets. Select the following nets for debugging:
  - GPIO\_BUTTONS\_c(2)
  - sine (20)

After selecting all the specified nets, right-click the nets and click **Mark Debug**, as shown in the following figure.

| Sources Netlis                                                                                                                                               | t ×                                                |                                                                                        |                    | ? _ 0 6                | Sch                |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|----------------------------------------------------------------------------------------|--------------------|------------------------|--------------------|
| 포 너                                                                                                                                                          |                                                    |                                                                                        |                    | ¢                      | +                  |
| <ul> <li>Nets (62)</li> <li>小 GPIO_B</li> <li>小 GPIO_</li> <li>小 GPIO_B</li> <li>小 GPIO_B</li> <li>小 GPIO_B</li> <li>小 GPIO_B</li> <li>小 武 GPIO_B</li> </ul> | _BUTT<br>OUTTO<br>_BUTT<br>_BUTT<br>OUTTO<br>_BUTT | ONS_c (2)<br>NS_c_i (2)<br>ONS_db (2)<br>ONS_dly_1 (2)<br>NS_dly_5 (2)<br>ONS_re_1 (2) |                    |                        |                    |
| > 师 LEDS_r<br>> 师 LEDS_r<br>> 师 sine (20<br>> 师☆ sineS                                                                                                       | n (4)<br>n_c (1)                                   |                                                                                        | Ctrl+E             |                        |                    |
| C k<br>Bus Net Properties                                                                                                                                    | <b>H</b>                                           | Unmark Debug<br>Assign to Debug Port<br>Select Driver Pin                              |                    | ? _ □ ⊡ ×<br>←   →   ✿ | anojuar<br>anojuar |
| Name:<br>Number of nets:                                                                                                                                     | я                                                  | Schematic<br>Show Connectivity<br>Show Hierarchy                                       | F4<br>Ctrl+T<br>F6 |                        |                    |
|                                                                                                                                                              | <u>▲</u>                                           | Highlight<br>Unhighlight<br>Mark<br>Unmark                                             | ►<br>Ctrl+Shift+M  |                        |                    |
| General Scalar                                                                                                                                               |                                                    | Go to Source                                                                           | F7                 |                        |                    |

Figure 43: Mark Additional Signals for Debug



3. You should be able to see all the nets that are marked for debug, as shown in the following figure.

| Tcl Console Messages Log Re    | ports Desi  | gn Runs    | Debug ×    | ? _ 🗆 🖸 |
|--------------------------------|-------------|------------|------------|---------|
| Q   素   ≑   兼   <b>∔</b>   ≓   |             |            |            | Φ.      |
| Name                           | Driver Cell | Driver Pin | Probe Type |         |
| 👻 ៉ Unassigned Debug Nets (30) |             |            |            |         |
| > Jac GPIO_BUTTONS_c (2)       | IBUF        | 0          |            |         |
| > JFS GPIO_BUTTONS_db (2)      | FDRE        | Q          |            |         |
| > JFS GPIO_BUTTONS_dly_1 (2)   | FDRE        | Q          |            |         |
| > 小☆ GPIO_BUTTONS_re_1 (2)     | FDRE        | Q          |            |         |
| 〉 -厅蛇 sine (20)                | FDRE        | Q          |            |         |
| ≻ √f☆ sineSel (2)              | FDRE        | Q          |            |         |
|                                |             |            |            |         |
|                                |             |            |            |         |
|                                |             |            |            |         |
| Debug Cores Debug Nets         |             |            |            |         |

Figure 44: Nets Added for Debug through the Synplify Pro Flow in Vivado IDE

## Running the Set up Debug Wizard

1. Click the **Set up Debug** icon in the **Debug** window or select the **Tools** menu, and select **Set up Debug**. The **Set up Debug** wizard opens.

| Tcl Console Me           | ssages Log I     | Reports | Design Runs | Debug ×       |   |
|--------------------------|------------------|---------|-------------|---------------|---|
| Q   ¥   ♦                | 🕷 🛨 🖃            |         |             |               |   |
| Name                     | Set Up Debug     | Driver  | Cell Driver | Pin Probe Typ | e |
| 🗸 🖨 Unassigned           | Debug Nets (30)  |         |             |               |   |
| > √f¤ GPIO_B             | UTTONS_c (2)     | IBUF    | 0           |               |   |
| > √f¤ GPIO_B             | UTTONS_db (2)    | FDRE    | Q           |               |   |
| > √f¤ GPIO_B             | UTTONS_dly_1 (2) | FDRE    | Q           |               |   |
| > Jr̃≋ GPIO_B            | UTTONS_re_1 (2)  | FDRE    | Q           |               |   |
| > - <b>∫</b> r¤ sine (20 | )                | FDRE    | Q           |               |   |
| > √r¤ sineSel            | (2)              | FDRE    | Q           |               |   |

#### Figure 45: Run the Set up Debug Wizard

2. Click through the wizard to create Vivado logic analyzer debug cores, keeping the default settings.

*Note*: In the *Specify Nets to Debug* dialog box, ensure that all the nets marked for debug have the same clock domain.



# Step 6: Implementing the Design and Generating the Bitstream

- 1. In the Flow Navigator, under the Program and Debug drop-down list, click Generate Bitstream.
- 2. In the **Save Project** dialog box, click **Save**.
- 3. When the Bitstream generation finishes, the **Bitstream Generation Completed** dialog box pops-up and **Open Implemented Design** is selected by default. Click **OK**.
- 4. If you get a dialog box asking to close the synthesized design before opening the implemented design, click **Yes**.
- 5. Proceed to Lab 5: Using Vivado Logic Analyzer to Debug Hardware to complete the rest of this lab.





## Lab 5: Using Vivado Logic Analyzer to Debug Hardware

## Introduction

The final step in debugging is to connect to the hardware and debug your design using the Integrated Logic Analyzer. Before continuing, make sure you have the KC705 hardware plugged into a machine.

In this step, you learn:

- How to debug the design using the Vivado® logic analyzer.
- How to use the currently supported Tcl commands to communicate with your target board (KC705).
- How to discover and correct a circuit problem by identifying unintended behaviors of the push button switch.
- Some useful techniques for triggering and capturing design data.

## **Step 1: Verifying Operation of the Sine Wave Generator**

After doing some setup work, you will use Vivado logic analyzer to verify that the sine wave generator is working correctly. Your two primary objectives are to verify that:

- All sine wave selections are correct.
- The selection logic works correctly.

## Target Board and Server Set Up

#### Connecting to the target board remotely

If you plan to connect remotely, you need to make sure that the KC705 board is plugged into a machine and you are running an hw\_server application on that machine. If you plan to connect locally, skip steps 1-5 below and go directly to the Connecting to the Target Board Locally section.

- 1. Connect the Digilent USB JTAG cable of your KC705 board to a USB port on a Windows system.
- 2. Ensure that the board is plugged in and powered on.
- 3. Power cycle the board to clear the device.
- 4. Turn DIP switch positions (pin 1 on SW13, De-bounce Enable) to the OFF position.





5. Assuming you are connecting your KC705 board to a 64-bit Windows machine and you will be running the hw\_server from the network instead of your local drive, open a cmd prompt and type the following:

<Xilinx\_Install>\Vivado\2018.x\bin\hw\_server

Leave this cmd prompt open while the hw\_server is running. Note the machine name that you are using, you will use this later when opening a connection to this instance of the hw\_server application.

#### **Connecting to the Target Board Locally**

If you plan to connect locally, ensure that the KC705 board is plugged into a Windows machine and then perform the following steps:

- 1. Connect the Digilent USB JTAG cable of your KC705 board to a USB port on a Windows system.
- 2. Ensure that the board is plugged in and powered on.
- 3. Power cycle the board to clear the device.
- 4. Turn DIP switch positions (pin 1 on SW13, De-bounce Enable) to the OFF position.

#### Using the Vivado Integrated Logic Analyzer

1. In the Flow Navigator, under Program and Debug, select Open Hardware Manager.



Figure 46: Open Hardware Manager

2. The Hardware Manager window opens. Click Open Target > Open New Target.





Lab 5: Using Vivado Logic Analyzer to Debug Hardware

| HARDWARE MANAGER - unconnected          |    |                             |          |  |  |  |  |  |
|-----------------------------------------|----|-----------------------------|----------|--|--|--|--|--|
| No hardware target is open. Open target |    |                             |          |  |  |  |  |  |
| Hardware                                | ø  | Auto Connect                |          |  |  |  |  |  |
|                                         |    | Recent Targets              | <b>•</b> |  |  |  |  |  |
|                                         |    | Available Targets on Server | > -      |  |  |  |  |  |
|                                         |    | Open New Target             |          |  |  |  |  |  |
|                                         |    |                             | N2-      |  |  |  |  |  |
| No conter                               | nt |                             |          |  |  |  |  |  |

Figure 47: Connect to a Hardware Target

- 3. The Open New Hardware Target wizard opens. Click Next.
- 4. In the **Hardware Server Settings** page, type the name of the server (or select **Local server** if the target is on the local machine) in the **Connect to** field. Click **Next**.

| 🥕 Open New Hardware Target                                                                                                                                                                                            | ×  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| Hardware Server Settings<br>Select local or remote hardware server, then configure the host name and port settings. Use Local<br>server if the target is attached to the local machine; otherwise, use Remote server. | 4  |
| Connect to: Local server (target is on local machine)                                                                                                                                                                 |    |
| Click Next to launch and/or connect to the hw_server (port 3121) application on the local machine.         ?         < Back                                                                                           | el |

Figure 48: Hardware Server Settings

Note: Depending on your connection speed, this may take about 10 to 15 seconds.

5. If there is more than one target connected, you will see multiple entries in the **Select Hardware Target** page. In this tutorial, there is only one target, as shown in the following figure. Click **Next**.





| ٨. ( | Open New H            | ardware Targ            | et           |                      |        |                                                 | ×      |
|------|-----------------------|-------------------------|--------------|----------------------|--------|-------------------------------------------------|--------|
| Se   |                       | e target from the l     |              |                      |        | ate JTAG clock (TCK)<br>lect a different target |        |
|      | Hardware <u>T</u> arg | ets                     |              |                      |        |                                                 |        |
|      | Туре                  | Name                    |              | JTAG Clock Free      | quency |                                                 |        |
|      | xilinx_tcf            | Xilinx/Port_#00         | 03.Hub_#0004 | 600000               | ~      |                                                 |        |
|      |                       |                         |              |                      |        |                                                 |        |
|      |                       |                         |              |                      |        |                                                 |        |
|      | Hardware <u>D</u> evi | c <b>es</b> (for unknow |              | nx Virtual Cable (X) |        | (IR) length)                                    |        |
|      | Name                  | ID Code                 | IR Length    |                      |        |                                                 |        |
|      | @ xc7k325t_0          | 33651093                | 6            |                      |        |                                                 |        |
|      | Hardware serve        | er: localhost:312       | 1            |                      |        |                                                 |        |
| (    | ?                     |                         | < <u>B</u>   | ack Ne               | ext >  | <u>F</u> inish                                  | Cancel |

Figure 49: Select Hardware Target





6. In the **Open Hardware Target Summary** page, click **Finish** as shown in the following figure.

| 🅕 Open New Hardward           | 🥕 Open New Hardware Target                                                                                                                   |    |  |  |  |  |  |  |
|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|----|--|--|--|--|--|--|
|                               | Open Hardware Target Summary                                                                                                                 |    |  |  |  |  |  |  |
| HLx Editions                  | <ul> <li>Hardware Server Settings:</li> <li>Server: localhost:3121</li> </ul>                                                                |    |  |  |  |  |  |  |
|                               | <ul> <li>Target Settings:         <ul> <li>Target: xilinx_tcf/Xilinx/Port_#0003.Hub_#0004</li> <li>Frequency: 6000000</li> </ul> </li> </ul> |    |  |  |  |  |  |  |
|                               |                                                                                                                                              |    |  |  |  |  |  |  |
|                               |                                                                                                                                              |    |  |  |  |  |  |  |
|                               |                                                                                                                                              |    |  |  |  |  |  |  |
|                               |                                                                                                                                              |    |  |  |  |  |  |  |
| E XILINX<br>ALL PROGRAMMABLE. | To connect to the hardware described above, click Finish                                                                                     |    |  |  |  |  |  |  |
| (?)                           | < <u>B</u> ack <u>N</u> ext > <u>Finish</u> Cance                                                                                            | el |  |  |  |  |  |  |

Figure 50: Hardware Target Summary

7. Wait for the connection to the hardware to complete. The dialog in following figure appears while hardware is connecting.

| 🍐 Open Hardware Target |                    | ×      |
|------------------------|--------------------|--------|
| Connecting to server   |                    |        |
|                        |                    |        |
|                        | <u>B</u> ackground | Cancel |

Figure 51: Open Hardware Target





After the connection to the hardware target is made, the Hardware window appears as in the following figure.

**Note**: The **Hardware** tab in the **Debug** view shows the hardware target and XC7K325T device detected in the JTAG chain.

| Hardware                                                                                                    | ? _ 🗆 🗹        | i × |
|-------------------------------------------------------------------------------------------------------------|----------------|-----|
| $Q \mid \underbrace{\star} \mid \diamondsuit \mid \varnothing \mid \models \mid \gg \mid \blacksquare \mid$ |                | ٥   |
| Name                                                                                                        | Status         |     |
| ✓ Iocalhost (1)                                                                                             | Connected      |     |
| ✓ ✓ ✓ ✓ xilinx_tcf/Xilinx/Port_#0003.Hu                                                                     | Open           |     |
| ✓ ⊕ xc7k325t_0 (1)                                                                                          | Not programmed |     |
| 壅 XADC (System Monitor)                                                                                     |                |     |
|                                                                                                             |                |     |
|                                                                                                             |                |     |
|                                                                                                             |                |     |
|                                                                                                             |                |     |
|                                                                                                             |                |     |
|                                                                                                             |                |     |
|                                                                                                             |                |     |

#### Figure 52: Active Target Hardware

8. Next, program the XC7K325T device using the previously created .bit bitstream by right-clicking the **XC7K325T** device and **selecting Program Device** as shown in the following figure.





| Hardware                                |      |                                    | ? _ 🗆      | ц× |        |  |
|-----------------------------------------|------|------------------------------------|------------|----|--------|--|
| Q   素   ♠   ∅   ▶   ≫                   |      |                                    |            | ٥  |        |  |
| Name                                    |      | Status                             |            |    |        |  |
| <ul> <li>Iocalhost (1)</li> </ul>       |      | Connected                          |            |    |        |  |
| ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ | 3.Hu | Open                               |            |    |        |  |
| <ul> <li></li></ul>                     | Ha   | rdware Device F                    | Properties |    | Ctrl+E |  |
|                                         | Pro  | gram Device                        |            |    |        |  |
| c                                       |      | ify Device<br>fresh Device         |            |    | 13     |  |
|                                         |      | d Configuration<br>ot from Configu | -          |    |        |  |
| Hardware Device Properties              |      | Program BBR Key<br>Clear BBR Key   |            |    |        |  |
|                                         | Pro  | gram eFUSE R                       | egisters   |    |        |  |
| <pre>     xc7k325t_0 </pre>             | Exp  | Export to Spreadsheet              |            |    |        |  |
|                                         |      |                                    |            |    |        |  |

Figure 53: Program Active Target Hardware

9. In the **Program Device** dialog box verify that the .bit and .ltx files are correct for the lab that you are working on and click **Program** to program the device as shown in the following figure.

| 🔥 Program Device                                                                                                                                                                                            |                                                                               | ×      |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|--------|--|--|--|--|
| Select a bitstream programming file and download it to your hardware device. You can optionally select a debug probes file that corresponds to the debug cores contained in the bitstream programming file. |                                                                               |        |  |  |  |  |
| Bitstre <u>a</u> m file:                                                                                                                                                                                    | C://ivado_Debug/2017.1/proj_netlist/proj_netlist.runs/impl_1/sinegen_demo.bit | 0      |  |  |  |  |
| Debu <u>q</u> probes file:                                                                                                                                                                                  | C:/Vivado_Debug/2017.1/proj_netlist/proj_netlist.runs/impl_1/sinegen_demo.ltx | 8      |  |  |  |  |
| ✓ Enable end of st                                                                                                                                                                                          | artup check                                                                   |        |  |  |  |  |
| ?                                                                                                                                                                                                           | <u>P</u> rogram                                                               | Cancel |  |  |  |  |

Figure 54: Select Bitstream File to Download for Lab 1



**CAUTION!** The file paths of the bitstream and debug probes to be programmed will be different for different labs. Ensure that the relative paths are correct.

*Note*: Wait for the program device operation to complete. This may take few minutes.

10. Ensure that an ILA core was detected in the Hardware panel of the Debug view.





Lab 5: Using Vivado Logic Analyzer to Debug Hardware

|            | ? _ 🗆                           | с×                                        |
|------------|---------------------------------|-------------------------------------------|
|            |                                 | ۰                                         |
| Status     |                                 |                                           |
| Connected  |                                 |                                           |
| Open       |                                 |                                           |
| Programmed |                                 |                                           |
|            |                                 |                                           |
| Oldle      |                                 |                                           |
|            |                                 |                                           |
|            |                                 |                                           |
|            |                                 |                                           |
|            | Connected<br>Open<br>Programmed | Status<br>Connected<br>Open<br>Programmed |

Figure 55: ILA Core Detection

11. The Integrated Logic Analyzer dashboard opens, as shown in the following figure.



Figure 56: Vivado Integrated Logic Analyzer window





## Verifying Sine Wave Activity

12. In the **Hardware** window, click **Run Trigger Immediate** to trigger and capture data immediately as shown in shown in the following figure.



Figure 57: Run Trigger Immediate Button

13. In the **Waveform** window, verify that there is activity on the 20-bit sine signal as shown in the following figure.

| Waveform - hw_ila_1                 |                  |               |              |                  |              |     | ? _ 🗆 > |  |
|-------------------------------------|------------------|---------------|--------------|------------------|--------------|-----|---------|--|
| Q   <b>+</b>   <b>-</b>   ♂   ▶   ≫ | <b>G</b>         | Q 🔀 📲 🛛       | <b>∢ )</b> ► | nt   tr   +F   F | ⊨   ⇒ '   !⊶ |     | ¢       |  |
| ILA Status: Idle                    | ILA Status: Idle |               |              |                  |              |     |         |  |
| Name                                | Value            |               | 20           | 90<br>           | 400          | 600 | 800     |  |
| UNT_EAT                             | 0                |               |              |                  |              |     |         |  |
| > 📢 GPIO_BUTTONS_db[1:0]            | 0                |               |              |                  | 0            |     |         |  |
| > 📢 GPIO_BUTTONS_dly[1:0]           | 0                |               |              |                  | 0            |     |         |  |
| > 🔣 GPIO_BUTTONS_IBUF[1:0]          | 0                |               |              |                  | 0            |     |         |  |
| > SPIO_BUTTONS_re[1:0]              | 0                |               |              |                  | 0            |     |         |  |
| > 🔣 U_SINEGEN/sel[1:0]              | 0                |               |              |                  | 0            |     |         |  |
| > V_SINEGEN/sine[19:0]              | 05133            |               |              |                  |              |     |         |  |
|                                     |                  |               |              |                  |              |     |         |  |
|                                     |                  |               |              |                  |              |     |         |  |
|                                     |                  | Updated at: 2 | 017-Mar-     | 16 14:59:13      |              |     |         |  |

Figure 58: Output Sine Wave Displayed in Digital Format

#### Displaying the Sine Wave

14. Right-click **U\_SINEGEN/sine[19:0]** signals, and select **Waveform Style > Analog** as shown in the following figure.



**TIP:** The waveform does not look like a sine wave. This is because you must change the radix setting from Hex to Signed Decimal, as described in the following subsection.





| Waveform - hw_ila_1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       | ? _ 🗆 ×                          |  |  |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------------------------------|--|--|--|--|--|--|--|
| Q + - & > = B @ Q X + I H H ± ± + F F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |                                  |  |  |  |  |  |  |  |
| ILA Status:Idle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       | 1,023                            |  |  |  |  |  |  |  |
| Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Value | a<br>0                           |  |  |  |  |  |  |  |
| UNT_EAT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0     |                                  |  |  |  |  |  |  |  |
| > Mage GPIO_BUTTONS_db[1:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0     | 0                                |  |  |  |  |  |  |  |
| > Mage GPIO_BUTTONS_dly[1:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0     | 0                                |  |  |  |  |  |  |  |
| > M GPIO_BUTTONS_IBUF[1:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0     | 0                                |  |  |  |  |  |  |  |
| Reference > Sector S | 0     |                                  |  |  |  |  |  |  |  |
| > 🔣 U_SINEGEN/sel[1:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0     |                                  |  |  |  |  |  |  |  |
| > 🍕 U_SINEGEN/sine[19:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 05133 |                                  |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                                  |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | < >>  | Updated at: 2017-Mar-16 14:59:13 |  |  |  |  |  |  |  |

Figure 59: Output Sine Wave Displayed in Analog Format - High Frequency 1

15. Right-click **U\_SINEGEN/sine[19:0]** signals, and select **Radix > Signed Decimal**.

You should now be able to see the high frequency sine wave as shown in the following figure instead of the square wave.

| Waveform - hw_ila_1                 |          | ? _ D X                          |  |  |  |  |  |
|-------------------------------------|----------|----------------------------------|--|--|--|--|--|
| Q   <b>+</b>   <b>−</b>   ♂   ▶   ≫ | <b>e</b> | Q X <b>4 1 1 1 1 1 1 1 1 1 1</b> |  |  |  |  |  |
| ILA Status: Idle                    |          |                                  |  |  |  |  |  |
| Name                                | Value    | 0                                |  |  |  |  |  |
| UNT_EAT                             | 0        |                                  |  |  |  |  |  |
| > 💐 GPIO_BUTTONS_db[1:0]            | 0        |                                  |  |  |  |  |  |
| > 💐 GPIO_BUTTONS_dly[1:0]           | 0        | • •                              |  |  |  |  |  |
| > 📲 GPIO_BUTTONS_IBUF[1:0]          | 0        | • • •                            |  |  |  |  |  |
| > 📲 GPIO_BUTTONS_re[1:0]            | 0        | 0                                |  |  |  |  |  |
| > 10 U_SINEGEN/sel[1:0]             | 0        |                                  |  |  |  |  |  |
| > 崎 U_SINEGEN/sine[19:0]            | 20787    |                                  |  |  |  |  |  |
|                                     |          |                                  |  |  |  |  |  |
|                                     |          | Updated at: 2017-Mar-16 14:59:13 |  |  |  |  |  |

Figure 60: Output Sine Wave Displayed in Analog Format - High Frequency 2

## Correcting Display of the Sine Wave

To view the mid, and low frequency output sine waves, perform the following steps:

16. Cycle the sine wave sequential circuit by pressing the GPIO\_SW\_E push button as shown in the following figure.





Lab 5: Using Vivado Logic Analyzer to Debug Hardware



Figure 61: Sine Wave Sequencer Push Button

17. Click **Run Trigger Immediately** again to see the new sine selected sine wave. You should see the mid frequency as shown in the following figure. Notice that the sel signal also changed from 0 to 1 as expected.

| Waveform - hw_ila_1        |                 | ? _ 🗆 X                                                             |  |  |  |  |  |  |
|----------------------------|-----------------|---------------------------------------------------------------------|--|--|--|--|--|--|
| Q + - V > 2                | 📕 🕞 🔍 🛛         | Q,   X,   ■             ±   ±   +     =   =   =   =   =   =   =   = |  |  |  |  |  |  |
| ILA Status:Idle            | ILA Status:Idle |                                                                     |  |  |  |  |  |  |
| Name                       | Value           |                                                                     |  |  |  |  |  |  |
| UNT_EAT                    | 0               |                                                                     |  |  |  |  |  |  |
| > 💐 GPIO_BUTTONS_db[1:0]   | 0               | 0                                                                   |  |  |  |  |  |  |
| > 💐 GPIO_BUTTONS_dly[1:0]  | 0               |                                                                     |  |  |  |  |  |  |
| > 💐 GPIO_BUTTONS_IBUF[1:0] | 0               |                                                                     |  |  |  |  |  |  |
| > 📲 GPIO_BUTTONS_re[1:0]   | 0               |                                                                     |  |  |  |  |  |  |
| > 📲 U_SINEGEN/sel[1:0]     | 1               | 1                                                                   |  |  |  |  |  |  |
| > ₱¥ U_SINEGEN/sine[19:0]  | -83150          |                                                                     |  |  |  |  |  |  |
|                            |                 | Updated at: 2017-Mar-16 15:02:38                                    |  |  |  |  |  |  |

Figure 62: Output Sine Wave Displayed in Analog Format - Mid Frequency





18. Repeat step 17 and 18 to view other sine wave outputs.



Figure 63: Output Sine Wave Displayed in Analog Format - Low Frequency

| Waveform - hw_ila_1                 |       | ? _ 🗆 ×                                                                                                   |
|-------------------------------------|-------|-----------------------------------------------------------------------------------------------------------|
| Q   <b>+</b>   <b>−</b>   ♂   ▶   ≫ | 📑 🔁   | 2 2 4 1 4 1 4 1 4 1 4 1 4 4 1 4 4 1 4 4 1 4 4 1 4 4 1 4 4 1 4 4 1 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 |
| ILA Status:Idle                     |       | 1,023                                                                                                     |
| Name                                | Value | 0<br>0 1 200 1 200 1 200 1 2 2 2 2 2 2 2 2 2                                                              |
| Ve DONT_EAT                         | 0     |                                                                                                           |
| > 😽 GPIO_BUTTONS_db[1:0]            | 0     |                                                                                                           |
| > 😽 GPIO_BUTTONS_dly[1:0]           | 0     |                                                                                                           |
| > 💐 GPIO_BUTTONS_IBUF[1:0]          | 0     |                                                                                                           |
| > Mage: GPIO_BUTTONS_re[1:0]        | 0     |                                                                                                           |
| > 📲 U_SINEGEN/sel[1:0]              | 3     | 3                                                                                                         |
| > 🍕 U_SINEGEN/sine[19:0]            | 75777 |                                                                                                           |
|                                     |       |                                                                                                           |
|                                     | <     | Updated at: 2017-Mar-16 15:03:56                                                                          |

Figure 64: Output Sine Wave Displayed in Analog Format - Mixed Frequency

**Note**: As you sequence through the sine wave selections, you may notice that the LEDs do not light up in the expected order. You will debug this in the next section of this tutorial. For now, verify for each LED selection, that the correct sine wave displays. Also, note that the signals in the **Waveform** window have been re-arranged in the previous three figures.





# Step 2: Debugging the Sine Wave Sequencer State Machine (Optional)

As you corrected the sine wave display, the LEDs might not have lit up in sequence as you pressed the Sine Wave Sequencer button. With each push of the button, there should be a single, cycle-wide pulse on the GPIO\_BUTTONS\_re[1] signal. If there is more than one, the behavior of the LEDs becomes irregular. In this section of the tutorial, use Vivado logic analyzer to probe the sine wave sequencer state machine, and to view and repair the root cause of the problem.

Before starting the actual debug process, it is important to understand more about the sine wave sequencer state machine.

## Sine Wave Sequencer State Machine Overview

The sine wave sequencer state machine selects one of the four sine waves to be driven onto the sine signal at the top-level of the design. The state machine has one input and one output. The following figure shows the schematic elements of the state machine. Refer to this diagram as you read the following description and as you perform the steps to view and repair the state machine glitch.

- The input is a scalar signal called "button". When the button input equals "1", the state machine advances from one state to the next.
- The output is a 2-bit signal vector called "Y", and it indicates which of the four sine wave generators is selected.

The input signal button connects to the top-level signal GPIO\_BUTTONS\_re[1], which is a low-to-high transition indicator on the Sine Wave Sequencer button. The output signal Y connects to the top-level signal, sineSel, which selects the sine wave.



Figure 65: Sine Wave Sequencer Button Schematic

## Viewing the State Machine Glitch

You cannot troubleshoot the issue identified above by connecting a debug probe to the GPIO\_BUTTON [1] input signal itself. The GPIO\_BUTTON [1] input signal is a PAD signal that is not directly accessible from the FPGA fabric. Instead, you must trigger on low-to-high transitions (rising edges) on the GPIO\_BUTTON\_IBUF signal, which is connected to the output of the input buffer of the GPIO\_BUTTON [1] input signal.





As described earlier, the glitch reveals itself as multiple low-to-high transitions on the GPIO\_BUTTONS\_1\_IBUF signal, but it occurs intermittently. Because it could take several button presses to detect it, you will now set up the Vivado logic analyzer tool to Repetitive Trigger Run Mode. This setting makes it easier to repeat the button presses and look for the event in the Waveform viewer.

- 1. Open the **Debug Probes** window if not already open by selecting **Window > Debug Probes** from the Vivado main menu.
- 2. In the **ILA Core Properties** window scroll down to the link marked **To view editable ILA Properties: Open ILA Dashboard** and set the following:
  - a. Trigger Mode to BASIC\_ONLY
  - b. Capture Mode to BASIC
  - c. Window Data Depth to 1024
  - d. Trigger position to 512
  - e. Press the + button in the Trigger Setup window and add probe GPIO\_BUTTONS\_IBUF\_1.
     Change the Value field to RX by selecting the value RX in the Value field, as shown in the following figure.

| Waveform - hw_ila_1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                 |                                              |          |                 |                      |             |               |       | ? _ 🗆 ×                         |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|----------------------------------------------|----------|-----------------|----------------------|-------------|---------------|-------|---------------------------------|
| Q + - B > 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | » 📕 📴 🛛                                         | (  32   <del>+</del>     <b>H</b>   <b>H</b> | 1        | :   ±r   +Γ   Γ | •   •   •   •        |             |               |       | 0                               |
| ILA Status: Idle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                 |                                              |          |                 |                      |             |               |       | 1,023 ^                         |
| Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Value                                           | <mark>2</mark><br> •                         | 200      |                 | 400                  | eoo         |               | 800   | l                               |
| 1 DONT_EAT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0                                               |                                              |          |                 |                      |             |               |       |                                 |
| GPIO_BUTTONS_db[1:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0                                               |                                              |          |                 | 0                    |             |               |       |                                 |
| GPIO_BUTTONS_dly[1:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                               | <u></u>                                      |          |                 | 0                    |             |               |       |                                 |
| > Variable Content of the second s | 0<br>0                                          | <u>}</u>                                     |          |                 | 0                    |             |               |       |                                 |
| > WU_SINEGEN/sel[1:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 3                                               |                                              |          |                 | 3                    |             |               |       |                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                 |                                              |          |                 |                      |             |               |       |                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                 |                                              |          |                 |                      |             |               |       |                                 |
| U_SINEGEN/sine[19:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | -183094                                         |                                              |          |                 |                      |             |               |       | ~ I I'                          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                 |                                              |          |                 |                      |             |               |       |                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                 | Updated at: 2017-Max                         | -16      | 15.00.22        |                      |             |               |       |                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | < >>                                            | <                                            | - 10     | 13.00.22        |                      |             |               |       | >                               |
| Cottings has its 4 and 5 factor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | a huu ila d                                     | ? _                                          |          | Trianan Catur   | have the start start | Cantura Cat | un huu ile d  |       | 0 5                             |
| Settings - hw_ila_1 × Status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | s - hw_ila_1                                    | ? <u> </u>                                   |          | Trigger Setup - |                      | Capture Set | up - nw_lia_1 |       | ? _ 🗆                           |
| Trigger Mode Settings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                 |                                              |          | Q + -           | Ð                    |             |               |       |                                 |
| Trigger mode: BASIC_ONL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | LY V                                            |                                              |          | Name            |                      | Operator    | Radix         | Value | Port                            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                 |                                              |          | GPIO_BUTTON     | IS_IBUF[1:0]         | == *        | [B] •         | XX    | <ul> <li>probe3[1:0]</li> </ul> |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                 |                                              |          |                 |                      |             |               |       |                                 |
| Capture Mode Settings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                 |                                              |          |                 |                      |             |               |       |                                 |
| Capture mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ALWAYS 🗸                                        |                                              | н        |                 |                      |             |               |       |                                 |
| Number of windows:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1 [1 - 1024]                                    |                                              | н        |                 |                      |             |               |       |                                 |
| Window data depth:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | <b>1024                                    </b> |                                              | н        |                 |                      |             |               |       |                                 |
| Trigger position in window:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <b>512</b> [0 - 1023]                           |                                              |          |                 |                      |             |               |       |                                 |
| General Settings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                 |                                              |          |                 |                      |             |               |       |                                 |
| Refresh rate: 500                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ms                                              |                                              | <b>.</b> | <               |                      |             |               |       | >                               |

Figure 66: Trigger Setup Window





| Trigger Setup - hw_ila_1 $\times$ | Capture Setu | p - hw_ila_1 |        | ? _ 🗆         |
|-----------------------------------|--------------|--------------|--------|---------------|
| Q + - D                           |              |              |        |               |
| Name                              | Operator     | Radix        | Value  | Port          |
| GPIO_BUTTONS_IBUF[1:0]            | == •         | [B] •        | XX 🗸   | probe3[1:0]   |
|                                   |              | Value: OK    | Cancel |               |
| < 🖂                               |              |              |        | $\rightarrow$ |

Figure 67: Setting Trigger Conditions

**CAUTION!** For different labs the GPIO\_BUTTONS\_IBUF may show up differently. This may show up as two individual bits or two bits lumped together in a bus. Ensure that you are using bit 1 of this bus to set up your trigger condition. For example in case of a two-bit bus, you will set the **Value** field in the **Compare Value** dialog box to **RX**.

3. Select Enable Auto Re-trigger mode on the ILA debug core as shown below.







#### Figure 68: Enable Auto Re-trigger



**CAUTION!** The **ILA properties** window may look slightly different for different labs.

When you issue a **Run Trigger** or a **Run Trigger Immediate** command after setting the **Auto Retrigger** mode, the ILA core does the following repetitively until you disable the **Auto Retrigger** mode option.

- Arms the trigger.
- Waits for the trigger.
- Uploads and displays waveforms.
- 4. On the KC705 board, press the Sine Wave Sequencer button until you see multiple transitions on the GPIO\_BUTTONS\_1\_IBUF signal (this could take 10 or more tries). This is a visualization of the glitch that occurs on the input. An example of the glitch is shown in the following two figures.



**CAUTION!** You may have to repeat the previous two steps repeatedly to see the glitch. Once you can see the glitch, you may observe that the signal glitches are not at exactly the same location as shown in the figure below.





| hw_la_data_1.wdg* ር ତ ×                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |        |                |     |     |  |     |     |         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|-----|-----|--|-----|-----|---------|
| <u>→</u> ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |        |                |     | _   |  |     |     | 1,024 - |
| 🚆 Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Value  | ۰ <sub>۱</sub> | 200 | 400 |  | 600 | 800 | 1.0     |
| TH M U_SINEGEN/sel[1:0]     The sel sel sel sel sel sel sel sel sel se                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 3      |                | 0   |     |  | 3   |     |         |
| 🔍 🖪 📲 GPIO_BUTTONS_re[1:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0      |                | 0   |     |  | 0   |     |         |
| 🔍 🖪 📲 GPIO_BUTTONS_dly[1:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 2      |                | 0   |     |  | 2   |     |         |
| ▲ GPIO_BUTTONS_db[1:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0      |                |     |     |  |     |     |         |
| I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I           I | 105321 |                |     |     |  |     |     |         |
| 솔                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |        |                |     |     |  |     |     |         |
| 🔐 🖽 🖬 GPIO_BUTTONS_IBUF[0:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0      |                |     |     |  |     |     |         |
| GPIO_BUTTONS_IBUF_1[1:1]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1      |                | Ó   |     |  | 1   |     |         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |        |                |     |     |  |     |     |         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |        |                |     |     |  |     |     | -       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ۰ ۲    | •              |     |     |  |     |     | - F     |

#### Figure 69: GPIO\_BUTTONS\_BUF1 Signal Glitch



Figure 70: GPIO Buttons\_1\_re Signal Glitch magnified





#### Fixing the Signal Glitch and Verifying the Correct State Machine Behavior

The multiple transition glitch or "bounce" occurs because the mechanical button is making and breaking electrical contact just as you press it. To eliminate this signal bounce, a "de-bouncer" circuit is required.

- 1. Enable the de-bouncer circuit by setting DIP switch position on the KC705 board (labeled Debounce Enable in Figure 1: KC705 Board Showing Key Components) to the **ON** or **UP** position.
- 2. Enable the **Auto-Retrigger** mode on the ILA debug core and click **RunTrigger** on the ILA core, and:
  - Ensure that you no longer see multiple transitions on the GPIO\_BUTTON\_re[1] signal on a single press of the Sine Wave Sequencer button.
  - Verify that the state machine is working correctly by ensuring that the sineSel signal transitions from 00 to 01 to 10 to 11 and back to 00 with each successive button press.

#### Verifying the VIO Core Activity (Only applicable to Lab 3)

1. From the **Program and Debug** section in **Flow Navigator**, click **Open Hardware Manager**.



Figure 71: Open Hardware Manager

The Hardware Manager window opens.





2. Click Open a new hardware target.



Figure 72: Connect to a New Hardware Target

- 3. The Open New Hardware Target wizard opens. Click Next.
- 4. In the **Hardware Server Settings** page, type the name of the server (or select **Local server** if the target is on the local machine) in the **Connect to** field.
- 5. Ensure that you are connected to the right target by selecting the target from the **Hardware Targets** page. If there is only one target, that target is selected by default. Click **Next**.
- 6. In the Set Hardware Target Properties page, click Next.
- 7. In the **Open Hardware Target Summary** page, verify that all the information is correct, and click **Finish**.
- 8. Program the device by selecting and right-clicking the device in the **Sources** window and then selecting **Program Device**.





| Hardware                     |                         |                                       | ? _ 🗆        | ц× |        |
|------------------------------|-------------------------|---------------------------------------|--------------|----|--------|
| Q   素   ⊜   ∅   ▶   ≫        |                         |                                       |              | ۰  |        |
| Name                         |                         | Status                                |              |    |        |
| Y localhost (1)              |                         | Connected                             |              |    |        |
| ✓                            | .Hu                     | Open                                  |              |    |        |
| ✓ ⊕ xc7k325t_0 (1)           | Har                     | dware Device P                        | roperties    |    | Ctrl+E |
|                              | Prog                    | gram Device                           |              |    | N      |
| c                            |                         | Verify Device                         |              |    |        |
|                              |                         | Refresh Device                        |              |    |        |
|                              | Add                     | Configuration I                       | Memory Devic | ce |        |
|                              | Boo                     | Boot from Configuration Memory Device |              |    |        |
|                              | Prog                    | gram BBR Key.                         |              |    |        |
| Hardware Device Properties   | Clear BBR Key           |                                       |              |    |        |
|                              | Program eFUSE Registers |                                       |              |    |        |
| <pre>     xc7k325t_0  </pre> | Exp                     | ort to Spreadsh                       | eet          |    |        |
|                              |                         |                                       |              |    |        |

Figure 73: Program FPGA

9. In the **Program Device** dialog box, ensure that the bit file to be programmed is correct. Click **OK**.

| 🔥 Program Device                                       |                                                                                                                                                                               |
|--------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                        | ramming file and download it to your hardware device. You can optionally select a debug probes file debug cores contained in the bitstream programming file.                  |
| Bitstre <u>a</u> m file:<br>Debu <u>a</u> probes file: | C:/Vivado_Debug/2017.1/proj_hdl_vio/proj_hdl_vio.runs/impl_1/sinegen_demo_inst_vio.bit C:/Vivado_Debug/2017.1/proj_hdl_vio/proj_hdl_vio.runs/impl_1/sinegen_demo_inst_vio.ltx |
| ✓ Enable end of st                                     | artup check                                                                                                                                                                   |
| ?                                                      | Program Cancel                                                                                                                                                                |

Figure 74: Program Device with the sinegen\_demo\_inst\_vio.bit File

10. After the FPGA device is programmed, you see the VIO and the ILA core in the **Hardware** window.







Figure 75: The ILA and VIO Cores in the Hardware Window





You now have a debug dashboard for the ILA core as shown in the following figure.

| hw.               | <u>/_ila_1</u>                                                                                                                                                                                                                                                     |                                     | ? 🗆 🖒 X |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|---------|
|                   | Waveform - hw_ila_1                                                                                                                                                                                                                                                |                                     | ? _ 🗆 × |
| suo               |                                                                                                                                                                                                                                                                    |                                     | 0       |
| Dashboard Options | ILA Status:Idle                                                                                                                                                                                                                                                    |                                     | ^       |
| hboar             |                                                                                                                                                                                                                                                                    | 30                                  | 70      |
| Das               | > Md GPIO_BUTTONS_dV(1:0)<br>> Md GPIO_BUTTONS_dV(1:0)<br>> Md GPIO_BUTTONS_re=(1:0)<br>\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\                                                                                                                                       |                                     | ``      |
|                   | Settings - hw_ila_1 Status - hw_ila_1 × ? _ D                                                                                                                                                                                                                      | hw_ila_1 × Capture Setup - hw_ila_1 | ? _ 🗆   |
|                   |                                                                                                                                                                                                                                                                    |                                     |         |
|                   | Core status          Idle       Pre-Trigger       Walting for Trigger       Post-Trigger       Full         Capture status       Window 1 of 1       Window sample 0 of 1024       Total sample 0 of 1024         Idle       Idle       Idle       Idle       Idle | Press the 🕇 button to add probes.   |         |

Figure 76: ILA Core and VIO Core Dashboards

11. Click **Run Trigger Immediate** to capture the data immediately.



Figure 77: Run Trigger Immediate

www.xilinx.com





- 12. Make sure that there is activity on the sine [19:0] signal.
- 13. Select the sine signal in the **Waveform** window, right-click and select **Waveform Style > Analog**.
- 14. Select the sine signal in the **Waveform** window again, right-click and select **Radix > Signed Decimal**. You should be able to see the sine wave in the **Waveform** window.



Figure 78: Sine Wave after Modifying the Properties of the sine [19:0] Signal

15. Instead of using the GPIO\_SW push button to cycle through each different sine wave output frequency, you are going to use the virtual "push\_button\_vio" toggle switch from the VIO core.





16. You can now customize the ILA dashboard options to include the VIO window. This allows you to toggle the VIO output drivers and observe the impact on the ILA waveform window all in one dashboard. Slide out the **Dashboard Options** window.

| hw                       | _ila_1                                              |    |
|--------------------------|-----------------------------------------------------|----|
|                          | Waveform - hw_ila_1                                 |    |
| ions                     | Q   +   −   &   ▶   ≫                               |    |
| d Opt                    | ILA Status:Idle                                     |    |
| <b>Dashboard Options</b> | Name                                                | Va |
| Dash                     | > ♥ GPIO_BUTTONS_dly[1:0] > ♥ GPIO_BUTTONS_dly[1:0] |    |
| 6                        | GPIO_BUTTONS_re_1[1:0]                              |    |
| S                        | how Dashboard Options                               |    |
|                          | > M sine[19:0]                                      |    |
|                          | > 🔣 sineSel[1:0]                                    |    |
|                          |                                                     |    |
|                          |                                                     | <  |
|                          | Settings - hw_ila_1 Status - hw_ila_1               |    |
|                          | 🖈   🕨   🌭   📕   85                                  |    |

Figure 79: Invoking Dashboard Options





17. Add the VIO window to the ILA dashboard by selecting hw\_vio\_1.



Figure 80: Dashboard Options Adding VIO

Note: The ILA dashboard now contains the VIO window as well.





18. Adjust the **Trigger Setup – hw\_ila\_1** window and the **hw\_vio\_1** window so that they are side by side as shown in the following figure.



Figure 81: ILA Basic Trigger Window and VIO Window Adjustment

- 19. In the **hw\_vio\_1** window, select the "+" button, and select all the probes under hw\_vio\_1.
- 20. Click **OK**.

*Note*: The initial values of all the probes.





| Waveform - hw_ila_1                                    |                    |                           |                       |                                       |                         |              |     |
|--------------------------------------------------------|--------------------|---------------------------|-----------------------|---------------------------------------|-------------------------|--------------|-----|
| Q + - ♂ ► » =                                          | 🕞 🔍                | Q.   X:   <b>+</b> ⊺   I4 | N   1≜   ±r   +Γ   Γ  | •   •F   I=                           |                         |              |     |
| ILA Status:Idle                                        |                    |                           |                       |                                       |                         |              |     |
| Name                                                   | Value              | 0,,,,,,,,,,,              | 200                   | 400                                   |                         | 600          | 800 |
| > GPIO_BUTTONS_dly[1:0]                                | 0<br>0             | <u></u>                   |                       |                                       | )                       |              |     |
| > \$ GPIO_BUTTONS_dly[1:0] > \$ GPIO_BUTTONS_re_1[1:0] | 0                  |                           |                       |                                       | )                       |              |     |
| ₩ push_button_reset_1                                  | 0                  |                           |                       |                                       |                         |              |     |
| ₩ push_button_vio                                      | 0                  |                           |                       | ΛΛ                                    | Λ                       |              | η η |
| > 🍣 sine[19:0]                                         | -23169             |                           |                       | $\left( \left  \right\rangle \right)$ | /                       |              |     |
| > 📲 sineSel[1:0]                                       | 0                  | (                         |                       |                                       | )                       |              |     |
|                                                        |                    |                           |                       |                                       |                         |              |     |
|                                                        | < >>               | Updated at: 2017-M        | ar-17 11:25:19        |                                       |                         |              |     |
| Settings - hw_ila_1 Status - hw_ila_                   | 1 Triagor Sotu     | p-hw × ? _ □              | hw_vio_1 × Captu      | ıre Setup - hw                        | ila 1                   |              |     |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $ | i ingger setu      | p-nw × r _ L              |                       |                                       | _114_1                  |              |     |
|                                                        |                    |                           |                       |                                       |                         |              |     |
|                                                        |                    |                           |                       |                                       | ļ                       | Add Probes   | ×   |
|                                                        |                    |                           |                       |                                       |                         |              | ¢   |
| Press the 🕂 bu                                         | tton to add probes |                           |                       | Search:                               | <b>λ</b> -              |              |     |
|                                                        |                    |                           |                       | Probes for                            |                         | 5)           | ~   |
|                                                        |                    |                           |                       | ~ ੰ hw_v                              |                         |              |     |
|                                                        |                    |                           | L                     | _                                     | DONT_EAT                |              |     |
|                                                        |                    |                           |                       |                                       | GPIO_BUTT<br>oush_butto | FONS_re[1:1] |     |
|                                                        |                    |                           |                       | _                                     | oush_butto              | n vio 1      |     |
| [LL NAME=~"U ILA"}]                                    |                    |                           |                       |                                       | sineSel_1[1             |              | _   |
| <pre>sxc7k325t_0] -filter {CELL_NAME=<br/>;:19</pre>   | ~"U_ILA"}]]        |                           |                       |                                       |                         |              |     |
| :19<br>!/proj_hdl_vio/proj_hdl_vio.hw/bac              | kup/hw_ila_dat     | a_1.ila. Use Tcl com      | mand 'import_hw_ila_d | la                                    |                         |              | u   |

Figure 82: VIO Add Probes Window





21. Note the values on all probes in the **hw\_vio\_1** window.



Figure 83: VIO Probes Added to hw\_vio\_1 Window





22. Set the push\_button\_reset output probe by right-clicking **push\_button\_reset** and select **Toggle Button**.

This will toggle the output driver from logic from '0' to '1' to '0' as you click. It is similar to the actual push button behavior, though there is no bouncing mechanical effect as with a real push button switch.

| hw_vio_1 × Capture Setur | o - hw_ila_1   |            |           |              | ? _ 🗆      |
|--------------------------|----------------|------------|-----------|--------------|------------|
| Q   ¥   €   +   -        |                |            |           |              |            |
| Name                     | Value          | Activity   | Direction | VIO          |            |
| Ъ DONT_EAT               | [B] 0          |            | Input     | hw_vio_1     |            |
| BUTTONS_re[1:1]          | [B] 0          |            | Input     | hw_vio_1     |            |
| ∿a push_button_rese*     | (D) 0 -        |            | 0.4.4     | hw_vio_1     |            |
| ∿a push_button_vio_      | Debug Probe    | Properties | Ctrl+E    | hw_vio_1     |            |
| > 🐌 sineSel_1[1:0] 🔹     | Text           |            |           | hw_vio_1     |            |
|                          | Active-High B  | utton      |           |              |            |
|                          | Active-Low B   | utton      |           |              |            |
|                          | Toggle Buttor  | n          | G         |              |            |
|                          | Radix          |            | 6         |              | ? _ 🗆      |
| _                        | Rename         |            |           |              |            |
|                          | Name           |            | +         |              | 1          |
|                          | Remove         |            | Delete    |              |            |
| nd 'import_hw_ila_da     | Export to Spre | eadsheet   |           | Data menu it | em to impo |

Figure 84: Toggle the push\_button\_reset Signal

The **Value** field for push\_button\_reset is highlighted.

23. Click in the **Value** field to change its value to **1**.

| hw_vio_1 × Capture Setup | - hw_ila_1 |          |           |          | ? _ 🗆 |
|--------------------------|------------|----------|-----------|----------|-------|
| Q   ¥   ♦   +   -        |            |          |           |          |       |
| Name                     | Value      | Activity | Direction | VIO      |       |
| Ъ DONT_EAT               | [B] 0      |          | Input     | hw_vio_1 |       |
| ৳ GPIO_BUTTONS_re[1:1]   | [B] 0      |          | Input     | hw_vio_1 |       |
| ∿a push_button_reset     | 1          |          | Output    | hw_vio_1 |       |
| ∿ push_button_vio_1      | 0          |          | Output    | hw_vio_1 |       |
| > 🍓 sineSel_1[1:0]       | [H] 0      |          | Input     | hw_vio_1 |       |
|                          |            |          |           |          |       |
|                          |            |          |           |          |       |

Figure 85: Toggle the Value of push\_button\_reset

24. Follow the step above to change the push\_button\_vio to Toggle button as well.





25. Set these two bits of the "sineSel" input probe by right-clicking **PROBE\_IN0[0] and PROBE\_IN0[1**] and selecting **LED**.



Figure 86: Change sineSel to LED

26. In the **Select LED Colors** dialog box, pick the **Low Value Color** and the **High Value Color** of the LEDs as you desire and click **OK**.

| Select LED Colors         |           |  |  |  |  |
|---------------------------|-----------|--|--|--|--|
| Low Value Color:          | Gray 🗸    |  |  |  |  |
| <u>H</u> igh Value Color: | 🔵 Red 🗸 🗸 |  |  |  |  |
| ОК                        | Cancel    |  |  |  |  |

Figure 87: Pick the Low Value and High Value Color of the LEDs





27. When finished, your **VIO Probes** window in the Hardware Manager should look similar to the following figure.

| hw_vio_1 × Capture Setup | - hw_ila_1 |          |           |          | ? _ 🗆 |
|--------------------------|------------|----------|-----------|----------|-------|
| Q   ¥   ♦   +   -        |            |          |           |          |       |
| Name                     | Value      | Activity | Direction | VIO      |       |
| ∿ DONT_EAT               | [B] 0      |          | Input     | hw_vio_1 |       |
| ৳ GPIO_BUTTONS_re[1:1]   | [B] 0      |          | Input     | hw_vio_1 |       |
| ے push_button_reset      | 1          |          | Output    | hw_vio_1 |       |
| ∿ a push_button_vio_1    | 0          |          | Output    | hw_vio_1 |       |
| > \u00e9 sineSel_1[1:0]  | [H] 0      |          | Input     | hw_vio_1 |       |
|                          |            |          |           |          |       |
|                          |            |          |           |          |       |

Figure 88: Input and Output VIO Signals Displayed

- 28. To cycle through each different sine wave output frequency using the virtual "push\_button\_vio" from the VIO core, perform the following simple steps:
  - a. Toggle the value of the "push\_button\_vio" output driver from 0 to 1 to 0 by clicking on the logic displayed under the Value column. You will notice the sineSel LEDs changed accordingly 0, 1, 2, 3, 0, etc...

| hw_vio_1 × Capture Setup | - hw_ila_1 |          |           |          | ? |
|--------------------------|------------|----------|-----------|----------|---|
| Q   ¥   ♦   +   -        |            |          |           |          |   |
| Name                     | Value      | Activity | Direction | VIO      |   |
| ∿ DONT_EAT               | [B] 0      |          | Input     | hw_vio_1 |   |
| BOPIO_BUTTONS_re[1:1]    | [B] 0      |          | Input     | hw_vio_1 |   |
| 🛥 push_button_reset      | 0          |          | Output    | hw_vio_1 |   |
| ✓ iie sineSel_1[1:0]     | [H] 1      |          | Input     | hw_vio_1 |   |
|                          |            |          | Input     | hw_vio_1 |   |
|                          | •          |          | Input     | hw_vio_1 |   |
| ∿ push_button_vio_1      | 1          |          | Output    | hw_vio_1 |   |

Figure 89: Toggle push\_button\_reset

b. Click **Run Trigger** for hw\_ila\_1 to capture and display the selected sine wave signal from the previous step.





| Waveform - hw_ila_1              |       |                     |                      |                    |   |     | ? _ 🗆 X |
|----------------------------------|-------|---------------------|----------------------|--------------------|---|-----|---------|
| Q   +   −   ϑ   ▶   ≫            | 🕒 🔁 🔍 | ર 🔀 📲 🖌 🕨           | l   të   ër   +F   F | <b>↓</b>   ⇒[    → |   |     | 0       |
| ILA Status: Idle                 |       |                     |                      |                    |   |     | 1,023   |
| Name                             | Value | <u>•</u>            | 200                  | 400                |   | 600 | 800 1.  |
| > 📓 GPIO_BUTTONS_dly[1:0]        | 1     |                     |                      |                    |   |     |         |
| V M GPIO_BUTTONS_re_1[1:0]       | 0     |                     |                      |                    | ) |     |         |
| Va [1]                           | 0     |                     |                      |                    |   |     |         |
| Դեն [0]                          | 0     |                     |                      |                    |   |     |         |
| <sup>™</sup> push_button_reset_1 | 0     |                     |                      |                    |   |     |         |
| ¼ push_button_vio                | 1     |                     |                      |                    |   |     |         |
| > 🔩 sine[19:0]                   | 75471 |                     |                      |                    |   |     |         |
| ✓ SineSel[1:0]                   | 1     | K                   |                      |                    |   |     |         |
| 10 [1]                           | 0     |                     |                      |                    |   |     |         |
| ₩a [0]                           | 1     |                     |                      |                    |   |     |         |
|                                  | < >>  | Updated at: 2017-Ma | r-17 12:41:31        |                    |   |     | `       |

Figure 90: Run Trigger for hw\_ila\_1





# Lab 6: Using ECO Flow to Replace Debug Probes Post Implementation

This simple tutorial shows you how to replace nets connected to an ILA core in a placed and routed design checkpoint using the Vivado® Design Suite Engineering Change Order (ECO) flow.



**TIP:** To learn more about using the ECO flow, refer to the <u>Debugging Designs Post</u> <u>Implementation Chapter</u> in the Vivado Design Suite User Guide: Programming and Debugging (UG908).

1. Open the Vivado Design Suite, and select File > Open Checkpoint.





| 🔶 Viva       | ado 2018.1                                                                                  |                                      |           |
|--------------|---------------------------------------------------------------------------------------------|--------------------------------------|-----------|
| <u>F</u> ile | Flow <u>T</u> ools <u>W</u> indow <u>H</u> elp                                              | Q- Quick Access                      |           |
|              | Project<br>Constraints<br>Simulation Waveform                                               |                                      |           |
|              | Chec <u>k</u> point                                                                         | > Open                               |           |
|              | <u>I</u> P                                                                                  | Popen Recent      P                  |           |
|              | I <u>m</u> port                                                                             |                                      |           |
|              | Exit                                                                                        |                                      |           |
|              | Create Project ><br>Open Project ><br>Open Example Project >                                |                                      |           |
|              | Tasks                                                                                       |                                      |           |
|              | Manage IP 🗲                                                                                 |                                      |           |
| L            | Open Hardware Manager ><br>Xilinx Tcl Store >                                               |                                      |           |
|              | Learning Cer<br>Documentation and Tutorials<br>Quick Take Videos ><br>Release Notes Guide > |                                      |           |
| Tel C        | onsole                                                                                      |                                      | ? _ O Ľ X |
|              | onsole                                                                                      |                                      | ? _ O G X |
|              |                                                                                             |                                      | ^         |
|              | <                                                                                           |                                      | ~         |
| Туре         | e a Tcl command here                                                                        |                                      |           |
| Open a       | checkpoint file containing a netlist, XDC                                                   | constraints, and a physical database |           |

Figure 91: Opening a Checkpoint in Vivado IDE





2. Open the routed checkpoint that you created in Lab 2: Using the HDL Instantiation Method for Debugging a Design in Vivado.

| 🍌 Open Checkpoin                                                                           | ıt                        |                                                                                                                                                                                                                                                                                                                                       |
|--------------------------------------------------------------------------------------------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Look <u>i</u> n: 🕠 impl_1                                                                  |                           |                                                                                                                                                                                                                                                                                                                                       |
| ₩ Xil A sinegen_demo.d A sinegen_demo_d A sinegen_demo_r A sinegen_demo_r A sinegen_demo_r | opt.dcp<br>placed.dcp     | Recent Directories C:/Vivado_Debug/2017.1/proj_netlist/proj_netlist.runs/impl_1 File Preview File: sinegen_demo_routed.dcp Directory: C://ivado_Debug/2017.1/proj_netlist/proj_netlist.runs/impl_1 Created: Wednesday 03/15/17 02:54 PM Accessed: Wednesday 03/15/17 02:54 PM Size: 4.5 MB Type: Checkpoint design Owner: XLNX\smitha |
| File <u>n</u> ame: sinege                                                                  | en_demo_routed.dcp        |                                                                                                                                                                                                                                                                                                                                       |
| Files of type: Vivado                                                                      | o Checkpoint Files (.dcp) | ~                                                                                                                                                                                                                                                                                                                                     |
|                                                                                            |                           | OK Cancel                                                                                                                                                                                                                                                                                                                             |

Figure 92: Open Checkpoint Dialog Box





Change the layout in the Vivado Design Suite toolbar dropdown to ECO.



Figure 93: Change Layout to ECO

**Note:** The **Flow Navigator** window now changes to **ECO Navigator** with a different set of options.





| File Edit Flow Tools W            | indow Layout View Help <u>Q- Quick Ac</u>                                      | ECO                                                                                                |        |
|-----------------------------------|--------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|--------|
| ECKPOINT DE SIGN - xc7k325tffg900 |                                                                                |                                                                                                    | ?      |
| ECKPOINT DESIGN - XC/K525urgson   | J-2                                                                            |                                                                                                    | -      |
| CO Navigator                      | Scratch F Propertie Netli × ? _ 🗆 🖆                                            | Schematic × Device × Package ×                                                                     | ? 🗆    |
| Edit                              | 조 뇌 수                                                                          | $\leftarrow \Rightarrow \Theta \Theta X \Sigma \Theta + - C 35 Cells 9 1/0$                        | Ports  |
| Create Net                        | sinegen_demo Nets (114)                                                        |                                                                                                    |        |
| Create Cell                       | > Leaf Cells (31)                                                              |                                                                                                    |        |
| Create Port                       | > 🦉 dbg_hub (dbg_hub_CV)                                                       |                                                                                                    |        |
| Create Pin                        | <ul> <li>U_DEBOUNCE_0 (debounce)</li> <li>U_DEBOUNCE_1 (debounce_0)</li> </ul> |                                                                                                    |        |
| Connect Net                       | > I U_FSM (fsm)                                                                |                                                                                                    |        |
| Disconnect Net                    | >      u_ila_0 (u_ila_0_CV)     U_SINEGEN (sinegen)                            |                                                                                                    |        |
| Replace Debug Probes              |                                                                                |                                                                                                    |        |
| Place Cell                        |                                                                                |                                                                                                    |        |
| Unplace Cell                      |                                                                                |                                                                                                    |        |
| Run                               |                                                                                |                                                                                                    |        |
| Check ECO                         |                                                                                |                                                                                                    |        |
| Optimize Logical Design           |                                                                                |                                                                                                    |        |
| Place Design                      |                                                                                |                                                                                                    | ╺┉╤╝─┘ |
| -                                 |                                                                                |                                                                                                    |        |
| Optimize Physical Design          |                                                                                |                                                                                                    |        |
| Route Design                      |                                                                                |                                                                                                    |        |
| Report                            |                                                                                |                                                                                                    |        |
| Edit Timing Constraints           |                                                                                |                                                                                                    |        |
| 🕲 Report Timing Summary           |                                                                                |                                                                                                    |        |
|                                   |                                                                                |                                                                                                    |        |
| Report Clock Interaction          |                                                                                |                                                                                                    |        |
| Report DRC                        | Tcl Console × Messages Package Pins                                            | I/O Ports                                                                                          | ? _ 🗆  |
| Report Utilization                | Q X ≑ II ₪ ₪ 面                                                                 |                                                                                                    |        |
| 🛸 Report Power                    | INFO: [Project 1-111] Unisim Transfo                                           |                                                                                                    |        |
| Program                           | A total of 734 instances were tran<br>CFGLUT5 => CFGLUT5 (SRLC32E, SRL16       |                                                                                                    |        |
| Save Checkpoint As                | RAM32M => RAM32M (RAMS32, RAMS32,<br>RAM64M => RAM64M (RAMD64E, RAMD64E        | RAMD32, RAMD32, RAMD32, RAMD32, RAMD32, RAMD32): 6 instances<br>2, RAMD64E, RAMD64E): 32 instances |        |
| III Generate Bitstream            |                                                                                | s created with Vivado v2017.1 (64-bit) build 1812560                                               |        |
| 🕒 Write Debug Probes              |                                                                                | 01:25 ; elapsed = 00:01:03 . Memory (MB): peak = 1962.723 ; gain = 1038.                           | .313   |
| Open Hardware Manager             | ·                                                                              |                                                                                                    | >      |

Figure 94: ECO Navigator Window





3. In the **ECO Navigator** window, click **Replace Debug Probes** to bring up the **Replace Debug Probes** dialog box. Note the Debug Hub and ILA cores in the design.

| Replace Debug Probes                                                             |                        | <b>-</b> × |
|----------------------------------------------------------------------------------|------------------------|------------|
| Use the Edit Probes button to replace or<br>changes in the Vivado Hardware Manag |                        |            |
|                                                                                  |                        |            |
| Search: Q-                                                                       |                        |            |
| Name                                                                             | Probe                  |            |
| Ch 13                                                                            | _ I NEGEN/sine[13]     | 0^         |
| Ch 14                                                                            | _ SINEGEN/sine[14]     | 0          |
| Ch 15                                                                            | _ I U_SINEGEN/sine[15] | 0          |
| Ch 16                                                                            | _ SINEGEN/sine[16]     | 0          |
| Ch 17                                                                            | _ SINEGEN/sine[17]     | 0          |
| Ch 18                                                                            | _ SINEGEN/sine[18]     | 0          |
| Ch 19                                                                            | _ SINEGEN/sine[19]     | 0          |
| probe2 (2)                                                                       |                        |            |
| Ch 0                                                                             | _ SPIO_BUTTONS_IBUF[0] | 0          |
| Ch 1                                                                             | _ SPIO_BUTTONS_IBUF[1] | 0          |
| probe3 (2)                                                                       |                        | - 11       |
| Ch 0                                                                             | _ SPIO_BUTTONS_db[0]   | 0          |
| Ch 1                                                                             | _ SPIO_BUTTONS_db[1]   | 0          |
| ✓                                                                                |                        | - 11       |
| Ch 0                                                                             | _ SPIO_BUTTONS_dly[0]  | 0          |
| Ch 1                                                                             | _ SPIO_BUTTONS_dly[1]  | 0          |
| ✓ ■ probe5 (2)                                                                   |                        |            |
| Ch 0                                                                             | _                      | 0 ~        |
| Probes changed: 0                                                                | ОК С                   | ancel      |

Figure 95: Replace Debug Probes Dialog Box



**IMPORTANT:** Xilinx strongly recommends that you do not replace the clock nets associated with ILA and Debug Hub cores.



- 4. In the **Replace Debug Probes** dialog box, highlight the probes whose nets you want to change. In this lab we will replace the **GPIO\_BUTTONS\_dly[0]** net that is being probed.
- 5. Click the **Edit Probes** button to the right of the **GPIO\_BUTTONS\_dly[0]** probe net to bring up the **Replace Debug Probes** dialog box.

| Replace Debug Probes                                                                      |                           |
|-------------------------------------------------------------------------------------------|---------------------------|
| Use the Edit Probes button to replace one of<br>changes in the Vivado Hardware Manager, i |                           |
|                                                                                           |                           |
| Search: Q-                                                                                |                           |
| Name                                                                                      | Probe                     |
| Ch 13                                                                                     | _ ¥ U_SINEGEN/sine[13]    |
| Ch 14                                                                                     | _ SINEGEN/sine[14]  ⊘     |
| • Ch 15                                                                                   | 「 ¥ U_SINEGEN/sine[15] ⊘  |
| • Ch 16                                                                                   | 「 ¥ U_SINEGEN/sine[16]    |
| • Ch 17                                                                                   | 「* U_SINEGEN/sine[17] ⊘   |
| Ch 18                                                                                     | _「 * U_SINEGEN/sine[18]   |
| € Ch 19                                                                                   | _ SINEGEN/sine[19] </td   |
| probe2 (2)                                                                                |                           |
| Ch 0                                                                                      | _ SPIO_BUTTONS_IBUF[0]    |
| Ch 1                                                                                      | _ SPIO_BUTTONS_IBUF[1] 	⊘ |
| ✓ ■ probe3 (2)                                                                            |                           |
| Ch 0                                                                                      | 「∗ GPIO_BUTTONS_db[0] /   |
| Ch 1                                                                                      | 「★ GPIO_BUTTONS_db[1] /   |
| ✓ probe4 (2)                                                                              |                           |
| Ch 0                                                                                      | _∫ * GPIO_BUTTONS_dly[0]  |
| Ch 1                                                                                      | 「∗ GPIO_BUTTONS_dly[1]    |
| ✓ probe5 (2)                                                                              |                           |
| Ch 0                                                                                      | _「 * GPIO_BUTTONS_re[0]   |
| Probes changed: 0                                                                         |                           |
|                                                                                           | OK Cancel                 |
|                                                                                           |                           |

Figure 96: Edit Probes Button





6. In the **Choose Nets** dialog box, choose the **U\_DEBOUNCE\_0/clear** net to replace the existing **GPIO\_BUTTONS\_dly[0]** probe net. Click **OK**.

| i Choose Nets                                                           |                     |             |                                    |                 | ×    |
|-------------------------------------------------------------------------|---------------------|-------------|------------------------------------|-----------------|------|
| Choose nets to replace existing probes.                                 |                     |             |                                    |                 | 4    |
| Properties                                                              |                     |             |                                    |                 |      |
| NAME 🗸 cor                                                              | ntains 🗸 🗸          | *           |                                    | ⊗ +             |      |
|                                                                         |                     |             |                                    |                 |      |
|                                                                         |                     |             |                                    |                 |      |
|                                                                         |                     |             |                                    |                 |      |
|                                                                         |                     |             |                                    |                 |      |
|                                                                         |                     |             |                                    |                 |      |
|                                                                         |                     |             |                                    |                 |      |
|                                                                         | archically 🗸 Displa | unique nets |                                    |                 |      |
| Of o <u>bj</u> ects:                                                    |                     |             |                                    |                 |      |
|                                                                         | ٦                   | Find        |                                    |                 |      |
| Found: 12857                                                            | L                   | Selected:   | 0 of 1                             | ₽₽              | Z]   |
| _ <const0></const0>                                                     | ^                   |             |                                    | 2.              | AV.  |
| ∫ <const1></const1>                                                     |                     |             |                                    |                 |      |
| 」 Clk<br>」 Clk_ibufgds                                                  |                     |             |                                    |                 | ×    |
| J CLK_N                                                                 |                     |             |                                    |                 | +    |
| J CLK_P                                                                 |                     | Lieoth      | e buttons on the left to copy Nets | into this List. | +    |
| ∫ dbg_hub/ <const0></const0>                                            | :                   |             |                                    |                 | +    |
| ∫ dbg_hub/inst/ <const0><br/>∫ dbg_hub/inst/BSCANID.u_xsdbm_id</const0> | / <const1></const1> |             |                                    |                 | +    |
| ∫ dbg_hub/inst/BSCANID.u_xsdbm_id                                       |                     |             |                                    |                 |      |
| ∫ dbg_hub/inst/BSCANID.u_xsdbm_id                                       | /bscanid[1]         |             |                                    |                 |      |
| <                                                                       | >                   |             |                                    |                 |      |
|                                                                         |                     |             | ОК                                 | Ca              | ncel |
|                                                                         |                     |             |                                    |                 |      |

Figure 97: Choose Nets





 Type for "\*clear net" in the Name field and Click Find. Notice the U\_DEBOUNCE\_0 net in the Found nets area. Select U\_DEBOUNCE\_0/clear net using the "->" arrow and click OK. The U\_DEBOUNCE\_0/clear net to replaces the existing GPIO\_BUTTONS\_dly[0] probe net.

| 🕕 Choose Nets                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                             |                                                          | ×       |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|----------------------------------------------------------|---------|
| Choose nets to replace existing probes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                             |                                                          | 4       |
| Properties                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | _                                                                                           |                                                          |         |
| NAME ~ contains                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ✓ *d                                                                                        | ear 🛛 🕇                                                  |         |
| Regular expression       ✓       Search hierarchically       ✓       □         Of objects:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | jisplay un<br><u>E</u> ii                                                                   | nd                                                       |         |
| Found: 68                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                             | Selected: 0 of 1                                         | ¢†      |
| U_DEBOUNCE_0/clear<br>U_ila_0/inst/ila_core_inst/u_ila_regs/CNT.CNT_SRL<br>U_ila_0/inst/ila_core_inst/u_ila_regs/CNT.CNT_SRL<br>U_ila_0/inst/ila_core_inst/u_ila_regs/CNT.CNT_SRL<br>U_ila_0/inst/ila_core_inst/u_ila_regs/CNT.CNT_SRL<br>U_ila_0/inst/ila_core_inst/u_ila_regs/MU_SRL[0].mu<br>U_ila_0/inst/ila_core_inst/u_ila_regs/MU_SRL[1].mu<br>U_ila_0/inst/ila_core_inst/u_ila_regs/MU_SRL[2].mu<br>U_ila_0/inst/ila_core_inst/u_ila_regs/MU_SRL[2].mu<br>U_ila_0/inst/ila_core_inst/u_ila_regs/MU_SRL[2].mu<br>U_uila_0/inst/ila_core_inst/u_ila_regs/MU_SRL[3].mu<br>U_uila_0/inst/ila_core_inst/u_ila_regs/MU_SRL[4].mu | 4<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>4 | Use the buttons on the left to copy Nets into this List. | × + + ± |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                             | OK Can                                                   | cel     |

Figure 98: Choose Nets – Clear





| 🔥 Cl | noose Nets                                        |                                   |                                            | <b>X</b> |
|------|---------------------------------------------------|-----------------------------------|--------------------------------------------|----------|
| Cho  | ose nets to replace existing pro                  | bes.                              |                                            | 4        |
| Pr   | operties                                          |                                   |                                            |          |
|      | NAME ~                                            | contains ~                        | *clear                                     | +        |
|      |                                                   |                                   |                                            |          |
|      |                                                   |                                   |                                            |          |
|      |                                                   |                                   |                                            |          |
|      |                                                   |                                   |                                            |          |
|      |                                                   |                                   |                                            |          |
|      | Regular expression 🗹 Searc                        | h hierarchically 🗹 <u>D</u> ispla | y unique nets                              |          |
| 01   | fobjects:                                         | r                                 |                                            |          |
|      |                                                   |                                   | Eind                                       |          |
|      | und: 68                                           |                                   | Selected: 1 of 1                           | A X↓     |
|      | dbg_hub/inst/BSCANID.u_xsdb<br>U_DEBOUNCE_0/clear | m_Id/CORE_XSDB.0                  | └ U_DEBOUNCE_0/clear                       |          |
|      | u_ila_0/inst/ila_core_inst/u_ila                  | reas/CNT.CNT_SRL                  |                                            |          |
|      | u_ila_0/inst/ila_core_inst/u_ila                  |                                   |                                            | ×        |
|      | u_ila_0/inst/ila_core_inst/u_ila                  |                                   | _                                          | <b>T</b> |
| 5    | u_ila_0/inst/ila_core_inst/u_ila                  | _regs/CNT.CNT_SRL                 |                                            |          |
| L    | u_ila_0/inst/ila_core_inst/u_ila                  | _regs/MU_SRL[0].mu                |                                            | Ť        |
| L    | u_ila_0/inst/ila_core_inst/u_ila                  | _regs/MU_SRL[1].mu                | Copy selected Nets into the Selection List | +        |
| L    | u_ila_0/inst/ila_core_inst/u_ila                  | _regs/MU_SRL[2].mu                |                                            | ±        |
| L    | u_ila_0/inst/ila_core_inst/u_ila                  | _regs/MU_SRL[3].mu                |                                            |          |
| 1    | u_ila_0/inst/ila_core_inst/u_ila                  | _regs/MU_SRL[4].mu                |                                            |          |
| <    |                                                   | >                                 |                                            |          |
|      |                                                   |                                   | ок                                         | Cancel   |
|      |                                                   |                                   |                                            |          |

Figure 99: Choose Nets - Copy





8. Now click **OK** in the **Replace Debug Probes** dialog.

| Replace Debug Probes |                                                                                               |       |
|----------------------|-----------------------------------------------------------------------------------------------|-------|
|                      | ce one or more debug probes. To reflect thes<br>anager, regenerate the debug probes file (LT. |       |
|                      | ŧ                                                                                             |       |
| Search: Q-           |                                                                                               |       |
| Name                 | Probe                                                                                         |       |
| Ch 13                | _                                                                                             | 0 ^   |
| Ch 14                | _                                                                                             | 0     |
| Ch 15                | _F ¥ U_SINEGEN/sine[15]                                                                       | 0     |
| Ch 16                | _F ¥ U_SINEGEN/sine[16]                                                                       | 0     |
| Ch 17                | _ I ¥ U_SINEGEN/sine[17]                                                                      | Ø     |
| Oh 18                | _ I ¥ U_SINEGEN/sine[18]                                                                      | 0     |
| Ch 19                | _                                                                                             | 0     |
| ✓ probe2 (2)         |                                                                                               |       |
| Ch 0                 | _                                                                                             | 0     |
| Ch 1                 | _                                                                                             | 0     |
| ✓ ■ probe3 (2)       |                                                                                               |       |
| Ch 0                 | _                                                                                             | 0     |
| 🖲 Ch 1               | _                                                                                             | 0     |
| ✓ ➡ probe4 (2)       |                                                                                               |       |
| 🖲 Ch 0               | _ U_DEBOUNCE_0/clear                                                                          | C     |
| 🖲 Ch 1               | _                                                                                             | 0     |
| ✓ ▶ probe5 (2)       |                                                                                               |       |
| 🖲 Ch 0               | _                                                                                             | 0 ~   |
| Probes changed: 1    |                                                                                               |       |
|                      | ок С                                                                                          | ancel |

Figure 100: Finish Replace Debug Probes





**IMPORTANT:** Check the Tcl Console to ensure that there are no Warnings/Errors.







#### Figure 102: Route Design Messages





9. Save your modifications to a new checkpoint. Use the **Save Checkpoint As** option in the ECO Navigator to bring up the **Save Checkpoint As** dialog box. Specify a file name for the .dcp file and click **OK**.

| 🌽 Save Checkpoint As                                                                               | ×    |
|----------------------------------------------------------------------------------------------------|------|
| Create a checkpoint file that contains the netlist, XDC constraints, and the physical<br>database. | A    |
| Checkpoint file: 2017.1/proj_netlist/proj_netlist.runs/impl_1/checkpoint_1.d<br>OK Car             | ncel |

Figure 103: Save Checkpoint As Dialog Box

10. Click **Write Debug Probes** in the ECO Navigator. When the **Write Debug Probes** dialog appears, click **OK** to generate a new .ltx file for the debug probes.

| Write Debug Probes                                                |
|-------------------------------------------------------------------|
| Write debug probes to a file.                                     |
| File Name: )17.1/proj_netlist/proj_netlist.runs/impl_1/probes_2 ③ |
| OK Cancel                                                         |

Figure 104: Write Debug Probes Dialog Box





11. When the Generate Bitstream dialog appears, change the bit file name to

project\_sinegen\_demo\_routed\_debug\_changes.bit in the **Bit File** field and click **OK** to generate a new .bit file that reflects the debug probe changes.

| 🔥 Generate                                        | e Bitstream                                       |                                 | ×    |  |  |  |  |  |  |
|---------------------------------------------------|---------------------------------------------------|---------------------------------|------|--|--|--|--|--|--|
| Create a pro                                      | Create a programming file from the current design |                                 |      |  |  |  |  |  |  |
|                                                   |                                                   |                                 |      |  |  |  |  |  |  |
| Bit File                                          | etlist/proj_netlist.runs/impl_1                   | /project_sinegen_demo_routed. 😒 |      |  |  |  |  |  |  |
| Options                                           |                                                   |                                 |      |  |  |  |  |  |  |
| -rav                                              | v_bitfile                                         |                                 | ^    |  |  |  |  |  |  |
| -ma                                               | ask_file                                          |                                 |      |  |  |  |  |  |  |
| -no                                               | _binary_bitfile                                   |                                 |      |  |  |  |  |  |  |
| -bin                                              | _file                                             |                                 |      |  |  |  |  |  |  |
| -rea                                              | adback_file                                       |                                 |      |  |  |  |  |  |  |
| -log                                              | ic_location_file                                  |                                 |      |  |  |  |  |  |  |
| -ver                                              | bose                                              |                                 | ~    |  |  |  |  |  |  |
| Select an option above to see a description of it |                                                   |                                 |      |  |  |  |  |  |  |
|                                                   |                                                   | ОК Сал                          | icel |  |  |  |  |  |  |

Figure 105: Generate Bitstream Dialog Box

- 12. Connect to the Vivado Hardware Manager by selecting **Open Hardware Manager** in the ECO Navigator.
- 13. Connect to the local hardware server by following the steps in the Target Board and Server Set Up section in Lab 5: Using Vivado Logic Analyzer to Debug Hardware.





Program the device using the .bit file and .ltx files that you created in the previous steps.

| iko Program Device                                                                                                                                                                                          |                   | ×     |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-------|--|--|--|--|--|
| Select a bitstream programming file and download it to your hardware device. You can optionally select a debug probes file that corresponds to the debug cores contained in the bitstream programming file. |                   |       |  |  |  |  |  |
| Bitstre <u>a</u> m file:<br>Debu <u>q</u> probes file:                                                                                                                                                      |                   |       |  |  |  |  |  |
| ✓ Enable end of st                                                                                                                                                                                          | artup check       |       |  |  |  |  |  |
| ?                                                                                                                                                                                                           | <u>P</u> rogram C | ancel |  |  |  |  |  |

Figure 106: Program Device Dialog Box

14. Select **Window > Debug Probes** from the Vivado Design Suite toolbar. Ensure that the probes that were replaced in step 8 and 9 above are reflected in the probes associated with **hw\_ila\_1**.









15. Run the Trigger on the ILA. Ensure the probes that were replaced in step 8 and 9 above are reflected in the **Waveform** window as well.



Figure 108: Running the Trigger on the ILA





## Lab 7: Debugging Designs Using Incremental Compile Flow

## Introduction

This lab introduces the Vivado® Incremental Compile Flow to add/edit/delete debug cores to an earlier implementation of the design.

## Procedure

This lab consists of five generalized steps followed by general instructions and supplementary detailed steps that allow you to make choices based on your skill level as you progress through the lab.

If you need help completing a general instruction, go to the detailed steps below it, or if you are ready, simply skip the step-by-step directions and move on to the next general instruction.

The lab has five primary steps as follows:

Step 1: Opening the Example Design and Adding a Debug Core

Step 2: Compiling the Reference Design

Step 3: Create New Runs Step

Step 4: Making Incremental Debug Changes

Step 5: Running Incremental Compile

# Step 1: Opening the Example Design and Adding a Debug Core

1. Start Vivado IDE

Load Vivado IDE by doing one of the following:

- Double-click the Vivado IDE icon on the Windows desktop
- Type vivado in a command terminal.

From the Getting Started page, click Open Example Project.

- 2. In the Open Example Project dialog box, click Next.
- 3. Select the CPU (Synthesized) design template, and click Next.
- 4. In the Project Name dialog box, specify the following:





- **Project name:** project\_cpu\_incremental
- Project location: <Project\_Dir>

Click Next.

- 5. In the **Default Part** screen, select **xc7k70tfbg676-2** and click **Next**.
- 6. The **New Project Summary** screen appears, displaying project details. Reviewed these and click **Finish**
- 7. When Vivado IDE opens with the default view, open the Synthesized design
- 8. In the **Netlist** window, select the set of signals specified below in the cpuEngine hierarchy and apply the MARK\_DEBUG property by right-clicking and selecting **Mark Debug** from the dialog.

```
cpuEngine/dcqmem_dat_qmem[*],
cpuEngine/dcpu_dat_qmem[*],
cpuEngine/dcqmem_adr_qmem[*],
cpuEngine/du_dsr[*],
cpuEngine/dvr0_0[*],
cpuEngine/du_dsr[*],
cpuEngine/dcqmem_sel_qmem[*]
```







Figure 109: Set MARK\_DEBUG Property

Alternatively use can use the Tcl command below to set the MARK\_DEBUG property on the signals specified.

```
set_property mark_debug true [get_nets [list {cpuEngine/dcqmem_dat_qmem[*]}
{cpuEngine/dcpu_dat_qmem[*]} {cpuEngine/dcqmem_adr_qmem[*]}
{cpuEngine/du_dsr[*]} {cpuEngine/dvr0_0[*]} {cpuEngine/du_dsr[*]}
{cpuEngine/dcqmem_sel_qmem[*]}]
```





9. In the **Flow Navigator**, click **Set Up Debug** to invoke the Set Up Debug wizard.



Figure 110: Setup Debug from Flow Navigator





10. When the Set Up Debug Wizard appears, click **Next**.

| Set Up Debug                                                                                                                        |               |               |                      |        |                             | ×       |
|-------------------------------------------------------------------------------------------------------------------------------------|---------------|---------------|----------------------|--------|-----------------------------|---------|
| <b>lets to Debug</b><br>The nets below will be debugged with ILA cores. To<br>vindows, then drag them to the list or click "Add Sel |               | nd Nets to Ad | d". You can also sel | ect ne | ets in the Netlist or other | 4       |
| Q   素   ≑   ㎡   Ш   +   −                                                                                                           |               |               |                      |        |                             | ٥       |
| Name                                                                                                                                | Clock Domain  | Driver Cell   | Probe Type           |        |                             |         |
| > Jf≅ cpuEngine/dcpu_dat_qmem (25)                                                                                                  | clkgen/cpuClk | FDRE          | Data and Trigger     | ~      |                             |         |
| > 小電 cpuEngine/dcqmem_adr_qmem (32)                                                                                                 | clkgen/cpuClk | FDRE          | Data and Trigger     | Υ.     |                             |         |
| > 小章 cpuEngine/dcqmem_dat_qmem (32)                                                                                                 | clkgen/cpuClk | FDRE          | Data and Trigger     | Υ.     |                             |         |
| > 小☆ cpuEngine/dcqmem_sel_qmem (4)                                                                                                  | clkgen/cpuClk | FDRE          | Data and Trigger     | Υ.     |                             |         |
| > 小☆ cpuEngine/du_dsr (11)                                                                                                          | clkgen/cpuClk | FDCE          | Data and Trigger     | Υ.     |                             |         |
| › √ft☆ cpuEngine/dvr00 (6)                                                                                                          | clkgen/cpuClk | FDCE          | Data and Trigger     | Υ.     |                             |         |
| Find Nets to Add                                                                                                                    |               |               |                      |        | Nets to debu                | ua: 110 |
|                                                                                                                                     |               | <             | Back Ne              | ext >  |                             | -       |
| ?                                                                                                                                   |               | <             | Back Ne              | ext >  | Einish Ca                   | ancel   |

#### Figure 111: Set Up Debug Nets to Debug

- 11. When ILA Core Options screen appears, click Next again.
- 12. When **Set Up Debug Summary** screen appears, ensure that **1 debug core** is created and click **Finish**.





13. Check the Debug widow to ensure that **u\_ila\_0** core has been inserted into the design.

| Tcl Console Messages Log Reports Design Ru | ins Debug   | ×          |                    | ? _ 🗆 🖸 |
|--------------------------------------------|-------------|------------|--------------------|---------|
| Q ≍ ≑ ӂ Ӊ <b>ะ</b>                         |             |            |                    | ٥       |
| Name                                       | Driver Cell | Driver Pin | Probe Type         |         |
| dbg_hub (labtools_xsdbm_v3)                |             |            |                    |         |
| u_ila_0 (labtools_ila_v6)                  |             |            |                    |         |
| > 🗃 clk (1)                                |             |            |                    |         |
| > 📄 probe0 (32)                            |             |            | Data and Trigger 👒 |         |
| > 🖻 probe1 (4)                             |             |            | Data and Trigger 👒 |         |
| > 📄 probe2 (32)                            |             |            | Data and Trigger 👒 |         |
| > 📄 probe3 (11)                            |             |            | Data and Trigger 👒 |         |
| > probe4 (25)                              |             |            | Data and Trigger 👒 |         |
| > 📄 probe5 (6)                             |             |            | Data and Trigger 👒 |         |
| Unassigned Debug Nets (0)                  |             |            |                    |         |
|                                            |             |            |                    |         |
| Debug Cores Debug Nets                     |             |            |                    |         |

#### Figure 112: Check u\_ila\_0 Core

14. Save the new debug XDC commands by selecting **File > Save Constraints** or clicking the **Save Constraints** button.

## **Step 2: Compiling the Reference Design**

The following are the steps to run implementation on the reference design.

- 1. From the Flow Navigator, select Run Implementation.
- 2. After implementation finishes, the Implementation Complete dialog box opens. Click Cancel.
- 3. In a project-based design, the Vivado Design Suite saves intermediate implementation results as design checkpoints in the implementation runs directory. You will use one of the saved design checkpoints from the implementation in the incremental compile flow.

0

**TIP:** When you re-run implementation, the previous results will be deleted. Save the intermediate implementation results to a new directory or create a new implementation run for your incremental compile to preserve the reference implementation run directory.

- 4. In the **Design Runs** window, right click **impl\_1** and select **Open Run Directory** from the popup menu. This opens the run directory in a file browser as seen in the figure below. The run directory contains the routed checkpoint (top\_routed.dcp) to be used later for the incremental compile flow. The location of the implementation run directory is a property of the run.
- 5. Get the location of the current run directory in the Tcl Console by typing:





get property DIRECTORY [current run]

This returns the path to the current run directory that contains the design checkpoint. You can use this Tcl command, and the DIRECTORY property, to locate the DCP files needed for the incremental compile flow.

### **Step 3: Create New Runs**

In this step, you define new synthesis and implementation runs to preserve the results of the current runs. Then you make debug related changes to the design and rerun synthesis and implementation. If you do not create new runs, Vivado overwrites the current results.

- 1. From the Vivado tool bar, select Flow > Create Runs to invoke the Create New Runs wizard.
- 2. In the Create New Runs screen, click Next.
- 3. The **Configure Implementation Runs** screen opens, as shown in the figure below. Select the **Make Active** check box, and click **Next**.

| A Create New Runs                                                                                                                            |               |                    |                |                                                             |                  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------|---------------|--------------------|----------------|-------------------------------------------------------------|------------------|--|--|--|
| Configure Implementation Runs<br>Create and configure one or more implementation runs using various parts, constraints, flows and strategies |               |                    |                |                                                             |                  |  |  |  |
|                                                                                                                                              | Create Implem | entation Runs      |                |                                                             |                  |  |  |  |
|                                                                                                                                              | + -           |                    |                |                                                             |                  |  |  |  |
|                                                                                                                                              | Name          | Constraints Set    | Part           | Strategy                                                    | Make Active      |  |  |  |
|                                                                                                                                              | impl_2 🔻      | 🛅 constrs_2 (act 🗸 | xc7k70tfbg67 ¥ | 🏂 Vivado Implementation Defaults (Vivado Implementation 2 👻 |                  |  |  |  |
|                                                                                                                                              |               |                    |                | R                                                           | uns to create: 1 |  |  |  |
|                                                                                                                                              |               |                    |                |                                                             |                  |  |  |  |
| (                                                                                                                                            | ?             |                    |                | < Back <u>N</u> ext > Einish                                | Cancel           |  |  |  |

Figure 113: Configure Implementation Runs





4. From the Launch Options window, select Do not launch now and click Next.

| n Create New Runs                                                                                                                         |                |        |                | ×      |
|-------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|----------------|--------|
| Launch Options<br>Configure hosts for launching runs, and/or set advanced launch options                                                  |                |        |                | 4      |
| Launch <u>d</u> irectory: 🛜 <default directory="" launch=""></default>                                                                    |                |        |                | ~      |
| Options <ul> <li>● Launch runs on local host: Number of jobs: 4 </li> <li>● Generate scripts only</li> <li>● Do not launch now</li> </ul> |                |        |                |        |
| •                                                                                                                                         | < <u>B</u> ack | Next > | <u>F</u> inish | Cancel |

#### Figure 114: Launch Options

5. In the **Create New Runs Summary** screen, click **Finish** to create the new runs.

The Design Runs window displays the new active runs in bold.

| Tcl Console Messa | ges Log     | Reports Package Pins De | esign Runs | ×   | Power | Timir | ng Met | thodology D | RC            |     |    |        |      |     |       | ? _      | 0 6    |
|-------------------|-------------|-------------------------|------------|-----|-------|-------|--------|-------------|---------------|-----|----|--------|------|-----|-------|----------|--------|
| Q   素   ≑   I4    | ≪ ►         | <b>» +</b> %            |            |     |       |       |        |             |               |     |    |        |      |     |       |          |        |
| Name              | Constraints | Status                  | WNS        | TNS | WHS   | THS   | TPWS   | Total Power | Failed Routes | LUT | FF | BRAMs  | URAM | DSP | Start | Elapsed  | Strate |
| ✓ impl_1 (active) | constrs_2   | route_design Complete!  | 1.265      | 0.0 | 0.057 | 0.0   | 0.000  | 2.393       | 0             | 21  | 1  | 112.50 | 0    | 68  | 3/1   | 00:14:25 | Vivad  |
| ▷ impl_2          | constrs_2   | Not started             |            |     |       |       |        |             |               |     |    |        |      |     |       |          | Vivad  |
|                   |             |                         |            |     |       |       |        |             |               |     |    |        |      |     |       |          |        |
|                   |             |                         |            |     |       |       |        |             |               |     |    |        |      |     |       |          |        |
|                   |             |                         |            |     |       |       |        |             |               |     |    |        |      |     |       |          |        |
|                   |             |                         |            |     |       |       |        |             |               |     |    |        |      |     |       |          |        |
|                   |             |                         |            |     |       |       |        |             |               |     |    |        |      |     |       |          |        |
| <                 |             |                         |            |     |       |       |        |             |               |     |    |        |      |     |       |          | >      |

#### Figure 115: New Design Runs





## **Step 4: Making Incremental Debug Changes**

In this step, in order to add/delete/edit debug cores, you need to reopen the synthesized netlist. Make debug related changes to the design using the Set Up Debug wizard.

- 1. If you have closed the synthesized netlist, go back to the synthesized design using the **Flow Navigator**.
- 2. For this tutorial, assume that you now need to debug some other nets in addition to the ones already being debugged. However, you want to reuse the previous place and route results. So now, you will debug the nets fftEngine/fifo out[\*].
- 3. Apply the MARK\_DEBUG property to this bus in the netlist window.



Figure 116: Netlist fifo\_out

4. Click Set Up Debug to invoke the Set Up Debug wizard in the Flow Navigator.





5. In the Existing Debug Nets tab, select Continue debugging 110 nets connected to existing debug cores.

| intersection Active Set Up Debug                                                                                                                                  |                |        |        | ×      |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|--------|--------|
| Existing Debug Nets<br>Choose how to handle existing nets connected to debug cores.                                                                               |                |        |        | 4      |
| <ul> <li>Continue debugging 110 nets connected to existing debug core</li> <li>Only debug new nets</li> <li>Disconnect all nets and remove debug cores</li> </ul> |                |        |        |        |
| ?                                                                                                                                                                 | < <u>B</u> ack | Next > | Einish | Cancel |

Figure 117: Existing Debug Nets





6. Click **Next** to debug the new unassigned debug nets.

| interview Set Up Debug                                                             |                |                |        | ×      |
|------------------------------------------------------------------------------------|----------------|----------------|--------|--------|
| Additional Debug Nets<br>Choose additional nets to debug.                          |                |                |        | 4      |
| <ul> <li>Debug 32 unassigned debug nets</li> <li>Debug 32 selected nets</li> </ul> |                |                |        |        |
|                                                                                    | < <u>B</u> ack | <u>N</u> ext > | Einish | Cancel |

Figure 118: Set Up Debug Additional Debug Nets





7. Click **Next** and ensure the new nets are in the list of **Nets to Debug**.

| Q   素   ♦   №   M   +   -                  |               |             |                  |          | 0                 |
|--------------------------------------------|---------------|-------------|------------------|----------|-------------------|
| Name                                       | Clock Domain  | Driver Cell | Probe Type       |          |                   |
| ≻ 『「★ cpuEngine/dcpu_dat_qmem (25)         | clkgen/cpuClk | FDRE        | Data and Trigger | <b>~</b> |                   |
| > 「「★ cpuEngine/dcqmem_adr_qmem (32)       | clkgen/cpuClk | FDRE        | Data and Trigger | <b>~</b> |                   |
| > <b>师微 cpuEngine/dcqmem_dat_qmem</b> (32) | clkgen/cpuClk | FDRE        | Data and Trigger | <b>~</b> |                   |
| > <b>师樂 cpuEngine/dcqmem_sel_qmem</b> (4)  | clkgen/cpuClk | FDRE        | Data and Trigger | <b>~</b> |                   |
| > 师樂 cpuEngine/du_dsr (11)                 | clkgen/cpuClk | FDCE        | Data and Trigger | <b>~</b> |                   |
| > <b>师₩ cpuEngine/dvr00</b> (6)            | clkgen/cpuClk | FDCE        | Data and Trigger | ~        |                   |
| 〉 师 fftEngine/fifo_out (32)                | clkgen/fftClk | RAMB36      | Data and Trigger | Υ.       |                   |
| Find Nets to Add                           |               |             |                  |          | Nets to debug: 14 |

#### Figure 119: Viewing Additional Debug Nets

- 8. Click Next and ensure that two debug cores are created and click Finish.
- Save the new debug XDC commands by clicking the Save Constraints button or selecting File > Save Constraints from the main Vivado toolbar.

## **Step 5: Running Incremental Compile**

In the previous steps, you have updated the design with debug changes. You could run implementation on the new netlist, to place and route the design and work to meet the timing requirements. However, with only minor changes between this iteration and the last, the incremental compile flow lets you reuse the bulk of your prior debug, placement and routing efforts. This can greatly reduce the time it takes to meet timing on design iterations. For more information, refer to *Vivado Design Suite User Guide: Implementation* (UG904).





- 1. Start by defining the design checkpoint (DCP) file to use as the reference design for the incremental compile flow. This is the design from which the Vivado Design Suite draws placement and routing data.
- 2. In the **Design Runs** window, right-click the **impl\_2 run** and select **Set Incremental Compile** from the popup menu. The Set Incremental Compile dialog box opens.
- 3. Click the **Browse** button in the **Set Incremental Compile** dialog box, and browse to the ./project\_cpu\_incremental.runs/impl\_1 directory.
- 4. Select top\_routed.dcp as the incremental compile checkpoint.

| incremental Compile                                                                 |        |
|-------------------------------------------------------------------------------------|--------|
| Enable/disable incremental compiling by choosing or clearing a checkpoint file.     | A      |
| Use checkpoint:synthesized/project_cpu_synthesized.runs/impl_1/top_routed.dcp<br>OK | Cancel |

Figure 120: Set Incremental Compile

- 5. Click **OK**. This information is stored in the INCREMENTAL\_CHECKPOINT property of the selected run. Setting this property tells the Vivado Design Suite to run the incremental compile flow during implementation.
- 6. You can check this property on the current run using the following Tcl command:

get\_property INCREMENTAL\_CHECKPOINT [current\_run]

This returns the full path to the top\_routed.dcp checkpoint.

**TIP:** To disable Incremental Compile for the current run, clear the INCREMENTAL\_CHECKPOINT property. This can be done using the Set Incremental Compile dialog box, or by editing the property directly through the Properties window of the design run, or through the reset\_property command.

7. From the Flow Navigator, select Run Implementation.

This runs implementation on the current run, using the top\_routed.dcp file as the reference design for the incremental compile flow. When the run is finished, the **Implementation Completed** dialog box opens.





8. Select **Open Implemented Design** and click **OK**. As shown in the following figure, the **Design Runs** window shows the elapsed time for implementation run **impl\_2** versus **impl\_1**.

| Tcl Console Messa | ges Log       | Reports Design Runs × P    | ower  | DRC   | Methodo | logy  | Timing |             |               |       |       |        |      |     |                 |          | ? _ 🗆 🖒     |
|-------------------|---------------|----------------------------|-------|-------|---------|-------|--------|-------------|---------------|-------|-------|--------|------|-----|-----------------|----------|-------------|
| Q   ¥   €   I4    | « <b>&gt;</b> | <b>» +</b> %               |       |       |         |       |        |             |               |       |       |        |      |     |                 |          |             |
| Name              | Constraints   | Status                     | WNS   | TNS   | WHS     | THS   | TPWS   | Total Power | Failed Routes | LUT   | FF    | BRAMs  | URAM | DSP | Start           | Elapsed  | Run Strateg |
| 🔸 impl_1          | constrs_2     | Implementation Out-of-date | 0.530 | 0.000 | 0.041   | 0.000 | 0.000  | 2.395       | 0             | 21386 | 18106 | 112.50 | 0    | 68  | 4/18/18 5:11 PM | 00:10:36 | Vivado Impl |
| ✓ impl_2 (active) | constrs_2     | route_design Complete!     | 0.530 | 0.000 | 0.055   | 0.000 | 0.000  | 2.408       | 0             | 22029 | 19264 | 113.50 | 0    | 68  | 4/18/18 5:26 PM | 00:10:05 | Vivado Impl |
|                   |               |                            |       |       |         |       |        |             |               |       |       |        |      |     |                 |          |             |
|                   |               |                            |       |       |         |       |        |             |               |       |       |        |      |     |                 |          |             |
|                   |               |                            |       |       |         |       |        |             |               |       |       |        |      |     |                 |          |             |
|                   |               |                            |       |       |         |       |        |             |               |       |       |        |      |     |                 |          |             |
|                   |               |                            |       |       |         |       |        |             |               |       |       |        |      |     |                 |          |             |

#### Figure 121: Design Runs

**Note:** This is an extremely small design. The advantages of the incremental compile flow are greater and significant with larger, more complex designs.

9. Select the **Reports** tab in the **Results** window area and under **Place Design**, double-click **Incremental Reuse Report** as shown in the following figure.

| Tcl Console Messages Log Reports × Design Runs Pow               | ver DRC Methodology Timing                                                                        | ? _ 🗆 🖸                                           |  |  |  |  |
|------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|---------------------------------------------------|--|--|--|--|
| Q   素   ≑   <b>+</b>   <b>=</b>   ∅   ▶                          |                                                                                                   |                                                   |  |  |  |  |
| Report<br>< implementation                                       | Report Type                                                                                       | Options                                           |  |  |  |  |
| ✓ impl_2                                                         |                                                                                                   |                                                   |  |  |  |  |
| > Design Initialization (init_design)                            |                                                                                                   |                                                   |  |  |  |  |
| > Opt Design (opt_design)                                        |                                                                                                   |                                                   |  |  |  |  |
| <ul> <li>Power Opt Design (power_opt_design)</li> </ul>          |                                                                                                   |                                                   |  |  |  |  |
| <ul> <li>Place Design (place_design)</li> </ul>                  |                                                                                                   |                                                   |  |  |  |  |
| impl_2_place_report_io_0                                         | Report information about all the IO sites on the device (report_io)                               |                                                   |  |  |  |  |
| impl_2_place_report_utilization_0                                | Report on utilization of resources on the targeted device (report_utilization)                    | slr = false; packthru = false; hierarchical = fal |  |  |  |  |
| impl_2_place_report_control_sets_0                               | Report the unique control sets in design (report_control_sets)                                    | verbose = true;                                   |  |  |  |  |
| impl_2_place_report_incremental_reuse_0                          | Report on achievable incremental reuse for the given design-checkpoint (report_incremental_reuse) | hierarchical = false;                             |  |  |  |  |
| impl_2_place_report_incremental_reuse_1                          | Report on achievable incremental reuse for the given design-checkpoint (report_incremental_reuse) | hierarchical = false;                             |  |  |  |  |
| impl_2_place_report_timing_summary_0                             | Report timing summary (report_timing_summary)                                                     | check_timing_verbose = false; setup = false;      |  |  |  |  |
| > Post-Place Power Opt Design (post_place_power_opt_design)      |                                                                                                   |                                                   |  |  |  |  |
| <ul> <li>Post-Place Phys Opt Design (phys_opt_design)</li> </ul> |                                                                                                   |                                                   |  |  |  |  |
| > Route Design (route_design)                                    |                                                                                                   |                                                   |  |  |  |  |
| > Post-Route Phys Opt Design (post_route_phys_opt_design)        |                                                                                                   |                                                   |  |  |  |  |
| > Write Bitstream (write_bitstream)                              |                                                                                                   | ~                                                 |  |  |  |  |
| <                                                                |                                                                                                   | >                                                 |  |  |  |  |

#### Figure 122: Opening Incremental Reuse Report

The Incremental Reuse Report opens in the Vivado IDE text editor. This report shows the percentage of reused Cells, Ports, and Nets. A higher percentage indicates more effective reuse of placement and routing from the incremental checkpoint.





| Proj                  | ect Summar                                                                   | y × Device × impl_                                                                      | 2_place_report_incremen                                                                | tal_reuse_0 - impl_2 ×                                                 |               |                     |            | Ľ   |  |  |
|-----------------------|------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------------------------|---------------|---------------------|------------|-----|--|--|
| Q,                    | 🖬   🔸                                                                        | →   X   🖬   🖬   X                                                                       | × //   ■   ♀                                                                           |                                                                        |               | 1                   | Read-only  | ¢   |  |  |
| 1                     |                                                                              |                                                                                         |                                                                                        |                                                                        |               |                     |            |     |  |  |
| 4<br>5<br>7<br>8<br>9 | Tool Ve<br>  Date<br>  Host<br>  Command<br>  Design<br>  Device<br>  Design | ersion : Vivado v.2018.<br>: Wed Apr 18 17:<br>: xcosmitha32 ru<br>d : report_increment | l (win64) Build 21886<br>34:29 2018<br>nning 64-bit Service 1<br>ntal_reuse -file top_ | 00 Wed Apr 4 18:40:38<br>Pack 1 (build 7601)<br>incremental_reuse_pre_ |               | <br>pt              |            |     |  |  |
| 11<br>12<br>13        | Increment                                                                    | tal Implementation Info                                                                 |                                                                                        |                                                                        |               |                     |            |     |  |  |
|                       | Table of                                                                     |                                                                                         |                                                                                        |                                                                        |               |                     |            |     |  |  |
| 16                    | 1. Reuse                                                                     | Summary                                                                                 |                                                                                        |                                                                        |               |                     |            |     |  |  |
|                       | 1                                                                            | ence Checkpoint Informa                                                                 |                                                                                        |                                                                        |               |                     |            |     |  |  |
|                       | -                                                                            | rison with Reference Ru<br>euse Information                                             | n                                                                                      |                                                                        |               |                     |            |     |  |  |
| 20                    | 1                                                                            |                                                                                         |                                                                                        |                                                                        |               |                     |            |     |  |  |
|                       | 1. Reuse                                                                     | -                                                                                       |                                                                                        |                                                                        |               |                     |            |     |  |  |
|                       |                                                                              |                                                                                         |                                                                                        |                                                                        |               |                     |            |     |  |  |
| 23                    |                                                                              | +                                                                                       |                                                                                        |                                                                        |               |                     |            |     |  |  |
| 25                    | Туре                                                                         | Matched % (of Total)                                                                    | Reuse % (of Total)                                                                     | Fixed % (of Total)                                                     | Total         |                     |            |     |  |  |
|                       | +                                                                            | +<br>  95.69                                                                            |                                                                                        |                                                                        | ++<br>  46475 |                     |            |     |  |  |
|                       | Nets                                                                         |                                                                                         |                                                                                        |                                                                        | 36769         |                     |            |     |  |  |
| 29                    | Pins                                                                         | -                                                                                       | 86.48                                                                                  | -                                                                      | 189880        |                     |            |     |  |  |
|                       | Ports                                                                        |                                                                                         |                                                                                        |                                                                        | 135           |                     |            |     |  |  |
|                       | 1 · · ·                                                                      | +                                                                                       | +                                                                                      | +                                                                      | ++            |                     |            |     |  |  |
| 32<br>33              |                                                                              |                                                                                         |                                                                                        |                                                                        |               |                     |            |     |  |  |
|                       | 1                                                                            | ence Checkpoint Informa                                                                 | tion                                                                                   |                                                                        |               |                     |            |     |  |  |
|                       |                                                                              |                                                                                         |                                                                                        |                                                                        |               |                     |            |     |  |  |
| 36                    |                                                                              |                                                                                         |                                                                                        |                                                                        |               |                     |            |     |  |  |
| 37                    |                                                                              | +                                                                                       |                                                                                        |                                                                        |               |                     |            | + 🗸 |  |  |
| 20                    | < CONTRACTOR                                                                 | astion: L C: Winndo Dol                                                                 | hug/2010 1/project on                                                                  | ingromental/preject                                                    | onu incremen  | tal muna/impl 1/tan | routed dep | >   |  |  |

#### Figure 123: Incremental Reuse Report Sample

In the report, fully reused nets indicate that the entire routing of the nets is reused from the reference design. Partially reused nets indicate that some of the routing of the nets reuses routing from the reference design. Some segments re-route due to changed cells, changed cell placements, or both. Non-reused nets indicate that the net in the current design was not matched in the reference design.

## Conclusion

This concludes the lab. You can close the current project and exit the Vivado IDE.

In this lab, you learned how to run the Incremental Compile Debug flow, using a checkpoint from a previously implemented design. You inserted a new debug core using the Set Up Debug wizard on the





synthesized netlist. You examined the similarity between a reference design checkpoint and the current design by examining the Incremental Reuse Report.





# Lab 8: Using Vivado Serial Analyzer to Debug Serial Links

## Introduction

The Serial I/O analyzer is used to interact with IBERT debug IP cores contained in a design. It is used to debug and verify issues in high speed serial I/O links.

The Serial I/O Analyzer has several benefits as listed below:

- Tight integration with Vivado® IDE.
- Ability to script during netlist customization/generation and serial hardware debug.
- Common interface with the Vivado Integrated Logic Analyzer.

The customizable LogiCORE<sup>™</sup> IP Integrated Bit Error Ratio Tester (IBERT) core for 7 series FPGA GTX transceivers is designed for evaluating and monitoring the GTX transceivers. This core includes pattern generators and checkers that are implemented in FPGA logic, and provides access to ports and the dynamic reconfiguration port attributes of the GTX transceivers. Communication logic is also included to allow the design to be run time accessible through JTAG.

In the course of this tutorial, you:

- Create, customize, and generate an Integrated Bit Error Ratio Tester (IBERT) core design in the Vivado Integrated Design Suite.
- Interact with the design using Serial I/O Analyzer. This includes connecting to the target KC705 board, configuring the device, and interacting with the IBERT/Transceiver IP cores.
- Perform a sweep test to optimize your transceiver channel and to plot data using the IBERT sweep plot GUI feature.





## **Design Description**

You can customize the IBERT core and use it to evaluate and monitor the functionality of transceivers for a variety of Xilinx devices. The focus for this tutorial is on Kintex®-7 GTX transceivers. Accordingly, the KC705 target board is used for this tutorial.

The following figure shows a block diagram of the interface between the IBERT Kintex-7 GTX core interfaces with Kintex-7 transceivers.

- **DRP Interface and GTX Port Registers**: IBERT provides you with the flexibility to change GTX transceiver ports and attributes. Dynamic reconfiguration port (DRP) logic is included, which allows the runtime software to monitor and change any attribute in any of the GTX transceivers included in the IBERT core. When applicable, readable and writable registers are also included. These are connected to the ports of the GTX transceiver. All are accessible at run time using the Vivado logic analyzer.
- **Pattern Generator**: Each GTX transceiver enabled in the IBERT design has both a pattern generator and a pattern checker. The pattern generator sends data out through the transmitter.
- **Error Detector**: Each GTX transceiver enabled in the IBERT design has both a pattern generator and a pattern checker. The pattern checker takes the data coming in through the receiver and checks it against an internally generated pattern.



Figure 124: IBERT Design Flow





# Step 1: Creating, Customizing, and Generating an IBERT Design

To create a project, use the New Project wizard to name the project, to add RTL source files and constraints, and to specify the target device.

- 1. Invoke the Vivado IDE.
- 2. In the Quick Start screen, click Create Project to start the New Project wizard, and click Next.
- 3. In the **Project Name** page, name the new project **ibert\_tutorial** and provide the project location (C:/ibert tutorial). Ensure that **Create Project Subdirectory** is selected. Click **Next**.
- 4. In the **Project Type** page, specify the **Type of Project** to create as **RTL Project**. Click **Next**.
- 5. In the **Add Sources** page, click **Next**.
- 6. In the Add Existing IP page, click Next.
- 7. In the Add Constraints page, click Next.
- 8. In the **Default Part** page, select **Boards** and then select **Kintex-7 KC705 Evaluation Platform**. Click **Next**.
- 9. Review the **New Project Summary** page. Verify that the data appears as expected, per the steps above. Click **Finish**.

*Note*: It might take a moment for the project to initialize.





## **Step 2: Adding an IBERT core to the Vivado Project**

#### 1. In the Flow Navigator click IP Catalog.

The IP Catalog opens.



Figure 125: Opening the Vivado IP Catalog

2. In the search field of the IP Catalog type **IBERT**, to display the IBERT 7 Series GTX IP.



#### Figure 126: Instantiating the IBERT IP from the Vivado IP Catalog

3. Double-click **IBERT 7 Series GTX IP**. This brings up the customization GUI for the IBERT.





- 4. In the **Customize IP** dialog box, choose the following options in the **Protocol Definition** tab:
  - a. Type the name of the component in the **Component Name** field. In this case, leave the name as the default name, **ibert\_7series\_gtx\_0**.
  - b. Ensure that the Silicon Version is selected as General ES/Production.
  - c. Ensure that the **Number of Protocols** option is set to **1**.
  - d. Change the LineRate (Gbps) to 8.
  - e. Change DataWidth to 40.
  - f. Change **Refclk (MHz)** to **125**.
  - g. Ensure that the **Quad Count** is set to **2**.
  - h. Ensure Quad PLL box is selected.

| i Customize IP                                                                                    |                     |                       |             |           |         |             |           |    | <b>×</b>     |
|---------------------------------------------------------------------------------------------------|---------------------|-----------------------|-------------|-----------|---------|-------------|-----------|----|--------------|
| IBERT 7 Series GTX (3.0)                                                                          |                     |                       |             |           |         |             |           |    | 4            |
| Occumentation 🕞 IP Location C Switch to Defaults                                                  |                     |                       |             |           |         |             |           |    |              |
| Show disabled ports                                                                               | Component Name ibe  | ert_7series_gtx_0     |             |           |         |             |           |    | 8            |
|                                                                                                   | Protocol Definition | Protocol Selection    | Clock S     | ettings S | Summary |             |           |    |              |
| RXN_I[3:0]<br>RXP_I[3:0] TXN_0[3:0]<br>GTREFCLK0_I[0:0] TXP_0[3:0]<br>GTREFCLK1_I[0:0] RXOUTCLK_0 | Silicon Version     | er of quads available | for this de | vice is 4 |         |             |           | 1  | ▼            |
|                                                                                                   | Protocol            | LineRate(Gbps)        |             | DataWidth |         | Refclk(MHz) | Quad Coun |    | Quad PLL     |
|                                                                                                   | Custom 1            | • 8                   | 8           | 40        | •       | 125.000 *   | 2         | •  | $\checkmark$ |
|                                                                                                   |                     |                       |             |           |         |             | [         | ОК | Cancel       |

Figure 127: Setting the Protocol Definition on the IBERT Core

- 5. Under the Protocol Selection tab, update the following selections:
  - a. For GTX Location QUAD\_117, in the Protocol Selected column, click the pull-down menu and select Custom 1 / 8 Gbps. This should automatically populate Refclk Selection to MGTREFCLK0 117 and TXUSRCLK Source to Channel 0.





- b. For GTX Location QUAD\_118, do the following:
  - i. In the **Protocol Selected** column, click the pull-down menu and select **Custom 1 / 8 Gbps.**
  - ii. In the **Refclk Selection** column, change the value to **MGTREFCLK0 117**.
  - iii. In the **TXUSRCLK Source** column, change the value to **Channel 0**.

| 🍋 Customize IP                                     |                     |                      |                |     |                  |   |                 | ×          |
|----------------------------------------------------|---------------------|----------------------|----------------|-----|------------------|---|-----------------|------------|
| IBERT 7 Series GTX (3.0)                           |                     |                      |                |     |                  |   |                 | A          |
| 1 Documentation 📄 IP Location C Switch to Defaults |                     |                      |                |     |                  |   |                 |            |
| Show disabled ports                                | Component Name it   | pert_7series_gtx_0   |                |     |                  |   |                 | 8          |
|                                                    | Protocol Definition | Protocol Selection   | Clock Settings | Sum | imary            |   |                 |            |
|                                                    | Please select Proto | col-Quad combination |                |     |                  |   |                 |            |
|                                                    | GTX Location        | Protocol Sele        | ected          |     | Refclk Selection |   | TXUSRCLK Source |            |
|                                                    | QUAD_115            | None                 |                | *   | None             | • | Channel 0       | Ŧ          |
|                                                    | QUAD 116            | None                 |                | v   | None             | • | Channel 0       | - <b>v</b> |
| RXN_[(7:0]<br>RXP_[(7:0]<br>TXN_0(7:0]             | QUAD_117            | Custom 1/8           | Gbps           | *   | MGTREFCLK0 117   |   | Channel 0       | •          |
| GTREFCLK0_(1:0) TXP_0[7:0]                         | QUAD_118            | Custom 1/8           | Gbps           | •   | MGTREFCLK0 117   | • | Channel 0       | •          |
| GTREFCLK1_(1:0) RXOUTCLK_O                         |                     |                      |                |     |                  |   |                 |            |
|                                                    |                     |                      |                |     |                  |   | ОК Са           | ancel      |

#### Figure 128: Setting the Protocol Selection on the IBERT Core

- 6. Click the **Clock Settings** tab and make the following changes for both QUAD\_117 and QUAD\_118:
  - a. Leave the **Source** column at its default value of **External**.
  - b. Change the I/O Standard column to DIFF SSTL15.
  - c. Change the **P Package Pin** to **AD12**.
  - d. Change the **N Package Pin** to **AD11**.
  - e. Leave the Frequency(MHz) at its default value of 200.00.





| 🍌 Customize IP                                                 |                     |                   |                      |               |               |                | ×    |
|----------------------------------------------------------------|---------------------|-------------------|----------------------|---------------|---------------|----------------|------|
| IBERT 7 Series GTX (3.0)                                       |                     |                   |                      |               |               |                | 4    |
| Documentation 🗁 IP Location C Switch to Defaults               |                     |                   |                      |               |               |                |      |
| Show disabled ports                                            | Component Name ib   | ert_7series_gtx_0 |                      |               |               |                | 8    |
|                                                                | Protocol Definition | Protocol Selectio | n Clock Settings Sum | mary          |               |                |      |
|                                                                | RXOUTCLK Probe      |                   |                      |               |               |                |      |
|                                                                | Add RXOUT           | CLK Probes        |                      |               |               |                |      |
| RXN_[(7:0]                                                     | Clock Type          | Source            | I/0 Standard         | P Package Pin | N Package Pin | Frequency(MHz) |      |
| RXP_I[7:0] TXN_O[7:0]                                          | System Clock        | External *        | DIFF SSTL15          | AD12          | AD11 🛛 🕄      | 200.00         | 8    |
| GTREFCLK0_[[1:0] TXP_0[7:0] =<br>GTREFCLK1_[[1:0] RXOUTCLK_0 = | System Clock Term   | ination Settings  |                      |               |               |                |      |
| - SYSCLK_I                                                     | Enable DIFF         | F Term            |                      |               |               |                |      |
|                                                                |                     |                   |                      |               |               |                |      |
|                                                                |                     |                   |                      |               |               |                |      |
|                                                                |                     |                   |                      |               |               |                |      |
|                                                                |                     |                   |                      |               |               |                |      |
|                                                                |                     |                   |                      |               |               |                |      |
|                                                                |                     |                   |                      |               | (             | DK Car         | ncel |

Figure 129: Specifying Clock Settings for the IBERT Core

7. Click the **Summary** tab and ensure that the content matches the following figure, then click **OK**.

| 🏊 Customize IP                                |                            |                     |                |              |                   |    | ×      |
|-----------------------------------------------|----------------------------|---------------------|----------------|--------------|-------------------|----|--------|
| IBERT 7 Series GTX (3.0)                      |                            |                     |                |              |                   |    | 4      |
| Occumentation P Location C Switch to Defaults |                            |                     |                |              |                   |    |        |
| Show disabled ports                           | Component Name             | ibert_7series_gtx_0 |                |              |                   |    | 8      |
|                                               | Protocol Definition        | Protocol Selection  | Clock Settings | Summary      |                   |    |        |
|                                               | IBERT Design Sur           | nmary               |                |              |                   |    |        |
|                                               | Number of P<br>System Cloc |                     |                | 1<br>Externe | II (P Pin : AD12) |    |        |
|                                               | System Cloc                |                     |                |              | II (N Pin : AD12) |    |        |
| RXN_[[7:0]                                    | QUAD Count                 |                     |                | 2            |                   |    |        |
| RXP_I[7:0] TXN_0[7:0]                         | MMCM Coun                  |                     |                | 1            |                   |    |        |
| GTREFCLK0_[[1:0] TXP_0[7:0]                   | RefClk Source              | es                  |                | 1            |                   |    |        |
| GTREFCLK1_[[1:0] RXOUTCLK_0 -                 |                            |                     |                |              |                   |    |        |
| - SYSCLK_I                                    |                            |                     |                |              |                   |    |        |
|                                               |                            |                     |                |              |                   |    |        |
|                                               |                            |                     |                |              |                   |    |        |
|                                               |                            |                     |                |              |                   |    |        |
|                                               |                            |                     |                |              |                   |    |        |
|                                               |                            |                     |                |              |                   |    |        |
|                                               |                            |                     |                |              |                   |    |        |
|                                               |                            |                     |                |              |                   |    |        |
|                                               |                            |                     |                |              |                   | ОК | Cancel |
|                                               |                            |                     |                |              |                   |    |        |
|                                               |                            |                     |                |              |                   |    |        |

Figure 130: IBERT Core Summary Page





8. When the Generate Output Products dialog box opens, click Generate.

| Generate Output Products                                                                                                                                                         |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| The following output products will be generated.                                                                                                                                 |  |
| Preview                                                                                                                                                                          |  |
| Q   素   ≑                                                                                                                                                                        |  |
| <ul> <li>✓ ₱ ibert_7series_gtx_0.xci (Global)</li> <li> <sup>™</sup> Instantiation Template         <sup>™</sup> RTL Sources         <sup>™</sup> Change Log         </li> </ul> |  |
| Synthesis Options                                                                                                                                                                |  |
| ● <u>G</u> lobal                                                                                                                                                                 |  |
| Out of context per IP                                                                                                                                                            |  |
| Run Settings                                                                                                                                                                     |  |
| Number of jobs: 8 🗸                                                                                                                                                              |  |
| Apply     Generate     Skip                                                                                                                                                      |  |

Figure 131: Generate Output Products





9. In the **Sources** window, right-click the IP, and select **Open IP Example Design**.



Figure 132: Open Example IP Design Menu Item





10. In the **Open IP Example Design** dialog box, and specify the location of your project directory. Ensure that the **Overwrite existing example project** is selected and click **OK**.

Note: This opens a new instance of Vivado IDE with the new example design opened.

| 🔶 Open IP Example Design                                                                        | × |
|-------------------------------------------------------------------------------------------------|---|
| Specify a location where the example project directory 'ibert_7series_gtx_0_ex' will be placed. | • |
| Location                                                                                        |   |
| Put example project directory here: C:/Vivado_Debug/2017.1                                      |   |
| ✓ Qverwrite existing example project                                                            |   |
|                                                                                                 |   |
| OK Cancel                                                                                       |   |
|                                                                                                 |   |

Figure 133: Open IP Example Design Dialog Box





# Step 3: Synthesize, Implement and Generate Bitstream for the IBERT design

1. In the newly opened instance of Vivado IDE, click **Generate Bitstream** in the **Flow Navigator**. When the **No Implementation Results Available** dialog box appears. Click **Yes**.



Figure 134: No Implementation Results Available Dialog Box

When the bitstream generation is complete, the **Bitstream Generation Completed** dialog box opens.

2. Select Open Hardware Manager, and click OK.



Figure 135: Bitstream Generation Completed Dialog Box





3. The **Hardware Manager** window appears as shown in the following figure.

| / ibert_7series_gtx_0_ex - [c:/ | Vivado_Debug/2017/ibert_7series_gtx_0_ex/ibert_7series_gtx_0_ex.xpr] - Vivado |                              |
|---------------------------------|-------------------------------------------------------------------------------|------------------------------|
| File Edit Flow Tools            | Window Layout View Help Qr Quick Access                                       | write_bitstream Complete 🛛 🗸 |
|                                 | 🕨 👫 🏟 ∑ 🗶 🖉 😹 Dashboard                                                       | 🔚 Serial I/O Analyzer 🗸 🗸    |
| Flow Navigator                  | - HARDWARE MANAGER - unconnected                                              | ? ×                          |
| ✓ PROJECT MANAGER               | 1 No hardware target is open. Open target                                     |                              |
| Settings                        | Hardware ? _ D L X                                                            |                              |
| Add Sources                     |                                                                               |                              |
| Language Templates              |                                                                               |                              |
| 후 IP Catalog                    |                                                                               |                              |
|                                 |                                                                               |                              |
| ✓ IP INTEGRATOR                 | No content                                                                    |                              |
| Create Block Design             |                                                                               |                              |
| Open Block Design               |                                                                               |                              |
| Generate Block Design           |                                                                               |                              |
| ✓ SIMULATION                    | Properties ? _ D 🗹 X                                                          |                              |
| Run Simulation                  | $\leftarrow   \Rightarrow   \diamond$                                         |                              |
|                                 |                                                                               |                              |
| ✓ RTL ANALYSIS                  |                                                                               |                              |
| > Open Elaborated Design        | Select an object to see properties                                            |                              |
| ✓ SYNTHESIS                     |                                                                               |                              |
| Run Synthesis                   |                                                                               |                              |
| > Open Synthesized Desigr       | Tcl Console Messages Serial I/O Links × Serial I/O Scans                      | 2 _ 0 6                      |
| ✓ IMPLEMENTATION                |                                                                               |                              |
| Run Implementation              |                                                                               |                              |
| > Open Implemented Desig        |                                                                               |                              |
|                                 |                                                                               |                              |
| Y PROGRAM AND DEBUG             | No content                                                                    |                              |
| Generate Bitstream              |                                                                               |                              |
| ✓ Open Hardware Manage          |                                                                               |                              |
| Open Target 🗸 🗸                 |                                                                               |                              |
|                                 |                                                                               |                              |

Figure 136: Hardware Manager Window





## **Step 4: Interact with the IBERT core using Serial I/O Analyzer**

In this tutorial step, you connect to the KC705 target board, program the bitstream created in the previous step, and then use the Serial I/O Analyzer to interact with the IBERT design that you created in Step 1. You perform some analysis using various input patterns and loopback modes, while observing the bit error count.



Figure 137: Open a New Hardware Target

1. Click Open New Target. When the Open Hardware Target wizard opens, click Next.

| 🥕 Open New Hardware | Target                                                                                                                                                                                                                                                          |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HLX Editions        | Open Hardware Target<br>This wizard will guide you through connecting to a hardware target.<br>To connect to a remote hardware target, provide the host name and IP port of the remote machine on which the<br>instance of a Vivado Hardware Server is running. |
| (?)                 | < <u>B</u> ack Cancel                                                                                                                                                                                                                                           |

Figure 138: Open New Hardware Target Wizard

2. In the Connect to field, choose Local server. Click Next.





| 🥕 Open New Hardware Target                                                                                                                                                                                            |                                                                                      |      |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|------|--|--|--|--|--|
| Hardware Server Settings<br>Select local or remote hardware server, then configure the host name and port settings. Use Local server if the target is attached to the<br>local machine; otherwise, use Remote server. |                                                                                      |      |  |  |  |  |  |
| <u>C</u> onnect to:                                                                                                                                                                                                   | Local server (target is on local machine)                                            |      |  |  |  |  |  |
|                                                                                                                                                                                                                       |                                                                                      |      |  |  |  |  |  |
|                                                                                                                                                                                                                       |                                                                                      |      |  |  |  |  |  |
|                                                                                                                                                                                                                       |                                                                                      |      |  |  |  |  |  |
| Click Next to                                                                                                                                                                                                         | launch and/or connect to the hw_server (port 3121) application on the local machine. |      |  |  |  |  |  |
| ?                                                                                                                                                                                                                     | < <u>B</u> ack <u>N</u> ext > <u>F</u> inish Car                                     | icel |  |  |  |  |  |

Figure 139: Vivado CSE Server Name Page





#### 3. In the **Select Hardware Target** page, and click **Next**.

There is only one target board in this case to connect to, so that the default is selected.

| Open New H                | ardware Targ      | et               |                                             |               |                  |                     |                    | <b>X</b> |
|---------------------------|-------------------|------------------|---------------------------------------------|---------------|------------------|---------------------|--------------------|----------|
|                           | e target from the |                  | argets, then set th<br>t a different target |               | riate JTAG clock | (TCK) frequency. If | you do not see the | A        |
| Hardware <u>T</u> arg     | ets               |                  |                                             |               |                  |                     |                    |          |
| Туре                      | Name              |                  | JTAG Clock Fre                              | quency        |                  |                     |                    |          |
| xilinx_tcf                | Xilinx/Port_#00   | 03.Hub_#0004     | 600000                                      | ~             |                  |                     |                    |          |
|                           |                   |                  |                                             |               |                  |                     |                    |          |
| Hardware <u>D</u> evi     | ces (for unknov   | vn devices, spec | Add Xilin                                   |               | Cable (XVC)      |                     |                    |          |
|                           |                   | · · · ·          |                                             |               |                  |                     |                    |          |
| Name                      | ID Code           | IR Length        |                                             | ,, <u>,</u> , |                  |                     |                    |          |
| Name<br>xc7k325t_0        |                   |                  |                                             |               |                  |                     |                    |          |
| <pre>(i) xc7k325t_(</pre> |                   | IR Length<br>6   |                                             |               |                  |                     |                    |          |

Figure 140: Select Hardware Target Page





4. In the **Open Hardware Target Summary** page, review the options that you selected. Click **Finish**.

| 🅕 Open New Hardware           | e Target                                                                                                                                                                                                                                                                           | ×     |
|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| HLx Editions                  | <ul> <li>Open Hardware Target Summary</li> <li>Hardware Server Settings: <ul> <li>Server: localhost:3121</li> </ul> </li> <li>Target Settings: <ul> <li>Target Settings:</li> <li>Target xilinx_tcf/Xilinx/Port_#0003.Hub_#0004</li> <li>Frequency: 6000000</li> </ul> </li> </ul> |       |
| E XILINX<br>ALL PROGRAMMABLE. | To connect to the hardware described above, click Finish          < Back       Next >       Finish       C                                                                                                                                                                         | ancel |

Figure 141: Open Hardware Target Summary Dialog Box

5. The **Hardware** window in Vivado IDE should show the status of the target FPGA device on the KC705 board.



Figure 142: Hardware Window Showing the XC7K325T Device on the KC705 Board

6. Select **XC7K325T\_0(0)** in the **Hardware** window, right-click and select **Program Device**.





| Hardware               |         |                                                     | ? _ 🗆 🖒 X                  |    |  |  |  |
|------------------------|---------|-----------------------------------------------------|----------------------------|----|--|--|--|
| Q   ₹   \$   ¢         | 2       | ▶   ≫   ■                                           | •                          |    |  |  |  |
| Name                   |         |                                                     | Status                     |    |  |  |  |
| Y 📱 localhost (1)      |         |                                                     | Connected                  |    |  |  |  |
| ✓ Ø xilinx_tcf/Xi      | ilinx/P | ort_#0003.Hu                                        | t_#0003.Hu Open            |    |  |  |  |
| ✓ ∅ xc7k325t<br>W XADC |         | Hardware Devic                                      | Hardware Device Properties |    |  |  |  |
|                        |         | Program Device                                      | e                          |    |  |  |  |
|                        |         | Verify Device                                       |                            | hs |  |  |  |
|                        | С       | C Refresh Device<br>Add Configuration Memory Device |                            |    |  |  |  |
| Hardware Device Pro    |         |                                                     |                            |    |  |  |  |
| xc7k325t_0             |         | Boot from Configuration Memory Device               |                            |    |  |  |  |
| Name: p                |         | Program BBR Key                                     |                            |    |  |  |  |
| Part: >                |         | Clear BBR Key.                                      |                            |    |  |  |  |
| ID code:               |         | Program eFUSE                                       | E Registers                |    |  |  |  |
| IR length:             |         | Export to Spread                                    | dsheet                     |    |  |  |  |
| General Propertie      | s       |                                                     | · · · · ·                  |    |  |  |  |

Figure 143: Program Target Device

7. The **Program Device** dialog box opens. Make sure that the correct .bit file is selected, and click **Program**.

| 🍌 Program Device                                                                                                                                                                                                  |                                                                | ×     |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|-------|--|--|--|
| Select a bitstream programming file and download it to your hardware device. You can<br>optionally select a debug probes file that corresponds to the debug cores contained in the<br>bitstream programming file. |                                                                |       |  |  |  |
| Bitstre <u>a</u> m file:                                                                                                                                                                                          | t_7series_gtx_0_ex.runs/impl_1/example_ibert_7series_gtx_0.bit | 3 8   |  |  |  |
| Debu <u>q</u> probes file:                                                                                                                                                                                        |                                                                |       |  |  |  |
| ✓ Enable end of st                                                                                                                                                                                                | tartup check                                                   |       |  |  |  |
| ?                                                                                                                                                                                                                 | <u>P</u> rogram C                                              | ancel |  |  |  |

Figure 144: Program Device Dialog Box with .bit File





8. The **Hardware** window now shows the IBERT IP that you customized and implemented from the previous steps. It contains two QUADS each of which has four GTX transceivers. These components of the IBERT were detected while scanning the device after downloading the bitstream. If you do not see the QUADS then select the **XC7K325** device, right-click and select **Refresh Device**.

| Hardware                                                                                                        | ? _ 🗆 🖒 X  |
|-----------------------------------------------------------------------------------------------------------------|------------|
| $Q \mid \underbrace{\star} \mid \diamondsuit \mid \wp \mid \blacktriangleright \mid \gg \mid \blacksquare \mid$ | 0          |
| Name                                                                                                            | Status     |
| <ul> <li>Iocalhost (1)</li> </ul>                                                                               | Connected  |
| ✓ ✓ ✓ ✓ × xilinx_tcf/Xilinx/Port_#0003.Hu                                                                       | Open       |
| <ul> <li>v xc7k325t_0 (2)</li> </ul>                                                                            | Programmed |
| XADC (System Monitor)                                                                                           |            |
| <ul> <li>IBERT (IBERT)</li> </ul>                                                                               |            |
| ✓ Ŋ Quad_117 (5)                                                                                                |            |
| COMMON_X0Y2                                                                                                     | Locked     |
| NGT_X0Y8                                                                                                        | No Link    |
| NGT_X0Y9                                                                                                        | No Link    |
| NGT_X0Y10                                                                                                       | No Link    |
| NGT_X0Y11                                                                                                       | No Link    |
| 🗸 🖄 Quad_118 (5)                                                                                                |            |
| COMMON_X0Y3                                                                                                     | Locked     |
| NGT_X0Y12                                                                                                       | No Link    |
| NGT_X0Y13                                                                                                       | No Link    |
| NGT_X0Y14                                                                                                       | No Link    |
| NGT_X0Y15                                                                                                       | No Link    |
|                                                                                                                 |            |

Figure 145: The Hardware Window Showing the QUADS after Device Programming





9. Next, create links for all eight transceivers. Vivado Serial I/O analyzer is a link-based analyzer, which allows users to link between any transmitter and receiver GTs within the IBERT design. For this tutorial, simply link the TX and RX of the same channel. To create a link, right-click the **IBERT Core** in the **Hardware** window and click **Create Links**.

| Hardware                           |                       |       | ? _ 🗆          | Ц×      |        |
|------------------------------------|-----------------------|-------|----------------|---------|--------|
| Q   ¥   ♦   ∅   ▶   ≫              |                       |       |                | ø       |        |
| Name                               |                       | St    | atus           |         |        |
| <ul> <li>Iocalhost (1)</li> </ul>  |                       | Co    | onnected       |         |        |
| ✓ ✓ × xilinx_tcf/Xilinx/Port_#000  | 3.Hu                  | . Op  | pen            |         |        |
| <ul> <li>xc7k325t_0 (2)</li> </ul> |                       | Pr    | rogrammed      |         |        |
| 🖉 XADC (System Monit               | or)                   |       |                |         |        |
| 🗸 📴 IBERT (IBERT)                  |                       | IBER  | T Core Prop    | erties  | Ctrl+E |
| ✓ 🖏 Quad_117 (5)                   |                       |       |                |         |        |
| COMMON_X0Y                         |                       |       | te Links       | L.      |        |
| NGT_X0Y8                           |                       | Auto- | -detect Links  |         |        |
| NGT_X0Y9                           | X0Y9 Serial I/O Links |       |                |         |        |
| NGT_X0Y10                          |                       | Seria | al I/O Scans   |         |        |
| NGT_X0Y11                          |                       | Com   | mit Propertie  | 9       |        |
| ✓ 🖏 Quad_118 (5)                   | с                     |       | esh Serial I/O |         |        |
|                                    | C                     | Relie | esti Senari/O  | Objects |        |
| NGT_X0Y12                          |                       | Sele  | ct             |         | F      |
| NGT_X0Y13                          |                       | Expo  | rt to Spreads  | heet    |        |
| NGT_X0Y14                          |                       | N     | o Link         |         |        |
| NGT_X0Y15                          |                       | N     | o Link         |         |        |
| <                                  |                       |       |                | <b></b> |        |
|                                    |                       |       |                |         | 1      |

Figure 146: Create Links

The **Create Links** dialog box opens.





10. Ensure the first transceiver pairs (MGT\_X0Y8/TX and MGT\_X0Y8/RX) are selected.

| Create Links                                             |                                                  |
|----------------------------------------------------------|--------------------------------------------------|
| To create a new link select a TX GT and/or an RX GT, the | n click the Add button on the New Links toolbar. |
|                                                          |                                                  |
| TX GTs                                                   | RX GTs                                           |
| Search: Q-                                               | Search: Q.                                       |
| MGT_X0Y8/TX (xc7k325t_0/Quad_117)                        | MGT_X0Y8/RX (xc7k325t_0/Quad_117)                |
| MGT_X0Y9/TX (xc7k325t_0/Quad_117)                        | MGT_X0Y9/RX (xc7k325t_0/Quad_117)                |
| MGT_X0Y10/TX (xc7k325t_0/Quad_117)                       | MGT_X0Y10/RX (xc7k325t_0/Quad_117)               |
| MGT_X0Y11/TX (xc7k325t_0/Quad_117)                       | MGT_X0Y11/RX (xc7k325t_0/Quad_117)               |
| MGT_X0Y12/TX (xc7k325t_0/Quad_118)                       | MGT_X0Y12/RX (xc7k325t_0/Quad_118)               |
| MGT_X0Y13/TX (xc7k325t_0/Quad_118)                       | MGT_X0Y13/RX (xc7k325t_0/Quad_118)               |
| MGT_X0Y14/TX (xc7k325t_0/Quad_118)                       | MGT_X0Y14/RX (xc7k325t_0/Quad_118)               |
| MGT_X0Y15/TX (xc7k325t_0/Quad_118)                       | MGT_X0Y15/RX (xc7k325t_0/Quad_118)               |
| New Links                                                |                                                  |
|                                                          |                                                  |
|                                                          |                                                  |
| Proce the                                                | button to Add Link                               |
| riess uie                                                |                                                  |
|                                                          |                                                  |
|                                                          |                                                  |
| ✓ Create link group                                      |                                                  |
| Link group description: Link Group 0                     | 0                                                |
| Eink Group desemption. Eink Group of                     |                                                  |
| ✓ Open Serial I/O Analyzer layout                        |                                                  |
|                                                          | OK                                               |

Figure 147: Selecting the Transceiver Pairs for Creating New Links





11. Click the "+" button add a new link. In the **Link group description** field, type **Link Group SMA**. Select the **Internal Loopback** check box.

| i o create a nev      | v link select a TX GT and/or an RX GT, then                                                                          | click the Add button on the New Links toolb                                                                                                                    | par.                          |
|-----------------------|----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|
| TX GTs                |                                                                                                                      | RX GTs                                                                                                                                                         |                               |
| Search: Q-            |                                                                                                                      | Search: Q.                                                                                                                                                     |                               |
| _                     | /TX (xc7k325t_0/Quad_117)<br>0/TX (xc7k325t_0/Quad_117)                                                              | MGT_X0Y9/RX (xc7k325t_0/Qua<br>G MGT_X0Y10/RX (xc7k325t_0/Qua)                                                                                                 |                               |
| MGT_X0Y1 MGT_X0Y1     | 1/TX (xc7k325t_0/Quad_117)<br>2/TX (xc7k325t_0/Quad_118)<br>3/TX (xc7k325t_0/Quad_118)<br>4/TX (xc7k325t_0/Quad_118) | <ul> <li>MGT_X0Y11/RX (xc7k325t_0/Qu</li> <li>MGT_X0Y12/RX (xc7k325t_0/Qu</li> <li>MGT_X0Y13/RX (xc7k325t_0/Qu</li> <li>MGT_X0Y14/RX (xc7k325t_0/Qu</li> </ul> | ad_117)<br>ad_118)<br>ad_118) |
| ▶ MGT_X0Y1            | 5/TX (xc7k325t_0/Quad_118)                                                                                           | MGT_X0Y15/RX (xc7k325t_0/Qu                                                                                                                                    |                               |
| New Links             |                                                                                                                      |                                                                                                                                                                |                               |
| +   -                 |                                                                                                                      |                                                                                                                                                                |                               |
| Description           | ТХ                                                                                                                   | RX                                                                                                                                                             | Internal Loopback             |
| % Link 0              | MGT_X0Y8/TX (xc7k325t_0/Quad_117)                                                                                    | MGT_X0Y8/RX (xc7k325t_0/Quad_117)                                                                                                                              | $\checkmark$                  |
|                       |                                                                                                                      |                                                                                                                                                                |                               |
| ✓ <u>C</u> reate link | scription: Link Group SMA                                                                                            |                                                                                                                                                                | 8                             |
|                       |                                                                                                                      |                                                                                                                                                                |                               |

#### Figure 148: Create Links Dialog Box

For the first link group, call this Link Group SMA as this is the only transceiver channel that is linked through the SMA cables. The new link shows up in the **Links** window.





| Tcl Console Me   | Tcl Console Messages Serial I/O Links × Serial I/O Scans |             |         |       |         |       |            |              |              |
|------------------|----------------------------------------------------------|-------------|---------|-------|---------|-------|------------|--------------|--------------|
| Q   ¥   ♦        | +                                                        |             |         |       |         |       |            |              |              |
| Name             | Create Links                                             | RX          | Status  | Bits  | Errors  | BER   | BERT Reset | TX Pattern   | RX Pattern   |
| 🖨 Ungrouped l    | Create Link Group                                        |             |         |       |         |       |            |              |              |
| 👻 🚳 Link Group S |                                                          |             |         |       |         |       | Reset      | PRBS 7-bit 🗸 | PRBS 7-bit 🗸 |
| % Link 0         |                                                          | MGT_X0Y8/RX | 7.988 G | 1.356 | 2.74E10 | 2.021 | Reset      | PRBS 7-bit 🐱 | PRBS 7-bit 🐱 |
|                  | Create Sweep                                             |             |         |       |         |       |            |              |              |
|                  |                                                          |             |         |       |         |       |            |              |              |
|                  |                                                          |             |         |       |         |       |            |              |              |

#### Figure 149: Create Link Groups for Other Transceiver Pairs

12. Click **Create Link** again to create link groups for the rest of the transceiver pairs. To do this ensure that the transceiver pairs are selected, and click the + sign icon (add new link) repeatedly, until all the links have been added to the new link group called **Link Group Internal Loopback**. Click **OK**.





| X GTs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                | RX GTs                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Search: Q-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                | Search: Q-                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Vew Links                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                |                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| +  -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                |                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | тх                                                                                                             | RX                                                                                                             | Internal Loopback                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| % Link 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | MGT_X0Y9/TX (xc7k325t_0/Quad_117)                                                                              | MGT_X0Y9/RX (xc7k325t_0/Quad_117)                                                                              | $\checkmark$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| O LINK I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                | MGT_X0Y10/RX (xc7k325t_0/Quad_117)                                                                             | $\checkmark$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| % Link 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | MGT_X0Y10/TX (xc7k325t_0/Quad_117)                                                                             |                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | MGT_X0Y10/TX (xc7k325t_0/Quad_117)<br>MGT_X0Y11/TX (xc7k325t_0/Quad_117)                                       | MGT_X0Y11/RX (xc7k325t_0/Quad_117)                                                                             | $\checkmark$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| % Link 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                |                                                                                                                | <ul> <li>Image: A start of the start of</li></ul> |
| % Link 2<br>% Link 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | MGT_X0Y11/TX (xc7k325t_0/Quad_117)                                                                             | MGT_X0Y11/RX (xc7k325t_0/Quad_117)                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Substance 2<br>Substance 2<br>Substa | MGT_X0Y11/TX (xc7k325t_0/Quad_117)<br>MGT_X0Y12/TX (xc7k325t_0/Quad_118)                                       | MGT_X0Y11/RX (xc7k325t_0/Quad_117)<br>MGT_X0Y12/RX (xc7k325t_0/Quad_118)                                       | $\checkmark$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| S Link 2<br>Link 3<br>Link 4<br>Link 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | MGT_X0Y11/TX (xc7k325t_0/Quad_117)<br>MGT_X0Y12/TX (xc7k325t_0/Quad_118)<br>MGT_X0Y13/TX (xc7k325t_0/Quad_118) | MGT_X0Y11/RX (xc7k325t_0/Quad_117)<br>MGT_X0Y12/RX (xc7k325t_0/Quad_118)<br>MGT_X0Y13/RX (xc7k325t_0/Quad_118) | <ul> <li>Image: A start of the start of</li></ul> |

Figure 150: Create Link Dialog Box to Create the Second Link Group





13. After the links have been created, they are added to the **Links** window as shown.

| Tcl Console Messages     | console Messages Serial I/O Links × Serial I/O Scans |              |            |          |          |          |            |                 |   |  |
|--------------------------|------------------------------------------------------|--------------|------------|----------|----------|----------|------------|-----------------|---|--|
| Q   素   ≑   <del>1</del> |                                                      |              |            |          |          |          |            |                 |   |  |
| Name                     | ТХ                                                   | RX           | Status     | Bits     | Errors   | BER      | BERT Reset | TX Pattern      | R |  |
| Ungrouped Links (0)      |                                                      |              |            |          |          |          |            |                 |   |  |
| Y 🚳 Link Group SMA (1)   |                                                      |              |            |          |          |          | Reset      | PRBS 7-bit 🗸    | Ρ |  |
| % Link 0                 | MGT_X0Y8/TX                                          | MGT_X0Y8/RX  | 7.988 Gbps | 1.343E12 | 2.645E11 | 1.969E-1 | Reset      | PRBS 7-bit 💉    | Ρ |  |
| ✓ I Link Group Internal  |                                                      |              |            |          |          |          | Reset      | PRBS 7-bit 🗸    | Ρ |  |
| % Link 1                 | MGT_X0Y9/TX                                          | MGT_X0Y9/RX  | 7.987 Gbps | 3.805E12 | 2.079E12 | 5.465E-1 | Reset      | PRBS 7-bit 🗸    | Ρ |  |
| % Link 2                 | MGT_X0Y10/TX                                         | MGT_X0Y10/RX | 7.988 Gbps | 3.805E12 | 2.175E12 | 5.715E-1 | Reset      | PRBS 7-bit \vee | Ρ |  |

Figure 151: Links Window after Link Groups are Created

The status of the links indicate an **8.0 Gbps** line rate.

For more information about the different columns of the **Links** windows, see the <u>Vivado Design</u> <u>Suite User Guide: Programming and Debugging (UG908)</u>.

- 14. Change the GT properties of the rest of the transceivers as described above.
- 15. Next, create a 2D scan. Click Create Scan in the Links window.

| General Proper   | ties |                            |        |      |
|------------------|------|----------------------------|--------|------|
| Tcl Console Me   |      | Link Properties            | Ctrl+E | ans  |
| Q ≚ ♦            | ×    | Delete                     | Delete |      |
| · · · · ·        |      | Create Links               |        |      |
| Name             |      |                            |        | us   |
| 🗅 Ungrouped I    |      | Create Link Group          |        |      |
| 👻 🚳 Link Group § |      | Create Stan                |        |      |
| % Link 0         |      | Create Sweep               |        | Gbps |
| 👻 🚳 Link Group I |      | Commit Properties          |        |      |
| % Link 1         | С    | Refresh Serial I/O Objects |        | Gbps |

Figure 152: Creating a 2D Scan for Link 1

The **Create Scan** dialog box opens. In this dialog box, you can change the various scan properties. In this case, leave everything to its default value and click **OK**. For more information on the scan properties, see <u>Vivado Design Suite User Guide: Programming and Debugging (UG908)</u>.





| 🍌 Create Sca                                                                                       | n                                 |                       | × |  |  |
|----------------------------------------------------------------------------------------------------|-----------------------------------|-----------------------|---|--|--|
| Set the description and other properties to create and optionally run a scan on the selected link. |                                   |                       |   |  |  |
| Link: L                                                                                            | .ink 0 (MGT_X0Y8/TX, MGT_X0Y8/RX) |                       |   |  |  |
| Description:                                                                                       | Scan 0 🛛                          |                       |   |  |  |
| Scan Propert                                                                                       | ties                              |                       |   |  |  |
| <u>S</u> can type:                                                                                 |                                   | 2D Full Eyescan 🗸     |   |  |  |
| <u>H</u> orizontal                                                                                 | increment                         | 8 ~                   |   |  |  |
| H <u>o</u> rizontal                                                                                | range:                            | -0.500 UI to 0.500 UI |   |  |  |
| <u>V</u> ertical inc                                                                               | crement:                          | 8 ~                   |   |  |  |
| V <u>e</u> rtical rai                                                                              | nge:                              | 100% ~                |   |  |  |
|                                                                                                    |                                   |                       |   |  |  |
| Dwell                                                                                              |                                   |                       |   |  |  |
| • <u>B</u> ER:                                                                                     | 1e-5                              | ~                     |   |  |  |
| ◯ <u>T</u> ime:                                                                                    |                                   | 0 🌲                   |   |  |  |
| ✓ <u>R</u> un scan                                                                                 |                                   |                       |   |  |  |
| ?                                                                                                  |                                   | OK                    | I |  |  |

Figure 153: The Create Scan Dialog Box





The Scan Plot window opens as shown in the following figure.



Figure 154: 2D Scan Plot

The 2D Scan Plot is a heat map of the BER value.

You can also perform a Sweep test on the links that you created earlier.

16. In the Links window, highlight Link 0 under the Link called Link Group SMA, right-click and select Create Sweep.







Figure 155: Create a Sweep Test

17. The **Create Sweep** dialog box opens, as shown below. Various properties for the Sweep test can be changed in this dialog box. Leave all the values to its default state and click **OK**.





| Create Sweep                                                                                             |                       |                                                     |                                                                          |             |  |  |  |  |
|----------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------------------------------|--------------------------------------------------------------------------|-------------|--|--|--|--|
| Select the sweep properties and values to create and optionally run a set of scans on the selected link. |                       |                                                     |                                                                          |             |  |  |  |  |
| Link: Link 0 (MGT_                                                                                       | X0Y8/TX, MGT_X0Y8     | /RX)                                                |                                                                          |             |  |  |  |  |
| Description: Sweep 0                                                                                     |                       |                                                     |                                                                          |             |  |  |  |  |
| Scan Properties                                                                                          |                       |                                                     |                                                                          |             |  |  |  |  |
| Scan type:                                                                                               | 2D Full Eyescan       | ~                                                   |                                                                          |             |  |  |  |  |
| <u>H</u> orizontal increment:                                                                            | 8                     | ~                                                   |                                                                          |             |  |  |  |  |
| H <u>o</u> rizontal range:                                                                               | -0.500 UI to 0.500 U  | л 🗸                                                 |                                                                          |             |  |  |  |  |
| Vertical increment:                                                                                      | 8                     | ~                                                   |                                                                          |             |  |  |  |  |
| Vertical range:                                                                                          | 100%                  | ~                                                   |                                                                          |             |  |  |  |  |
| Dwell                                                                                                    | Durall                |                                                     |                                                                          |             |  |  |  |  |
| • <u>B</u> ER: 1e-5                                                                                      |                       | ~                                                   |                                                                          |             |  |  |  |  |
|                                                                                                          |                       |                                                     |                                                                          |             |  |  |  |  |
|                                                                                                          | ○ <u>T</u> ime: 0 ♣   |                                                     |                                                                          |             |  |  |  |  |
| Sweep Properties                                                                                         |                       |                                                     |                                                                          |             |  |  |  |  |
| Sweep <u>m</u> ode: Sen                                                                                  | ii Custom 🗸 🗸         | For each property select value                      | s to be swept. The sweep will cover all combinations of property values. |             |  |  |  |  |
| Set Properties & Va                                                                                      | ues Preview 81        | Scans                                               |                                                                          |             |  |  |  |  |
| +   -   +                                                                                                |                       |                                                     |                                                                          |             |  |  |  |  |
| Order Property                                                                                           | Name Valu             | es to Sweep                                         |                                                                          | # of Values |  |  |  |  |
| % 1 RXTERN                                                                                               | I <b>▼</b> 100        |                                                     |                                                                          |             |  |  |  |  |
| S 2 TXDIFFS                                                                                              | WING • 269            | 269 mV (0000),741 mV (0111),1119 mV (1111) 🔹 3      |                                                                          |             |  |  |  |  |
| % 3 TXPOST                                                                                               |                       |                                                     |                                                                          |             |  |  |  |  |
| % 4 TXPRE                                                                                                | ▼ 0.00                | 7 0.00 dB (00000),4.08 dB (01111),6.02 dB (11111) 3 |                                                                          |             |  |  |  |  |
| Reset RX after applyin                                                                                   | g Settings for each s | can                                                 |                                                                          |             |  |  |  |  |
| ✓ Run s <u>w</u> eep                                                                                     |                       |                                                     |                                                                          |             |  |  |  |  |
| ?                                                                                                        |                       |                                                     | ок                                                                       | Cancel      |  |  |  |  |
|                                                                                                          |                       |                                                     |                                                                          |             |  |  |  |  |

Figure 156: Create Sweep Dialog Box





Because here are four different Sweep Properties and each of these properties has three different values (as seen in the **Values to Sweep** column), a total number of 81 sweep tests are carried out. The **Scans** window shows the results of all the scans that have been done for the selected link.



**CAUTION!** Since there are 81 scans to be done, it could be a few minutes before all the scans are complete.

| Tcl Console Messages | Serial | I/O Links Serial I/O Scans ×                                                 |          |             |        |          |           |           |           | ? _ 🗆 [               |
|----------------------|--------|------------------------------------------------------------------------------|----------|-------------|--------|----------|-----------|-----------|-----------|-----------------------|
| Q   ≚   ♦   ▶   ■    | B      | <b>B</b>                                                                     |          |             |        |          |           |           |           |                       |
| Name                 | Link   | Link Settings                                                                | Reset RX | Scan Type   | Status | Progress | Open Area | Open UI % | Horz Incr | Horz Range            |
| > 🗁 Scans (4)        |        |                                                                              |          |             |        |          |           |           |           |                       |
| 🗸 🚽 Sweep 0 (81)     |        |                                                                              |          | 2d_full_eye | Done   |          |           |           | 8 🗸       | -0.500 UI to 0.500 UI |
| 🧧 Sweep 0 - Scan 2   |        | RXTERM {100 mV} TXDIFFSWING {269 mV (0000)} TXPOST {0.00 dB (00000)} TXPRE { |          | 2d_full_eye | Done   | 100%     | 10176     | 77.78     | 8 🗸       | -0.500 UI to 0.500 UI |
| 🧧 Sweep 0 - Scan 3   |        | RXTERM {100 mV} TXDIFFSWING {269 mV (0000)} TXPOST {0.00 dB (00000)} TXPRE { |          | 2d_full_eye | Done   | 100%     | 10240     | 77.78     | 8 V       | -0.500 UI to 0.500 UI |
| Sweep 0 - Scan 4     |        | RXTERM {100 mV} TXDIFFSWING {269 mV (0000)} TXPOST {0.00 dB (00000)} TXPRE { |          | 2d_full_eye | Done   | 100%     | 10112     | 77.78     | 8 ~       | -0.500 UI to 0.500 UI |
| 🔲 Sweep 0 - Scan 5   |        | RXTERM {100 mV} TXDIFFSWING {269 mV (0000)} TXPOST {4.08 dB (01111)} TXPRE { |          | 2d_full_eye | Done   | 100%     | 10176     | 77.78     | 8 ~       | -0.500 UI to 0.500 UI |
| 🧧 Sweep 0 - Scan 6   |        | RXTERM {100 mV} TXDIFFSWING {269 mV (0000)} TXPOST {4.08 dB (01111)} TXPRE { |          | 2d_full_eye | Done   | 100%     | 10240     | 77.78     | 8 ~       | -0.500 UI to 0.500 UI |
| 🧧 Sweep 0 - Scan 7   |        | RXTERM {100 mV} TXDIFFSWING {269 mV (0000)} TXPOST {4.08 dB (01111)} TXPRE { |          | 2d_full_eye | Done   | 100%     | 10240     | 77.78     | 8 🗸       | -0.500 UI to 0.500 UI |
| Sweep 0 - Scan 8     |        | RXTERM {100 mV} TXDIFFSWING {269 mV (0000)} TXPOST {12.96 dB (11111)} TXPRE  |          | 2d_full_eye | Done   | 100%     | 10112     | 77.78     | 8 ~       | -0.500 UI to 0.500 UI |
| 🔲 Sweep 0 - Scan 9   |        | RXTERM (100 mV) TXDIFFSWING (269 mV (0000)) TXPOST (12.96 dB (11111)) TXPRE  |          | 2d_full_eye | Done   | 100%     | 10112     | 77.78     | 8 V       | -0.500 UI to 0.500 UI |
| 🔄 Sweep 0 - Scan 10  |        | RXTERM {100 mV} TXDIFFSWING {269 mV (0000)} TXPOST {12.96 dB (11111)} TXPRE  |          | 2d_full_eye | Done   | 100%     | 10240     | 77.78     | 8 ~       | -0.500 UI to 0.500 UI |
| 🔄 Sweep 0 - Scan 11  |        | RXTERM {100 mV} TXDIFFSWING {741 mV (0111)} TXPOST {0.00 dB (00000)} TXPRE { |          | 2d_full_eye | Done   | 100%     | 10240     | 77.78     | 8 ~       | -0.500 UI to 0.500 UI |
| Sweep 0 - Scan 12    |        | RXTERM (100 mV) TXDIFESWING (741 mV (0111)) TXPOST (0.00 dB (00000)) TXPRE ( |          | 2d full eve | Done   | 100%     | 10112     | 77.78     | 8 ¥       | -0.500 UI to 0.500 UI |

#### Figure 157: Sweep Test Results in the Scans Window

To see the results of any of the scans that have been performed, highlight the scan, right-click, and select **Display Scan Plots**.

| Tcl Console Messag   | es Serial I/O Links Serial I/O Scans ×                                 |
|----------------------|------------------------------------------------------------------------|
| Q   素   <b>≑</b>   ▶ |                                                                        |
| Name                 | Link Link Settings                                                     |
| > 🗁 Scans (4)        |                                                                        |
| 🕆 👩 Sweep 0 (81)     |                                                                        |
| Sweep 0              | Scan Properties Ctrl+E FSWING {269 mV (0000)} TXPOST {0.00 dB (000     |
| 🖸 Sweep C            | Scan Properties Ctrl+E<br>FFSWING {269 mV (0000)} TXPOST {0.00 dB (000 |
| 🖸 Sweep C 🕨          | Run Sweep or Scan FSWING (269 mV (0000)) TXPOST (0.00 dB (000          |
| 🖸 Sweep C            | Stop Sweep or Scan FSWING (269 mV (0000)) TXPOST (4.08 dB (011         |
| 🖸 Sweep C 🔁          | Display Scan Plots FSWING (269 mV (0000)) TXPOST (4.08 dB (011         |
| 🖸 Sweep 🕻 🕞          | Write Scan Data FSWING {269 mV (0000)} TXPOST {4.08 dB (011            |
| Sweep C              | FSWING {269 mV (0000)} TXPOST {12.96 dB (11                            |
| Sweep C              | FSWING {269 mV (0000)} TXPOST {12.96 dB (11                            |
| Sweep C              | FFSWING {269 mV (0000)} TXPOST {12.96 dB (11                           |
| 🔲 Sweep ( 🗙          | Delete Delete FSWING {741 mV (0111)} TXPOST {0.00 dB (000              |
| Sweep C              | Export to Spreadsheet FSWING {741 mV (0111)} TXPOST {0.00 dB (000      |

Figure 158: Displaying Scan Plots





The Scan Plots window opens showing the details of the scan performed.



Figure 159: Analyzing the Results of Individual Scans





## Lab 9: Using Vivado ILA Core to Debug JTAG-AXI Transactions

## Introduction

The purpose of this tutorial is to provide a very quick and easy to reproduce introduction to inserting an ILA core into the JTAG to AXI Master IP core example design, and using the ILA's advanced trigger and capture capabilities.

## What is the JTAG to AXI Master IP core?

The LogiCORE<sup>™</sup> IP JTAG-AXI core is a customizable core that can generate AXI transactions and drive AXI signals internal to FPGA at run-time. This supports all memory-mapped AXI interfaces (except AXI4-Stream) and Lite protocol and can be selected using a parameter. The width of AXI data bus is customizable. This IP can drive any AXI4-Lite or Memory Mapped Slave directly. This can also be connected as master to the interconnect. Run-time interaction with this core requires the use of the Vivado® logic analyzer feature.

### **Key Features**

- AXI4 master interface
- Option to select AXI4-Memory Mapped and AXI4-Lite interfaces
- User controllable AXI read and write enable
- User Selectable AXI datawidth : 32 and 64
- User Selectable AXI ID width up to four bits
- Vivado logic analyzer Tcl Console interface to interact with hardware

### Additional Documentation

LogiCORE IP JTAG AXI Master v1.0 Product Guide (AXI) (PG174) contains more information the JTAG to AXI Master IP core.





## **Design Description**

This section has three steps as follows:

- 1. Opening the JTAG to AXI Master IP Example Design project and adding MARK\_DEBUG to the AXI interface connection. Inserting an ILA core into the design and configuring it for advanced trigger is also included in this step.
- 2. Programming the KC705 board and interacting with the JTAG to AXI Master IP core.
- 3. Using the ILA Advanced Trigger Feature to Trigger on an AXI Read Transaction.

## Step 1: Opening the JTAG to AXI Master IP Example Design and Configuring the AXI Interface Debug Connections

To create a project, use the New Project wizard to name the project, add RTL source files and constraints, and specify the target device.

- 1. Invoke the Vivado IDE.
- 2. In the Quick Start tab, click Create Project to start the New Project wizard. Click Next.
- 3. In the **Project Name** page, name the new project jtag\_2\_axi\_tutorial and provide the project location (C:/jtag\_2\_axi\_tutorial). Ensure that **Create Project Subdirectory** is selected. Click **Next**.
- 4. In the Project Type page, specify the Type of Project to create as RTL Project. Click Next.
- 5. In the Add Sources page, click Next.
- 6. In the Add Constraints page, click Next.





7. In the **Default Part** page, shown in the following figure, choose **Boards** and choose the **Kintex-7 KC705 Evaluation Platform**. Click **Next**.

| New Project                                                      |                                                  |                             |            |                        |                                                                         |
|------------------------------------------------------------------|--------------------------------------------------|-----------------------------|------------|------------------------|-------------------------------------------------------------------------|
|                                                                  | part or board for your project. This can be chan | nged later.                 |            |                        |                                                                         |
| Select:  Parts V Filter/ Preview                                 | Boards                                           |                             | 200        | an kultura kanza bagan |                                                                         |
| Ve <u>n</u> dor:<br>Display <u>N</u> ame:<br>Board Re <u>v</u> : | All ~<br>All ~<br>Latest ~<br>Reset All Filters  | From Honor<br>De Hy Marca A |            |                        | Honolada<br>An Francisco<br>Handrada<br>Handrada<br>Handrada<br>Handrad |
| <u>S</u> earch: Q <sub>₹</sub>                                   | ~                                                |                             |            |                        |                                                                         |
| Display Name                                                     |                                                  | Vendor                      | Board Rev  | Part                   | I/O Pin Cour                                                            |
| 📓 ZedBoard Zyng E                                                | valuation and Development Kit                    | em.avnet.com                | d          | xc7z020clg484-1        | 484                                                                     |
| Artix-7 AC701 Ev                                                 | aluation Platform                                | xilinx.com                  | 1.1        | xc7a200tfbg676-2       | 676                                                                     |
| Kintex-7 KC705                                                   | Evaluation Platform                              | xilinx.com                  | 1.1        | xc7k325tffg900-2       | 900                                                                     |
| Kintex-UltraScale KCU105 Evaluation Platform                     |                                                  | xilinx.com                  | 1.0        | xcku040-ffva1156-2-e   | 1,156                                                                   |
| Kintex-UltraScale+ KCU116 Evaluation Platform                    |                                                  | xilinx.com                  | b          | xcku5p-ffvb676-2-e     | 676                                                                     |
| Kintex UltraScale KCU1500 Acceleration Development Board         |                                                  | xilinx.com                  | 1.0        | xcku115-flvb2104-2-e   | 2,104                                                                   |
| Virtex-7 VC707 E                                                 | valuation Platform                               | xilinx.com                  | 1.1        | xc7vx485tffg1761-2     | 1,761                                                                   |
| <                                                                |                                                  |                             |            |                        | >                                                                       |
| Board Connectors                                                 |                                                  | Target Conr                 | nections   |                        |                                                                         |
| FMC_HPC                                                          |                                                  |                             |            |                        | ~                                                                       |
| FMC_LPC                                                          |                                                  |                             |            |                        | ~                                                                       |
|                                                                  |                                                  |                             |            |                        |                                                                         |
| ?                                                                |                                                  | < <u>B</u> ac               | k <u>N</u> | lext > <u>F</u> inish  | Cancel                                                                  |

Figure 160: Choosing the Kintex-7 KC705 Evaluation Platform Board





8. In the **New Project Summary** page, shown in the following figure, click **Finish**.

| 🅕 New Project                 |                                                                                                                                                                                                                                |
|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                               | New Project Summary                                                                                                                                                                                                            |
| HLx Editions                  | A new RTL project named 'jtag_2_axi_tutorial' will be created.                                                                                                                                                                 |
|                               | () No source files or directories will be added. Use Add Sources to add them later.                                                                                                                                            |
|                               | () No constraints files will be added. Use Add Sources to add them later.                                                                                                                                                      |
|                               | The default part and product family for the new project:<br>Default Board: Kintex-7 KC705 Evaluation Platform<br>Default Part: xc7k325tffg900-2<br>Product: Kintex-7<br>Family: Kintex-7<br>Package: ffg900<br>Speed Grade: -2 |
| E XILINX<br>ALL PROGRAMMABLE. | To create the project, click Finish                                                                                                                                                                                            |
| ?                             | < <u>B</u> ack <u>N</u> ext > <u>Finish</u> Cancel                                                                                                                                                                             |

Figure 161: New Project Summary





9. In the leftmost panel of the Flow Navigator under Project Manager, click IP Catalog.

| 🍌 jtag_2_axi_tutorial - [C:/Vivado_D                                                                                     | ebug/jtag_2_axi_tutorial/jtag_2_axi_tutorial.xpr] - Vivado                                                                                                                                                                                                                              |                  | ×                                                             |
|--------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------------------------------------------------------|
| File Edit Flow Tools Window                                                                                              | v Layout View Help Q- Quick Access                                                                                                                                                                                                                                                      | Ready            | /                                                             |
|                                                                                                                          |                                                                                                                                                                                                                                                                                         | 🔚 Default Layout | ~                                                             |
| Flow Navigator 🗧 🚔 ?                                                                                                     | PROJECT MANAGER - jtag_2_axi_tutorial                                                                                                                                                                                                                                                   |                  | ? ×                                                           |
| PROJECT MANAGER      Settings                                                                                            | Sources         ? _ □ □ ×         Project Summary           Q, ↓ ♦ + ?         0         Φ                                                                                                                                                                                              | ? 🗆              |                                                               |
| Add Sources<br>Language Templates<br>₽ IP Catalog                                                                        | Settings     Edit       Design Sources     Project name:     jtag_2_axi_tutorial       V Simulation Sources     Project location:     C://\vado_Debug/itag_2_axi_tutorial       Project location:     C://\vado_Debug/itag_2_axi_tutorial                                               |                  |                                                               |
| <ul> <li>IP INTEGRATOR</li> <li>Create Block Design</li> <li>Open Block Design</li> <li>Generate Block Design</li> </ul> | Hierarchy     Libraries     Compile Order     Project part     Kintex-7 KC705 Evaluation Platform (xc7k325tffg900-2)       Top module name:     Not defined       Target language:     VHDL       Simulator language:     Mixed                                                         |                  |                                                               |
|                                                                                                                          | Properties ? _ □ Ľ ×                                                                                                                                                                                                                                                                    |                  |                                                               |
| Run Simulation                                                                                                           | Display name:       Kintex-7 KC705 Evaluation Platform         Board part name:       xilinx.com:kc705 part0:1.5         Select an object to see properties       Connectors:         Repository path:       C/Xilinx/Vivado/boards/board_files         URL:       www.xilinx.com/kc705 |                  | natas<br>atar<br>atar<br>atar<br>atar<br>atar<br>atar<br>atar |
| <ul> <li>Run Synthesis</li> <li>Open Synthesized Design</li> </ul>                                                       | Tcl Console     Messages     Log     Reports     Design Runs     ×       Q     X     ♦     I4     ≪     ▶     +     %                                                                                                                                                                   | ? _              | 0 6                                                           |
| IMPLEMENTATION     Run Implementation     Open Implemented Design                                                        | Name         Constraints         Status         WNS         TNS         WHS         THS         TPWS         Total Power         Failed Routes         LUT         FF         ^1         URAM         DSP         Start                                                                 | t BRAMS Elapsed  | Strate:<br>Vivadc<br>Vivadc                                   |
| <ul> <li>✓ PROGRAM AND DEBUG</li> <li>III Generate Bitstream</li> <li>&gt; Open Hardware Manager</li> </ul>              |                                                                                                                                                                                                                                                                                         |                  | >                                                             |

Figure 162: IP Catalog from Flow Navigator





10. In the **Search** field on the upper left of the **IP Catalog** tab, type in **JTAG to AXI**.

**Note**: The JTAG to AXI Master core shows up under the **Debug & Verification > Debug** category.

| Project Summary × IP Catalog ×                      |           | ? 🗆 🖸      |
|-----------------------------------------------------|-----------|------------|
| Cores   Interfaces                                  |           |            |
| 🛣 🚔 🕰 🎤 🖉 🁜 🔳 🔍 Jtag to AXI                         | $\otimes$ | •          |
| Name A 1                                            | AXI4      | Status     |
| 🗠 🚍 Vivado Repository                               |           |            |
| ∽ 	□ Debug & Verification                           |           |            |
| 🗸 🗁 Debug                                           |           |            |
| 👎 JTAG to AXI Master                                | AXI4      | Production |
|                                                     |           |            |
|                                                     |           | >          |
| Details                                             |           |            |
| Select an IP or Interface or Repository to see deta | ils       |            |

Figure 163: JTAG to AXI Master IP Core





11. Double-click **JTAG to AXI Master** core. The **Customization** dialog of the core appears. Accept the default core settings by clicking **OK**.

| 🍌 Customize IP                       |                                |                 |            | ×       |
|--------------------------------------|--------------------------------|-----------------|------------|---------|
| JTAG to AXI Master (1.2)             |                                |                 |            | 4       |
| 1 Documentation 📄 IP Location C Swit | ch to Defaults                 |                 |            |         |
| Show disabled ports                  | Component Name                 | jtag_axi_0      |            | 0       |
|                                      | AXI Protocol                   | AXI4            | ~          |         |
|                                      | AXI Address Width              | 32              | ~          |         |
|                                      | AXI Data Width                 | 32              | ~          |         |
|                                      | AXI ID Width                   | 1               | 🛞 [1 - 4]  |         |
|                                      | AXI4 Burst Type Support        | ALL BURST TYPES | ~          |         |
|                                      | Write Transaction Queue Length | 1               | 🗵 [1 - 16] |         |
| acik M_AXI +                         | Read Transaction Queue Length  | 1               | 🙁 [1 - 16] |         |
| • aresetn                            |                                |                 |            |         |
|                                      |                                |                 |            |         |
|                                      |                                |                 |            |         |
|                                      |                                |                 |            |         |
|                                      |                                |                 |            |         |
|                                      |                                |                 |            |         |
|                                      |                                |                 |            |         |
|                                      |                                |                 | ок         | Cancel  |
|                                      |                                |                 |            | Calicer |

Figure 164: JTAG to AXI Master Customization Dialog





12. In the Generate Output Products dialog box, click Generate.

| 🍋 Generate Output Products                                                                                                           | × |
|--------------------------------------------------------------------------------------------------------------------------------------|---|
| The following output products will be generated.                                                                                     | 4 |
| Preview                                                                                                                              |   |
| Q ≚ ≑                                                                                                                                |   |
| <ul> <li>Instantiation Template</li> <li>Synthesized Checkpoint (.dcp)</li> <li>Structural Simulation</li> <li>Change Log</li> </ul> | Ì |
| Synthesis Options                                                                                                                    |   |
| <ul> <li>Global</li> <li>Out of context per IP</li> <li>Run Settings</li> </ul>                                                      |   |
| Number of jobs: 8 🗸                                                                                                                  |   |
| Apply     Generate     Skin                                                                                                          | 0 |

Figure 165: Generate Output Products Dialog Box

13. The **jtag\_axi\_0 IP** core is inserted into the design.



Figure 166: Generated JTAG to AXI Master IP in the Design





14. Right-click jtag\_axi\_0 and select Open IP Example Design.



Figure 167: Open IP Example Design Menu Item





15. In the **Open IP Example Design** dialog, ensure that **Overwrite existing example project** is selected. Click **OK**.

| Open IP Example Design                                                                          |
|-------------------------------------------------------------------------------------------------|
| Specify a location where the example project directory 'ibert_7series_gtx_0_ex' will be placed. |
| Location                                                                                        |
| Put example project directory here: C://ivado_Debug/2017.1                                      |
| ✓ Overwrite existing example project                                                            |
|                                                                                                 |
| OK Cancel                                                                                       |
|                                                                                                 |

Figure 168: Open IP Example Design Dialog Box

- 16. Open the example\_jtag\_axi\_0.v file and notice that the jtag\_axi\_0 module is connected to an axi\_bram\_ctrl\_0 (AXI-BRAM block memory) module.
- 17. In the example\_jtag\_axi\_0.v file, add the following string to the beginning of the wire declaration for each axi\_\* signal from lines 72-108:
  - (\* mark\_debug \*)

**Note**: Do not put mark\_debug on the axi\_aclk signal since this might result in Vivado Synthesis adding a LUT1 to the clock path, which could possibly cause you to not meet timing.





Lines 72-108 should look like this:

| ( .l. | 1 1 1         | -l- )    |      |                                |
|-------|---------------|----------|------|--------------------------------|
| (*    | mark_debug    | *)<br>+) | wire |                                |
| (*    | mark_debug    | *)       | wire |                                |
| (*    | mark_debug    | *)       | wire | [3:U]ax1_arcache;              |
| (*    | mark_debug    | *)       | wire | [0 :0]axi_arid;                |
| (*    | mark_debug    | *)       | wire | [7:0]axi_arlen;                |
| (*    | mark_debug    | *)       | wire | axi_arlock;                    |
| (*    | mark_debug    | *)       | wire | <pre>[2:0]axi_arprot;</pre>    |
| (*    | $mark\_debug$ | *)       | wire | [3:0]axi_arqos;                |
| (*    | mark_debug    | *)       | wire | axi_arready;                   |
| (*    | mark_debug    | *)       | wire | [2:0]axi_arsize;               |
| (*    | mark_debug    | *)       | wire | axi_arvalid;                   |
| (*    | mark_debug    | *)       | wire |                                |
| (*    | mark_debug    | *)       | wire |                                |
| (*    | mark_debug    | *)       | wire |                                |
| (*    | mark_debug    | *)       | wire |                                |
| (*    | mark_debug    | *)       | wire | [7:0]axi_awlen;                |
| (*    | mark debug    | *)       | wire | axi awlock;                    |
| (*    | mark debug    | *)       | wire | [2:0]axi awprot;               |
| (*    | mark_debug    | *)       | wire | [3:0]axi_awqos;                |
| (*    | mark debug    | *)       | wire | axi awready;                   |
| (*    | mark debug    | *)       | wire | [2:0]axi_awsize;               |
| (*    | mark debug    | *)       | wire | axi awvalid;                   |
| (*    | mark debug    | *)       | wire | [0 :0]axi bid;                 |
| (*    | mark debug    | *)       | wire | axi bready;                    |
| (*    | mark debug    | *)       | wire | [1:0]axi bresp;                |
| (*    | mark debug    | *)       | wire | axi bvalīd;                    |
| (*    | mark debug    | *)       | wire | [31 <sup>-</sup> :0]axi rdata; |
| (*    | mark debug    | *)       | wire | [0 :0]axi rid;                 |
| (*    | mark debug    | *)       | wire | axi rlast;                     |
| (*    | mark debug    | *)       | wire | axi rready;                    |
| (*    | mark debug    | *)       | wire | [1:0]axi rresp;                |
| (*    | mark debug    | *)       | wire | axi rvalid;                    |
| (*    | mark debug    | *)       | wire | [31 :0]axi wdata;              |
| (*    | mark_debug    | *)       | wire | axi_wlast;                     |
| (*    | mark debug    | *)       | wire | axi wready;                    |
| (*    | mark_debug    | *)       |      | [3 :0]axi wstrb;               |
| (*    | mark debug    | *)       | wire | axi wvalid;                    |
| •     |               |          | -    |                                |

18. Save changes to example\_jtag\_axi\_o.v file.





- 19. In the Flow Navigator on the left side of the Vivado window, click Run Synthesis.
- 20. Open the synthesized design by selecting Open Synthesized Design and clicking OK.

| Synthesis Completed               |
|-----------------------------------|
| Synthesis successfully completed. |
| • Run Implementation              |
| Open Synthesized Design           |
| ◯ <u>V</u> iew Reports            |
| Don't show this dialog again      |
| OK Cancel                         |

Figure 169: Open Synthesized Design Dialog Box

- 21. After the synthesized design opens, do the following:
  - a. Select the **Debug** layout in the main toolbar Layout drop-down of the Vivado IDE.



Figure 170: Debug Layout in the Vivado IDE Toolbar





b. Select the **Debug** window near the bottom of the Vivado IDE.



Figure 171: Debug Window in the Vivado IDE





c. Click the **Set Up Debug** toolbar button to launch the **Set up Debug** wizard.

| 🏊 Set Up Debug                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HLx Editions                  | Set Up Debug<br>This wizard will guide you through the process of<br>1. Choosing nets and connecting them to debug cores.<br>2. Associating a clock domain with each of the nets chosen for debug.<br>3. Choosing additional features on the debug cores like Data Depth, Advanced Trigger mode and Capture<br>Control.<br>Note: This setup wizard does not apply to the VIO, IBERT or JTAG-to-AXI-Master debug cores. Please refer to<br>Vivado Design Suite User Guide: Programming and Debugging (UG908) for further instructions on how to use<br>these IPs. |
| E XILINX<br>ALL PROGRAMMABLE. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>?</b>                      | < <u>B</u> ack <u>N</u> ext > <u>F</u> inish Cancel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

Figure 172: Set Up Debug Wizard

22. The **Set Up Debug** wizard opens, click **Next**.





23. In the next page of the **Setup Debug** wizard, note that some of the nets that you would like to debug have no detectable clock domains selected. Click the **more info** link in the message banner.

| vindows, then drag them to th                        | e list or click "Add Se | lected Ne | Nets".                                                                                     |
|------------------------------------------------------|-------------------------|-----------|--------------------------------------------------------------------------------------------|
| <ul> <li>Some net(s) do not hav</li> <li>Q</li></ul> | ve a clock domain. m    | nore info | o Missing Clock Domain                                                                     |
| Name                                                 | Clock Domain            | D To s    | show only nets that do not have a clock domain, click 66 nets                              |
| > fit axi_araddr (32)                                | partially defined       | F         |                                                                                            |
| > fit axi arburst (2)                                | aclk                    | F To a    | assign the same clock domain to all nets, click Assign All Clock Domains                   |
| > J axi_arcache (4)                                  | undefined               | F         |                                                                                            |
| > - 17 22 axi arlen (8)                              | aclk                    | F To a    | assign a clock domain to specified nets, select the nets and click the Select Clock Domain |
| > Jr to axi arprot (3)                               | undefined               | G butto   | tton or right click and choose the Select Clock Domain command                             |
| > J axi_argos (4)                                    | undefined               | G         |                                                                                            |
| > Jr axi_arsize (3)                                  | aclk                    | FTOR      | remove nets, select the nets and click the Remove Nets button or press the Delete key      |
| > Jr axi_awaddr (32)                                 | partially defined       | FDRE      | E Data and Trigger 🗸                                                                       |
| > Ja axi_awburst (2)                                 | aclk                    | FDRE      | E Data and Trigger 🗸                                                                       |
| > JES avi awcache (4)                                | undefined               | FDRE      | F Data and Trinner 🗸                                                                       |
| Find Nets to Add                                     |                         |           | Nets to debug: 202                                                                         |
|                                                      |                         |           |                                                                                            |

Figure 173: Missing Clock Domain Dialog Box

24. In the resulting pop-up, click **Assign All Clock Domains**.





25. In the **Select Clock Domain** dialog box, select the **aclk** clock net, then click **OK**.

| idows, then drag the                         | 🥕 Select Clock Domain                                                                                                                                                                                                                                                                          |                       |
|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|
| <ul> <li>Gome net(s) dc</li> <li>Q</li></ul> | The list below contains 'GLOBAL_CLOCK' nets.<br>To see other types of clock nets use the drop-down button.<br>There are 66 net(s) that do not have a clock domain selection. Please select a clock<br>net from the list below to apply to all 66 net(s). If you want to select different clock | 4                     |
| Name                                         | domains foreach net, click Cancel and follow the instructions in the wizard.                                                                                                                                                                                                                   |                       |
| > .fr∞ axi_araddr                            |                                                                                                                                                                                                                                                                                                |                       |
| > .fr¤ axi_arburs                            | $Q \ge Q$ GLOBAL_CLO $\checkmark \swarrow$ Search hierarchically                                                                                                                                                                                                                               | ock Domains           |
| > .fr¤ axi_arcach                            | III ack                                                                                                                                                                                                                                                                                        |                       |
| > .fr¤ axi_arlen (                           |                                                                                                                                                                                                                                                                                                | e Select Clock Domain |
| > .fr¤ axi_arprot                            |                                                                                                                                                                                                                                                                                                |                       |
| > .fr¤ axi_arqos                             |                                                                                                                                                                                                                                                                                                |                       |
| > Jr≅ axi_arsize                             |                                                                                                                                                                                                                                                                                                | ress the Delete key   |
| > Jr≅ axi_awadd                              |                                                                                                                                                                                                                                                                                                |                       |
| > -fr¤ axi_awbur                             |                                                                                                                                                                                                                                                                                                |                       |
| > JF⇔ avi awrar                              | (?) ОК Сало                                                                                                                                                                                                                                                                                    | cel 🗸                 |
| Find Nets to Add.                            |                                                                                                                                                                                                                                                                                                | Nets to debug: 202    |
| Find Nets to <u>A</u> dd                     |                                                                                                                                                                                                                                                                                                | Nets to debug: 202    |

Figure 174: Select Clock Domain Dialog Box

26. Observe that all of the nets now have an assigned clock domain. Click Next.





27. In the **Trigger and Storage Settings** area of the **ILA General Options** page, ensure that **Advanced Trigger** and **Capture Control** are selected. Click **Next**.

| 🍌 Set Up Debug                                                                         |                                              | ×      |
|----------------------------------------------------------------------------------------|----------------------------------------------|--------|
| ILA Core Options<br>Choose features for the ILA debug cores.                           |                                              | 4      |
| Sample of data depth: 1024 v<br>Input pipe stages: 0 v<br>Trigger and Storage Settings |                                              |        |
| ✓ Capture control                                                                      |                                              |        |
| Advanced trigger                                                                       |                                              |        |
|                                                                                        |                                              |        |
|                                                                                        |                                              |        |
|                                                                                        |                                              |        |
|                                                                                        |                                              |        |
|                                                                                        |                                              |        |
| ?                                                                                      | < <u>B</u> ack <u>N</u> ext > <u>F</u> inish | Cancel |

Figure 175: Trigger and Capture Modes Page





28. When Set up Debug Summary page appears, ensure that summary is correct and click Finish.

*Note*: See that the ILA core was inserted and attached to the dbg\_hub core.



Figure 176: ILA Core Inserted into the Design

29. Save the constraints by clicking **Save**.





- 30. In the **Flow Navigator** on the left side of the Vivado IDE, click **Generate Bitstream**.
- 31. Click **Yes** to implement the design.
- 32. Wait until the Vivado status shows write\_bitstream complete.
- 33. In the **Bitstream Generation Completed** dialog box, select **Open Hardware Manager** and click **OK**.



Figure 177: Select Open Hardware Manager

## Step 2: Program the KC705 Board and Interact with the JTAG to AXI Master Core

- 1. Connect your KC705 board's USB-JTAG interface to a machine that has Vivado IDE and cable drivers installed on it and power up the board.
- 2. The Hardware Manager window opens. Click **Open New Target**. The **Open New Hardware Target** dialog box opens.





## Lab 9: Using Vivado ILA Core to Debug JTAG-AXI Transactions

| HARDWARE MANAGER - unconnected   |         |                             |     |  |  |  |
|----------------------------------|---------|-----------------------------|-----|--|--|--|
| 🕖 No hardware target is open. Op | en targ | get                         |     |  |  |  |
| Hardware                         | ø       | Auto Connect                |     |  |  |  |
|                                  |         | Recent Targets              | + - |  |  |  |
|                                  |         | Available Targets on Server | × . |  |  |  |
|                                  |         | Open New Target             |     |  |  |  |
|                                  |         |                             | N-  |  |  |  |
| No conten                        | nt      |                             |     |  |  |  |
|                                  |         |                             |     |  |  |  |
|                                  |         |                             |     |  |  |  |

Figure 178: Connect to a Hardware Target

3. In the **Connect to** field choose **Local server**, and click **Next**.

| 🥕 Open New Hardware Target                                                                                                                                                                                            |                                                                                         |    |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|----|--|--|--|--|
| Hardware Server Settings<br>Select local or remote hardware server, then configure the host name and port settings. Use Local server if the target is attached to the<br>local machine; otherwise, use Remote server. |                                                                                         |    |  |  |  |  |
| <u>C</u> onnect to:                                                                                                                                                                                                   | : Local server (target is on local machine)                                             |    |  |  |  |  |
|                                                                                                                                                                                                                       |                                                                                         |    |  |  |  |  |
|                                                                                                                                                                                                                       |                                                                                         |    |  |  |  |  |
|                                                                                                                                                                                                                       |                                                                                         |    |  |  |  |  |
| Click Next to                                                                                                                                                                                                         | to launch and/or connect to the hw_server (port 3121) application on the local machine. |    |  |  |  |  |
| ?                                                                                                                                                                                                                     | < <u>B</u> ack <u>N</u> ext > <u>Finish</u> Cano                                        | el |  |  |  |  |



*Note*: Depending on your connection speed, this may take about 10 to 15 seconds.





4. If there is more than one target connected to the hardware server, you will see multiple entries in the **Select Hardware Target** page. In this tutorial, there is only one target as shown in the following figure. Leave these settings at their default values and click **Next**.

| 🍌 Open New H          | ardware Targe       | et             |              |                  |                                                  | ×      |
|-----------------------|---------------------|----------------|--------------|------------------|--------------------------------------------------|--------|
|                       | e target from the I |                |              |                  | priate JTAG clock (TC<br>select a different targ |        |
| Hardware <u>T</u> arg | ets                 |                |              |                  |                                                  |        |
| Туре                  | Name                |                | JTAG C       | lock Frequency   |                                                  |        |
| xilinx_tcf            | Xilinx/Port_#000    | 3.Hub_#0004    | 600000       | 0 🗸              |                                                  |        |
|                       |                     |                |              |                  |                                                  |        |
|                       |                     |                |              |                  |                                                  |        |
|                       |                     |                |              |                  |                                                  |        |
|                       |                     |                |              |                  |                                                  |        |
|                       |                     |                |              |                  |                                                  |        |
|                       |                     |                | nx virtual ( | Cable (XVC)      |                                                  |        |
| Hardware <u>D</u> evi | ces (for unknow     | n devices, spe | cify the Ins | struction Regist | er (IR) length)                                  |        |
| Name                  | ID Code             | IR Length      |              |                  |                                                  |        |
| @ xc7k325t_0          | 0 33651093          | 6              |              |                  |                                                  |        |
|                       |                     |                |              |                  |                                                  |        |
|                       |                     |                |              |                  |                                                  |        |
| Hardware serve        | er: localhost:312   | 1              |              |                  |                                                  |        |
| ?                     |                     | < <u>E</u>     | ack          | <u>N</u> ext >   | <u>F</u> inish                                   | Cancel |

Figure 180: Select Hardware Target

5. Leave these settings at their default values as shown. Click **Next**.





6. In the **Open Hardware Target Summary** page, click **Finish** as shown in the following figure.

| 🍌 Open New Hardware          | Target                                                                                                                                       |  |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--|
| VIVADO.                      | Open Hardware Target Summary                                                                                                                 |  |
| HL <sub>x</sub> Editions     | Hardware Server Settings:     Server: localhost:3121                                                                                         |  |
|                              | <ul> <li>Target Settings:         <ul> <li>Target: xilinx_tcf/Xilinx/Port_#0003.Hub_#0004</li> <li>Frequency: 6000000</li> </ul> </li> </ul> |  |
|                              |                                                                                                                                              |  |
|                              |                                                                                                                                              |  |
|                              |                                                                                                                                              |  |
| EXILINX<br>ALL PROGRAMMABLE. | To connect to the hardware described above, click Finish                                                                                     |  |
| •                            | < <u>B</u> ack <u>N</u> ext > <u>Finish</u> Cancel                                                                                           |  |

#### Figure 181: Open Hardware Summary

Wait for the connection to the hardware to complete. After the connection to the hardware target is made, the dialog shown in the following figure opens.

**Note**: The **Hardware** tab in the **Debug** view shows the hardware target and XC7K325T device that was detected in the JTAG chain.





### Lab 9: Using Vivado ILA Core to Debug JTAG-AXI Transactions

| ? _ 🗆 🖸        | ×                 |
|----------------|-------------------|
|                | ۰                 |
| Status         |                   |
| Connected      |                   |
| Open           |                   |
| Not programmed |                   |
|                |                   |
|                |                   |
|                |                   |
|                |                   |
|                |                   |
|                | Connected<br>Open |

Figure 182: Hardware Target and XC7K325T Device

7. Next, program the previously created XC7K325T device using the .bit bitstream file by right-clicking the **XC7K325T** device and selecting **Program Device** as shown in the following figure.

| Hardware                      |                |      |                            | ? _ 🗆                        | Ľ X |        |
|-------------------------------|----------------|------|----------------------------|------------------------------|-----|--------|
| Q   ¥   ♦   ∅   ▶             | $\gg$          |      |                            |                              | •   |        |
| Name                          |                |      | Status                     |                              |     |        |
| Y 📱 localhost (1)             |                |      | Connected                  |                              |     |        |
| ✓ Ø xilinx_tcf/Xilinx/Port_#0 | 0003.H         | Нu   | Open                       |                              |     |        |
| <ul> <li></li></ul>           |                | Hard | dware Device P             | roperties                    |     | Ctrl+E |
| · ADC (System in              | Program Device |      |                            |                              | Ν   |        |
|                               |                |      | y Device<br>esh Device     |                              |     | 1/2    |
|                               |                |      |                            | Memory Devic<br>ation Memory |     | ł      |
| Hardware Device Properties    |                | -    | gram BBR Key<br>ar BBR Key |                              |     |        |
| Hardware Device Properties    |                | Prog | gram eFUSE R               | egisters                     |     |        |
| <pre>@ xc7k325t_0</pre>       |                | Expo | ort to Spreadsh            | eet                          |     |        |
|                               |                |      |                            |                              |     |        |

Figure 183: Program Active Target Hardware





8. In the **Program Device** dialog box verify that the .bit file is correct for the lab that you are working on. Click **Program** to program the device.

| 🔥 Program Device                                                                                                                                                                                            |                                                                    | ×    |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|------|--|--|--|
| Select a bitstream programming file and download it to your hardware device. You can optionally select a debug probes file that corresponds to the debug cores contained in the bitstream programming file. |                                                                    |      |  |  |  |
| Bitstre <u>a</u> m file:                                                                                                                                                                                    | 1/jtag_axi_0_ex/jtag_axi_0_ex.runs/impl_1/example_jtag_axi_0.bit   |      |  |  |  |
| Debu <u>a</u> probes file:                                                                                                                                                                                  | 1/jtag_axi_0_ex/jtag_axi_0_ex.runs/impl_1/example_jtag_axi_0.ltx 💿 |      |  |  |  |
| ? Enable and of al                                                                                                                                                                                          | <u>P</u> rogram Car                                                | icel |  |  |  |

Figure 184: Select Bitstream File to Download

Note: Wait for the program device operation to complete. This may take few minutes.

9. Verify that the JTAG to AXI Master and ILA cores are detected by locating the **hw\_axi\_1** and **hw\_ila\_1** instances in the **Hardware Manager** window.



Figure 185: ILA Core Instances in the Hardware Window





10. You can communicate with the JTAG to AXI Master core with Tcl commands only. You can issue AXI read and write transactions using the run\_hw\_axi command. However, before issuing these transactions, it is important to reset the JTAG to AXI Master core. Because the aresetn input port of the jtag\_axi\_0 core instance is not connected to anything, you need to use the following Tcl commands to reset the core:

```
reset_hw_axi [get_hw_axis hw_axi_1]
```

| Tcl Console x Messages Serial I/O Links Serial I/O Scans                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ? _ 🗆 🗳 |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |
| <pre>b program_hw_devices: Time (s): cpu = 00:00:25 ; elapsed = 00:00:25 . Memory (MB): peak = 1514.480 ; gain = 0.000<br/>refresh_hw_devices [lindex [get_hw_devices arCN2355_0] 0]<br/>iNRO: [Labtools 27-2302] Device xrCN235t (JTAG device index = 0) is programmed with a design that has 1 ILA core(s).<br/>INRO: [Labtools 27-2302] Device xrCN235t (JTAG device index = 0) is programmed with a design that has 1 JTAG AXI core(s).<br/>INRO: [Labtools 27-2302] Device xrCN235t (JTAG device index = 0) is programmed with a design that has 1 JTAG AXI core(s).<br/>INRO: [Labtools 27-2302] Device xrCN235t (JTAG device index = 0) is programmed with a design that has 1 JTAG AXI core(s).<br/>Jintpoint (Labtools 27-2304) ILA Waveform data saved to file cr/Vindeo Debug/COUT.//jtag axi 0 ex./w/backup/kw ila data lila. Use Tcl command 'import hw ila data' or Vivado File-&gt;Imp<br/>INRO: [Labtools 27-2304] ILA Waveform data saved to file cr/Vindeo Debug/COUT.//jtag axi 0 ex./w/backup/kw ila data lila. Use Tcl command 'import hw ila data' or Vivado File-&gt;Imp<br/>INRO: [Labtools 27-2304] ILA Waveform data saved to file cr/Virado Debug/COUT.//jtag axi 0 ex./w/backup/kw ila data lila. Use Tcl command 'import hw ila data' or Vivado File-&gt;Imp<br/>INRO: [Labtools 27-2304] ILA Waveform data saved to file cr/Virado Debug/COUT.//jtag axi 0 ex./w/backup/kw ila data lila. Use Tcl command 'import hw ila data' or Vivado File-&gt;Imp<br/>INRO: [Labtools 27-2304] ILA Waveform data saved to file cr/Virado Debug/COUT.//jtag axi 0 ex./w/backup/kw ila data lila. Use Tcl command 'import hw ila data' or Vivado File-&gt;Imp<br/>INRO: [Labtools 27-2304] ILA Waveform data saved to file cr/Virado Debug/COUT.//jtag axi 0 ex./w/backup/kw ila data lila. Use Tcl command 'import hw ila data' or Vivado File-&gt;Imp<br/>INRO: [Labtools 27-2304] ILA Waveform data saved to file cr/Virado Debug/COUT.//jtag axi 0 ex./w/backup/kw ila data lila. Use Tcl command 'import hw ila data' or Vivado File-&gt;Imp<br/>INRO: [Labtools 27-2304] ILA Waveform data saved to file cr/Vira</pre> |         |
| <pre>C incor [baccous incore] in metalin das seted to file C://iesu_becupitin.jbs_sr_u_exipes_in/iectup/metalgate_tile. Ose for command import_im_inc_sets of visuo file/imp<br/>incore [bm_sxi [ge_bm_sxi]]<br/>;<br/>;<br/>;</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         |

Figure 186: Reset JTAG to AXI core

11. The next step is to create a 4-word AXI burst transaction to write to the first four locations of the BRAM:

```
set wt [create_hw_axi_txn write_txn [get_hw_axis hw_axi_1] -type WRITE -address
00000000 -len 128 -data {44444444_33333333_22222222_11111111}]
```

### where:

- o write\_txn is the name of the transaction
- [get\_hw\_axis hw\_axi\_1] returns the hw\_axi\_1 object
- o address 00000000 is the start address
- o -len 128 sets the AXI burst length to 128 words
- o -data {4444444\_3333333\_2222222\_11111111} is the data to be written.

**Note**: The data direction is MSB to the left (i.e., address 3) and LSB to the right (i.e., address 0). Also note that the data will be repeated from the LSB to the MSB to fill up the entire burst.

12. The next step is to set up a 128-word AXI burst transaction to read the contents of the first four locations of the AXI-BRAM core:

set rt [create\_hw\_axi\_txn read\_txn [get\_hw\_axis hw\_axi\_1] -type READ -address 00000000 -len 128]

where:

- read\_txn is the name of the transaction
- [get\_hw\_axis hw\_axi\_1] returns the hw\_axi\_1 object
- -address 00000000 is the start address
- o -len 128 sets the AXI burst length to 4 words





13. After creating the transaction, you can run it as a write transaction using the run\_hw\_axi command:

run\_hw\_axi \$wt

This command should return the following:

INFO: [Labtools 27-147] : WRITE DATA is : 444444433333333222222221111111...

14. After creating the transaction, you can run it as a read transaction using the run\_hw\_axi command: run hw axi \$rt

This command should return the following:

INFO: [Labtools 27-147] : READ DATA is : 4444444333333333222222221111111...





## Step 3: Using ILA Advanced Trigger Feature to Trigger on an AXI Read Transaction

- 1. In the **ILA hw\_ila\_1** dashboard, locate the **Trigger Mode Settings** area and set **Trigger mode** to **ADVANCED\_ONLY**.
- 2. In the Capture Mode Settings area set the Trigger position to 512.
- 3. In the Trigger State Machine area click the Create new trigger state machine link.

| Settings - hw_ila_1                             |                                                            | ? _ 🗆 × | Trigger Setup - hw_ila_1           | Capture Setup         | hw_ila_1 Status -   | hw_ila_1 × ?           | ? _ 🗆 |
|-------------------------------------------------|------------------------------------------------------------|---------|------------------------------------|-----------------------|---------------------|------------------------|-------|
| Trigger Mode Settings                           |                                                            |         | ৬ 🕨 💌                              | ↓<br>0                |                     |                        |       |
| Trigger mode:                                   | ADVANCED_ONLY ~                                            |         | Core status                        |                       |                     |                        |       |
| Trigger state machine:                          | BASIC_ONLY                                                 | ]       | Idle                               | Pre-Trigger           | Waiting for Trigger | Post-Trigger           |       |
| Capture Mode Settings                           |                                                            |         | Trigger State Machine              |                       |                     |                        |       |
| Capture mode:                                   | ALWAYS 🗸                                                   |         | Flag O                             | Flag 1                | Flag 2              | Flag 3                 |       |
| Number of windows:                              | <b>1</b> [1 - 1024]                                        |         | Trigger state: 0<br>Capture status |                       |                     |                        |       |
| Window data depth:<br>Trigger position in windo | 1024     ✓     [1 - 1024]       ow:     512     [0 - 1023] |         | Window 1 of 1<br>Idle              | Window sample<br>Idle | 0 of 1024 Total san | nple 0 of 1024<br>Idle |       |
| General Settings                                |                                                            | _       |                                    |                       |                     |                        |       |
| Refresh rate: 500                               | ms                                                         |         |                                    |                       |                     |                        |       |
|                                                 |                                                            |         | <                                  |                       |                     |                        | >     |

Figure 187: Setting Trigger Mode to ADVANCED and Trigger Position to 512 in the ILA Dashboard





4. In the **New Trigger State Machine File** dialog box set the name of the state machine script to **txns.tsm**.

| 🔥 New Trigg                                  | er State Machine File                                                |                                                                                                                                                      |
|----------------------------------------------|----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Save <u>I</u> n: 🕠                           | jtag_axi_0_ex                                                        |                                                                                                                                                      |
|                                              | _ex.hw<br>_ex.ioplanning<br>_ex.ip_user_files<br>_ex.runs<br>_ex.sim | Recent Directories         □ c:/Vivado_Debug/2017.1/jtag_axi_0_ex/jtag_axi_0_ex.runs/impl_1 ✓         File Preview         Select a file to preview. |
| File <u>n</u> ame:<br>Files of <u>t</u> ype: | txns<br>Trigger State Machine Files (.tsm)                           |                                                                                                                                                      |
| rites of type.                               |                                                                      | Save Cancel                                                                                                                                          |

Figure 188: Creating a New Trigger State Machine Script

5. A basic template of the trigger state machine script is displayed in the Trigger State Machine gadget. Expand the trigger state machine gadget in the ILA dashboard. Copy the script below after line 17 of the state machine script and save the file.

```
# The "wait for arvalid" state is used to detect the start
# of the read address phase of the AXI transaction which
# is indicated by the axi arvalid signal equal to '1'
#
state wait for arvalid:
    if (axi arvalid == 1'b1) then
      goto wait for rready;
    else
      goto wait for arvalid;
    endif
#
# The "wait for rready" state is used to detect the start
# of the read data phase of the AXI transaction which
# is indicated by the axi rready signal equal to '1'
#
state wait for rready:
  if (axi rready == 1'b1) then
   goto wait for rlast;
  else
    goto wait_for_rready;
  endif
# The "wait for rlast" state is used to detect the end
```





```
# of the read data phase of the AXI transaction which
# is indicated by the axi_rlast signal equal to '1'.
# Once the end of the data phase is detected, the ILA core
# will trigger.
#
state wait_for_rlast:
    if (axi_rlast == 1'b1) then
        trigger;
    else
        goto wait_for_rlast;
    endif
```

**Note**: The state machine is used to detect the various phases of an AXI read transaction:

- Beginning of the read address phase.
- Beginning of the read data phase.
- End of the read data phase.





6. Arm the trigger of the ILA by right-clicking the **hw\_ila\_1** core in the **Hardware Manager** window and selecting **Run Trigger**.

| Hardware                                 |             |        | ? _ 🗆                    |           | exa          | ample_jtag_axi_0.v             |
|------------------------------------------|-------------|--------|--------------------------|-----------|--------------|--------------------------------|
| Q ≚ ⊜ ∅ ►                                | <b>»</b>    |        |                          | ٥         |              | Waveform - hw_ila              |
| Name                                     |             |        | Status                   |           | Ś            | Q + -                          |
| <ul> <li>Iocalhost (1)</li> </ul>        |             |        | Connected                |           | otion        | <b>4</b>   <b>T</b>   -        |
| ✓ ✓ × xilinx_tcf/Xilinx/Port             | #0003       | .Hu    | Open                     |           | oard Options | ILA Status:Idle                |
| <ul> <li>× (i) xc7k325t_0 (3)</li> </ul> | _           | 1      | Programmed               |           | gal          | Nome                           |
| XADC (System)                            | N           | Hard   | ware Device Properties   |           | 0            | Ctrl+Eaxi_araddr[31            |
| 🦉 hw_axi_1 (AXI)                         |             | Progr  | am Device                |           |              | axi_arburst[1:                 |
| 🦉 hw_ila_1 (u_ila                        | a_          | Verify | Device                   |           |              | axi_arcache[3                  |
|                                          |             | Run 1  | Frigger                  |           |              | axi_arlen[7:0]                 |
|                                          | <b>&gt;</b> | Run 1  | Frigger Immediate        |           |              | axi_arprot[2:0<br>axi_awaddr[3 |
|                                          |             | Stop   | Trigger                  |           |              | axi_argos[3:0                  |
|                                          | 17          |        | le Auto Re-trigger       |           |              | axi_arsize[2:0                 |
|                                          |             |        | ple Auto Re-trigger      |           |              | axi_awburst[1                  |
|                                          |             |        | e User Defined Probe     |           |              | axi_awcache[                   |
|                                          |             | Creat  | e Oser Delined Probe     |           |              | axi_awlen[7:0                  |
|                                          | C           | Refre  | sh Device                |           |              |                                |
|                                          |             | Add C  | Configuration Memory Dev | /ice      |              |                                |
|                                          |             | Boot   | from Configuration Memo  | ry Device |              |                                |
| Hardware Device Properties               |             | Progr  | am BBR Key               |           |              | igs - hw_ila_1                 |
| <pre></pre>                              |             | Clear  | BBR Key                  |           |              | jer Mode Sett                  |
| Name: xc7k325t                           | (           | Progr  | am eFUSE Registers       |           |              | rigger mode:                   |
| Part: xc7k325t                           |             | Expo   | t to Spreadsheet         |           |              | rigger state m                 |
| ID code: 3365109                         | 3           |        |                          |           |              |                                |
| IR length: 6                             |             |        |                          |           |              | Capture Mode Set               |

Figure 189: Run Trigger





7. In the **Trigger Capture Status** window, note that the ILA core is waiting for the trigger to occur, and that the trigger state machine is in the **wait\_for\_a\_valid** state. Note that the pre-trigger capture of 512 samples has completed successfully:

| Trigger Setup - hw_ila              | 1 Capture Setup - | hw_ila_1 Status - h  | w_ila_1 × ?       | _ 🗆 |  |  |
|-------------------------------------|-------------------|----------------------|-------------------|-----|--|--|
| 🕑 🕨 渊 📕 🖽                           |                   |                      |                   |     |  |  |
| Core status                         |                   |                      |                   |     |  |  |
| Idle                                | Pre-Trigger       | Waiting for Trigger  | Post-Trigger      |     |  |  |
| Trigger State Machin                | e                 |                      |                   |     |  |  |
| Flag O                              | Flag 1            | Flag 2               | Flag 3            |     |  |  |
| Trigger state: wait_for_arvalid (0) |                   |                      |                   |     |  |  |
| Capture status                      |                   |                      |                   |     |  |  |
| Window 1 of 1                       | Window sample 5   | 512 of 1024 Total sa | ample 512 of 1024 |     |  |  |
| 100%                                | 50 <mark>%</mark> |                      | 50%               |     |  |  |
|                                     |                   |                      |                   |     |  |  |
|                                     |                   |                      |                   |     |  |  |
|                                     |                   |                      |                   |     |  |  |
|                                     |                   |                      |                   |     |  |  |
| < <                                 |                   |                      |                   | >   |  |  |

Figure 190: Trigger Capture Status Window





8. In the Tcl console, run the read transaction that you set up in the previous section of this tutorial.

run\_hw\_axi \$rt

**Note**: The ILA core has triggered and the trigger mark is on the sample where the axi\_rlast signal is equal to '1', just as the trigger state machine program intended.



Figure 191: Waveform window





## Lab 10: Using Vivado Serial Analyzer to Debug GTR Serial Links

## Introduction

IBERT UltraScale+<sup>™</sup> GTR (IBERT GTR) can be used to evaluate and monitor GTR transceivers in Zynq<sup>®</sup> UltraScale+ MPSoC devices. With this feature, a user can accomplish the following tasks:

- Perform eye scans with user data
- Change GTR settings
- View link status
- Check the "lock" status of all PLLs used by all GTR lanes

IBERT GTR does NOT provide the following capabilities:

- Perform eye scans with raw PRBS data patterns
- Measure Bit Error Ratio (no bit or error counters)

Note that this solution is purely software based, meaning that no IP or logic is required in the programmable logic of the device. This documentation will guide you through the setup of the GTR Transceivers by creating a First Stage Boot Loader (FSBL). It will then demonstrate how to load the FSBL into the Zynq UltraScale+ and use IBERT GTR.



**IMPORTANT:** This is a supported feature in Vivado® 2017.2 and beyond.

## **IBERT GTR Flow**

The IBERT GTR Bring-up and subsequent EyeScan involves three different components:

- 1. Generating Zynq UltraScale+ MPSoC PS Hardware Definition File (HDF) from Vivado after configuring the GTR
- 2. Using SDK XSCT flow to generate First Stage Boot Loader file by using the Hardware Definition File (HDF)
- 3. Using First Stage Boot Loader file with Vivado Serial I/O Analyzer to bring up IBERT GTR.

## **Tools Required:**

• Vivado





- SDK
- XSCT (Part of SDK)

## **Board/Part/Components required:**

- ZCU102 Rev 1.0 board
- XCZU9EG-FFVB1156 production device
- PCIe®:
  - A PCIe card which has at least x4 lanes
  - PCI Express® 4x Male to PCI-E 16x Female Riser Cable if PCIe card is larger than x4
- SATA:
  - o SanDisk 128 GB SATA SSD Drive
  - SATA connector cable
  - 4 Pin Molex to SATA Power Cable Adapter
- USB:
  - o SanDisk Ultra 32 GB USB 3.0 Flash Drive
  - USB 3.0 Type A Female to Micro Male Adapter

## **Required Files**

- First Stage Boot Loader ELF File (Created using instructions below) which configures the GTR
- Configuration Bitstream File (Optional file that may be needed to custom configure the FPGA depending on the board setup)
- Tcl Script to generate the FSBL and modify C-source for USB Support (when available)

## Assumptions

- 1. FSBL should always target A53 processor as R5 (psu\_cortexr5\_0) is exclusively used by IBERT GTR.
- 2. Physical devices such as SATA drive, PCIE card, etc. are needed for validation.

# Step 1: Generating Zynq UltraScale+ MPSoC PS Hardware Definition File (HDF)

- 1. Open Vivado.
- 2. Click on **Create Project** and click **Next**.





| 🍌 Vivado 2017.2                                                                   |                      |                                                                                                                                                                                                                                                                                                                                                       |                                                                                         |
|-----------------------------------------------------------------------------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
| <u>File Flow T</u> ools <u>W</u> indow                                            | Help Q+ Quick Access | _                                                                                                                                                                                                                                                                                                                                                     |                                                                                         |
|                                                                                   |                      |                                                                                                                                                                                                                                                                                                                                                       | <b>XILINX</b><br>ALL PROGRAMMABLE.                                                      |
|                                                                                   | 🍌 New Project        | X                                                                                                                                                                                                                                                                                                                                                     |                                                                                         |
| Quick Stat<br><u>Create Project</u> ><br>Open Project ><br>Open Example Project = |                      | Create a New Vivado Project<br>This wizard will guide you through the creation of a new project.<br>To create a Vivado project you will need to provide a name and a location for your project files. Next, you<br>will specify the type of flow you'll be working with. Finally, you will specify your project sources and<br>choose a default part. |                                                                                         |
| Tasks<br>Manage IP ><br>Open Hardware Manag<br>Xilinx Tcl Store >                 |                      |                                                                                                                                                                                                                                                                                                                                                       | zcu102_gth_ES1_2016_4_ex<br>p<br>11p5dB_ex<br>s_gth_linerate_10Gbps_refclk<br>s_20dB_ex |
| Learning (<br>Documentation and Tut<br>Quick Take Videos >                        |                      |                                                                                                                                                                                                                                                                                                                                                       | ect_1                                                                                   |
| Tcl Console                                                                       | ?                    | <back next=""> Einish Cancel</back>                                                                                                                                                                                                                                                                                                                   | ? _ 🗆 🖒 X                                                                               |
| Q     X     +                            start_gui                                |                      | gn sources and a target device for a new project.                                                                                                                                                                                                                                                                                                     | ><br>>                                                                                  |

Figure 192: New Project Window

- 3. Set your project name and specify the project directory. Click **Next**.
- 4. Select Project type as **RTL project**
- 5. To generate default HDF, keep **Do not specify sources at this time** checked, then click **Next**.
- 6. To choose the board, click on the board icon and select **Zynq UltraScale+ ZCU102 Evaluation board**, with **Board Rev 1.0**. Click **Next**.





| interview Andrew Project                                                               |                               |                | ×      |
|----------------------------------------------------------------------------------------|-------------------------------|----------------|--------|
| <b>Default Part</b><br>Choose a default Xilinx part or board for your project. This ca | n be changed later.           |                | 4      |
| Parts   Boards                                                                         |                               |                |        |
| Reset All Filters<br>Vendor: All ✓ Name: All<br>Search: Q-                             | •                             |                |        |
| Display Name                                                                           | Preview                       | Vendor         | Fil    |
| Zynq UltraScale+ ZCU102 Evaluation Board<br>Add Daughter Card Connections              |                               | xilinx.com     | 3.2    |
| Zynq UltraScale+ ZCU104 Evaluation Board<br>Add Daughter Card Connections              |                               | xilinx.com     | 1.0    |
|                                                                                        |                               |                | >      |
| <ul> <li>?</li> </ul>                                                                  | < <u>B</u> ack <u>N</u> ext > | <u>F</u> inish | Cancel |

Figure 193: Board Selection Window

7. The project summary displays. To create the project, click **Finish**.





8. Select **Create Block Design** in the Flow Navigator. You can specify the design name and directory, but it is not necessary for a local project directory. Click **OK** to create the block design.



Figure 194: Create Block Design





9. An empty design diagram displays. Click on **Add IP** button to add IP. Select IP based on selected board (for ZCU102 evaluation board, search for 'Zynq UltraScale+ MPSoC') and double click on the selected IP.

| BLOCK DESIGN - design_1                                                                 |                                                       | ? ×                                           |
|-----------------------------------------------------------------------------------------|-------------------------------------------------------|-----------------------------------------------|
| Sources Design × Signals Board ? _ 다 다<br>Q 꽃 붉                                         | Diagram                                               | ? 🗆 🖾 X                                       |
| ▲ design_1                                                                              | Search: Q- Zy (1 match)<br>Zyng UltraScale+ MPSoC     | <u>, , , , , , , , , , , , , , , , , , , </u> |
| Properties       ? _ □ □ ×         ←   →   ◆         Select an object to see properties |                                                       |                                               |
|                                                                                         | ENTER to select, ESC to cancel, Ctrl+Q for IP details |                                               |

Figure 195: Add IP Window





10. Select **Run Block Automation** in the design diagram window. Click **OK** to continue creating the ZCU102 design.

| Diagram × Address Editor ×                                                                                                                                                                                                                                | ? 🗆 🖒 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| ${\bf 6} \mid {\bf 6} \mid {\bf X} \mid {\bf \Sigma} \mid {\bf 6} \mid {\bf C} \mid {\bf \overline{X}} \mid {\bf 6} \mid {\bf 4} \mid {\bf \overline{X}} \mid {\bf 6} \mid {\bf 4} \mid {\bf 6} \mid {\bf 6} \mid {\bf C} \mid {\bf 6} \mid {\bf 6} \mid$ | •     |
| ★ Designer Assistance available. Run Block Automation                                                                                                                                                                                                     |       |
|                                                                                                                                                                                                                                                           |       |
|                                                                                                                                                                                                                                                           |       |
|                                                                                                                                                                                                                                                           |       |
|                                                                                                                                                                                                                                                           |       |
| zynq_ultra_ps_e_0                                                                                                                                                                                                                                         |       |
|                                                                                                                                                                                                                                                           |       |
|                                                                                                                                                                                                                                                           |       |
| maxihpm0_lpd_aclk Z Y I NQ pl_reset                                                                                                                                                                                                                       |       |
| UltraSCALE+                                                                                                                                                                                                                                               |       |
| Zynq UltraScale+ MPSoC                                                                                                                                                                                                                                    |       |
|                                                                                                                                                                                                                                                           |       |
|                                                                                                                                                                                                                                                           |       |
|                                                                                                                                                                                                                                                           |       |
|                                                                                                                                                                                                                                                           |       |

#### Figure 196: Run Block Automation





- 11. When the design diagram appears, follow the below steps to validate design:
  - a. Connect maxihpm0\_fpd\_aclk and maxihpm1\_fpd\_aclk together to pl\_clk0, as shown in the figure below.
    - i. Select maxihpm0\_fpd\_aclk and drag it to maxihpm1\_fpd\_aclk.
    - ii. Select maxihpm1\_fpd\_aclk and drag it to pl\_clk0.
  - b. Right-click on the Zynq UltraScale+ MPSoC block and select **Validate Design** to validate the design. It will say validation successful. Click **OK**.



#### Figure 197: Validating the Design

12. Customize the design by double-clicking on the Zynq UltraScale+ MPSoC block and configuring the parameters. There are 4 valid GT configurations for ZCU102 board as shown below:





| SEL<br>(S3,2,1,0) | ICM Settings<br>(Lane 0,1,2,3)    | PCIe<br>Connector | DP Connector | USB<br>Connector | SATA<br>Connector |
|-------------------|-----------------------------------|-------------------|--------------|------------------|-------------------|
| 0000              | PCIe.o, PCIe.1,<br>PCIE.2, PCIe.3 | PCIe Gen2 x4      | N.C.         | N.C.             | N.C.              |
| 1111              | DP.1, DP.0, USB,<br>SATA          | N.C.              | DP.0, DP.1   | USB0             | SATA1             |
| 1100              | PCIe.0, PCIe.1,<br>USB, SATA      | PCIe Gen2 x2      | N.C.         | USB0             | SATA1             |
| 1110              | PCIe.0, DP.0, USB,<br>SATA        | PCIe Gen2 x1      | DP.0         | USB0             | SATA1             |

Table 2: Supported GTR Connector Functionality

13. Select the settings based on your requirements by double-clicking on the Zynq UltraScale+ MPSoC block to customize GT Lane configuration.





- 14. Select **I/O Configuration** > **High Speed**. Select one of the four combinations using the settings in the screenshots below:
  - a. PCIe Display Port USB SATA (Default Vivado preset )

| ike-customize IP    |        |                                                          |                            |              |        |                   | ×        |
|---------------------|--------|----------------------------------------------------------|----------------------------|--------------|--------|-------------------|----------|
| Zynq UltraScale+ N  | //PSo  | C (3.0)                                                  |                            |              |        |                   | 4        |
| Documentation       | Procot | s 📮 IR Location                                          |                            |              |        |                   |          |
|                     | Flesei |                                                          |                            |              |        |                   |          |
| Page Navigator      |        | O Configuration                                          |                            |              |        |                   |          |
| Switch To Advar     | +      | <ul> <li>MIO Voltage Standar</li> </ul>                  | rd                         |              |        |                   |          |
| PS UltraScale+ Blo  | Q,     |                                                          | Bank1 (MIO 26:<br>LVCMOS18 | 51] Bank2 [N |        | Bank3 [Dedicated] |          |
| I/O Configuration   | *      | Search: Q-                                               |                            |              |        |                   |          |
| Clock Configuration | -      | Peripheral                                               | I/O                        |              |        | Signal            | I/O Type |
| DDR Configuration   | — ,    | > Low Speed                                              |                            |              |        |                   |          |
|                     |        | ✓ High Speed                                             |                            |              |        |                   |          |
| PS-PL Configuratio  |        | > GEM                                                    |                            |              |        |                   |          |
|                     |        | ✓ USB                                                    |                            |              |        |                   |          |
|                     |        | ~ ✓ USB 0                                                |                            |              |        |                   |          |
|                     |        | > USB 2.0                                                |                            | 5263         | ~      |                   |          |
|                     |        | > 🖉 USB 3.0                                              | GT                         | Lane2        | ~      |                   |          |
|                     |        | USB 1                                                    |                            |              |        |                   |          |
|                     |        | ✓ ✓ PCle                                                 |                            |              |        |                   |          |
|                     |        | > Rootport Mode Re                                       |                            |              | ~      |                   |          |
|                     |        | Reset Polarity                                           |                            | ve Low       | ~      |                   |          |
|                     |        | Lane Selection<br>PCIe Lane0                             | x1                         |              | ~      |                   |          |
|                     |        |                                                          | GIL                        | ane0         |        |                   |          |
|                     |        | <ul> <li>✓ ✓ Display Port</li> <li>&gt; DPAUX</li> </ul> | MIC                        | 2730         | ~      |                   |          |
|                     |        | > Lane Selection                                         |                            |              | *<br>* |                   |          |
|                     |        | ✓ ✓ SATA                                                 | SIII                       | gle Lower    | •      |                   |          |
|                     |        | SATA Lane0                                               |                            |              |        |                   |          |
|                     |        | SATA Lane1                                               | CT                         | Lane3        | ~      |                   |          |
|                     |        | > Reference Clocks                                       | GI                         | Lanes        | •      |                   |          |
|                     |        |                                                          |                            |              |        |                   |          |
|                     |        | <                                                        |                            | -            | _      |                   | >        |
|                     |        |                                                          |                            |              |        | ОК                | Cancel   |

Figure 198: I/O Customization Window: PCIe – Display Port – USB – SATA (Default)





b. PCIe - PCIe - USB - SATA

| Documentation 🔅     | Prese    | ts 🛯 📄 IP Location                       |             |                  |                   |          |  |  |  |  |
|---------------------|----------|------------------------------------------|-------------|------------------|-------------------|----------|--|--|--|--|
| Page Navigator      | 1        | I/O Configuration                        |             |                  |                   |          |  |  |  |  |
| Switch To Advar     | +        | <ul> <li>MIO Voltage Standard</li> </ul> |             |                  |                   |          |  |  |  |  |
|                     | Q,       | Bank0 [MIO 0:25] Bank*                   | [MIO 26:51] | Bank2 [MIO 52:77 | Bank3 [Dedicated] |          |  |  |  |  |
| PS UltraScale+ Blo  | -        | LVCMOS18 V LVCM                          | 10S18 🗸     | LVCMOS18 V       | LVCMOS33 V        |          |  |  |  |  |
| I/O Configuration   | ×        | Search: Q.                               |             |                  | ]]                |          |  |  |  |  |
| Clock Configuration | <u> </u> | Peripheral                               | I/O         |                  | Signal            | I/O Type |  |  |  |  |
|                     | •        | > Low Speed                              | 10          |                  | olynai            | no type  |  |  |  |  |
| DDR Configuration   |          | <ul> <li>High Speed</li> </ul>           |             |                  |                   |          |  |  |  |  |
| PS-PL Configuratio  |          | > GEM                                    |             |                  |                   |          |  |  |  |  |
| -                   |          | ✓ USB                                    |             |                  |                   |          |  |  |  |  |
|                     |          | ~ ✓ USB 0                                |             |                  |                   |          |  |  |  |  |
|                     |          | > USB 2.0                                | MIO 52      | 63 🗸             |                   |          |  |  |  |  |
|                     |          | > 🗸 USB 3.0                              | GT Lar      | ie2 🗸            |                   |          |  |  |  |  |
|                     |          | USB 1                                    |             |                  | 1                 |          |  |  |  |  |
|                     |          | <ul> <li>✓ ✓ PCIe</li> </ul>             |             |                  |                   |          |  |  |  |  |
|                     |          | > Rootport Mode Reset                    | MIO 31      | ~                |                   |          |  |  |  |  |
|                     |          | Reset Polarity                           | Active L    | _ow v            |                   |          |  |  |  |  |
|                     |          | Lane Selection                           | x2          | ~                |                   |          |  |  |  |  |
|                     |          | PCIe Lane0                               | GT Lane     | 0                |                   |          |  |  |  |  |
|                     |          | PCle Lane1                               | GT Lane     | 91               |                   |          |  |  |  |  |
|                     |          | > Display Port                           |             |                  |                   |          |  |  |  |  |
|                     |          | <ul> <li>✓ ✓ SATA</li> </ul>             |             |                  |                   |          |  |  |  |  |
|                     |          | SATA Lane0                               |             |                  |                   |          |  |  |  |  |
|                     |          | 🖌 SATA Lane1                             | GT Lar      | ie3 🗸 🗸          |                   |          |  |  |  |  |
|                     |          | > Reference Clocks                       |             |                  |                   |          |  |  |  |  |
|                     |          |                                          |             |                  |                   |          |  |  |  |  |

Figure 199: I/O Configuration Window: PCIe – PCIe – USB – SATA





c. Display Port - Display Port - USB - SATA

| Documentation 🂠     | Prese | ts 🔚 IP Location                         |                          |        |                   |          |  |  |  |  |  |
|---------------------|-------|------------------------------------------|--------------------------|--------|-------------------|----------|--|--|--|--|--|
| Page Navigator      | I     | O Configuration                          |                          |        |                   |          |  |  |  |  |  |
| Switch To Advar     | +     | <ul> <li>MIO Voltage Standard</li> </ul> |                          |        |                   |          |  |  |  |  |  |
|                     | Q,    | Bank0 [MIO 0:25] Bank1                   | [MIO 26:51] Bank2 [MIO 5 | 52:77] | Bank3 [Dedicated] |          |  |  |  |  |  |
| PS UltraScale+ Blo  |       | LVCMOS18 V LVCM                          |                          | ~      | LVCMOS33 V        |          |  |  |  |  |  |
| I/O Configuration   | Ŧ     |                                          |                          |        |                   |          |  |  |  |  |  |
| io comgutation      | \$    | Search: Q-                               |                          |        |                   |          |  |  |  |  |  |
| Clock Configuration | ÷     | Peripheral                               | 1/0                      |        | Signal            | I/O Type |  |  |  |  |  |
|                     | •     | > Low Speed                              |                          |        | - Ignai           |          |  |  |  |  |  |
| DDR Configuration   |       | <ul> <li>High Speed</li> </ul>           |                          |        |                   |          |  |  |  |  |  |
| PS-PL Configuratio  |       | > GEM                                    |                          |        |                   |          |  |  |  |  |  |
|                     |       | ✓ USB                                    |                          |        |                   |          |  |  |  |  |  |
|                     |       | ✓ ✓ USB 0                                |                          |        |                   |          |  |  |  |  |  |
|                     |       | > USB 2.0                                | MIO 5263                 | ~      |                   |          |  |  |  |  |  |
|                     |       | > 🗸 USB 3.0                              | GT Lane2                 | ~      |                   |          |  |  |  |  |  |
|                     |       | USB 1                                    |                          |        |                   |          |  |  |  |  |  |
|                     |       | > PCle                                   |                          |        |                   |          |  |  |  |  |  |
|                     |       | <ul> <li>✓ ✓ Display Port</li> </ul>     |                          |        |                   |          |  |  |  |  |  |
|                     |       | > DPAUX                                  | MIO 27 30                | ~      |                   |          |  |  |  |  |  |
|                     |       | ~ Lane Selection                         | Dual Lower               | ~      |                   |          |  |  |  |  |  |
|                     |       | DP Lane0                                 | GT Lane1                 |        |                   |          |  |  |  |  |  |
|                     |       | DP Lane1                                 | GT Lane0                 |        |                   |          |  |  |  |  |  |
|                     |       | ∽ 🖌 SATA                                 |                          |        |                   |          |  |  |  |  |  |
|                     |       | SATA Lane0                               |                          |        |                   |          |  |  |  |  |  |
|                     |       | 🖌 SATA Lane1                             | GT Lane3                 | ~      |                   |          |  |  |  |  |  |
|                     |       | > Reference Clocks                       |                          |        |                   |          |  |  |  |  |  |
|                     |       |                                          |                          |        |                   |          |  |  |  |  |  |
|                     |       |                                          |                          |        |                   |          |  |  |  |  |  |

Figure 200: I/O Configuration Window: Display Port - Display Port - USB – SATA





d. PCIe - PCIe - PCIe - PCIe (PCIe x4)

| Re-customize IP          |                                    |          |            |                   |                   |          |                    |     |  |
|--------------------------|------------------------------------|----------|------------|-------------------|-------------------|----------|--------------------|-----|--|
| Zynq UltraScale+ MPSo    | C (3.0)                            |          |            |                   |                   |          |                    | 1   |  |
| Documentation 🔅 Preset   | s 📄 IP Location                    |          |            |                   |                   |          |                    |     |  |
| Page Navigator —         | I/O Configuration                  |          |            |                   |                   |          |                    |     |  |
| Switch To Advanced M     | <ul> <li>MIO Voltage St</li> </ul> | andard   |            |                   |                   |          |                    |     |  |
|                          | Q Bank0 [MIO 0:2                   |          | MIO 26:51] | Bank2 [MIO 52:77] | Bank3 [Dedicated] |          |                    |     |  |
| PS UltraScale+ Block Des | LVCMOS18                           | ~ LVCMC  | 0S18 🗸     | LVCMOS18 V        | LVCMOS33 🗸        |          |                    |     |  |
| I/O Configuration        | X                                  |          |            |                   |                   |          |                    |     |  |
|                          |                                    |          |            |                   |                   |          |                    |     |  |
| Clock Configuration      | Peripheral                         |          | I/O        |                   | Signal            | I/O Type | Drive Strength(mA) | Spe |  |
| DDR Configuration        | > Low Speed                        |          |            |                   |                   |          |                    |     |  |
|                          | <ul> <li>High Speed</li> </ul>     |          |            |                   |                   |          |                    |     |  |
| PS-PL Configuration      |                                    | > GEM    |            |                   |                   |          |                    |     |  |
|                          | > USB                              |          |            |                   |                   |          |                    |     |  |
|                          | > Rootport Mod                     | le Reset | MIO 31     | ~                 |                   |          |                    |     |  |
|                          | Reset Polarit                      |          | Active Lo  |                   |                   |          |                    |     |  |
|                          | Lane Selection                     |          | x4         | ~                 |                   |          |                    |     |  |
|                          | PCIe Lane0                         |          | GT Lane(   | )                 |                   |          |                    |     |  |
|                          | PCIe Lane1                         |          | GT Lane1   | 1                 |                   |          |                    |     |  |
|                          | PCIe Lane2                         |          | GT Lane2   | 2                 |                   |          |                    |     |  |
|                          | PCIe Lane3                         |          | GT Lane3   | 3                 |                   |          |                    |     |  |
|                          | > Display Port                     |          |            |                   |                   |          |                    |     |  |
|                          | > SATA                             |          |            |                   |                   |          |                    |     |  |
|                          | > Reference Clocks                 |          |            |                   |                   |          |                    |     |  |
|                          |                                    |          |            |                   |                   |          |                    |     |  |
|                          | <                                  |          |            |                   |                   |          |                    |     |  |
|                          |                                    |          |            |                   |                   | _        |                    |     |  |
|                          |                                    |          |            |                   |                   |          | OK Cano            | el  |  |
|                          |                                    |          |            |                   |                   |          |                    |     |  |

Figure 201: PCIe - PCIe - PCIe - PCIe





15. You can save customized presets using preset by selecting **Presets** > **Save Configuration** at the top of the window. This is useful if you want to save various configurations for future use.

| 🔥 Re-customize IP    |       |                                |                              |                     |          |                            |       |                          | <b>×</b> |
|----------------------|-------|--------------------------------|------------------------------|---------------------|----------|----------------------------|-------|--------------------------|----------|
| Zynq UltraScale+ Mi  | PSoC  | C (3.0)                        |                              |                     |          |                            |       |                          | 4        |
| Documentation Open P | reset | s 📄 IP L                       | ocation                      |                     |          |                            |       |                          |          |
| Page Navigator       |       |                                | nfiguration                  |                     |          |                            |       |                          |          |
| Switch To Advar      | +     | ~ MIO                          | Voltage Standa               | rd                  |          |                            |       |                          |          |
| PS UltraScale+ Blo   | Q,    |                                | nk0 [MIO 0:25]<br>CMOS18 🗸 🗸 | Bank1 [MI<br>LVCMOS |          | Bank2 [MIO 52:<br>LVCMOS18 |       | 3 [Dedicated]<br>10S33 V |          |
| I/O Configuration    | ¥     | <u>S</u> earch:                | Q,                           |                     |          |                            |       | ,                        |          |
| Clock Configuration  | -     | Periphera                      | I                            |                     | I/O      |                            | Signa | I                        | I/O Type |
| DDR Configuration    | - I   | > Low Sp                       |                              |                     |          |                            |       |                          |          |
|                      |       | <ul> <li>High Speed</li> </ul> |                              |                     |          |                            |       |                          |          |
| PS-PL Configuratio   |       | > GEM                          |                              |                     |          |                            |       |                          |          |
|                      |       | > USE<br>∼ ✓ P                 |                              |                     |          |                            |       |                          |          |
|                      |       |                                | ootport Mode Re              | sot                 | MIO 31   |                            | ~     |                          |          |
|                      |       |                                | eset Polarity                |                     | Active L | ow                         | ~     |                          |          |
|                      |       |                                | ane Selection                |                     | x4       |                            | ~     |                          |          |
|                      |       |                                | Cle Lane0                    |                     | GT Lane  | 0                          |       |                          |          |
|                      |       | PC                             | Cle Lane1                    |                     | GT Lane  | 1                          |       |                          |          |
|                      |       | PC                             | Cle Lane2                    |                     | GT Lane  | 2                          |       |                          |          |
|                      |       | PC                             | Cle Lane3                    |                     | GT Lane  | 3                          |       |                          |          |
|                      |       | > 🗌 D                          | isplay Port                  |                     |          |                            |       |                          |          |
|                      |       | > 🗌 S                          | ATA                          |                     |          |                            |       |                          |          |
|                      |       | > Refere                       | nce Clocks                   |                     |          |                            |       |                          |          |
|                      |       | <                              |                              |                     |          |                            |       |                          | >        |
|                      |       |                                |                              |                     |          |                            |       | ОК                       | Cancel   |

Figure 202: Selecting Save Configuration





16. Saved preset can be applied by selecting **Preset** > **Apply Configuration**. A file selection dialogue will appear as shown below. Choose the preset **PCIE-PCIE-USB-SATA** and click **OK**.

| 4                                       |                                                                                                       |
|-----------------------------------------|-------------------------------------------------------------------------------------------------------|
| Look <u>i</u> n: 🥡 temp                 | ✓ Ø S = k ≥ × S = :::                                                                                 |
| 🚚 tmplpa2ty                             | Recent Directories                                                                                    |
| 🚛 tmppqvrud                             | C:/temp 🗸                                                                                             |
| 🐙 tmppuplpm                             | File Preview                                                                                          |
| 🗼 tmpte9mi1                             | proc getPresetInfo {} {                                                                               |
| vio_0                                   | return [dict create name {pcie_all} description {pcie                                                 |
| √ xinstall                              | 3                                                                                                     |
| 🖲 pcie_alltcl                           | <pre>proc validate_preset {IPINST} { return true }</pre>                                              |
|                                         |                                                                                                       |
|                                         | proc apply_preset {IPINST} {                                                                          |
|                                         | return [dict create \                                                                                 |
|                                         | CONFIG.PSU_PSS_REF_CLK_FREQMHZ {33.333} \<br>CONFIG.PSU_CAN1_PERIPHERAL_ENABLE {1} \                  |
|                                         | CONFIG.PSU_CAN1_PERIPHERAL_IO {MIO 24 25} \                                                           |
|                                         | CONFIG.PSU_DPAUX_PERIPHERAL_ENABLE {0} \                                                              |
|                                         | CONFIG.PSU_DPAUX_PERIPHERAL_IO { <select>} \<br/>CONFIG.PSU ACT DDR FREQ MHZ {1066.656006} \</select> |
|                                         | CONFIG.PSU_FPGA_PLO_ENABLE {1} \                                                                      |
|                                         | CONFIG.PSU ENET3 PERIPHERAL ENABLE {1}                                                                |
|                                         | CONFIG.PSU_ENET3_PERIPHERAL_IO {MIO 64 75}                                                            |
| >                                       |                                                                                                       |
|                                         |                                                                                                       |
| File <u>n</u> ame: pcie_alltcl          |                                                                                                       |
| Files of type: Preset Tcl Files (*.tcl) | *                                                                                                     |
|                                         |                                                                                                       |
|                                         | OK Cancel                                                                                             |
|                                         |                                                                                                       |

Figure 203: Applying a Preset Configuration

- 17. Click **OK** when finished customizing GT Lane configuration.
- 18. Do not click **Run Block Automation** again, even though the banner will reappear. It will reset the customized values if used.
- 19. Click on the **Sources** tab on the top left of the Block Design window. Under the Block Designs group, click on **IP Sources**. Right click on **design\_1** and then click on **Create HDL Wrapper**.





#### Lab 10: Using Vivado Serial Analyzer to Debug GTR Serial Links



Figure 204: Create HDL Wrapper

- 20. Leave the option **Let Vivado manage wrapper and auto-update** selected. Click on **OK** in the dialogue to create HDL Wrapper.
- 21. Right click on design\_1\_i in IP Sources tab and click on Generate Output Products.
- 22. Click on Generate to generate with the default options in the panel.
- 23. Click **OK** after the generation is complete.





#### 24. Select File > Export > Export Hardware.



Figure 205: Export Hardware





25. You can specify an export directory or use Local to Project. Click **OK** to export the hardware.



Figure 206: Export Hardware Window

26. You can see generated HDF path in the Tcl Console after the write\_hwdef function call.



#### Figure 207: Running write\_hwdef

## Step 2: Using XSCT flow to generate FSBL by using HDF

Xilinx Software Command-line Tool (XSCT) is an interactive and scriptable command-line interface to Xilinx Software Development Kit (Xilinx SDK). The XSCT flow should be used for a more automated flow that is Tcl based and only requires running a Tcl script. There is an SDK flow that should be used for a more interactive setup of the FSBL which uses a GUI. You can use the SDK flow if you need to make changes/customizations to the FSBL. SDK flow could also be used for custom board. See "Appendix A" for the SDK or XSCT Manual flow.





## Generating using XSCT Automated Flow:

To create an FSBL for the A53 #0 (64 bit) automatically (and modify the xfsbl\_main.c/h files if USB is present) using the provided script, use the follow steps:

- Copy the src/lab10/xsct\_create\_fsbl.tcl script to the directory where the HDF file is located (e.g. project\_gtr/project\_gtr.sdk). You can modify the Tcl script if you changed the default name of the HDF file in Vivado. You can also change the script if the compiler options need to be different.
- 2. Open a terminal on Linux or command prompt on Windows.
- 3. Cd into the directory where the HDF file is located.
- 4. Call xsct from the SDK install area:

```
% xsct xsct_create_fsbl.tcl
```

5. It prints out the location of the generated .elf file when the script completes.

## Step 3: ZCU102 Board Settings

### USB jumper setting requirements for HOST mode on ZCU102:

- 1. Make sure below jumpers are correctly set for USB to be in HOST mode (refer to UG1182).
  - e. J7 ON
  - f. J113 1-2
  - g. J110 2-3
- 2. Refer to the below image for jumper settings on a ZCU102 Rev 1.0 board:







Figure 208: Jumper Settings for the ZCU102 Board

# Using FSBL with Serial I/O Analyzer to bring up IBERT GTR

- 1. Connect all the physical devices such as SATA Drive, PCIE card, and USB device based on your selection from the four valid GT configurations for ZCU102 prior to loading the FSBL. Hot swap or hot plug is not supported.
- 2. Open Vivado.





3. Open hardware manager and connect to a board with a Zynq UltraScale+ device. The example below shows connecting to a board on a remote machine, so hw\_server needs to be running on the remote machine before it can connect.

| 🍐 Open New Ha         | rdware Target                                                                                                                                                                                                         | ×     |  |  |  |  |  |  |  |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--|--|--|--|--|--|--|
| Select local or rem   | Hardware Server Settings<br>select local or remote hardware server, then configure the host name and port settings. Use Local server if the target is attached to the<br>local machine; otherwise, use Remote server. |       |  |  |  |  |  |  |  |
| <u>C</u> onnect to: F | Remote server (target is on remote machine)                                                                                                                                                                           |       |  |  |  |  |  |  |  |
| Remote Server         |                                                                                                                                                                                                                       |       |  |  |  |  |  |  |  |
| <u>H</u> ost name:    | ibert-0 💿 🗸                                                                                                                                                                                                           |       |  |  |  |  |  |  |  |
| Port:                 | 3121 [default is 3121]                                                                                                                                                                                                |       |  |  |  |  |  |  |  |
| Click Next to lau     | nch and/or connect to the hw_server (port 3121) application on the remote machine 'lentinus14'.                                                                                                                       |       |  |  |  |  |  |  |  |
| •                     | < <u>B</u> ack <u>N</u> ext > <u>F</u> inish C:                                                                                                                                                                       | ancel |  |  |  |  |  |  |  |

Figure 209: Hardware Server Settings





4. Verify the **ARM\_DAP** is visible in the hardware device list and click **Next**, and then click **Finish**.

| Select Hardwa         | Open New Hardware Target Select Hardware Target Select a hardware target from the list of available targets, then set the appropriate JTAG clock (TCK) frequency. If you do not see the expected devices, decrease the frequency or select a different target. |           |                            |                                           |       |        |        |  |  |  |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----------------------------|-------------------------------------------|-------|--------|--------|--|--|--|
| Hardware <u>T</u> arg | Hardware Targets                                                                                                                                                                                                                                               |           |                            |                                           |       |        |        |  |  |  |
| Туре                  | Name                                                                                                                                                                                                                                                           |           | JTAG Clock Frequency       |                                           |       |        |        |  |  |  |
| xilinx_tcf            | Digilent/210308                                                                                                                                                                                                                                                |           | 15000000 🗸                 |                                           |       |        |        |  |  |  |
| _                     |                                                                                                                                                                                                                                                                |           | specify the Instruction Re | rtual Cable (XVC)<br>egister (IR) length) |       |        |        |  |  |  |
| Name                  | ID Code                                                                                                                                                                                                                                                        | IR Length |                            |                                           |       |        |        |  |  |  |
| xczu9_0     arm_dap_  | 04738093<br>5BA00477                                                                                                                                                                                                                                           | 12<br>4   |                            |                                           |       |        |        |  |  |  |
| Hardware serve        |                                                                                                                                                                                                                                                                |           |                            | < Back                                    | Next> | Finish | Cancel |  |  |  |

Figure 210: Selecting the Device

5. Right-click on the **ARM\_DAP** device in the hardware tree and select **Configure IBERT GTR**.



Figure 211: Selecting Configure IBERT GTR

www.xilinx.com





6. When the dialog box opens, you must provide the FSBL ELF file created in the previous steps and optionally a configuration file (a bitstream, if your design requires one). You can also reset the system before configuring with the **Reset Zynq** option checked. Click **OK** when done.

*Note*: The **Reset Zynq** option leaves the ARM\_DAP in a bad state on early versions of Zynq UltraScale+ devices (e.g. ZU9EG es1). If that occurs, power cycle the board and keep the **Reset Zynq** option unchecked.

| 🔥 Configure IBERT GTR                                                               |                                                                       |    |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------|-----------------------------------------------------------------------|----|--|--|--|--|--|--|
| A Zynq FSBL is required to configure IBERT GTR. The configuration file is optional. |                                                                       |    |  |  |  |  |  |  |
|                                                                                     |                                                                       | _  |  |  |  |  |  |  |
| Zynq FSBL:                                                                          | >roject_gtr/project_gtr.sdk/fsbl_design_1/Debug/fsbl_design_1.elf 💿 - | -  |  |  |  |  |  |  |
| Configuration File:                                                                 | •                                                                     |    |  |  |  |  |  |  |
|                                                                                     |                                                                       |    |  |  |  |  |  |  |
| <u>R</u> eset Zynq                                                                  |                                                                       |    |  |  |  |  |  |  |
|                                                                                     |                                                                       | _  |  |  |  |  |  |  |
|                                                                                     | ОК Сапса                                                              | el |  |  |  |  |  |  |
|                                                                                     |                                                                       |    |  |  |  |  |  |  |

Figure 212: Selecting the FSBL File





7. config\_hw\_sio\_gts is executed with the selected settings. refresh\_hw\_device is then called to rescan the device for new debug cores. The IBERT should be configured as shown in the example below:



Figure 213: IBERT Configuration





8. The **Auto-detect links** option does not work for GTR. You can manually create links by using **Create Links** as shown below:



Figure 214: Selecting Create Links





9. Create links for all four lanes with each lane's **TX** connected to the same lane's **RX**, as shown in the figure below.

Click **OK** when done.

| 🔥 Create Links                  |                                | N                       |                 |                  | ×      |
|---------------------------------|--------------------------------|-------------------------|-----------------|------------------|--------|
| To create a new link            | select a TX GT and/or an RX GT | , then click the Add bu | utton on the Ne | w Links toolbar. | 4      |
| TX GTs                          |                                | RX GTs                  |                 |                  |        |
| Search: Q-                      |                                | Search                  | Q.              |                  |        |
|                                 |                                |                         |                 |                  |        |
|                                 |                                |                         |                 |                  |        |
|                                 |                                |                         |                 |                  |        |
|                                 |                                |                         |                 |                  |        |
| New Links                       |                                |                         |                 |                  |        |
| +   -                           |                                |                         |                 |                  |        |
| Description $\sim$ <sup>1</sup> | ТХ                             | RX                      |                 |                  |        |
| % Link 3                        | L3/TX (arm_dap_1/Quad_0)       | L3/RX (arm_dap_1        | (Quad_0)        |                  |        |
| % Link 2                        | L2/TX (arm_dap_1/Quad_0)       | L2/RX (arm_dap_1        | (Quad_0)        |                  |        |
| % Link 1                        | L1/TX (arm_dap_1/Quad_0)       | L1/RX (arm_dap_1        | (Quad_0)        |                  |        |
| % Link 0                        | L0/TX (arm_dap_1/Quad_0)       | L0/RX (arm_dap_1        | (Quad_0)        |                  |        |
|                                 |                                |                         |                 |                  |        |
|                                 |                                |                         |                 |                  |        |
| ✓ <u>C</u> reate link grou      | p                              |                         |                 |                  |        |
| Link group descript             | ion: Link Group 0              |                         |                 |                  | 8      |
| 🖌 Open Serial I/O               | Analyzer layout                |                         |                 |                  |        |
| (?)                             |                                |                         |                 | ок               | Cancel |
|                                 |                                |                         |                 | on               | Ganoor |

Figure 215: Creating Links





10. The figure below shows the Serial I/O Links view where **Status** shows all the four lanes as linked.

| 🖕 🔸 🛹 🔳 🛍                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | × •                                                | 🕺 🖉 🔀 Dashboar                                                                                                                                                 | d 🔻                                                          |                                                               |                                                 |                      | III Se         | rial I/O Analyzer                                                |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|---------------------------------------------------------------|-------------------------------------------------|----------------------|----------------|------------------------------------------------------------------|--|
| Hardware                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                    |                                                                                                                                                                | ? _ O Ľ X                                                    | GT Properties                                                 |                                                 |                      | ?              | _ O Ľ X                                                          |  |
| Q   ≚   ♦   Ø   ▶                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | > =                                                |                                                                                                                                                                | 0                                                            | Rg L1                                                         |                                                 |                      |                | ←   →   Φ                                                        |  |
| Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                    | Status                                                                                                                                                         |                                                              |                                                               |                                                 |                      |                |                                                                  |  |
| / 📔 ibert-0 (1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                    | Connected                                                                                                                                                      |                                                              | A11BFC/1_1_0/IBERT/                                           | 0/IBERT/Quad_0/L1                               |                      |                |                                                                  |  |
| ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 10308A11B                                          | Open                                                                                                                                                           |                                                              | Status:                                                       |                                                 |                      |                |                                                                  |  |
| xczu9_0 (1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                    | Not programmed                                                                                                                                                 |                                                              | GT group:                                                     |                                                 |                      |                |                                                                  |  |
| 🦉 SysMon (Syste                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | em Monitor)                                        |                                                                                                                                                                |                                                              | IBERT core:                                                   | IBERT                                           |                      |                |                                                                  |  |
| @ arm_dap_1 (2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                    | N/A                                                                                                                                                            |                                                              | Device:                                                       | @ arm_dap_1                                     |                      |                |                                                                  |  |
| 🦉 SysMon (Syste                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | em Monitor)                                        |                                                                                                                                                                |                                                              |                                                               |                                                 |                      |                |                                                                  |  |
| IBERT (IBERT)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | )                                                  |                                                                                                                                                                |                                                              |                                                               |                                                 |                      |                |                                                                  |  |
| V No. 0 (4)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | )                                                  |                                                                                                                                                                |                                                              |                                                               |                                                 |                      |                |                                                                  |  |
| Na 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                    | Pcie.0 - Linked                                                                                                                                                |                                                              |                                                               |                                                 |                      |                |                                                                  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                    | Pcie.1 - Linked                                                                                                                                                |                                                              |                                                               |                                                 |                      |                |                                                                  |  |
| P⊲ L1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                    |                                                                                                                                                                |                                                              |                                                               |                                                 |                      |                |                                                                  |  |
| ₽a L1<br>₽a L2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                    | Usb0 - No Link (rx_det)                                                                                                                                        |                                                              |                                                               |                                                 |                      |                |                                                                  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                    |                                                                                                                                                                | )                                                            | General Pro                                                   | operties PLLs                                   |                      |                |                                                                  |  |
| Pa L2<br>Pa L3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Serial I/O Li                                      | Usb0 - No Link (rx_det)                                                                                                                                        | )                                                            | General Pr                                                    | operties PLLs                                   |                      |                | ? _ 0 [                                                          |  |
| R <sub>d</sub> L2<br>R <sub>d</sub> L3<br>Tcl Console Messages<br>Q X X I € Y                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                    | Usb0 - No Link (rx_det)<br>Sata1 - No Link (awaitcominit<br>sata2 - No Link (awaitcominit                                                                      |                                                              |                                                               |                                                 | TV PL   Status       |                |                                                                  |  |
| Pa L2<br>Pa L3<br>Incl Console Messages<br>Q X X I ♀ Y                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Serial I/O Li<br>TX RX                             | Usb0 - No Link (rx_det)<br>Sata1 - No Link (awaitcominit                                                                                                       | )<br>TX Post-Cursor                                          | General Pro                                                   | operties PLLs<br>RX PLL Status                  | TX PLL Status        | TXUSERCLK Freq | ? _ D                                                            |  |
| Ra L2<br>Ra L3<br>CCI Console Messages<br>Q X ↓ ↓ ↓<br>Name<br>Digrouped Links (0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                    | Usb0 - No Link (rx_det)<br>Sata1 - No Link (awaitcominit<br>sata2 - No Link (awaitcominit                                                                      | TX Post-Cursor                                               | TX Diff Swing                                                 |                                                 | TX PLL Status        | TXUSERCLK Freq |                                                                  |  |
| Ra L2<br>Ra L3<br>CCI Console Messages<br>Q X ↓ ↓ ↓<br>Name<br>Digrouped Links (0)<br>Y ⊕ Link Group 0 (4)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | TX RX                                              | Usb0 - No Link (rx_det)<br>Sata1 - No Link (awaitcominit<br>sata2 - No Link (awaitcominit                                                                      | TX Post-Cursor                                               |                                                               | RX PLL Status                                   | TX PLL Status        | TXUSERCLK Freq | RXUSERCLK Freq                                                   |  |
| Ra L2<br>Ra L3<br>CCI Console Messages<br>Q X Console + Console<br>Q X Console + Console<br>Vame<br>Console + Console + Co                                                                                                                                                                | TX RX                                              | Usb0 - No Link (rx_det)<br>Sata1 - No Link (awaitcominit<br>nks × Serial I/O Scans<br>Status                                                                   | TX Post-Cursor<br>Multiple ~                                 | TX Diff Swing<br>User Value 🗸                                 | RX PLL Status                                   |                      |                | RXUSERCLK Freq<br>100.00                                         |  |
| Ra L2<br>Ra L3<br>CCI Console Messages<br>Q X Console Participation<br>CONSOLE Partico Participation<br>Console Participatio<br>Console Participation | TX RX<br>L0/TX L0/RX<br>L1/TX L1/RX                | Usb0 - No Link (rx_det)       Sata1 - No Link (awaitcominit       inks     ×       Serial I/O Scans       Status       Pcie.0 - Linked                         | TX Post-Cursor<br>Multiple<br>User Value                     | TX Diff Swing<br>User Value ~<br>User Value ~                 | RX PLL Status<br>Locked<br>Not Locked           | Locked               | 100.000        | RXUSERCLK Freq<br>100.00<br>100.00                               |  |
| Pa L2       Pa L3       Fcl Console     Messages       Q     ₹     ♦     ♥       Name     ●     ♥     ↓       Name     ●     ↓       ©     Ungrouped Links (0)         ♥     ↓        ♥     ↓        ♥     ↓        ♥     ↓        ♥     ↓        ♥     ↓        ♥     ↓                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | TX RX<br>L0/TX L0/RX<br>L1/TX L1/RX<br>L2/TX L2/RX | Usb0 - No Link (rx_det)       Sata1 - No Link (awaitcominit       inks     ×       Serial I/O Scans       Status       Pcie. 0 - Linked       Pcie. 1 - Linked | TX Post-Cursor<br>Multiple ~<br>User Value ~<br>User Value ~ | TX Diff Swing<br>User Value ~<br>User Value ~<br>User Value ~ | RX PLL Status<br>Locked<br>Not Locked<br>Locked | Locked<br>Not Locked | 100.000        | ? _ 0 0<br>RXUSERCLK Freq<br>100.00<br>100.00<br>26.00<br>150.00 |  |

#### Figure 216: Serial I/O Links View

*Note:* The Link 1 PLL Status shows **Not Locked**, because it uses the Link 0 PLL as required by PCIe protocol.





11. Right-click on any link and select **Create Scan**.

| cl Console Messages                    | Serial I/O Links × |       |            | 1 | Link Properties            | Ctrl+E |  |
|----------------------------------------|--------------------|-------|------------|---|----------------------------|--------|--|
| Q   <u>∓</u>   <b>≑</b>   <del>†</del> |                    |       |            | × | Delete<br>Create Links     | Delete |  |
| Name                                   | ΤХ                 | RX    | Status     |   | Create Link Group          |        |  |
| Ungrouped Links (0)                    |                    |       |            |   |                            |        |  |
| Y 🚳 Link Group 0 (4)                   |                    |       |            |   | Create Scan                | 2      |  |
| % Link 0                               | L0/TX              | L0/RX | Pcie.0 - L |   | Create Sweep               | -0     |  |
| % Link 1                               | L1/TX              | L1/RX | Pcie.1 - L |   | Commit Properties          |        |  |
| % Link 2                               | L2/TX              | L2/RX | Pcie.2 - L | c | Refresh Serial I/O Objects |        |  |
| % Link 3                               | L3/TX L3/RX        |       | Pcie.3 - L | - |                            |        |  |

Figure 217: Selecting Create Scan





12. Select the appropriate parameters for EyeScan and perform the EyeScan. For example, the figure below is performing EyeScan on Lane L1 (Link 1). Once the EyeScan completes, the eye from -1UI to +1UI will be displayed.

**Note:** Although the **Create Scan** pop up shows -0.5UI to +0.5UI, the EyeScan displayed is from -1UI to +1UI.

| 🍐 Create Scan                                                                                      |            |                                       | ×      |  |  |  |  |
|----------------------------------------------------------------------------------------------------|------------|---------------------------------------|--------|--|--|--|--|
| Set the description and other properties to create and optionally run a scan on the selected link. |            |                                       |        |  |  |  |  |
| Link: Link                                                                                         | : 1 (L1/TX | , L1/RX)                              |        |  |  |  |  |
| Description: Sc                                                                                    | an O       |                                       | 8      |  |  |  |  |
| Scan Properties                                                                                    | ;          |                                       |        |  |  |  |  |
| <u>S</u> can type:                                                                                 |            | 2D Full Eyescan                       | •      |  |  |  |  |
| <u>H</u> orizontal inc                                                                             | rement:    | 4 ~                                   | •      |  |  |  |  |
| Horizontal rar                                                                                     | nge:       | -0.500 UI to 0.500 UI                 | *      |  |  |  |  |
| Vertical incre                                                                                     | ment:      | 4 ~                                   | ·      |  |  |  |  |
| V <u>e</u> rtical range:                                                                           |            | 100% ~                                | •      |  |  |  |  |
|                                                                                                    |            |                                       |        |  |  |  |  |
| Dwell                                                                                              |            |                                       |        |  |  |  |  |
| • <u>B</u> ER: 1                                                                                   | e-5        | · · · · · · · · · · · · · · · · · · · | •      |  |  |  |  |
| O <u>T</u> ime:                                                                                    |            | 0 4                                   | *<br>* |  |  |  |  |
| ✓ <u>R</u> un scan                                                                                 |            |                                       |        |  |  |  |  |
| ?                                                                                                  |            | OK Canc                               | el     |  |  |  |  |
|                                                                                                    |            |                                       |        |  |  |  |  |

Figure 218: Selecting EyeScan Parameters





13. Below is a sample EyeScan performed on Lane L1:



#### Figure 219: Sample EyeScan

*Note:* The value reported by **Open UI %** is a percentage of the entire horizontal axis, which is 2UI wide for GTR.





# Troubleshooting

### Known Issues

- 1. By default, FSBL does not enumerate USB as that is something Linux drivers would do. To put USB in link state without Linux, a small modification is required in the FSBL C-code. This modification still does not enumerate the device, it only brings the USB into link state.
- The EyeScan does not have a built-in time-out mechanism. If your link is poor (for example, if L\*\_TM\_DIG\_8.EYESURF\_ENABLE != 1), then the EyeScan will hang without providing a user. No results are returned in this case.
- 3. If the EyeScan progress is not moving, make sure the below parameters for all lanes are set for EyeScan to function correctly. Note that \* represents the lane number (as in, for Lane 0 the parameter would be L0).

Click on the lane in the hardware tree and then click on the properties tab. There's a search button you can use to find the properties below.

- a. L\*\_TM\_MISC3.CDR\_EN\_FPL = 0
- b. L\*\_TM\_MISC3.CDR\_EN\_FFL = 0
- c. L\*\_TM\_DIG\_8.EYESURF\_ENABLE = 1

Also check below parameters values which ensures Eye Scan circuit is operational.

- d.  $L*_PLL_LOCK = 1$
- e. L\*\_TM\_SAMP\_STATUS4.E\_SAMP\_PH0\_CALIB\_CODE is non-zero value
- f. <code>L\*\_TM\_SAMP\_STATUS5.E\_SAMP\_PH180\_CALIB\_CODE</code> is non-zero value

### Notes

- 1. As mentioned in Assumptions, IBERT GTR uses the psu\_cortexr5\_0 core, so no other applications should use this core.
- 2. TCM0 and TCM1 memory are combined to form a unified memory for IBERT GTR. Any other processor core should not access this memory while IBERT GTR is running.
- 3. The error counter is 16 bits and the sample counter is 32 bits. Each sample can have 8 bits of error count. Therefore on the edges, the error counter can saturate with a sample count value of 8192. GTR does not stop the sample counter even if the error counter saturates. A prescale=0 produces 8192 samples and thus a total samples of 8192 \*8 (65536) and thus the outside edges of eye could show a BER of e-01 or less depending on the prescale selected.
- 4. The EyeScan assumes there is link present. If there is no link, then the EyeScan may not complete. Cancelling the EyeScan stops the command sequence, but the state of the previous point scan will be unknown.





- 5. If you run EyeScan and because of no link the EyeScan does not complete, set the register L\*\_TM\_MISC\_ST\_0.EYE\_SURF\_RUN to 0 for the given lane before you run the EyeScan again.
- 6. If you run EyeScan on a lane that is either powered down or Display Port, it will immediately stop and the scan will be marked as incomplete. EyeScan will not work in either scenario.

# Using SDK Flow or XSCT Flow to Generate FSBL by Using HDF

The SDK flow should be used for a more interactive setup of the FSBL which uses a GUI as well as when creating FSBL for custom board. The XSCT flow should be used for a Tcl based flow.

## Generating using SDK Flow:

 Launch SDK from Vivado with the opened Zynq project from earlier with the HDF file generated. This could be either for ZCU102 board or custom Zynq board. Launch the SDK by selecting File > Launch SDK.

| <u>F</u> ile | <u>E</u> dit F <u>l</u> ov                                                     | w <u>T</u> ools                                           | <u>W</u> indow  | La⊻out                                           | <u>V</u> iew | <u>H</u> elp | Deb       | bug      | <b>Q</b> , v Quick | Acce  | SS                       |
|--------------|--------------------------------------------------------------------------------|-----------------------------------------------------------|-----------------|--------------------------------------------------|--------------|--------------|-----------|----------|--------------------|-------|--------------------------|
| $\sim$       | <u>N</u> ew Project<br>Open Project<br>Open <u>R</u> ecent Project ▶           |                                                           |                 | \$                                               | Σ            | 2            | 8 38      | £        |                    |       |                          |
|              |                                                                                |                                                           |                 | OJECT N                                          | IANAC        | GER          | pro       | ject_1   |                    |       |                          |
|              |                                                                                |                                                           |                 | ources                                           |              |              |           |          | -                  | >     |                          |
|              | Open Ex <u>a</u> mp                                                            |                                                           |                 |                                                  |              |              |           | _        |                    |       |                          |
|              | S <u>a</u> ve Project                                                          |                                                           |                 |                                                  |              | +            |           | 0        |                    |       | \$                       |
|              | Write Project Tcl                                                              |                                                           |                 |                                                  | -            | urces (1)    |           | r (docio | in_1_wrapp         | orià  | (1)                      |
|              | Arc <u>h</u> ive Proje                                                         | -                                                         | istrain         | -                                                | rappe        | (aesig       | m_t_wrapp | er.v)    | (1)                |       |                          |
|              | <u>C</u> lose Project                                                          |                                                           |                 | _                                                |              | Sources      | (1)       |          |                    |       |                          |
|              | ·                                                                              | pen Chec <u>k</u> point<br>pen Re <u>c</u> ent Checkpoint |                 |                                                  |              |              |           |          |                    |       |                          |
|              | Open Re <u>c</u> ent Checkpoint<br><u>W</u> rite Checkpoint<br>New IP Location |                                                           |                 | Hierarch                                         | y IF         | Sources      | ; Li      | braries  | Compi              | le Or | der                      |
|              |                                                                                |                                                           |                 |                                                  | _            |              |           |          | -                  |       |                          |
|              | <br>Open IP Loca                                                               |                                                           |                 | Propertie                                        | 5            |              |           |          | 1                  | _     |                          |
|              | Open Recent IP Location                                                        |                                                           |                 |                                                  |              |              |           |          |                    | +     | $\Rightarrow$ $\Diamond$ |
|              | Ne <u>w</u> File                                                               |                                                           |                 |                                                  |              |              |           |          |                    |       |                          |
|              | Open Fi <u>l</u> e                                                             |                                                           | Ctrl+0          | Select an object to see properties               |              |              |           |          |                    |       |                          |
|              | Open Recent                                                                    | _                                                         | Þ               | ► _                                              |              |              |           |          |                    |       |                          |
|              | Open IP-XA <u>C</u> T File                                                     |                                                           |                 |                                                  |              |              |           |          |                    |       |                          |
|              | <u>S</u> ave File                                                              |                                                           | Ctrl+S          | Tcl Cons                                         | ole          | Messag       | es        | Log      | Reports            | De    | sign Runs                |
|              | Sa <u>v</u> e File As<br>Save All F <u>i</u> les.                              |                                                           |                 | Q 🛛 🛨                                            | \$           |              | $\ll$     | ▶   3    | » +                | %     |                          |
|              |                                                                                |                                                           | A. 14           | Name                                             |              |              |           |          |                    |       | Constraints              |
|              | Add So <u>u</u> rces.<br>Open Source                                           |                                                           | Alt+A<br>Ctrl+N | > synth_1 (active)                               |              |              |           |          |                    |       | constrs_1                |
|              | Import                                                                         | - me                                                      | curri           | impl_1     constrs_1     Constrs_1     Constrs_1 |              |              |           |          |                    |       | constrs_1                |
|              | Export                                                                         |                                                           | · · ·           |                                                  |              |              |           |          |                    |       |                          |
|              | Launch SDK                                                                     |                                                           |                 |                                                  |              |              |           |          |                    |       |                          |
|              | Open Log File                                                                  |                                                           |                 |                                                  |              |              |           |          |                    |       |                          |
|              | Open Journal                                                                   |                                                           |                 |                                                  |              |              |           |          |                    |       |                          |
|              | <u>P</u> rint                                                                  |                                                           | Ctrl+P          |                                                  |              |              |           |          |                    |       |                          |
|              |                                                                                |                                                           |                 |                                                  |              |              |           |          |                    |       |                          |

Figure 220: Launching the SDK





2. Provide the **Exported Location** path (where your \*.hdf file was exported). The SDK **Workspace** could also be the same path. This creates the SDK workspace. Click **OK**.

| Launch SDK ×                                            |
|---------------------------------------------------------|
| Launch software development tool.                       |
| Exported location: 🛜 <local project="" to=""> 🗸</local> |
| Workspace: 📴 <local project="" to=""> 🗸 🗸 🗸</local>     |
| OK   Cancel                                             |

Figure 221: Creating the SDK Workspace

- Once the SDK is open, select File > New > Application Project to open the New Project window. Provide a name for the FSBL project
- 4. The Target Hardware section is be populated by your generated hardware platform from Vivado along with the processor **psu\_cortexa53\_0**. Keep this processor for FSBL generation.

*Note*: The psu\_cortexr5\_0 is used by the IBERT GTR. No other applications should use this core.

5. For psu\_cortexa53\_\*, select 64-bit (default) for Compiler.





#### Lab 10: Using Vivado Serial Analyzer to Debug GTR Serial Links

| SOK                    | New Project 🗆 🗆 🗙                          |
|------------------------|--------------------------------------------|
| Application Project    | -                                          |
| Create a managed mal   | ke application project.                    |
|                        |                                            |
| Project name: pcie_dp  | o_usb_sata                                 |
|                        |                                            |
| ☑ Use default location |                                            |
| Location: //home       | Browse                                     |
| Choose file s          | system: default   ≎                        |
|                        |                                            |
| OS Platform: standa    | lone 🗘                                     |
| Target Hardware        |                                            |
| Hardware Platform:     | design_1_wrapper_hw_platform_0 🛛 🗘 New     |
| Processor:             | psu_cortexa53_0                            |
|                        |                                            |
| Target Software        |                                            |
| Language:              |                                            |
| Compiler:              | 64-bit 🗘                                   |
| Hypervisor Guest:      | No                                         |
| Board Support Packag   | ge: • Create New pcie dp usb sata bsp      |
|                        |                                            |
|                        | O Use existing pcie_usb_dp_sata_fsbl_bsp ↓ |
|                        |                                            |
|                        |                                            |
|                        |                                            |
| (?)                    | < Back Next > Cancel Finish                |
| _                      |                                            |

Figure 222: Creating a New Project

6. Leave other options set to their defaults and click **Next**.





7. Select the **Zynq MP FSBL** template.

| 🔯 💿 New Project                                                                                                                | $\odot$ $\odot$ $\otimes$                                                                                                                                                                                                                                                                                                                                                                                                                     | 0 |
|--------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| Templates<br>Create one of the available templates t                                                                           | o generate a fully-functioning                                                                                                                                                                                                                                                                                                                                                                                                                | - |
| application project.                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |
| Available Templates:                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |
| Empty Application<br>Hello World<br>IwIP Echo Server<br>Memory Tests<br>Peripheral Tests<br>Zyng MP DRAM tests<br>Zyng MP FSBL | First Stage Bootloader (FSBL) for<br>Zynq Ultrascale+ MPSoC. The FSBL<br>configures the FPGA with HW bit<br>stream (if it exists) and loads the<br>Operating System (OS) Image or<br>Standalone (SA) Image or 2nd Stage<br>Boot Loader image from the non-<br>volatile memory (NAND/SD/QSPI) to<br>RAM (DDR) and takes A53/R5 out of<br>reset. It supports multiple<br>partitions, and each partition can<br>be a code image or a bit stream. |   |
| ? < Back Net                                                                                                                   | xt > Finish Cancel                                                                                                                                                                                                                                                                                                                                                                                                                            |   |

Figure 223: Selecting the New Project Template

- 8. Click **Finish** to generate the A53 FSBL. This populates the FSBL code and also builds it, along with the BSP.
- 9. Change the compiler optimization flag from 00 to 02. To change this in the SDK, follow these steps:
  - a. Right-click the FSBL application project and select C/C++ Build Settings.
  - b. On the Tool Settings tab, select Optimization (under the ARM A53 gcc compiler).
  - c. On the **Optimization Level** drop-down menu, change **None (-O0)** to **Optimize more (-O2)**.
  - d. Click **OK** to close the Properties window.
- 10. Debug prints in FSBL are now disabled by default (except for FSBL banner). To enable debug prints, you must define the symbol FSBL\_DEBUG\_INFO. To change this in the SDK, follow these steps:
  - a. Right-click the FSBL application project and select **C/C++ Build Settings**.
  - b. On the Tool Settings tab, select Symbols (under the ARM A53 gcc compiler).
  - c. Click the **Add** button in the **Defined symbols (-D)** section and enter the value: FSBL\_DEBUG\_INFO
  - d. Click **OK** to close the Properties window.





11. Skip this step if you are building FSBL for a custom board.

For building the FSBL for a ZCU102, define the additional symbol XPS\_BOARD\_ZCU102. Note that in this flow, the Hardware Platform (HDF) was created using the ZCU102 board preset, so the XPS\_BOARD\_ZCU102 symbol may be defined by default in the FSBL. If it is present, it does not need to be redefined.

To define the symbol in the SDK, follow these steps:

- a. Right-click the FSBL application project and select C/C++ Build Settings.
- b. On the Tool Settings tab, select Symbols (under ARM A53 gcc compiler).
- c. Click the **Add** button in the **Defined symbols (-D)** section and enter the value: XPS\_BOARD\_ZCU102
- d. Click **OK** to close the Properties window.
- 12. If the current configuration has **USB** set on one of the GTR lanes, then the FSBL source files need to be modified. This is needed to set the USB in a linked state. This step should only be performed when using an "FSBL only" setup with IBERT GTR. When Linux setup is used, USB drivers set the link appropriately and this step is not needed.
- 13. Open the files in SDK mentioned in next step, located in the applications src folder.

Make the appropriate changes and save the file, which automatically builds the project and generates <application name>.elf in the Debug folder inside the applications folder.

If building for a custom board, make sure you do the appropriate changes to bring up the USB in a linked state. After this step the FSBL should be ready to be used in Vivado.

## Bringing the USB into a Linked State

#### xfsbl\_main.h

After the first line below, add the EyeScan changes as highlighted to xfsbl main.h:







### xfsbl\_main.c

After the lines below, add the EyeScan changes as highlighted to xfsbl main.c:

```
XFsbl_Printf(DEBUG_INFO,
   "============= In Stage 4 ========= \n\r");
//EyeScan
u32 RegValue;
RegValue = Xil_In32(USB3_0_XHCI_GCTL_OFFSET) &
   USB3_0_XHCI_GCTL_U0_LTSSM_MASK;
Xil Out32(USB3 0 XHCI_GCTL_OFFSET, RegValue);
```

### Generating using XSCT Manual Flow:

- 1. To create an FSBL for the A53 #0 (64 bit), type xsct from shell in the directory where the HDF file is located.
- 2. From the xsct console, issue the following commands:

```
setws
createhw -name hw0 -hwspec <path to hdf generated by you>
createapp -name fsbl_design_1 -app {Zynq MP FSBL} -proc psu_cortexa53_0 -
    hwproject hw0 -os standalone -arch 64 -lang C
configapp -app fsbl_design_1 -set compiler-optimization {Optimize more (-O2)}
configapp -app fsbl_design_1 -add define-compiler-symbols FSBL_DEBUG_INFO
```

3. If using the ZCU102, also run this command:

configapp -app fsbl\_design\_1 -add define-compiler-symbols XPS\_BOARD\_ZCU102

- 4. Make changes to xfsbl\_main.c and xfsbl\_main.h as shown above in Bringing the USB into a Linked State if the USB is in one of the GTR lanes. Save these files.
- 5. Run the following command:

projects -build

The FSBL ELF file, fsbl design 1.elf, will be generated in the fsbl design 1/Debug/ directory.





# Legal Notices

## **Please Read: Important Legal Notices**

The information disclosed to you hereunder (the "Materials") is provided solely for the selection and use of Xilinx products. To the maximum extent permitted by applicable law: (1) Materials are made available "AS IS" and with all faults, Xilinx hereby DISCLAIMS ALL WARRANTIES AND CONDITIONS, EXPRESS, IMPLIED, OR STATUTORY, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, NON-INFRINGEMENT, OR FITNESS FOR ANY PARTICULAR PURPOSE; and (2) Xilinx shall not be liable (whether in contract or tort, including negligence, or under any other theory of liability) for any loss or damage of any kind or nature related to, arising under, or in connection with, the Materials (including your use of the Materials), including for any direct, indirect, special, incidental, or consequential loss or damage (including loss of data, profits, goodwill, or any type of loss or damage suffered as a result of any action brought by a third party) even if such damage or loss was reasonably foreseeable or Xilinx had been advised of the possibility of the same. Xilinx assumes no obligation to correct any errors contained in the Materials or to notify you of updates to the Materials or to product specifications. You may not reproduce, modify, distribute, or publicly display the Materials without prior written consent. Certain products are subject to the terms and conditions of Xilinx's limited warranty, please refer to Xilinx's Terms of Sale which can be viewed at <a href="https://www.xilinx.com/legal.htm#tos">https://www.xilinx.com/legal.htm#tos</a>; IP cores may be subject to warranty and support terms contained in a license issued to you by Xilinx. Xilinx products are not designed or intended to be fail-safe or for use in any application requiring fail-safe performance; you assume sole risk and liability for use of Xilinx products in such critical applications, please refer to Xilinx's Terms of Sale which can be viewed at <a href="https://www.xilinx.com/legal.htm#tos">https://www.xilinx.com/legal.htm#tos</a>.

#### AUTOMOTIVE DISCLAIMER

AUTOMOTIVE PRODUCTS (IDENTIFIED AS "XA" IN THE PART NUMBER) ARE NOT WARRANTED FOR USE IN THE DEPLOYMENT OF AIRBAGS OR FOR USE IN APPLICATIONS THAT AFFECT CONTROL OF A VEHICLE ("SAFETY APPLICATION") UNLESS THERE IS A SAFETY CONCEPT OR REDUNDANCY FEATURE CONSISTENT WITH THE ISO 26262 AUTOMOTIVE SAFETY STANDARD ("SAFETY DESIGN"). CUSTOMER SHALL, PRIOR TO USING OR DISTRIBUTING ANY SYSTEMS THAT INCORPORATE PRODUCTS, THOROUGHLY TEST SUCH SYSTEMS FOR SAFETY PURPOSES. USE OF PRODUCTS IN A SAFETY APPLICATION WITHOUT A SAFETY DESIGN IS FULLY AT THE RISK OF CUSTOMER, SUBJECT ONLY TO APPLICABLE LAWS AND REGULATIONS GOVERNING LIMITATIONS ON PRODUCT LIABILITY.

© Copyright 2012-2018 Xilinx, Inc. Xilinx, the Xilinx logo, Artix, ISE, Kintex, Spartan, Virtex, Zynq, and other designated brands included herein are trademarks of Xilinx in the United States and other countries. PCI, PCIe and PCI Express are trademarks of PCI-SIG and used under license. All other trademarks are the property of their respective owners.

