



# QuickPCIe Expert for Xilinx

## **Getting Started**

Version 1.5.6 February 2016  
Copyright © PLDA 1996-2016

# QuickPCIe Expert

## Getting Started

### Document Change History

| Date          | Version Number | Changes                                                                                                                                                                       |
|---------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| February 2016 | 1.5.6          | <ul style="list-style-type: none"> <li>Added support for Virtex UltraScale.</li> </ul>                                                                                        |
| March 2015    | 1.5.5          | <ul style="list-style-type: none"> <li>Added support for Kintex UltraScale.</li> </ul>                                                                                        |
| December 2014 | 1.5.4          | <ul style="list-style-type: none"> <li>Updated Vivado tool requirements.</li> <li>Added support for Gen1, and x1 and x2 lanes.</li> </ul>                                     |
| November 2014 | 1.5.3          | <ul style="list-style-type: none"> <li>Updated EDA tool requirements.</li> <li>Removed \$mode argument from simulation.</li> <li>Updated \$target argument values.</li> </ul> |
| April 2014    | 1.5.2          | <ul style="list-style-type: none"> <li>Updated EDA tool requirements.</li> <li>Updated simulation file structure and targeted boards.</li> </ul>                              |
| November 2013 | 1.5.1          | <ul style="list-style-type: none"> <li>Updated EDA tool requirements.</li> <li>Updated package names.</li> </ul>                                                              |
| August 2013   | 1.5.0          | <ul style="list-style-type: none"> <li>Added support for x4 link width.</li> </ul>                                                                                            |
| June 2013     | 1.4.6          | <ul style="list-style-type: none"> <li>Added support for 8.0 Gbps link speed (Gen3).</li> </ul>                                                                               |
| May 2013      | 1.4.5          | <ul style="list-style-type: none"> <li>Updated EDA tool requirements.</li> <li>Updated package description.</li> <li>Changed product name.</li> </ul>                         |
| December 2012 | 1.4.3          | <ul style="list-style-type: none"> <li>Updated EDA tool requirements.</li> <li>Updated package description.</li> </ul>                                                        |
| August 2012   | 1.4.1          | <ul style="list-style-type: none"> <li>Updated Reference Design registers.</li> <li>Updated Wizard information.</li> </ul>                                                    |
| June 2012     | 1.4.0          | <ul style="list-style-type: none"> <li>First release</li> </ul>                                                                                                               |

### Proprietary Notice

Words and logos marked with ® or ™ are registered trademarks or trademarks owned by PLDA SAS. Other brands and names mentioned herein may be the trademarks of their respective owners.

Neither the whole nor any part of the information contained in, or the product described in, this document may be adapted or reproduced in any material form except with the prior written permission of the copyright holder.

The product described in this document is subject to continuous developments and improvements. All particulars of the product and its use contained in this document are given by PLDA in good faith. This document is provided "as is" with no warranties whatsoever, including any warranty of merchantability, non infringement, fitness for any particular purpose, or any warranty otherwise arising out of any proposal, specification, or sample.

This document is intended only to assist the reader in the use of the product. PLDA shall not be liable for any loss or damage arising from the use of any information in this document, or any error or omission in such information, or any incorrect use of the product. Nor shall PLDA be liable for infringement of proprietary rights relating to use of information in this document. No license, express or implied, by estoppel or otherwise, to any intellectual property rights is granted herein.

# Table of Contents

