

# ADM-PCIE-9H7 Support & Development Kit Release: 1.0.0

Document Revision: 1.2 2nd July 2019



© 2019 Copyright Alpha Data Parallel Systems Ltd. All rights reserved.

This publication is protected by Copyright Law, with all rights reserved. No part of this publication may be reproduced, in any shape or form, without prior written consent from Alpha Data Parallel Systems Ltd.

Head Office

US Office

| Address:   | Suite L4A, 160 Dundee Street, | 611 Corporate Circle, Suite H |
|------------|-------------------------------|-------------------------------|
| Telephone: | +44 131 558 2600              | (303) 954 8768                |
| Fax:       | +44 131 558 2700              | (866) 820 9956 - toll free    |
| email:     | sales@alpha-data.com          | sales@alpha-data.com          |
| website:   | http://www.alpha-data.com     | http://www.alpha-data.com     |

All trademarks are the property of their respective owners.



# Table Of Contents

| 1   | Introduction                         | 1 |
|-----|--------------------------------------|---|
| 1.1 | Structure of this package            | 1 |
| 1.2 | The ADXDMA Driver                    | 2 |
| 2   | Recommended Vivado versions          | 3 |
| 3   | Development operating system support | 4 |
| 3.1 | Windows                              | 4 |
| 3.2 | Linux                                | 4 |
| 4   | Conventions used in this SDK         | 5 |
| 4.1 | Version numbers                      | 5 |
| 4.2 | Common HDL code                      | 5 |
| 4.3 | Vivado IP repositories               | 5 |
| 4.4 | Example FPGA designs                 | 5 |
| 5   | Associated documents                 | 8 |
| 6   | Release history                      | 9 |
| 6.1 | Release 0.1.0                        | 9 |
| 6.2 | Release 0.1.1                        | 9 |
| 6.3 | Release 1.0.0                        | 9 |

# List of Tables

| Table 1 | Recommended Vivado version by example FPGA design and silicon revision | 3 |
|---------|------------------------------------------------------------------------|---|
| Table 2 | Vivado Tcl scripts used in example FPGA designs                        | 6 |

### List of Figures

| Figure 1 | Structure of the SDK                | 1 |
|----------|-------------------------------------|---|
| Figure 2 | Structure of an example FPGA design | 6 |



### 1 Introduction

The ADM-PCIE-9H7 Support & Development Kit (SDK) is a set of resources for FPGA designers and software engineers working with Alpha Data's ADM-PCIE-9H7 reconfigurable computing card. The latest release of the ADM-PCIE-9H7 SDK can be found at:

https://support.alpha-data.com/Downloads.aspx?fldr\_req=Downloads/admpcie9h7/sdk

#### Note

This release of the ADM-PCIE-9H7 SDK supports engineering silicon (ES1) only. At the time of writing, production silicon for the Xilinx VU35P and VU37P FPGAs is not generally available.

The resources of the ADM-PCIE-9H7 SDK include:

- Resources for developing application software for a machine that hosts Alpha Data reconfigurable computing hardware, using the ADXDMA Driver:
  - C/C++ header files and libraries which provide Application Programming Interfaces (APIs).
  - Documentation about Application Programming Interfaces (APIs).
  - Utilities (with source code), which make use of the Application Programming Interfaces (APIs).
- Example FPGA designs and host programs (with source code) demonstrating various features of the ADM-PCIE-9H7:
  - The Standalone HBM Test FPGA Design, which demonstrates how to use Xilinx's Ultrascale+ HBM IP with the ADM-PCIE-9H7.
  - The DMA Demonstration FPGA Design, which demonstrates high performance DMA using the Xillinx XDMA (PCI Express) IP together with Alpha Data's ADXDMA Driver.
  - The Host Interface to HBM FPGA Design, which demonstrates combining the Xilinx XDMA (PCI Express) IP with the Xilinx Ultrascale+ HBM IP in order to create a host interface that permits access to the on-chip HBM from the host system.

