

# ADM-PCIE-7V3 Support & Development Kit Release: 2.0.0

Document Revision: 1.1



## © 2017 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:
 4 West Silvermills Lane.
 611 Corporate Circle Suite H Golden, CO 84041

 Telephone:
 +44 131 558 2800
 (303) 954 8788

 Fax:
 +44 131 558 2700
 (866) 820 9966 - 10l free email:

 sales @alpha-ddta.com
 sales @alpha-ddta.com

 website:
 http://www.alpha-ddta.com

All trademarks are the property of their respective owners.



## Table Of Contents

| 1   | Introduction                         | ı |
|-----|--------------------------------------|---|
| 1.1 | Structure of this package            | 1 |
| 2   | Development operating system support | 5 |
| 2.1 | Windows                              | 3 |
| 2.2 | Linux                                | 3 |
| 3   | Associated documents                 | ı |
| 4   | Release history                      | ó |
| 4.1 | Release 2.0.0                        | 5 |
| 4.2 | Release 1.0.0                        | 5 |

## List of Figures

| Figure 1 | Structure of the SDK |  |
|----------|----------------------|--|
|----------|----------------------|--|



### 1 Introduction

The ADM-PCIE-7V3 Support & Development Kit (SDK) is a set of resources for FPGA designers and software engineers working with Alpha Data's ADM-PCIE-7V3 reconfigurable computing card.

The resources of the ADM-PCIE-7V3 SDK include:

- Resources for developing application software for a machine that hosts Alpha Data reconfigurable computing hardware:
  - C/C++ header files and libraries which provide Application Programming Interfaces (APIs) for controlling reconfigurable computing hardware.
  - Documentation about Application Programming Interfaces (APIs) for controlling reconfigurable computing hardware.
  - Common utilities (with source code) for viewing information about reconfigurable computing devices, programming nonvolatile memory, and more.
- Example FPGA designs and host programs (with source code) demonstrating various features of the ADM-PCIE-7V3:
  - The Standalone DIMM Test FPGA Design, which demonstrates how to use the Xilinx 7 Series Memory Interface Generator (MIG) IP to create memory controllers for the DDR3 SDRAM SODIMMs in the JUM-PCIE-7VI.
    - The DMA demonstration FPGA Design, which demonstrates how to use the DMA engine (AXI4) in Alpha Data's ADM-PCIE-7V3 Board Control and Host Interface IP (ADM-PCIE-7V3-BCHI).
    - The Host Interface to DIMMs FPGA Design, which demonstrates combining Alpha Data's ADM-PCIE-7/3 Board Control and Host Interface IP (ADM-PCIE-7/3-BCH) with the Xilinx 7 Series Memory Interface Generator (MIG) IP in order to create a host interface that permits access to the DDR S DRAM SODIMMS.
  - 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 SFP and SATA connectors of the ADM-PCIE-7V3.
  - The Register Access FPGA Design, which demonstrates how to use the Direct Slave (AXI4) channel in Alpha Data's ADM-PCIE-7V3 Board Control and Host Interface IP (ADM-PCIE-7V3-BCH)
- IP and common HDL code provided by Alpha Data:
  - ADM-PCIE-7V3 Board Control and Host Interface IP (ADM-PCIE-7V3-BCHI), which provides a fully functional PCI Express to AXI4 interface with a configurable number of DMA engines (AXI4), as well as other features.
- Common HDL code (i.e. not specific to the ADM-PCIE-7V3), used by the example FPGA designs.

#### 1.1 Structure of this package

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





Figure 1 : Structure of the SDK



### 2 Development operating system support

#### 2.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 what release of Microsoft Visual Studio and/or Xilinx Vivado 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 2016.4 is the current release, and Windows 7 (64-bit), Windows 8.1 (64-bit) & Windows 10 (64-bit) are recommended.

#### Vivado path length issue

In Windows, Vivado requires that path lengths of lifes 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 (xpt) exceeds about 80 characters. Exceeding the MAX\_PATH limit can result in otherwise inexplicable failures when implementing an PFOA desirm 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}{2}** 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 2012 onwards, Windows 7, Windows 8 & Windows 10 are recommended.

#### 221 inux

Alpha Data general 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 release of Vivado chosen for a project. As of writing, Vivado 2016.4 is the current release and therefore the following Linux distributions are recommended:

- Red Hat Enterprise Workstation/Server 7.1 & 7.2 (64-bit)
- Red Hat Enterprise Workstation 5.11, 6.7 & 6.8 (64-bit)
- SUSE Linux Enterprise 11.4 & 12.1 (64-bit)
- CentOS 6.8 (64-bit)
- Ubuntu Linux 16.04 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.



### 3 Associated documents

