### Table of Contents

**IP Facts**

**Chapter 1: Overview**
- Functional Description ........................................... 5
- Feature Summary .................................................. 5
- Applications ...................................................... 8
- Licensing and Ordering Information .............................. 8

**Chapter 2: Product Specification**
- Performance ........................................................... 9
- Resource Utilization ............................................... 9
- Port Descriptions .................................................. 9

**Chapter 3: Designing with the Core**
- General Design Guidelines ....................................... 10
- Clocking ............................................................... 11
- Resets ................................................................. 11

**Chapter 4: Design Flow Steps**
- Customizing and Generating the Core .......................... 12
- Constraining the Core ............................................. 18
- Simulation ............................................................ 19
- Synthesis and Implementation .................................. 19

**Chapter 5: Example Design**

**Appendix A: Debugging**
- Finding Help on Xilinx.com ...................................... 21
- Debug Tools .......................................................... 22

**Appendix B: Migrating and Upgrading**
- Migrating to the Vivado Design Suite .......................... 24
- Upgrading in the Vivado Design Suite .......................... 24
Appendix C: Additional Resources and Legal Notices

Xilinx Resources ................................................................. 25
References ........................................................................ 25
Revision History ................................................................. 26
Please Read: Important Legal Notices ................................. 26
Introduction

The LogiCORE™ IP Integrated Bit Error Ratio Tester (IBERT) core for UltraScale™ architecture GTH transceivers is designed for evaluating and monitoring the GTH transceivers. This core includes pattern generators and checkers that are implemented in FPGA logic, and access to ports and the dynamic reconfiguration port attributes of the GTH transceivers. Communication logic is also included to allow the design to be run-time accessible through JTAG. This core can be used as a self-contained or open design, based on customer configuration, and as described in this document.

Features

- Provides a communication path to the Vivado® Serial I/O Analyzer feature
- Provides a user-selectable number of UltraScale architecture GTH transceivers
- Transceivers can be customized for the desired line rate, reference clock rate, and reference clock source
- Requires a system clock that can be sourced from a pin or one of the enabled GTH transceivers