A host program that uses the ADXDMA Driver demonstrates DMA data transfer between host memory and the HBM.

 The Host Interface to SPI Flash Design, which demonstrates combining the Xilinx XDMA (PCI Express) IP with the Xilinx AXI SPI IP in order to create a host interface that permits the host CPU to access the on-board SPI flash that is used to configure the FPGA.

The ADXDMA Driver includes a utility adxdma\_spi that allows the host CPU to erase, program and verify SPI Flash chips via the Xilinx AXI SPI IP.

- The IBERT FPGA Design, which makes use of the Xilinx IBERT IP to provide ready-to-use IBERT bitstreams that can be used to test the QSFP, FireFly and OpenCAPI connectors of the ADM-PCIE-9H7.
- · IP and common HDL code provided by Alpha Data:
  - ADM-PCIE-9H7 Board Control Interface IP (ADM-PCIE-9H7-BCI), which provides an AXI4 Lite interface to the board's microcontroller, among other functions.
  - Common HDL code (i.e. not specific to the ADM-PCIE-9H7), used by the example FPGA designs.

#### 1.1 Structure of this package

The directories making up the ADM-PCIE-9H7 SDK are organised as in Figure 1 below:





| - example                    |                                                         |
|------------------------------|---------------------------------------------------------|
| - dma_demo-admpcie9h7-v1_0_0 | DMA Demonstration FPGA Design                           |
| - hbm_test-admpcie9h7-v1_0_0 | Standalone HBM Test FPGA Design                         |
| - host_hbm-admpcie9h7-v1_0_0 | Host Interface to HBM FPGA Design                       |
| host_spi-admpcie9h7-v1_0_0   | Host Interface to SPI Flash FPGA Design                 |
| bert-admpcie9h7-v1_0_0       | IBERT FPGA Design                                       |
| — fpga                       |                                                         |
| lib                          | Common HDL code                                         |
| L repo                       | Repositories for Vivado IP                              |
| host                         |                                                         |
| - adxdma-v0_9_6              | Header files and libraries for the ADXDMA API           |
| - bin                        | Binaries of utilities                                   |
| - doc                        | Documentation                                           |
| - include                    | Header files                                            |
| - lib                        | Library binaries                                        |
| apps                         | Source code, projects and makefiles for utilities       |
| app_framework-v1_3_0         | Framework used by host programs of example FPGA designs |

#### Figure 1 : Structure of the SDK

### 1.2 The ADXDMA Driver

The ADXDMA Driver is a kernel-mode driver for the PCI Express Endpoint in the Xilinx XDMA IP, which provides a user-mode application programming interface (API). The latest release can be found here:

https://support.alpha-data.com/Downloads.aspx?fldr\_req=Downloads/adxdma



# 2 Recommended Vivado versions

Recommended Vivado versions for the example FPGA designs are as follows:

| Example FPGA design                   | Short name | Silicon<br>revision | Vivado version<br>compatibility [1] | Rec. Vivado<br>version [2] |
|---------------------------------------|------------|---------------------|-------------------------------------|----------------------------|
| DMA Demonstration CDCA Desires        | dma_demo   | Production          | 2018.3.1 - 2019.1                   | 2019.1                     |
| DWA Demonstration PPGA Design         |            | ES1                 | 2018.1 - 2019.1                     | 2018.3                     |
| Chandelane UDM Test EDCA Desire       | hhar trat  | Production          | 2018.3.1 - 2019.1                   | 2019.1                     |
| Standalone HBM Test FPGA Design       | nom_test   | ES1                 | 2018.1 - 2019.1                     | 2018.3                     |
| Linest Interferen de LIDM EDCA Dening |            | Production          | 2019.1                              | 2019.1                     |
| Host intenace to How FPGA Design      | nost_nom   | ES1                 | 2018.1 - 2019.1                     | 2018.3                     |
| Host Interface to SPI Flash FPGA      | host_spi   | Production          | 2018.3.1 - 2019.1                   | 2019.1                     |
| Design                                |            | ES1                 | 2018.1 - 2019.1                     | 2018.3                     |
| IDEDT FROM Desire                     | ibert      | Production          | 2018.3.1 - 2019.1                   | 2019.1                     |
| IBERT FPGA Design                     |            | ES1                 | 2018.1 - 2019.1                     | 2018.3                     |