- (1) Common Host Utilities for Windows & Linux
- (root)/host/util-v1\_11\_0/doc/ad-ug-0055\_v1\_3.pdf
- (2) Common Host Utilities for VxWorks (root)/host/util-v1\_11\_0/doc/ad-ug-0086\_v1\_1.pdf
- (3) ADMXRC3 API Specification
- (root)/host/api-v1\_4\_18b9/doc/ad-ug-0003\_v1\_13.pdf
- (4) ADMXRC3 API Hardware Addendum
- (root)/host/api-v1\_4\_18b9/doc/ad-ug-0009\_v1\_12.pdf
  (5) ADM-PCIE-7V3 Standalone DIMM Test FPGA Design
- (root)/example/dimm\_test-admpcie7v3-v3\_1\_0/doc/ad-ug-0045\_v1\_4.pdf
  (6) Using Xilinx 7 Series MIG 2.3 with the ADM-PCIE-7V3
- (root)/example/dimm\_test-admpcie7v3-v3\_1\_0/doc/ad-ug-0044\_v1\_4.pdf
- (7) ADM-PCIE-7V3 DMA Demonstration FPGA Design (root)/example/dma\_demo-admpcie7v3-v3\_0\_0/doc/ad-ug-0047\_v1\_3.pdf
- (8) ADM-PCIE-7V3 Host Interface to DIMMs FPGA Design
- (root)/example/host\_dimm-admpcie7v3-v1\_0\_0/doc/ad-ug-0095\_v1\_0.pdf
  (9) ADM-PCIE-7V3 IBERT FPGA Design
- (root)/example/ibert-admpcie7v3-v1\_0\_0/doc/ad-ug-0085\_v1\_1.pdf
- (10) ADM-PCIE-7V3 Register Access FPGA Design (root)/example/reg access-admpcie7v3-v2 1 0/doc/ad-ug-0046 v1 3.pdf
- (11) IPROG Reconfiguration from Flash Memory on the ADM-PCIE-7V3 (root)/doc/ad-an-0049\_v1\_0.pdf



## 4 Release history

#### 4.1 Release 2.0.0

- (1) General
- (a) 2016 4 is the recommended Xilinx Vivado version for this release of the SDK
- (2) Example FPGA designs
  - (a) Updated all example FPGA designs for Vivado 2016.4.
  - (b) For all example FPGA designs, invidual project generation scripts (named mkxpr-configurationxcl) no longer close the Vivado project after generating it. Now, after sourceing such a script using "Tools -> Run Tid Script..." from the Vivado GUI menu, it can be simulated or implemented without needing to first recent it.

Bulk project generation scripts (typically named **mkxpr-all.tcl**) still close projects after generating them, to avoid a proliferation of Vivado GUI windows.

- (c) The Standalone DIMM Test FPGA Design (dimm\_test-admpcie7v3) now has a behavioral simulation testbench including DDR3 SDRAM chip models, and now has additional configurations for hoards fitted with 2 x 16 GIR SODIMMs
- (d) The DMA Demonstration FPGA Design (dma\_demo-admpcie7v3) now has a behavioral simulation testbench which, applies AXIA stimulus to rest of the design via the master AXIA interfaces of the ADM-PCIE-7VIA-RIH III interface.
- (e) New FPGA Design: Host Interface to DIMMs FPGA Design (host\_dimm-admpcie7v3), which demonstrates one way to make the DDR3 SDRAM SODIMMs readable and writable from a host program.
- (f) New FPGA Design: IBERT FPGA design (ibert-admpcie7v3), which provides a Bit Error Rate Test (BERT) for the SEP connectors and the SATA connectors.
- (3) IP
  - (a) This release of the SDK includes and uses ADM-PCIE-7V3-BCHI IP v1.8, for Vivado 2015.4 and later
- (4) Host software
  - (a) The Common Host Utilities have been updated to version 1.11.0, although there are effectively no functional differences for the ADM-PCIE-7V3
  - (b) The ADMXRC3 API Header Files have been updated v1.8.3, although there are effectively no functional differences for the ADM-PCIE-7V3
  - (c) The framework used by test/demonstration programs for example FPGA designs has been updated to version 1.1.0. although there are effectively no functional differences for the ADM-PCIE-7V3.

#### 4.2 Release 1.0.0

This is the first release of the ADM-PCIE-7V3 Support & Development Kit.



## **Revision History**

| Date        | Revision | Nature of change                                                                                       |
|-------------|----------|--------------------------------------------------------------------------------------------------------|
| 9 Sep 2015  | 1.0      | Initial version.                                                                                       |
| 27 Feb 2017 |          | Updated for release 2.0.0:<br>New example FPGA design "ibert".<br>New example FPGA design "host_dimm". |

Address: 4 West Silvermills Lane, Edinburgh, EH3 58D, UK Telephone: +44 131 558 2500 Fax: +44 131 558 2700 email: sales @ alpha-data.com website: http://www.alpha-data.com Address: 611 Corporate Circle Suite H Golden, CO 80401 Telephone: (303) 954 8768 Fax: (866) 820 9956 - toll free email: sales (8 alpha-data.com website: http://www.alpha-data.com