<table>
<thead>
<tr>
<th>LogiCORE IP Facts Table</th>
</tr>
</thead>
<tbody>
<tr>
<td>Core Specifics</td>
</tr>
<tr>
<td>Supported Device Family</td>
</tr>
<tr>
<td>Supported User Interfaces</td>
</tr>
<tr>
<td>Resources</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Provided with Core</th>
</tr>
</thead>
<tbody>
<tr>
<td>Design Files</td>
</tr>
<tr>
<td>Example Design</td>
</tr>
<tr>
<td>Test Bench</td>
</tr>
<tr>
<td>Constraints File</td>
</tr>
<tr>
<td>Simulation Model</td>
</tr>
<tr>
<td>Supported S/W Driver</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Tested Design Flows(2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Design Entry</td>
</tr>
<tr>
<td>Simulation</td>
</tr>
<tr>
<td>Synthesis</td>
</tr>
</tbody>
</table>

Support

Provided by Xilinx at the Xilinx Support web page

Notes:
1. For a complete listing of supported devices, see the Vivado IP catalog.
2. For the supported versions of the tools, see the Xilinx Design Tools: Release Notes Guide.
Overview

Chapter 1

Functional Description

The IBERT for UltraScale GTH Transceivers core provides a broad-based Physical Medium Attachment (PMA) evaluation and demonstration platform for UltraScale™ architecture GTH transceivers. Parameterizable to use different GTH transceivers and clocking topologies, the IBERT for UltraScale GTH Transceivers core can also be customized to use different line rates, reference clock rates, and logic widths. Data pattern generators and checkers are included for each GTH transceiver desired, giving several different pseudo-random binary sequence (PRBS) and clock patterns to be sent over the channels.

In addition, the configuration and tuning of the GTH transceivers is accessible through logic that communicates to the Dynamic Reconfiguration Port (DRP) port of the GTH transceiver, to change attribute settings, as well as registers that control the values on the ports. At run time, the Vivado® serial I/O analyzer communicates to the IBERT for UltraScale GTH Transceivers core through JTAG, using the Xilinx cables and proprietary logic that is part of the IBERT for UltraScale GTH Transceivers core.

Feature Summary

The IBERT for UltraScale GTH Transceivers core is designed for PMA evaluation and demonstration. All the major PMA features of the GTH transceiver are supported and controllable, including:

- TX pre-emphasis and post-emphasis
- TX differential swing
- RX equalization
- Decision Feedback Equalizer (DFE)
- Phase-Locked Loop (PLL) divider settings

Some of the Physical Coding Sublayer (PCS) features offered by the transceiver are outside the scope of IBERT, including:
Chapter 1: Overview

- Clock Correction
- Channel Bonding
- 8B/10B, 64B/66B, or 64B/67B encoding
- TX or RX Buffer Bypass

PLL Configuration

For each serial transceiver channel, there is a ring PLL called Channel PLL (CPLL). The UltraScale GTH architecture has two additional shared PLLs per quad, QPLL0 and QPLL1. These PLLs are shared to support high speed, high performance, and low power multi-lane applications.

Figure 1-1 shows a Quad in a UltraScale architecture. The GTHE3_CHANNEL component has the serial transceiver and CPLL units and the GTHE3_COMMON has the QPLL unit.

![Quad in UltraScale Architecture](image)

The serial transceiver REFCLK can be sourced from either CPLL or QPLL based on multiplexers as shown in Figure 1-2.
Chapter 1: Overview

Figure 1-2: Serial Transceiver REFCLK Sourcing
Pattern Generation and Checking

Each GTH transceiver enabled in the IBERT design has a pattern generator and a pattern checker. The pattern generator sends data out through the transmitter. The pattern checker accepts data through the receiver and checks it against an internally generated pattern. IBERT offers PRBS 7-bit, PRBS 15-bit, PRBS 23-bit, PRBS 31-bit, Clk 2x (101010...), and Clk 10x (11111111100000000000...) patterns.

These patterns are optimized for the logic width that was selected at run time. The TX and RX patterns are individually selected.

Using the pattern checker logic, the incoming data is compared against a pattern that is internally generated. When the checker receives five consecutive cycles of data with no errors, the LINK signal is asserted. If the LINK signal is asserted and the checker receives five consecutive cycles with data errors, the LINK signal is deasserted. Internal counters accumulate the number of words and errors received.

DRP and Port Access

The GTH transceiver ports and attributes can be changed. The DRP interface logic allows the run time software to monitor and change any attribute of the GTH transceivers and the corresponding CPLL/QPLL. When applicable, readable and writable registers are also included that are connected to the various ports of the GTH transceiver. All are accessible at run time using the Vivado serial I/O analyzer.

Applications

The IBERT for UltraScale GTH Transceivers core is designed to be used in any application that requires verification or evaluation of UltraScale architecture GTH transceivers.

Licensing and Ordering Information

This Xilinx LogiCORE IP module is provided at no additional cost with the Xilinx Vivado Design Suite tool under the terms of the Xilinx End User License.

Information about this and other Xilinx LogiCORE IP modules is available at the Xilinx Intellectual Property page. For information on pricing and availability of other Xilinx LogiCORE IP modules and tools, contact your local Xilinx sales representative.
Product Specification

Chapter 2

Performance

The IBERT for UltraScale™ GTH Transceivers core can be configured to run any of the allowable line rates for the GTH transceivers.

Maximum Frequencies

The core can operate at the maximum user clock frequencies for the FPGA logic width/speed grade selected. The maximum system clock rate is 100 MHz and the generated design divides any incoming system clock to adhere to this constraint.

Resource Utilization

For details about resource utilization, visit Performance and Resource Utilization.

Port Descriptions

The core ports are shown in Table 2-1.

Table 2-1: IBERT I/O Signals

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>I/O</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>IBERT_SYSCLOCK_I</td>
<td>I</td>
<td>Clock that clocks all communication logic. This port is present only when an external clock is selected in the generator.</td>
</tr>
<tr>
<td>X\textsubscript{i}Y\textsubscript{j}.TX.N.OPAD[n - 1:0]\textsuperscript{(1)}</td>
<td>O</td>
<td>Transmit differential pairs for each of the n GTH transceivers used.</td>
</tr>
<tr>
<td>X\textsubscript{i}Y\textsubscript{j}.TX.P.OPAD[n - 1:0]\textsuperscript{(1)}</td>
<td></td>
<td></td>
</tr>
<tr>
<td>X\textsubscript{i}Y\textsubscript{j}.RX.N.IPAD[n - 1:0]\textsuperscript{(1)}</td>
<td>I</td>
<td>Receive differential pairs for each of the n GTH transceivers used.</td>
</tr>
<tr>
<td>X\textsubscript{i}Y\textsubscript{j}.RX.P.IPAD[n - 1:0]\textsuperscript{(1)}</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Q\textsubscript{k}.CLK0.MGTREFCLK_I[m - 1:0]\textsuperscript{(2)}</td>
<td>I</td>
<td>GTH transceiver reference clocks used. The number of MGTREFCLK ports can be equal to or less than the number of transmit and receive ports because some GTH transceivers can share clock inputs.</td>
</tr>
<tr>
<td>Q\textsubscript{k}.CLK1.MGTREFCLK_I[m - 1:0]\textsuperscript{(2)}</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Notes:

1. The X\textsubscript{i}Y\textsubscript{j} name refers to the GTH transceiver site location.
2. The Q\textsubscript{k} name refers to the GTH transceiver quad site location.
Chapter 3

Designing with the Core

This chapter includes guidelines and additional information to facilitate designing with the core.

General Design Guidelines

GTH Transceiver Naming Style

There are two conventions for naming the GTH transceiver, based on the location in the serial transceiver tile in the device. In the XmYn naming convention, m and n indicate the X and Y coordinates of the serial transceiver location. In serial transceiver m_n naming convention, m and n indicate serial transceiver number and the associated quad.

Line Rate Support

IBERT supports a maximum of three different line rates in a single design. For each of these line rates, you can select a custom value based on your requirements, or you can choose from provided industry standard protocols (for example, CPRI™, Gigabit Ethernet, or XAUI). Specify the number of serial transceivers for each line rate that is programmed with these settings. Because the use of a QPLL is recommended for line rates above 8 Gb/s, you can select QPLL/CPLL for each line rate falling in the range 0.5 Gb/s to 16.3 Gb/s.

Serial Transceiver Location

Based on the total number of serial transceivers selected, provide the specific location of each serial transceiver that you intend to use. The region shown in the panel indicates the location of serial transceivers in the tile. This demarcation of region is based on the physical placement of serial transceivers with respect to median of BUFGs available for each device.
Clocking

System Clock

The IBERT for UltraScale GTH Transceivers core requires a free-running system clock for communication and other logic that is included in the core. This clock can be chosen at generation time to originate from an FPGA pin, or from a dedicated \texttt{REFCLK} input of one of the GTH transceivers. In order for the core to operate properly, this system clock source must remain operational and stable when the FPGA is configured with the IBERT for UltraScale GTH Transceivers core.

If the system clock is running faster than 100 MHz, it is divided down internally using a Mixed-Mode Clock Manager (MMCM) to satisfy timing constraints. The clock source selected must be stable and free running after the FPGA is configured with the IBERT design. The system clock is used for core communication and as a reference for system measurements. Therefore, the clock source selected must remain operational and stable when using the IBERT for UltraScale GTH Transceivers core.

Receiver Output Clock

The receiver clock probe enable is provided to pull out a recovered clock from any serial transceiver, if desired. When enabled, a new panel appears just before the summary page where you can fill in the serial transceiver source and probe pin standards. The \texttt{RXOUTCLK} and \texttt{TXOUTCLK} signals of each GT transceiver (also known as serial transceiver) is available at example design top. The selected \texttt{RXOUTCLK} of single GT is connected to output port/pin.

Reference Clock

The reference clock source should be provided for all the serial transceivers selected. The drop-down list provides you with possible sources based on local clocks in the same quad and shared clocks from north/south quads.

Resets

Run time resets are available for the IBERT counters and all transceiver resets are available. The reset controller state machine from the UltraScale™ Transceiver Wizard is used to properly time and sequence resets. See \textit{UltraScale FPGAs Transceivers Wizard Product Guide} (PG182) [Ref 8] for details.
Chapter 4

Design Flow Steps

This chapter describes customizing and generating the core, constraining the core, and synthesis and implementation steps that are specific to this IP core. More detailed information about the standard Vivado® design flows and the Vivado IP integrator can be found in the following Vivado Design Suite user guides:

- Vivado Design Suite User Guide: Designing IP Subsystems using IP Integrator (UG994) [Ref 5]
- Vivado Design Suite User Guide: Designing with IP (UG896) [Ref 7]
- Vivado Design Suite User Guide: Getting Started (UG910) [Ref 4]

Customizing and Generating the Core

You can customize the IP for use in your design by specifying values for the various parameters associated with the IP core using the following steps:

1. Select the IP from the IP catalog.
2. Double-click the selected IP or select the Customize IP command from the toolbar or right-click menu.

For details, see the Vivado Design Suite User Guide: Designing with IP (UG896) [Ref 7] and the Vivado Design Suite User Guide: Getting Started (UG910) [Ref 4].

Note: Figures in this chapter are illustrations of the Vivado Integrated Design Environment (IDE). The layout depicted here might vary from the current version.

The IBERT for UltraScale GTH Transceivers core can be found in /Debug & Verification/ Debug/ in the Vivado IP catalog.

To access the core name, perform the following:

1. Open a project by selecting File then Open Project or create a new project by selecting File then New Project.
2. Open the IP catalog and navigate to any of the taxonomies.
3. Double-click IBERT UltraScale GTH to bring up the IBERT Customize IP dialog box.
**Entering the Component Name**

The Component Name field can consist of any combination of alpha-numeric characters including the underscore symbol. However, the underscore symbol cannot be the first character in the component name.

Figure 4-1 to Figure 4-5 show the IBERT Customize IP dialog boxes with information about customizing ports.

**Protocol Definition**

A protocol is a line rate/data width/reference clock rate combination. Up to three protocols can be defined for an IBERT for UltraScale GTH Transceivers, and any number of available Quads can be designated as any protocol defined.

1. Choose the number of protocols desired.
2. In the Protocol combination box, select either Custom or a Pre-defined protocol. If Custom, type in the line rate (the rate appears in red text if outside the range allowed).
   a. Select the data width.
   b. Choose the \texttt{REFCLK} rate and the number of Quads running at this rate.
3. Changing the line rate entered changes the choices in the \texttt{REFCLK} combination box.
4. The Quad PLL (QPLL0/QPLL1) is selected by default. To select CPLL instead, select CPLL from the combination box named PLL.

```
<table>
<thead>
<tr>
<th>Component Name</th>
<th>iber_t_ultrascale_gth_0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Protocol</td>
<td>Protocol Selection</td>
</tr>
<tr>
<td>LineRate(Gbps)</td>
<td>DataWidth</td>
</tr>
<tr>
<td>Refclk(MHz)</td>
<td>Quad Count</td>
</tr>
<tr>
<td>Custom 1</td>
<td>5</td>
</tr>
<tr>
<td></td>
<td>40</td>
</tr>
<tr>
<td></td>
<td>100</td>
</tr>
<tr>
<td></td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>QPLL0</td>
</tr>
</tbody>
</table>
```

![Vivado Customize IP Dialog Box – Protocol Definition](image)

**Figure 4-1:**  Vivado Customize IP Dialog Box – Protocol Definition
Advanced Settings

Advanced serial transceiver receiver settings are customized by options in each protocol frame (Custom_1, Custom_2, and Custom_3). The number of expandable section available on this page is equal to the Number of Protocols selected under the Protocol Definition tab.

- **Insertion loss at Nyquist (dB)**. Specify the insertion loss of the channel between the transmitter and receiver at the Nyquist frequency in dB.

- **Equalization mode**. Select between decision feedback equalization (DFE) mode and low-power mode (LPM) for the receiver equalization. When the Auto option is selected, the mode is set automatically based on the channel insertion loss, where a value greater than 14 dB causes DFE to be used; otherwise LPM is used. Refer to the UltraScale Architecture GTH Transceivers User Guide (UG576) [Ref 9] for further guidance.

- **Link coupling**. Options are AC and DC. Select AC if external AC coupling is enabled in the application, and DC otherwise.

- **Termination**. Select the receiver termination voltage. Your choice of termination should depend on the protocol and its link coupling.

![Advanced Tab](image-url)
Chapter 4: Design Flow Steps

- **Programmable termination voltage (mV).** When termination is set to programmable, select the termination voltage in mV.

- **PPM offset between receiver and transmitter.** Specify the offset between received data and transmitter data in PPM. For example, if your protocol specifies ±100 ppm, you would enter 200 in this field. This offset affects the receiver CDR settings.

- **Spread spectrum clocking.** Specify the spread spectrum clocking (SSC) modulation in PPM. SSC affects the receiver CDR settings.

**Protocol Selection**

In the **Protocol Selection** tab, the Quads available in the device/package combination are shown. To allocate a Quad to a specific protocol, select it in the **Protocol Selected** combination. The legal choices for the reference clock input are listed in the **REFCLK** selection combination. Each channel uses its own **TXOUTCLK** as **TXUSRCLK**. The **TXUSCLK** source selection option is removed (as compared to IBERT 7 Series GTH).

<table>
<thead>
<tr>
<th>GTH Location</th>
<th>Protocol Selected</th>
<th>REFCLK Selection</th>
</tr>
</thead>
<tbody>
<tr>
<td>QUAD_224</td>
<td>Custom 1 / 5 Gbps</td>
<td>MGTREFCLK0_224</td>
</tr>
<tr>
<td>QUAD_225</td>
<td>None</td>
<td>None</td>
</tr>
<tr>
<td>QUAD_226</td>
<td>None</td>
<td>None</td>
</tr>
<tr>
<td>QUAD_227</td>
<td>None</td>
<td>None</td>
</tr>
<tr>
<td>QUAD_228</td>
<td>None</td>
<td>None</td>
</tr>
</tbody>
</table>

*Figure 4-3: Vivado Customize IP Dialog Box – Protocol Selection*
**Clock Settings**

In the **Clock Settings** tab, select **Add RXOUTCLK Probes** to drive an output pin or pin pair with the RXOUTCLK of required lane (0 to 3) of the Quad. Select the **I/O Standard** from the list and assign valid pin locations. For System Clock, specify an I/O Standard, valid pin locations, and frequency to complete the system clock settings.

**Note:** The system clock I/O standard list will update if **Enable Diff Term** is selected (this is deselected by default).

Alternatively, any enabled Quad reference clock can be selected instead. In addition to RXOUTCLK, TXOUTCLK is available at example design top instance.

**Summary**

Review the settings chosen in the summary page and if they are satisfactory, click **OK** to generate the IBERT for UltraScale GTH Transceivers core.
Chapter 4: Design Flow Steps

User Parameters

Table 4-1: Vivado IDE Parameter to User Parameter Relationship

<table>
<thead>
<tr>
<th>Vivado IDE Parameter/Value</th>
<th>User Parameter/Value</th>
<th>Default Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>C REFCLK SOURCE QUAD &lt;n&gt;</td>
<td>C_REFCLK_SOURCE_QUAD_&lt;n&gt;</td>
<td>None</td>
</tr>
<tr>
<td>C PROTOCOL QUAD &lt;n&gt;</td>
<td>C_PROTOCOL_QUAD&lt;n&gt;</td>
<td>None</td>
</tr>
<tr>
<td>INS LOSS NYQ &lt;q&gt;</td>
<td>INS_LOSS_NYQ_&lt;q&gt;</td>
<td>20</td>
</tr>
<tr>
<td>RX EQ MODE &lt;q&gt;</td>
<td>RX_EQ_MODE_&lt;q&gt;</td>
<td>AUTO</td>
</tr>
<tr>
<td>RX COUPLING &lt;q&gt;</td>
<td>RX_COUPLING_&lt;q&gt;</td>
<td>AC</td>
</tr>
<tr>
<td>RX TERMINATION &lt;q&gt;</td>
<td>RX_TERMINATION_&lt;q&gt;</td>
<td>PROGRAMMABLE</td>
</tr>
<tr>
<td>RX TERMINATION PROG VALUE &lt;q&gt;</td>
<td>RX_TERMINATION_PROG_VALUE_&lt;q&gt;</td>
<td>800</td>
</tr>
<tr>
<td>RX PPM OFFSET &lt;q&gt;</td>
<td>RX_PPM_OFFSET_&lt;q&gt;</td>
<td>0</td>
</tr>
<tr>
<td>RX SSC PPM &lt;q&gt;</td>
<td>RX_SSC_PPM_&lt;q&gt;</td>
<td>0</td>
</tr>
<tr>
<td>C RXOUTCLK GT LOCATION</td>
<td>C_RXOUTCLK_GT_LOCATION</td>
<td>None</td>
</tr>
<tr>
<td>C REFCLK SOURCE QUAD &lt;n&gt;</td>
<td>C_REFCLK_SOURCE_QUAD_&lt;n&gt;</td>
<td>None</td>
</tr>
<tr>
<td>C ENABLE DIFF TERM</td>
<td>C_ENABLE_DIFF_TERM</td>
<td>TRUE</td>
</tr>
<tr>
<td>C SYSCLK FREQUENCY</td>
<td>C_SYSCLK_FREQUENCY</td>
<td>300</td>
</tr>
<tr>
<td>C SYSCLK IO PIN LOC N</td>
<td>C_SYSCLK_IO_PIN_LOC_N</td>
<td>UNASSIGNED</td>
</tr>
<tr>
<td>C SYSCLK IO PIN LOC P</td>
<td>C_SYSCLK_IO_PIN_LOC_P</td>
<td>UNASSIGNED</td>
</tr>
<tr>
<td>C SYSCLK IS DIFF</td>
<td>C_SYSCLK_IS_DIFF</td>
<td>1</td>
</tr>
<tr>
<td>C SYSCLK SOURCE INT</td>
<td>C_SYSCLK_SOURCE_INT</td>
<td>External</td>
</tr>
<tr>
<td>C SYSCLK MODE EXTERNAL</td>
<td>C_SYSCLK_MODE_EXTERNAL</td>
<td>1</td>
</tr>
<tr>
<td>C PROTOCOL QUAD COUNT &lt;q&gt;</td>
<td>C_PROTOCOL_QUAD_COUNT_&lt;q&gt;</td>
<td>1</td>
</tr>
<tr>
<td>C PROTOCOL REFCLK FREQUENCY &lt;q&gt;</td>
<td>C_PROTOCOL_REFCLK_FREQUENCY_&lt;q&gt;</td>
<td>100</td>
</tr>
<tr>
<td>C PROTOCOL MAXLINERATE &lt;q&gt;</td>
<td>C_PROTOCOL_MAXLINERATE_&lt;q&gt;</td>
<td>5</td>
</tr>
<tr>
<td>C PROTOCOL COUNT</td>
<td>C_PROTOCOL_COUNT</td>
<td>1</td>
</tr>
<tr>
<td>C GT TYPE</td>
<td>C_GT_TYPE</td>
<td>GTH</td>
</tr>
<tr>
<td>Component_Name</td>
<td>Component_Name</td>
<td>ibert_ultrascale_gth_v1_3</td>
</tr>
<tr>
<td>C RXOUTCLK FREQUENCY</td>
<td>C_RXOUTCLK_FREQUENCY</td>
<td>105</td>
</tr>
</tbody>
</table>

Notes:
1. <n> is a range from 0 to 29 and <q> is a range from 1 to 3.

Output Generation

For details, see the Vivado Design Suite User Guide: Designing with IP (UG896) [Ref 7].
Constraining the Core

This section contains information about constraining the core in the Vivado Design Suite.

Required Constraints

The IBERT for UltraScale GTH Transceivers core is generated with its own timing and location constraints, based on the choices made when customizing the core. No additional constraints are required.

Device, Package, and Speed Grade Selections

This section is not applicable for this IP core.

Clock Frequencies

This section is not applicable for this IP core.

Clock Management

This section is not applicable for this IP core.

Clock Placement

This section is not applicable for this IP core.

Banking

This section is not applicable for this IP core.

Transceiver Placement

This section is not applicable for this IP core.

I/O Standard and Placement

This section is not applicable for this IP core.
Chapter 4: Design Flow Steps

Simulation

The IBERT for UltraScale GTH Transceivers core does not support simulation.

Synthesis and Implementation

For details about synthesis and implementation, see the Vivado Design Suite User Guide: Designing with IP (UG896) [Ref 7].

Interacting with Tcl Commands

After the design is loaded into the device, a set of hw_sio commands interact with the IBERT for UltraScale GTH Transceivers core. See the Generating an IBERT Core using the Vivado IP Catalog chapter in the Vivado Design Suite User Guide: Programming and Debugging (UG908) [Ref 2] for more details on Tcl commands.
Example Design

This chapter contains information about the example design provided in the Vivado® Design Suite.

An example design can be generated for any customization of the UltraScale™ and UltraScale+™ IBERT core. After you have customized and generated a core instance, right-click the generated core and select Open IP Example Design in the Vivado IDE for that instance. A separate Vivado project opens with the IBERT example design as the top-level module. The example design instantiates the customized core. The recommended and supported flow is to use the example design as-is, without modifications outside the Vivado IDE.

The purpose of the IBERT IP example design is to:

• Provide a quick demonstration of the customized core instance operating in hardware through the use of a link status indicator based on pseudo-random binary sequence (PRBS) generators and checkers which are part of core and generated during IP generation.

• Provide a system which includes reference clock buffers and example system-level constraints.

• Speed up hardware bring-up and debug through the inclusion of a pattern generator and checker.

The example design contains configurable PRBS generator and checker modules per transceiver channel that enable simple data integrity testing, and resulting link status reporting. The example design is also synthesizable so it can be used to check for data integrity and hardware links, either through loopback or connection to a suitable link partner. All key status signals, driving basic control signals, and hardware I/O interaction can be done using the Serial I/O Analyzer from the Vivado Hardware Manager after downloading the example design generated bit file.
Debugging

This appendix includes details about resources available on the Xilinx Support website and debugging tools. In addition, this appendix provides a step-by-step debugging process to guide you through debugging the IBERT UltraScale GTH transceivers core.

Finding Help on Xilinx.com

To help in the design and debug process when using the IBERT UltraScale GTH transceivers, the Xilinx Support web page contains key resources such as product documentation, release notes, answer records, information about known issues, and links for opening a Technical Support WebCase.

Documentation

This product guide is the main document associated with the IBERT UltraScale GTH transceivers. This guide, along with documentation related to all products that aid in the design process, can be found on the Xilinx Support web page or by using the Xilinx Documentation Navigator.

Download the Xilinx Documentation Navigator from the Downloads page. For more information about this tool and the features available, open the online help after installation.

Known Issues

Answer Records include information about commonly encountered problems, helpful information on how to resolve these problems, and any known issues with a Xilinx product. Answer Records are created and maintained daily ensuring that users have access to the most accurate information available.

Answer Records for this core are listed below, and can also be located by using the Search Support box on the main Xilinx support web page. To maximize your search results, use proper keywords such as

- Product name
- Tool message(s)
- Summary of the issue encountered
A filter search is available after results are returned to further target the results.

**Master Answer Record for the IBERT for UltraScale Architecture GTH Transceivers**

AR 54607.

**Technical Support**

Xilinx provides technical support in the Xilinx Support web page for this LogiCORE™ IP product when used as described in the product documentation. Xilinx cannot guarantee timing, functionality, or support if you do any of the following:

- Implement the solution in devices that are not defined in the documentation.
- Customize the solution beyond that allowed in the product documentation.
- Change any section of the design labeled DO NOT MODIFY.

To contact Xilinx Technical Support, navigate to the Xilinx Support web page.

---

**Debug Tools**

There are many tools available to address IBERT UltraScale GTH transceivers design issues. It is important to know which tools are useful for debugging various situations.

**Vivado Design Suite Debug Feature**

The Vivado® Design Suite debug feature inserts logic analyzer and virtual I/O cores directly into your design. The debug feature also allows you to set trigger conditions to capture application and integrated block port signals in hardware. Captured signals can then be analyzed. This feature in the Vivado IDE is used for logic debugging and validation of a design running in Xilinx.

The Vivado logic analyzer is used to interact with the logic debug LogiCORE IP cores, including:

- ILA 4.0 (and later versions)
- VIO 3.0 (and later versions)
License Checkers

If the IP requires a license key, the key must be verified. The Vivado design tools have several license check points for gating licensed IP through the flow. If the license check succeeds, the IP can continue generation. Otherwise, generation halts with error. License checkpoints are enforced by the following tools:

- Vivado Synthesis
- Vivado Implementation
- Bitstream Generation

**IMPORTANT:** IP license level is ignored at checkpoints. The test confirms a valid license exists. It does not check IP license level.
Appendix B

Migrating and Upgrading

This appendix contains information about migrating a design from the ISE® Design Suite to the Vivado® Design Suite, and for upgrading to a more recent version of the IP core. For customers upgrading in the Vivado Design Suite, important details (where applicable) about any port changes and other impact to user logic are included.

Migrating to the Vivado Design Suite

For information about migrating to the Vivado Design Suite, see the ISE to Vivado Design Suite Migration Guide (UG911) [Ref 1].

Upgrading in the Vivado Design Suite

This section provides information about any changes to the user logic or port designations that take place when you upgrade to a more current version of this IP core in the Vivado Design Suite.

Parameter Changes

No changes.

Port Changes

No changes.

Other Changes

No changes.
Appendix C

Additional Resources and Legal Notices

Xilinx Resources

For support resources such as Answers, Documentation, Downloads, and Forums, see Xilinx Support.

References

These documents provide supplemental material useful with this product guide:

1. *ISE to Vivado Design Suite Migration Guide* (UG911)
8. *UltraScale FPGAs Transceivers Wizard Product Guide* (PG182)
Revision History

The following table shows the revision history for this document.

<table>
<thead>
<tr>
<th>Section</th>
<th>Revision Summary</th>
</tr>
</thead>
<tbody>
<tr>
<td>06/06/2018</td>
<td>Version 1.4</td>
</tr>
<tr>
<td>General updates</td>
<td>Updated for version 1.4 of the core.</td>
</tr>
<tr>
<td>04/05/2017</td>
<td>Version 1.3</td>
</tr>
<tr>
<td>General updates</td>
<td>Added Advanced Settings and User Parameters sections to Chapter 4.</td>
</tr>
<tr>
<td>06/08/2016</td>
<td>Version 1.3</td>
</tr>
<tr>
<td>General updates</td>
<td>Example Design Added.</td>
</tr>
<tr>
<td>11/18/2015</td>
<td>Version 1.3</td>
</tr>
<tr>
<td>General updates</td>
<td>Added UltraScale+ support.</td>
</tr>
<tr>
<td>09/30/2015</td>
<td>Version 1.3</td>
</tr>
<tr>
<td>General updates</td>
<td>Updated clocking RXOUTCLK and TXOUTCLK signals.</td>
</tr>
<tr>
<td>04/01/2015</td>
<td>Version 1.2</td>
</tr>
<tr>
<td>General updates</td>
<td>Updated GUI screens.</td>
</tr>
<tr>
<td>10/01/2014</td>
<td>Version 1.1</td>
</tr>
<tr>
<td>General updates</td>
<td>Updated for version 1.1 of the core.</td>
</tr>
<tr>
<td>04/02/2014</td>
<td>Version 1.0</td>
</tr>
<tr>
<td>General updates</td>
<td>Initial Xilinx release.</td>
</tr>
</tbody>
</table>

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 https://www.xilinx.com/legal.htm#tos; 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 https://www.xilinx.com/legal.htm#tos.

AUTOMOTIVE APPLICATIONS 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 2014-2018 Xilinx, Inc. Xilinx, the Xilinx logo, Artix, ISE, Kintex, Spartan, Virtex, Vivado, Zynq, and other designated brands included herein are trademarks of Xilinx in the United States and other countries. CPRI is a trademark of Siemens AG. All other trademarks are the property of their respective owners.