|                                                          |            |
|----------------------------------------------------------|------------|
| <b>List of Figures .....</b>                             | <b>.4</b>  |
| <b>Preface .....</b>                                     | <b>.5</b>  |
| About this Document .....                                | 5          |
| Additional Reading .....                                 | 5          |
| Feedback and Contact Information .....                   | 6          |
| <b>Chapter 1    Before you Start... .....</b>            | <b>.7</b>  |
| 1.1    System Requirements .....                         | 7          |
| 1.2    EDA Tools Requirements .....                      | 7          |
| 1.3    Available Packages .....                          | 7          |
| 1.4    Installing the Package .....                      | 8          |
| 1.5    Package Features .....                            | 8          |
| <b>Chapter 2    Reference Design .....</b>               | <b>.9</b>  |
| 2.1    Introduction .....                                | 9          |
| 2.2    Architecture of the Reference Design .....        | 9          |
| 2.2.1    Top-Level Blocks .....                          | 9          |
| 2.2.2    Reference Design Files and File Structure ..... | 10         |
| 2.2.3    Registers .....                                 | 11         |
| 2.3    Simulation of the Reference Design .....          | 12         |
| 2.3.1    Overview .....                                  | 12         |
| 2.3.2    Launching the Simulation .....                  | 13         |
| <b>Chapter 3    Creating a Core Instance .....</b>       | <b>.14</b> |
| <b>Chapter 4    Simulating your Design .....</b>         | <b>.15</b> |
| 4.1    Simulation Environment .....                      | 15         |
| 4.2    Simulating with the PLDA PCIe BFM3 .....          | 16         |
| 4.2.1    ModelSim .....                                  | 16         |
| 4.2.2    NCSim .....                                     | 16         |
| 4.2.3    Simulating with ModelSim .....                  | 16         |
| 4.2.4    Additional Xilinx Considerations .....          | 17         |

# List of Figures

|                                                                   |           |
|-------------------------------------------------------------------|-----------|
| <b>Figure 1: Top-level blocks of the Reference Design.....</b>    | <b>9</b>  |
| <b>Figure 2: Architecture of the simulation environment .....</b> | <b>10</b> |
| <b>Figure 3: Overview of the simulation environment.....</b>      | <b>12</b> |
| <b>Figure 4: The choose wrapper window .....</b>                  | <b>14</b> |
| <b>Figure 5: Simulation environment .....</b>                     | <b>15</b> |

# Preface

# About this Document

## **Intended Audience**

This document has been written for design managers, system engineers, and designers who are evaluating or using the PLDA QuickPCIe Expert.

## Typographical Conventions

|               |                                                  |
|---------------|--------------------------------------------------|
| <i>italic</i> | Highlights important notes or publications       |
| <b>bold</b>   | <b>Highlights interface elements.</b>            |
| COURIER NEW   | DENOTES TEXT USED IN A CODE EXAMPLE OR A SIGNAL. |

## **Additional Reading**

This section lists additional resources from PLDA and third-parties.

PLDA periodically updates its documentation. Please contact PLDA Technical Support or check the Web site at <http://www.plda.com> for current versions.

**PLDA Publications**

Please refer to the following documents for further information:

- *QuickPCIe Expert Reference Manual* for Xilinx: The *Reference Manual* provides the complete functional description of the PLDA QuickPCIe Expert Core.
  - *Bus Functional Model Reference Manual*: The *BFM 3 Reference Manual* provides the complete functional description of the PLDA PCI Express Testbench for PCI Express 3.0.

## **Other Publications**

Please refer to the following documents for information on specification standards:

- PCI Express™ Base Specification Revision 3.0
  - PHY Interface for the PCI Express, SATA and USB 3.0 Architectures, Version 4.0

# Feedback and Contact Information

## Feedback about this Document

PLDA welcomes comments and suggestions about this documentation. Please contact PLDA Technical Support and provide the following information:

- the title of the document
- the page number to which your comments refer
- a description of your comments

## Contact information

### Corporate Headquarters

PLDA  
805, avenue J.R.G.G. de la Lauzière  
13290 Aix-en-Provence  
France

Tel: USA +1 408 273 4528 - International +33 442 393 600  
Fax: +33 442 394 902

### Sales

For sales questions, please contact [sales@plda.com](mailto:sales@plda.com).

### Technical Support

For technical support questions, please contact PLDA Support at <https://www.plda.com/support> using the Support Center if you have a PLDA online account.

If you don't have a PLDA account, contact <https://www.plda.com/user/register>.

# Chapter 1 Before you Start...

This Getting Started guide is intended to enable you to integrate the PLDA QuickPCIe Expert into your design flow as quickly and easily as possible.

This chapter describes how to install the Core.