Table 1 : Recommended Vivado version by example FPGA design and silicon revision

Notes:

- In general, a version of Vivado that is outside of the stated "Vivado version compatibility" range for a given example FPGA design may or may not introduce new problems or issues.
- [2] "Rec. Vivado version" is the Vivado version recommended for use with a given example FPGA design and is also the Vivado version used to generate the pre-built bitstreams in the SDK package.

Please refer to the documentation for each example FPGA design for details of any known issues that affect them.



### 3 Development operating system support

### 3.1 Windows

Generally speaking, Alpha Data's Windows software, when supplied in binary form, is compatible with Windows XP and later. However, the choice of Windows operating system used for development mainly depends upon which releases of Microsoft Visual Studio and/or Xilinx Visual or are chosen for a project.

When developing an FPGA design, the Xilinx Vivado toolset is used and therefore a Windows operating system must be capable of running Vivado. As of writing, Vivado 2019.1 is the current release, and and as per the Vivado 2019.1 release notes 2; Windows 7 SP1 and Windows to lare recommended.

#### Vivado path length issue

In Windows, Vinado requires that path lengths of files are no greater than the MAX, PATH Win32 constant, which is 260 characters (including the NUL character used to terminate a string). This limit is easily exceeded when a Vivado project uses (IP (cores) and the path length of the Vivado project file (pd) exceeds about 80 characters. Exceeding the MAX, PATH limit can result in otherwise inexplicable failures when implementing an FPGA design in Vivado.

The recommended workaround for this issue is to use the subst command to map a drive letter (e.g. Z:) to the root of this SDK. If done correctly, the result is the existence of directories Z:\doc, Z:\example, Z:\frac{1}{ga} etc.

When developing software to run on a host machine, Microsoft Visual Studio is likely to be used for building applications. Therefore, the Windows operating system must be capable of running a particular version of Microsoft Visual Studio. For Microsoft Visual Studio 2017, Windows 7, Windows 8.1 and Windows 10 are recommended.

### 3.2 Linux

Alpha Data generally does not supply binaries for Linux because of the large number of architectures and configurations that exist across various Linux distributions. Source code is provided, however, and can be built for most Linux distributions.

When developing an FPGA design, the Xilinx Vivado toolset is used, and therefore the supported Linux distributions depend upon the version of Vivado chosen for a project. As of writing, Vivado 2019.1 is the latest version, and as per the Vivado 2019.1 release notes 3, the following Linux distributions are recommended:

- Red Hat Enterprise Workstation / Server 7.4, 7.5 & 7.6 (64-bit)
- Red Hat Enterprise Workstation 6.6, 6.7, 6.8 & 6.9 (64-bit)
- SUSE Linux Enterprise 12.4 & 12.3 (64-bit)
- CentOS 7.4, 7.5 & 7.6 (64-bit)
- Ubuntu Linux 16.04.5 LTS & 18.04.1 LTS (64-bit)

Linux distributions that are not listed might result in Vivado failing to work, or only partially working. They are not supported by Xilinx.



## 4 Conventions used in this SDK

#### 4.1 Version numbers

If the name of a folder in the SDK has a suffix such as v1\_0\_0, it denotes a version number for that subtree as a whole.

### 4.2 Common HDL code

The folder fpga/lib/ contains common HDL code used by certain example FPGA designs. Within this folder, each component (a collection of HDL source files) is a subtree whose name has a version suffix (for example, v1\_0\_0)

### 4.3 Vivado IP repositories

The folder **fpga/repo/** contains Vivado IP repositories used by certain example FPGA designs. Generally speaking, if this folder contains a subfolder XXXXY, it means that the IP-XACT definitions found within it are compatible with Vivado XXXXY. Vor later.

The folder fpga/repo/interfaces/ might exist in some SDKs. This folder contains IP-XACT interface definitions, which are generally compatible with any version of Vivado.

#### 4.4 Example FPGA designs

The example FPGA designs, found in the example folder, consist of the following elements:

- Documentation describing the example FPGA design.
- FPGA-related:
  - HDL code (VHDL / Verilog / SystemVerilog).
  - Constraints (.xdc files).
  - Tcl scripts for generating Vivado projects.
    - Note that ready-made Vivado projects are not supplied; see below for an explanation of this.
  - · Pre-built bitstreams, generally built with the latest version of Vivado available at time of publication.
- · Host-related, if required for the example FPGA design in question:
  - C / C++ source and header files.
  - Project files for Microsoft Visual Studio and Makefiles for Linux & VxWorks, where supported for the example FPGA design in question.
  - Pre-built binaries, for Windows running on Intel architecture, if supported for the example FPGA design in question.

For Linux and VxWorks, there are so many possible architectures, binary formats, compilers, environmental issues and other build options that supplying binaries is deemed impractical. For these operating systems, the user must compile demonstration programs before running them.

As mentioned above, ready-made Vivado projects are **not** supplied in this SDK, but Tcl scripts for generating Vivado projects are provided. This is for several reasons, principally:

- Vivado projects using certain IP or certain features can be broken simply by being moved within the filesystem, and such a move would always occur when the user unpacks this SDK to the folder of his or her choice.
- Vivado projects using certain IP or certain features can be broken by being upgraded (to a newer version
  of Vivado). Vivado projects cannot in general be reliably downgraded (to an older version of Vivado).
- · Tcl scripts for generating Vivado projects can determine the version of Vivado in use and apply



workarounds for known issues at time of publication.

The structure of each example FPGA design conforms to the following general template:





Some folders may be omitted for certain example FPGA designs; for example, the IBERT FPGA Design does not have a host folder because it has no host interface and is driven solely by Vivado Hardware Manager.

#### Vivado Tcl script naming conventions

Within the fpga/proj/ folder of each example FPGA design, a number of Tcl scripts are provided. Most important are the Vivado project-generation scripts, whose filenames contain the mkxpr prefix and a suffix that identifies a particular design configuration. The commonly-provided Tcl scripts are given in Table 2 below.

| General form of filename                      | Purpose                                                                                                                                                                                                                           |
|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| build- <design configuration="">.tcl</design> | Implements the design in Vivado for a particular design<br>configuration                                                                                                                                                          |
| debug- <design configuration="">.tcl</design> | Opens Vivado Hardware Manager and configures the FPGA in<br>a card with the bitstream for a particular design configuration.<br>These scripts can also be found in the <b>fpga/bit/</b> folder of a<br>given example FPGA design. |
| flash- <design configuration="">.tcl</design> | Opens Vivado Hardware Manager and writes the bitstream (a<br>.mcs file) for a particular design configuration into the<br>configuration Flash memory of an FPGA card.                                                             |
| mkxpr- <design configuration="">.tcl</design> | Generates a Vivado project for a particular design<br>configuration.                                                                                                                                                              |

Table 2 : Vivado Tcl scripts used in example FPGA designs (continued on next page)



| General form of filename                        | Purpose                                                                     |
|-------------------------------------------------|-----------------------------------------------------------------------------|
| rebuild- <design configuration="">.tcl</design> | Re-implements the design in Vivado for a particular design<br>configuration |

#### Table 2 : Vivado Tcl scripts used in example FPGA designs

Design configurations allow for several variants to exist for a given example FPGA design. For example, in the IBERT FPGA Design, there are multiple design configurations, corresponding to different line rates and different FPGA dies (e.g. VU35P vs VU37P). In general, the total number of design configurations for a given example FPGA design is the result of enumerating the valid combinations of one or more 'orthogonal' options.



### 5 Associated documents

- ADXDMA API (root)/host/adxdma-v0\_9\_6/doc/ad-ug-0105\_v1\_3.pdf
- ADXDMA Board Control API (root)/host/adxdma-v0\_9\_6/doc/ad-ug-0112\_v1\_2.pdf
- (3) ADXDMA Driver Utilities (root)/host/adxdma-v0\_9\_6/doc/ad-ug-0110\_v1\_3.pdf
- (4) ADM-PCIE-9H7 DMA Demonstration FPGA Design (root)/example/dma\_demo-admpcie9h7-v1\_0\_0/doc/ad-ug-0114\_v1\_2.pdf
- ADM-PCIE-9H7 Standalone HBM FPGA Design (root)/example/hbm\_test-admpcie9h7-v1\_0\_0/doc/ad-ug-0116\_v1\_2.pdf
- ADM-PCIE-9H7 Host Interface to HBM FPGA Design (root)/example/host\_hbm-admpcie9h7-v1\_0\_0/doc/ad-ug-0113\_v1\_2.pdf
- ADM-PCIE-9H7 Host Interface to SPI Flash FPGA Design (root)/example/host\_spi-admpcie9h7-v1\_0\_0/doc/ad-ug-0119\_v1\_2.pdf
- (8) ADM-PCIE-9H7 IBERT FPGA Design (root)/example/ibert-admpcie9h7-v1\_0\_0/doc/ad-ug-0115\_v1\_2.pdf



# 6 Release history

### 6.1 Release 0.1.0

This is the first release of the ADM-PCIE-9H7 Support & Development Kit, with support for ES1 silicon revision (only) of the VU35P and VU37P FPGAs.

### 6.2 Release 0.1.1

- Corrects various issues encountered when attempting to generate projects for the example FPGA designs and build them using Vivado 2018.3:
  - a. Fixed an issue in the dma\_demo example FPGA design where, due new IP parameters introduced for the Xilinx Block Memory Generator IP in Vivado 2018.3, the read latency of the instantiated Ultra RAM is 1 (incorrect) instead of 5 (correct) and fails to meet timing requirements.
  - b. Fixed an issue in the hbm\_test and host, hbm example FPGA designs where, due the address map segment size changing from 512 MiB (Vivado 2018.2 and earlier) to 256 MB (Vivado 2018.3) in the Xilinx HBM IP, Vivado projects cannot be successfully generated.
  - c. Added a workaround to the debug-\*tcl scripts of the hbm\_test and host\_hbm example FPGA designs for a JTAG clock frequency issue where the default JTAG clock frequency of 15 MHz used prevents the HBM showing up correctly in Vivado 2018.3 Hardware Manager.

### 6.3 Release 1.0.0

- Added design configurations for production silicon VU35P and VU37P FPGAs to all example FPGA designs, and updated documentation accordingly.
- Corrects various issues encountered when attempting to generate projects for the example FPGA designs and build them using Vivado versions up to 2019.1:
  - a. Fixed an issue in the dma\_demo example FPCA design caused by restrictions introduced in Vkado 2019.1 in how the IP can be configured when the UltraRAM primitive type is used. If a project is generated using Vivado 2019.1 or later, BlockRAM is now used as the primitive type (as opposed to UltraRAM).
  - Extended the HBM JTAG clock frequency workaround (change 1c in release 0.1.1) to the flash-\*.tcl scripts for the hbm\_test and host\_hbm example FPGA designs.
  - c. Added a workaround to the walk\_gsfp\_led.tcl script in the ibert example FPGA design to take account of the physical positions of the QSFP+ C G0 and G1 LEDs being swapped compared to the G0 and G1 LED orders 0 QSFP+ A, B and D.



# **Revision History**

| Date              | Revision | Nature of change                                                                                    |
|-------------------|----------|-----------------------------------------------------------------------------------------------------|
| 22nd October 2018 | 1.0      | Initial release 0.1.0 for ES1.                                                                      |
| 3rd January 2019  | 1.1      | Fixes to example FPGA designs for compatibility with Vivado 2018.3.                                 |
| 2nd July 2019     | 1.2      | Fixes to example FPGA designs for compatibility with Vivado versions up to<br>and including 2019.1. |

| Address:   | Suite L4A, 160 Dundee Street, |
|------------|-------------------------------|
|            | Edinburgh, EH11 1DQ, UK       |
| Telephone: | +44 131 558 2600              |
| Fax        | +44 131 558 2700              |
| email:     | sales@alpha-data.com          |
| website:   | http://www.alpha-data.com     |