[Chapter 2](#) describes the Reference Design that is provided in the Core package. You can use this Reference Design as an example to see how the Core works and to test that it is working correctly.

[Chapter 3](#) describes how to use the Core Wizard to modify the parameters for the Core instance included in the Reference Design or to create a new Core instance using your own custom values and inputs.

[Chapter 4](#) describes how to simulate your Core instance.

## 1.1 System Requirements

To install the QuickPCIe Expert package, you need:

- **Operating System:** Windows 2000/XP/Vista/7 or any Unix/Linux platform supporting Java
- **Hard Disk:** 1 GB for Core installation and component design

## 1.2 EDA Tools Requirements

One of the following EDA tools are required for simulation:

- ModelSim SE 10.4b or above
- NCSim 14.20-s024

**Note:** Aldec 2015.10 is supported on demand. Contact PLDA Technical support for more information.

For synthesis, you will also require:

- Vivado Design Suite 2015.3
- Xilinx Platform USB cable

## 1.3 Available Packages

The QuickPCIe Expert Core is available in any of the following packages:

- **Xilinx Source**, which contains full source code for the Core:  
quickpcie-expert\_genX\_vXXXXbuildXXX\_xilinx\_source.tar.gz
- **Xilinx Full**: enables you to generate programming files for any supported device:  
quickpcie-expert\_genX\_vXXXXbuildXXX\_xilinx\_full.tar.gz
- **Xilinx Board/Eval**, which is used for testing hardware: For the Board package, there is no time limit when connecting protocore signals with PLDA boards.  
quickpcie-expert\_genX\_vXXXXbuildXXX\_xilinx\_board\_eval.tar.gz

In the above packages, 'genX' can be Gen3, Gen2, or Gen1, while vXXXX and buildXXX indicate the current version and build number.

**Note:** With the Eval package, the design will only work for a limited time.

## 1.4 Installing the Package

1. Unzip the tar.gz file using unzip software such as WinRAR or 7-Zip.
2. Open a shell and set the working directory to the directory where the Core package has been downloaded from the PLDA web site.
3. Create an empty directory.
4. At the prompt, type:

```
tar -xzf <full package name> -C <your directory path>
```

## 1.5 Package Features

The following table shows the directory structure and contents of your package:

|                         |                                                                                                                                                                                                                                                                                                                                                                               |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Core</b>             | <b>Simulation</b> <ul style="list-style-type: none"><li>• <b>Modelsim</b><ul style="list-style-type: none"><li>• <b>Verilog</b>: pre-compiled Verilog library</li></ul></li><li>• <b>NCSim</b><ul style="list-style-type: none"><li>• <b>Verilog</b>: Verilog-protected, UNIX/Linux</li></ul></li></ul>                                                                       |
|                         | <b>Source</b> (in the Full and Source packages only) <ul style="list-style-type: none"><li>• <b>Verilog</b>: Original clear-text source code, Xilinx Hard IP and QuickPCIe Expert include files</li></ul>                                                                                                                                                                     |
|                         | <b>Synthesis</b> <ul style="list-style-type: none"><li>• <b>Xilinx</b><ul style="list-style-type: none"><li>• <b>Verilog</b>: Single Xilinx clear-text (Source) or encrypted (Full, Board/Eval) file</li></ul></li></ul>                                                                                                                                                      |
| <b>Documentation</b>    | <ul style="list-style-type: none"><li>• quickpcie_expert_build_history_xx.pdf</li><li>• quickpcie_expert_revision_history_xx.pdf</li><li>• quickpcie_expert_getting_started_xx.pdf</li><li>• quickpcie_expert_reference_manual_xx.pdf</li><li>• pcie_bfm_3_reference_manual.pdf</li></ul>                                                                                     |
| <b>Software</b>         | <ul style="list-style-type: none"><li>• API and test application for QuickPCIe Expert.</li></ul>                                                                                                                                                                                                                                                                              |
| <b>Reference Design</b> | <ul style="list-style-type: none"><li>• <b>Simulation</b><ul style="list-style-type: none"><li>• Endpoint</li></ul></li><li>• <b>Source</b><ul style="list-style-type: none"><li>• Endpoint</li></ul></li><li>• <b>Synthesis</b><ul style="list-style-type: none"><li>• Endpoint</li></ul></li></ul>                                                                          |
| <b>PLDA Testbench</b>   | The PLDA Testbench for PCI Express 3.0, exclusively compatible with the Core, includes the following: <ul style="list-style-type: none"><li>• Unlimited duration for purchased products</li><li>• BFM Instance: Root Port, Endpoint</li><li>• Number of Transactions: 1,000</li><li>• Monitor</li></ul> Refer to the <i>PLDA BFM 3 Reference Manual</i> for more information. |
| <b>Wizard</b>           | The QuickPCIe Expert wizard is used to create a top-level instance of the Core. See <a href="#">Chapter 3: Creating a Core Instance</a> for more information.                                                                                                                                                                                                                 |

## Chapter 2 Reference Design

### 2.1 Introduction

The Reference Design demonstrates an implementation example of the QuickPCIe Expert Core. It enables you to perform DMA testing (Host to Card and Card to Host) through Stream and AXI Master interfaces. It also enables testing of the AXI4-Lite Master and Slave interfaces.

The complete Register Transfer Level (RTL) source code of the design is provided so that you can:

- Perform hardware testing using a prototyping board.
- Modify the Reference Design in order to integrate the Core with your own design.

### 2.2 Architecture of the Reference Design

#### 2.2.1 Top-Level Blocks

The Reference Design is illustrated below:



Figure 1: Top-level blocks of the Reference Design

- **AXI4-Lite Slave:** Loops back to the AXI4-Lite Master through the AXI4-Lite Decoder Module.
- **AXI4-Lite Master:** Accesses the Reference Design external registers. It also accesses the QuickPCIe Expert internal registers through the AXI4-Lite Slave interface. See [Section 2.2.3](#).
- **AXI4 Stream Out:** Connected to DMA Engine 0 and loops back to AXI4 Stream In through an 8 KB FIFO.
- **AXI4 Stream In:** Connected to DMA Engine 1 and loops back to AXI4 Stream Out through an 8 KB FIFO or a data generator.
- **AXI4 Master:** Connected to DMA Engines 2 and 3 and to an 8 KB embedded SRAM.

## 2.2.2 Reference Design Files and File Structure

The following figure provides an overview of the files implicated in the Reference Design.



**Figure 2: Architecture of the simulation environment**

The following table describes each file used by the Reference Design.

| Module / File          | Description                                                                                              |
|------------------------|----------------------------------------------------------------------------------------------------------|
| (core_module_instance) | QuickPCIe Expert Core module instance, as shown in <a href="#">Figure 1</a> .                            |
| (top_level)            | Reference Design top level, as shown in <a href="#">Figure 1</a> .                                       |
| ref_design_v0          | Reference design wrapper that connects the peripheral modules.                                           |
| axi4lite_dec           | Sample interconnection module between one AXI4-Lite Slave interface and two AXI4-Lite Master interfaces. |
| external_reg           | Sample of AXI4-Lite Slave access to external registers.                                                  |
| scfifo                 | Generic single-clock FIFO model.                                                                         |
| scram                  | Generic SCRAM model.                                                                                     |
| axi4slv_ram            | Example of AXI4 Slave access to SCRAM, which instantiates the scram_be module.                           |
| scram_be               | Generic SCRAM with Byte Enable model.                                                                    |

## 2.2.3 Registers

The following table describes the registers used by the Reference Design:

| Byte Address              | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>External Registers</b> |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x0000 - 0x0003           | RW  | <b>REFD_MODE</b> : Reference Design Mode: <ul style="list-style-type: none"> <li>Bit [0]:</li> <ul style="list-style-type: none"> <li>when 0b, Stream Out is looped to Stream In through a FIFO</li> <li>when 1b, Stream In data is automatically generated</li> </ul> <li>Bit [15:3]: Stream In Packet Size: indicates the size of Stream In Packets in QWords. A value of 13'd0 specifies a size of <math>2^{13} = 8192</math> QW = 64KBytes.</li> <li>Bit [16]:</li> <ul style="list-style-type: none"> <li>when 0b, Stream In Data are generated infinitely</li> <li>when 1b, Stream In Data generation is stopped once Stream In Packet numbers have been sent.</li> </ul> <li>Bit [31:24]: Stream In Packet Number, from 1 (8'h01) to 255 (8'hff).</li> </ul> |
| 0x0004 - 0x0007           | RW  | <b>LED_CONTROL</b> : LED States for the Control Board: <ul style="list-style-type: none"> <li>Bit [0]: when 1b, LED0 is on; when 0b, LED0 is off</li> <li>Bit [1]: when 1b, LED1 is on; when 0b, LED1 is off</li> <li>Bit [2]: when 1b, LED2 is on; when 0b, LED2 is off</li> <li>Bits [31:3]: Mailbox Registers</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0x0008 - 0x000B           | RW  | <b>INTERRUPT_CONTROL</b> : Interrupt Requests towards the PCIe Host: <ul style="list-style-type: none"> <li>Bit [0]: when 1b, qpcie_interrupt_in[6] local interrupt signal is asserted</li> <li>Bit [1]: when 1b, qpcie_interrupt_in[7] local interrupt signal is asserted</li> <li>Bits [31:2]: Mailbox Registers</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0x000C - 0x001F           | RW  | <b>Mailbox Registers</b> : General purpose 32-bit read/write registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0x0020 - 0x0023           | RO  | <b>STR_FIFOCNT</b> : Stream FIFO Count (in words of 128-bits): <ul style="list-style-type: none"> <li>Bits[9:0]: FIFO count from 0 to 512 words</li> <li>Bits [31:10]: reserved</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0x0024 - 0x0027           | RO  | <b>USER_SWITCH</b> : User Switch states for the Control Board: <ul style="list-style-type: none"> <li>Bit [0]: when 1b, Switch0 is on; when 0b, Switch0 is off</li> <li>Bit [1]: when 1b, Switch1 is on; when 0b, Switch1 is off</li> <li>Bit [2]: when 1b, Switch2 is on; when 0b, Switch2 is off</li> <li>Bits [31:3]: reserved</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0x0028 - 0x002B           | --  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0x002C - 0x002F           | --  | <b>REFD_PERF</b> : Reference Design Performance: <ul style="list-style-type: none"> <li>Bit [15:0]: reserved</li> <li>Bit [25:16]: Reference Design Clock Frequency in MHz. 10'd250 indicates a frequency of 250 MHz, for example.</li> <li>Bit [31:26]: Reference Design Data Path in Bytes. For example, 6'd16 means 16 Bytes.</li> </ul> <p>The maximal throughput that can reach an interface in MBytes/second is equal to the Reference Design Clock Frequency in MHz multiplied by the Data Path in Bytes.</p>                                                                                                                                                                                                                                                |
| 0x0030 - 0x0033           | RO  | <b>STREAM_PERF</b> : Percentage of bandwidth used in last 134-ms period: <ul style="list-style-type: none"> <li>Bit [15:0]: Percentage of Stream In interface bandwidth from 0h to FFFFh</li> <li>Bit [31:16]: Percentage of Stream Out interface bandwidth from 0h to FFFFh</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Byte Address              | R/W   | Description                                                                                                                                                                                                                            |
|---------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x0034 - 0x0037           | RO    | <b>MASTER_PERF</b> : Percentage of bandwidth used in last 134-ms period:<br>• Bit [15:0]: Percentage of AXI Master Read I/F bandwidth from 0h to FFFFh<br>• Bit [31:16]: Percentage of AXI Master Write I/F bandwidth from 0h to FFFFh |
| 0x0038 - 0x003F           | RW/RO | <b>FLASH_UPDATE</b> : Flash Update registers                                                                                                                                                                                           |
| <b>Internal Registers</b> |       |                                                                                                                                                                                                                                        |
| 0x1000 - 0x1FFF           | RO/RW | <b>QuickPCIe Expert Internal Registers</b>                                                                                                                                                                                             |

## 2.3 Simulation of the Reference Design

### 2.3.1 Overview

The following figure offers an overview of the simulation environment:



Figure 3: Overview of the simulation environment

The following table describes each file used in the Simulation environment:

| Module/File       | Description                                                                                                                                                                                                                                                           |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| refdesign_stimuli | Verilog model of QuickPCIe Expert Test Application that lists different test cases.                                                                                                                                                                                   |
| pciebfm3_ser      | PLDA BFM with serial link interface.                                                                                                                                                                                                                                  |
| refdesign_testb   | Testbench design that connects the BFM and the Reference Design. This file is the top-level file for simulation, described in <a href="#">Section 2.2.2</a> . It also contains a stimuli module that sends PCI Express transactions to configure and test the design. |

## 2.3.2 Launching the Simulation

A **.do** script file is provided for simulating the project with ModelSim.

To run a simulation:

1. Change Directory to `./ref_design/simulation/endpoint`.
2. Type the following command line to run the script file:

```
do simulate.tcl $simulator $target $lane $payload $script $gen
```

The following table describes each argument:

| Argument    | Argument Name                     | Supported Values                                                                                                                                   |
|-------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| \$simulator | Simulator                         | <ul style="list-style-type: none"> <li>• model (for ModelSim)</li> <li>• ncsm</li> <li>• aldec</li> </ul>                                          |
| \$target    | Device targeted                   | <ul style="list-style-type: none"> <li>• vus</li> <li>• kus</li> <li>• v7gth</li> <li>• v7gtx</li> <li>• z7</li> <li>• k7</li> <li>• a7</li> </ul> |
| \$lane      | PCIe Link Width                   | <ul style="list-style-type: none"> <li>• x1</li> <li>• x2</li> <li>• x4</li> <li>• x8</li> </ul>                                                   |
| \$payload   | PCIe Maximum Payload Size         | <ul style="list-style-type: none"> <li>• 128B</li> <li>• 256B</li> </ul>                                                                           |
| \$script    | Script                            | <ul style="list-style-type: none"> <li>• m0</li> </ul>                                                                                             |
| \$gen       | Link speed - 2.5, 5.0 or 8.0 Gbps | <ul style="list-style-type: none"> <li>• gen1</li> <li>• gen2</li> <li>• gen3</li> </ul>                                                           |

The simulation then performs each of the following steps:

- Initializes the PCIe BFM.
- Initializes the Reference Design PCIe Configuration.
- Reads and Writes to the QuickPCIe Expert Internal Registers.
- Programs a Direct DMA Transfer from the 64-bit PCIe link to the AXI Stream Interface.
- Programs a Direct DMA Transfer from the AXI Stream Interface to the 32-bit PCIe link.
- Programs two simultaneous Direct DMA Transfers between the PCIe link and the AXI Stream Interface.
- Programs a Direct DMA Transfer from the 64-bit PCIe link to the AXI Master Interface.
- Programs a Direct DMA Transfer from the AXI Master Interface to the 32-bit PCIe link.
- Programs a SG-DMA Transfer from the 64-bit PCIe link to the AXI Master Interface.
- Programs a SG-DMA Transfer from AXI Master Interface to the 64-bit PCIe link.
- Programs two simultaneous SG-DMA Transfers between the PCIe link and the AXI Stream Interface.
- Executes a Direct Write and Read between the 64-bit PCIe link and the AXI Master Interface.
- Closes the simulation.

## Chapter 3 Creating a Core Instance

The QuickPCIe Expert Wizard generates a Verilog wrapper that instantiates the Core with custom values, input ports, and output ports.

The following sections describe how to instantiate the Core using the Wizard.

### WARNING:

- The file created by the Wizard *should not* be modified with a text editor. Open the Wizard and select an existing .v file in order to modify an existing instance of the Core.
- If you have already created an instance of the Core and you create a second instance of the Core with the same name, the Wizard will overwrite your original file without warning.

Follow the directions below to launch a Wizard and create an instance of the Core:

#### 1. Launch the Wizard:

- **Linux:** Browse to the /wizard/linux gtk.x86 or /wizard/linux gtk.x86\_64 directory and run pldaWizard.
- **Windows:** Browse to the /wizard/win32.win32.x86 or /wizard/win32.win32.x86\_64 directory and run pldaWizard.exe.

The following window appears:



Figure 4: The choose wrapper window

To modify an existing wrapper, browse your Hard Drive, select the desired wrapper, and click **Open**.

To create a new wrapper, type a name in the **Name** text box and click **Open**. The Wizard will then guide you through the modification or creation of your Core instance.

You can click the **Help** button on any page in the Wizard for more information about the settings on that page.

# Chapter 4 Simulating your Design

This chapter provides background information for running a functional simulation of the Core. The simulation environment includes the Core, the Core wrapper, the PCI Express BFM3, and all or part of your design (application layer logic).

## 4.1 Simulation Environment

The figure below illustrates a typical simulation environment using a serial or parallel interface



**Figure 5: Simulation environment**

The simulation architecture includes the following elements:

- **PCI Express BFM3:** The Core package includes evaluation versions of the PLDA PCI Express 3.0 BFM. The BFM is provided as compiled libraries or as protected code for various simulators. It includes a link monitor, and can be instantiated at the serial, parallel, and PIPE interface levels. Refer to the *BFM3 Reference Manual* in the documentation directory for additional information.
- **User Design:** Application layer logic implemented by the designer that connects to the Core's local Application Layer interface. For a tryout simulation, a fully functional or complete design is not required, however, all of the Core's Application Layer inputs should be set to appropriate values. The interface between the Core and the Application Layer is described in the *Reference Manual*.
- **QuickPCIe Expert Core wrapper:** This is the customized wrapper you create with the Core Wizard, as described in the previous section.
- **Xilinx Hard IP:** This is a customized IP instance of the Xilinx PCI Express Hard IP dedicated to the QuickPCIe Expert Core.
- **QPCle Layer:** This layer consists of the Internal Registers, DMA Engine Modules, Address Translator Modules and an Interconnect Module.
- **AXI Layer:** This layer consists of the AXI4 and AXI4-Lite Slave and Master interfaces, the AXI4 Master Descriptor interface, and the AXI4 Stream In/out interfaces.

## 4.2 Simulating with the PLDA PCIe BFM3

### 4.2.1 ModelSim

The BFM is delivered as a simulation library. To use the BFM, map the library **pciebfm\_lib**. When compiling with Verilog, you must include the **.h** file located in the **include** directory. When launching vsim, add the BFM library with the following command: **vsim -L pciebfm\_lib**

### 4.2.2 NCSim

The BFM is delivered in the form of encrypted files. To use the BFM, compile the encrypted library **pciebfm\_lib**. When compiling with Verilog, you must include the **.h** file located in the **include** directory.

### 4.2.3 Simulating with ModelSim

The following directions describe how to create a project and compile the necessary libraries in order to run a simulation with the Core. Note that this section is offered as background information only. The **simulate.tcl** script provided with the Core package automatically performs these tasks and starts a simulation for you.

1. Launch ModelSim.
2. Select the working directory:
  - Choose Change Directory from the File menu. The **Choose a Directory** window appears.
  - Browse your hard drive and select or create a directory in which to compile your project.
3. Create a work library:
4. Map the required libraries:
  1. Create and map the PLDA BFM (PCI-Express Testbench) library. At the ModelSim prompt, type:

```
vlib libs/pciebfm_lib
vmap pciebfm_lib «libs/pciebfm_lib»
vlog -quiet -work pciebfm_lib \ +includer+$pciebfm_path/source/vlog/include \
$pciebfm_path/simulation/$model/vlog/pciebfm_lib.vp
```
  2. Map the QuickPCIe Expert library. At the ModelSim prompt, type:

```
vlib libs/qpcie_lib
vmap q_lib «libs/qpcie_lib»
vlog -quiet -work $core_lib_name \ +includer+$core_config_path \ +includer+$core_include_path \
$core_path/simulation/$model/vlog/qpcie_lib.vp \
where "$core path" is replaced by the directory in which you installed your project.
```
  5. Compile your core instance file(s) previously generated with the QuickPCIe Expert Wizard, by typing:
    - **vlog -work work <absolute path>/<filename>.v**
  6. Compile all your design files.
  7. Compile the stimuli file used to simulate your design by generating traffic with the Core. An example file, **ref\_design\_stimuli**, is provided with the Reference Design.
  8. Compile your top level that connects your design with the Core, the BFM, and the stimuli instance. Example files (**ref\_design\_testb**) are provided with the Reference Design.
  9. Simulate the project, by typing:  
**vsim -t ps -L pciebfm\_lib -L qpcie\_lib work.<design\_top\_level>**

#### 4.2.4 Additional Xilinx Considerations

In order to simulate your design, Xilinx smart models must be installed and configured and Xilinx simulation libraries must be compiled. Please refer to the Vivado installation guide for details.

Use the memory model furnished with the Xilinx Library of Parameterized Modules (UNISIM). Note that the DCRAM located in the Xilinx primitive directory uses this Xilinx library for compilation.