# **IP CORE MANUAL**



# **PCI Express Interrupt Controller IP**

px\_pcie\_irq\_ctlr



Pentek, Inc. One Park Way Upper Saddle River, NJ 07458 (201) 818-5900 http://www.pentek.com/

Copyright © 2016

Rev: 1.0 - December 09, 2016

#### **Manual Revision History**

Comments

| <b>Date</b> | Version |                 |
|-------------|---------|-----------------|
| 12/09/16    | 1.0     | Initial Release |

#### Legal Notices

The information disclosed to you hereunder (the "Materials") is provided solely for the selection and use of Pentek products. To the maximum extent permitted by applicable law: (1) Materials are made available "AS IS" and with all faults, Pentek 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) Pentek 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 conjunction with, the Materials (including your use of 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 and loss was reasonably foreseeable or Pentek had been advised of the possibility of the same. Pentek assumes no obligation to correct any error 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 Pentek's limited warranty, please refer to Pentek's Ordering and Warranty information which can be viewed at http://www.pentek.com/contact/customerinfo.cfm; IP cores may be subject to warranty and support terms contained in a license issued to you by Pentek. Pentek 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 the use of Pentek products in such critical applications.

#### **Copyright**

Copyright © 2016, Pentek, Inc. All Rights Reserved. Contents of this publication may not be reproduced in any form without written permission.

#### **Trademarks**

Pentek, Jade, and Navigator are trademarks or registered trademarks of Pentek, Inc.

ARM and AMBA are registered trademarks of ARM Limited. PCI, PCI Express, PCIe, and PCI-SIG are trademarks or registered trademarks of PCI-SIG. Xilinx, Kintex UltraScale, Vivado, and Platform Cable USB are registered trademarks of Xilinx Inc., of San Jose, CA.

# Table of Contents

### Page

## **IP** Facts

| Description               | .5 |
|---------------------------|----|
| Features                  | .5 |
| Table 1-1: IP Facts Table | .5 |

## Chapter 1: Overview

| 7 |
|---|
| 7 |
| 8 |
| 8 |
| 8 |
| 8 |
| 8 |
|   |

## **Chapter 2: General Product Specifications**

| 2.1 | Standards                                  | 9  |
|-----|--------------------------------------------|----|
| 2.2 | Performance                                | 9  |
|     | 2.2.1 Maximum Frequencies                  | 9  |
| 2.3 | Resource Utilization                       |    |
|     | Table 2-1: Resource Usage and Availability | 9  |
| 2.4 | Limitations and Unsupported Features       |    |
| 2.5 | Generic Parameters                         |    |
|     | Table 2-2: Generic Parameters              | 10 |
|     |                                            |    |

### Chapter 3: Port Descriptions

|     | Table 3                   | -2: I/O Signals                                                      | 14 |  |
|-----|---------------------------|----------------------------------------------------------------------|----|--|
| 3.2 | I/O Sigr                  | nals                                                                 | 14 |  |
|     |                           | Table 3-1: Control/Status Register (CSR) Interface Port Descriptions | 11 |  |
|     | 3.1.1                     | Control/Status Register (CSR) Interface                              | 11 |  |
| 3.1 | AXI4-Lite Core Interfaces |                                                                      |    |  |

# Table of Contents

### Page

## Chapter 4: Register Space

|     | Table 4-1: Register Space Memory Map                      | 17 |
|-----|-----------------------------------------------------------|----|
| 4.1 | Interrupt Enable Register                                 | 17 |
|     | Table 4-2: Interrupt Enable Register (Base Address + 0x0) |    |
| 4.2 | Interrupt Flag Register                                   | 18 |
|     | Table 4-3: Interrupt Flag Register (Base Address + 0x4)   | 18 |

## Chapter 5: Designing with the Core

| 5.1 | General Design Guidelines                                                                | 19     |
|-----|------------------------------------------------------------------------------------------|--------|
| 5.2 | Clocking                                                                                 | 19     |
| 5.3 | Resets                                                                                   |        |
| 5.4 | Interrupts                                                                               | 19     |
| 5.5 | Interface Operation                                                                      |        |
| 5.6 | Programming Sequence                                                                     |        |
| 5.7 | Timing Diagrams                                                                          |        |
|     | Figure 5-1: PCI Express Interrupt Controller Core Simulation Output - Legacy Interrupt M | lode21 |
|     | Figure 5-2: PCI Express Interrupt Controller Core Simulation Output - MSI Mode           | 21     |

### Chapter 6: Design Flow Steps

|     | Figure 6-1: PCI Express Interrupt Controller Core in Pentek IP Catalog         |  |
|-----|--------------------------------------------------------------------------------|--|
|     | Figure 6-2: PCI Express Interrupt Controller Core IP Symbol                    |  |
| 6.2 | User Parameters                                                                |  |
| 6.3 | Generating Output                                                              |  |
| 6.4 | Constraining the Core                                                          |  |
| 6.5 | Simulation                                                                     |  |
|     | Figure 6-3: PCI Express Interrupt Controller Core Test Bench Simulation Output |  |
| 6.6 | Synthesis and Implementation                                                   |  |
|     |                                                                                |  |

# **IP** Facts

## Description

Pentek's Navigator<sup>TM</sup> PCI Express (PCIe<sup>®</sup>) PCIe Interrupt Controller Core converts edge-type interrupt inputs from the user design into Legacy Interrupts, and Message Signaled Interrupt (MSI) signals required by the Xilinx<sup>®</sup> Gen3 Integrated Block for PCI Express IP Core.

This core complies with the ARM<sup>®</sup> AMBA<sup>®</sup> AXI4 Specification and also provides a control/status register interface. This user manual defines the hardware interface, software interface, and parameterization options for the PCIe Interrupt Controller Core.

### Features

- Configurable number of (up to 32) interrupt inputs
- Supports single vector MSI
- Register access through AXI4-Lite Interface
- Supports Xilinx Kintex Ultrascale and Xilinx Virtex-7 design families
- Supports dword addressing mode

| Table 1-1: IP Facts Table                 |                                                     |  |
|-------------------------------------------|-----------------------------------------------------|--|
| Core Specifics                            |                                                     |  |
| Supported Design<br>Family <sup>a</sup>   | Kintex <sup>®</sup> Ultrascale and<br>Virtex-7      |  |
| Supported User<br>Interfaces              | AXI4-Lite                                           |  |
| Resources                                 | See Table 2-1                                       |  |
| Provided with the Cor                     | e                                                   |  |
| Design Files                              | VHDL                                                |  |
| Example Design                            | Not Provided                                        |  |
| Test Bench                                | VHDL                                                |  |
| Constraints File                          | Not Provided <sup>b</sup>                           |  |
| Simulation Model                          | VHDL                                                |  |
| Supported S/W<br>Driver                   | HAL Software Support                                |  |
| Tested Design Flows                       |                                                     |  |
| Design Entry                              | Vivado <sup>®</sup> Design Suite<br>2016.3 or later |  |
| Simulation                                | Vivado VSim                                         |  |
| Synthesis                                 | Vivado Synthesis                                    |  |
| Support                                   |                                                     |  |
| Provided by Pentek fpgasupport@pentek.com |                                                     |  |

a.For a complete list of supported devices, see the *Vivado Design Suite Release Notes*.

b.Clock constraints can be applied at the top level module of the user design.

This page is intentionally blank

# Chapter 1: Overview

### **1.1** Functional Description

The PCIe Interrupt Controller Core serves as an interrupt controller which combines the interrupts from the other modules of the user design and generates the necessary signals for the Xilinx PCIe core. The core generates MSI or Legacy configuration interface interrupt signals based on the interrupt mode selected. The core also has an output status signal to indicate the interrupt operation mode (Legacy or MSI) of the core. The PCIe Interrupt Controller Core has an AXI4-Lite Slave Interface which is connected to the Register Space as shown in Figure 1-1.

Figure 1-1 is a top-level block diagram of the Pentek PCIe Interrupt Controller Core. The modules within the block diagram are explained in the later sections of this manual.



Figure 1-1: PCI Express Interrupt Controller Core Block Diagram

### **1.1 Functional Description** (continued)

- ❑ AXI4-Lite Interface: This module implements a 32-bit AXI4-Lite Slave interface to access the Register Space. For additional details about the AXI4-Lite Interface, refer to Section 3.1 AXI4-Lite Core Interfaces.
- □ **Register Space:** This module contains the Interrupt registers like Interrupt Enable and Interrupt Flag registers. Registers are accessed through the AXI4-Lite Interface.
- □ MSI Interrupt State Machine: This state machine is used to generate the configuration interface MSI signals when the MSI Interrupt mode is enabled.

### 1.2 Applications

This PCIe Interrupt Controller Core can be used for any application that requires combining edge-type interrupts from peripheral devices into one interrupt signal and converting it to legacy and MSI signals for the Xilinx Gen3 Integrated Block for PCIe IP core.

### **1.3** System Requirements

For a list of system requirements, see the Vivado Design Suite Release Notes.

### 1.4 Licensing and Ordering Information

This core is included with all Pentek Navigator FPGA Design Kits for Pentek Jade series board products. Contact Pentek for Licensing and Ordering Information (www.pentek.com).

### 1.5 Contacting Technical Support

Technical Support for Pentek's Navigator FPGA Design Kits is available via e-mail (fpgasupport@pentek.com) or by phone (201-818-5900 ext. 238, 9 am to 5 pm EST).

### **1.6 Documentation**

This user manual is the main document for this IP core. The following documents provide supplemental material:

- 1) Vivado Design Suite User Guide: Designing with IP
- 2) Vivado Design Suite User Guide: Programming and Debugging
- 3) ARM AMBA AXI4 Protocol Version 2.0 Specification http://www.arm.com/products/system-ip/amba-specifications.php
- 4) Xilinx Gen3 Integrated Block for PCI Express Product Guide

# **Chapter 2: General Product Specifications**

### 2.1 Standards

The PCIe Interrupt Controller Core has bus a interface that complies with the *ARM AMBA AXI4-Lite Protocol Specification*.

### 2.2 Performance

The performance of the PCIe Interrupt Controller Core is limited only by the FPGA logic speed. The values presented in this section should be used as an estimation guideline. Actual performance can vary.

### 2.2.1 Maximum Frequencies

The PCIe Interrupt Controller Core is designed to meet a target frequency of 250 MHz on a Kintex Ultrascale -2 speed grade FPGA. 250 MHz is typically the PCI Express (PCIe<sup>®</sup>) AXI bus clock frequency.

#### 2.3 **Resource Utilization**

The resource utilization of the PCIe Interrupt Controller Core is shown in Table 2-1. Resources have been estimated for the Kintex Ultrascale XCKU060 -2 speed grade device. These values were generated using the Vivado Design Suite.

| Table 2-1: Resource Usage and Availability |        |  |
|--------------------------------------------|--------|--|
| Resource                                   | # Used |  |
| LUTs                                       | 113    |  |
| Flip-Flops                                 | 279    |  |

**NOTE:** Actual utilization may vary based on the user design in which the PCIe Interrupt Controller Core is incorporated.

### 2.4 Limitations and Unsupported Features

- □ This IP core does not support the multi-vector MSI operation.
- □ This IP core does not support MSI-X interrupt mode.

## 2.5 Generic Parameters

The generic parameters of the PCIe Interrupt Controller Core are described in Table 2-2. These parameters can be set as required by the user application while customizing the core.

| Table 2-2: Generic Parameters |         |                                                                                                                                                           |  |
|-------------------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Port/Signal Name              | Туре    | Description                                                                                                                                               |  |
| num_interrupt_sources         | Integer | <b>Number of Interrupt Sources:</b> This parameter defines the number of interrupt source inputs to the core. It can range from 1 to 32.                  |  |
| ku                            |         | <ul> <li>FPGA Type: This parameter defines the type of FPGA this core is being used with.</li> <li>0 - Virtex-7</li> <li>1 - Kintex Ultrascale</li> </ul> |  |

# **Chapter 3: Port Descriptions**

This chapter provides details about the port descriptions for the following interface types:

- AXI4-Lite Core Interfaces
- I/O Signals

### 3.1 AXI4-Lite Core Interfaces

The PCIe Interrupt Controller Core uses the Control/Status Register (CSR) interface to control, and receive status from, the user design.

### 3.1.1 Control/Status Register (CSR) Interface

The CSR interface is an AXI4-Lite Slave Interface that can be used to access the control and status registers in the PCIe Interrupt Controller Core. Table 3-1 defines the ports in the CSR interface. See Chapter 4 for a Control/Status Register memory map and bit definitions. See the *AMBA AXI4-Lite Specification* for more details on operation of the AXI4-Lite interfaces.

| Table 3-          | Table 3-1: Control/Status Register (CSR) Interface Port Descriptions |       |                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|-------------------|----------------------------------------------------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Port              | Direction                                                            | Width | Description                                                                                                                                                                                                                                                                                                                                                       |  |  |
| s_axi_csr_aclk    | Input                                                                | 1     | Clock                                                                                                                                                                                                                                                                                                                                                             |  |  |
| s_axi_csr_aresetn | Input                                                                | 1     | <b>Reset:</b> Active low. This signal will reset all control registers to their initial states.                                                                                                                                                                                                                                                                   |  |  |
| s_axi_csr_awaddr  | Input                                                                | 4     | Write Address: Address used for write operations. It must<br>be valid when <b>s_axi_csr_awvalid</b> is asserted and must be<br>held until <b>s_axi_csr_awready</b> is asserted by the PCIe<br>Interrupt Controller Core.                                                                                                                                          |  |  |
| s_axi_csr_awprot  | Input                                                                | 3     | <b>Protection:</b> The PCIe Interrupt Controller Core ignores these bits.                                                                                                                                                                                                                                                                                         |  |  |
| s_axi_csr_awvalid | Input                                                                | 1     | Write Address Valid: This input must be asserted to<br>indicate that a valid write address is available on<br>s_axi_csr_awaddr. The PCIe Interrupt Controller Core<br>asserts s_axi_csr_awready when it is ready to accept the<br>address. The s_axi_csr_awvalid must remain asserted until<br>the rising clock edge after the assertion of<br>s_axi_csr_awready. |  |  |

| Table 3-1: Cor    | ntrol/Status | Registe | er (CSR) Interface Port Descriptions (Continued)                                                                                                                                                                                                                                                                                                                                                               |
|-------------------|--------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port              | Direction    | Width   | Description                                                                                                                                                                                                                                                                                                                                                                                                    |
| s_axi_csr_awready | Output       | 1       | Write Address Ready: This output is asserted by the PCIe<br>Interrupt Controller Core when it is ready to accept the write<br>address.The address is latched when <b>s_axi_csr_awvalid</b><br>and <b>s_axi_csr_awready</b> are high on the same cycle.                                                                                                                                                         |
| s_axi_csr_wdata   | Input        | 32      | Write Data: This data will be written to the address specified<br>by s_axi_csr_awaddr when s_axi_csr_wvalid and<br>s_axi_csr _wready are both asserted. The value must be<br>valid when s_axi_csr_wvalid is asserted and held until<br>s_axi_csr_wready is also asserted.                                                                                                                                      |
| s_axi_csr_wstrb   | Input        | 4       | Write Strobes: This signal, when asserted, indicates the number of bytes of valid data on the <b>s_axi_csr_wdata</b> signal. Each of these bits, when asserted, indicate that the corresponding byte of <b>s_axi_csr_wdata</b> contains valid data. Bit 0 corresponds to the least significant byte, and bit 3 to the most significant.                                                                        |
| s_axi_csr_wvalid  | Input        | 1       | Write Valid: This signal must be asserted to indicate that the write data is valid for a write operation. The value on s_axi_csr _wdata is written into the register at address s_axi_csr_awaddr when s_axi_csr_wready and s_axi_csr_wvalid are high on the same cycle.                                                                                                                                        |
| s_axi_csr_wready  | Output       | 1       | Write Ready: This signal is asserted by the PCIe Interrupt<br>Controller Core when it is ready to accept data. The value on<br>s_axi_csr _wdata is written into the register at address<br>s_axi_csr_awaddr when s_axi_csr_wready and<br>s_axi_csr_wvalid are high on the same cycle, assuming<br>that the address has already or simultaneously been<br>submitted.                                            |
| s_axi_csr_bresp   | Output       | 2       | Write Response: The PCIe Interrupt Controller Core<br>indicates success or failure of a write transaction through<br>this signal, which is valid when <b>s_axi_csr_bvalid</b> is<br>asserted;<br>00 = Success of normal access<br>01 = Success of exclusive access<br>10 = Slave Error<br>11 = Decode Error<br>Note: For more details about this signal refer to the <i>AMBA</i><br><i>AXI Specification</i> . |
| s_axi_csr_bready  | Input        | 1       | Write Response Ready: This signal must be asserted by the user logic when it is ready to accept the Write Response.                                                                                                                                                                                                                                                                                            |
| s_axi_csr_bvalid  | Output       | 1       | Write Response Valid: This signal is asserted by the PCIe<br>Interrupt Controller Core when the write operation is<br>complete and the Write Response is valid. It is held until<br>s_axi_csr_bready is asserted by the user logic.                                                                                                                                                                            |

| Table 3-1: Cor    | ntrol/Status | Registe | er (CSR) Interface Port Descriptions (Continued)                                                                                                                                                                                                                                                                                                                                                                 |
|-------------------|--------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port              | Direction    | Width   | Description                                                                                                                                                                                                                                                                                                                                                                                                      |
| s_axi_csr_araddr  | Input        | 4       | <b>Read Address:</b> Address used for read operations. It must<br>be valid when <b>s_axi_csr_arvalid</b> is asserted and must be<br>held until <b>s_axi_csr_arready</b> is asserted by the PCIe<br>Interrupt Controller Core.                                                                                                                                                                                    |
| s_axi_csr_arprot  | Input        | 3       | <b>Protection:</b> These bits are ignored by the PCIe Interrupt Controller Core                                                                                                                                                                                                                                                                                                                                  |
| s_axi_csr_arvalid | Input        | 1       | <b>Read Address Valid:</b> This input must be asserted to<br>indicate that a valid read address is available on the<br><b>s_axi_csr_araddr</b> . The PCIe Interrupt Controller Core<br>asserts <b>s_axi_csr_arready</b> when it ready to accept the<br>Read Address. This input must remain asserted until the<br>rising clock edge after the assertion of <b>s_axi_csr_arready</b> .                            |
| s_axi_csr_arready | Output       | 1       | <b>Read Address Ready:</b> This output is asserted by the PCIe<br>Interrupt Controller Core when it is ready to accept the read<br>address. The address is latched when <b>s_axi_csr_arvalid</b><br>and <b>s_axi_csr_ arready</b> are high on the same cycle.                                                                                                                                                    |
| s_axi_csr_rdata   | Output       | 32      | <b>Read Data:</b> This value is the data read from the address specified by the <b>s_axi_csr_araddr</b> when <b>s_axi_csr_arvalid</b> and <b>s_axi_csr_arready</b> are high on the same cycle.                                                                                                                                                                                                                   |
| s_axi_csr_rresp   | Output       | 2       | <b>Read Response:</b> The PCIe Interrupt Controller Core<br>indicates success or failure of a read transaction through this<br>signal, which is valid when <b>s_axi_csr_rvalid</b> is asserted;<br>00 = Success of normal access<br>01 = Success of exclusive access<br>10 = Slave Error<br>11 = Decode Error<br>Note: For more details about this signal refer to the <i>AMBA</i><br><i>AXI Specification</i> . |
| s_axi_csr_rvalid  | Output       | 1       | <b>Read Data Valid:</b> This signal is asserted by the PCIe<br>Interrupt Controller Core when the read is complete and the<br>read data is available on <b>s_axi_csr_rdata</b> . It is held until<br><b>s_axi_csr_ rready</b> is asserted by the user logic.                                                                                                                                                     |
| s_axi_csr_rready  | Input        | 1       | <b>Read Data Ready:</b> This signal is asserted by the user logic when it is ready to accept the Read Data.                                                                                                                                                                                                                                                                                                      |

# 3.2 I/O Signals

The I/O port/signal descriptions of the top-level module of the PCIe Interrupt Controller Core are discussed in the Table 3-2. For more details about Configuration Interrupt Controller Interface of the Xilinx Gen3 Integrated Block for PCI Express IP Core, refer to the Product Guide(*Xilinx Gen3 Integrated Block for PCI Express IP Core Product Guide*).

|                                          |                                                                      | Table 3-2    | : I/O Signals                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |
|------------------------------------------|----------------------------------------------------------------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Port/Signal Name                         | Туре                                                                 | Direction    | Description                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
| Interrupt Sources                        |                                                                      |              |                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
| int_in [num_interrupt_<br>sources-1 : 0] | std_logic<br>_vector                                                 | Input        | <b>Interrupt Sources:</b> These are the interrupt source inputs to the core. The width of this signal depends on the generic parameter <b>num_interrupt_sources</b> .                                                                                                                                                                                                                              |  |  |  |  |  |  |  |
|                                          |                                                                      | Interrupt Mo | de Status Signal                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |
| msi_enable_out[3:0]                      | std_logic<br>_vector                                                 | Output       | MSI Mode Status Signal: This signal indicates if the MSI mode is enabled.<br>msi_enable_out[0] = 0 => MSI mode disabled.<br>Legacy mode enabled.<br>msi_enable_out[0] = 1 => MSI mode enabled.                                                                                                                                                                                                     |  |  |  |  |  |  |  |
|                                          | Config                                                               | uration Inte | rface Interrupt Signals                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |
|                                          |                                                                      | Legacy Int   | errupt Signals                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |
| cfg_interrupt_int[3:0]                   | std_logic<br>_vector                                                 | Output       | <b>Configuration INTx vector:</b> The core uses this signal to indicate an interrupt in Legacy Interrupt mode. These four bits correspond to INTA, INTB, INTC, and INTD. Asserting one of these signals causes the Xilinx PCIe core to send out an <b>Assert_INTx</b> message, deassserting this signal causes the Xilinx PCIe core to transmit a <b>Deassert_INTx</b> message over the PCIe link. |  |  |  |  |  |  |  |
| cfg_interrupt_pending                    | Configuration INTx Interrupt Pending: Indicates a pending interrupt. |              |                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
| cfg_interrupt_sent                       | std_logic                                                            | Input        | <b>Configuration INTx Sent:</b> A pulse on this input from<br>the Xilinx PCIe core indicates that an <b>Assert_INTx</b> or<br>a <b>Deassert_INTx</b> message has been sent in<br>response to a change in the <b>cfg_interrupt_int</b> output<br>from the core.                                                                                                                                     |  |  |  |  |  |  |  |

|                                                | Table                                                 | e 3-2: I/O S | Signals (Continued)                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
|------------------------------------------------|-------------------------------------------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Port/Signal Name                               | Туре                                                  | Direction    | Description                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
| C                                              | Configuration Interface Interrupt Signals (continued) |              |                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|                                                |                                                       | MSI          | Signals                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
| cfg_interrupt_msi_<br>attr[2:0]                | std_logic<br>_vector                                  | Output       | Configuration MSI Interrupt TLP Attribute: These<br>bits provide the attribute bits setting for the MSI<br>request.<br>Bit 0 - No Snoop<br>Bit 1 - Relaxed ordering<br>Bit 2 - ID-Based ordering                                                                                                                                                                                                                                      |  |  |  |  |  |  |
| cfg_interrupt_msi<br>_data[31:0]               | std_logic<br>_vector                                  | Input        | Configuration Interrupt MSI Data                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
| cfg_interrupt_msi_<br>enable                   |                                                       |              | <b>Configuration Interrupt MSI Fuction Enabled:</b> This signal indicates that the MSI messaging mode is enabled.                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
| cfg_interrupt_msi_fail                         | std_logic                                             |              | <b>Configuration Interrupt MSI Operation Failed:</b> This signal from the Xilinx PCIe core indicates that the MSI interrupt messge had been aborted before transmission over the PCIe link. The core must retransmit the MSI interrupt when this signal is High.                                                                                                                                                                      |  |  |  |  |  |  |
| cfg_interrupt_msi<br>_function_number          | std_logic<br>_vector                                  | Output       | <b>Configuration MSI Function Number:</b> This indicates the endpoint function number initiating the MSI transaction.                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| cfg_interrupt_msi_int<br>[63-(ku*32) downto 0] | std_logic<br>_vector                                  |              | <b>Configuration MSI Vector:</b> These bits are used to indicate the interrupt condition associated with the PCI function for an interrupt request. The core must activate only one of these signals for one cycle to transmit an interrupt. After asserting the interrupt the core must wait until an cfg_interrupt_msi_sent or cfg_interrupt_msi_fail indication from the PCIe core is received before asserting another interrupt. |  |  |  |  |  |  |
| cfg_interrupt_msi<br>_mask_update              | std_logic                                             | Input        | <b>Configuration Interrupt MSI Mask Update:</b><br>Asserted for one cycle when any enabled funtions in<br>the MSI Mask Register change value. MSI mask<br>register contains the mask bits for MSI Interrupts.                                                                                                                                                                                                                         |  |  |  |  |  |  |
| cfg_interrupt_msi<br>_mmenable                 | std_logic<br>_vector                                  |              | <b>Configuration Interrupt MSI Multiple Message</b><br><b>Enable:</b> This is the value of the Multiple Message<br>Enable field and indicates the number of allocated<br>MSI Interrupt vectors.                                                                                                                                                                                                                                       |  |  |  |  |  |  |

|                                                    | Table                                                 | e 3-2: I/O S | ignals (Continued)                                                                                                                                                                                                             |  |  |  |  |  |  |
|----------------------------------------------------|-------------------------------------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Port/Signal Name                                   | Туре                                                  | Direction    | Description                                                                                                                                                                                                                    |  |  |  |  |  |  |
| C                                                  | Configuration Interface Interrupt Signals (continued) |              |                                                                                                                                                                                                                                |  |  |  |  |  |  |
|                                                    | MSI Signals (continued)                               |              |                                                                                                                                                                                                                                |  |  |  |  |  |  |
| cfg_interrupt_msi<br>_pending_status               | std_logic<br>_vector                                  | Output       | <b>Configuration Interrupt MSI Pending Status:</b> The core provides the status of pending MSI interrupts through this signal.                                                                                                 |  |  |  |  |  |  |
| cfg_interrupt_msi_pending<br>_status_data_enable   | std_logic                                             |              | <b>Configuration Interrupt MSI Pending Status Data</b><br><b>Enable:</b> This signal enables the MSI pending status signal.                                                                                                    |  |  |  |  |  |  |
| cfg_interrupt_msi_pending<br>_status_func_num[3:0] | std_logic<br>_vector                                  |              | Configuration Interrupt MSI Pending Status<br>Function number: This signal indicates the function<br>number of the pending MSI interrupt request.                                                                              |  |  |  |  |  |  |
| cfg_interrupt_msi<br>_select[3:0]                  | std_logic<br>_vector                                  | Output       | <b>Configuration Interrupt MSI Select:</b> These bits indicate the selected function of the MSI interrupt request 0000 - 0001 = Physical Function 0 - 1 0010 - 1111 = Virtual Function 0 - 5                                   |  |  |  |  |  |  |
| cfg_interrupt_msi_sent                             | std_logic                                             | Input        | <b>Configuration Interrupt MSI Sent:</b> A one clock cycle pulse on this input indicates that an MSI interrupt message has been transmitted over the PCIe link by the Xilinx PCIe core.                                        |  |  |  |  |  |  |
| cfg_interrupt_msi<br>_tph_present                  |                                                       | Output       | Configuration Interrupt MSI Transaction<br>Processing Hint (TPH) Present: Indicates the<br>presence of a TPH in the MSI request. The core<br>asserts this bit while asserting cfg_interrupt_msi<br>_int, if it includes a TPH. |  |  |  |  |  |  |
| cfg_interrupt_msi<br>_tph_st_tag[8:0]              | std_logic<br>_vector                                  |              | Configuration Interrupt MSI TPH Steering Tag:<br>When cfg_interrupt_msi_tph_present is High, the<br>steering tag associated with the hint must be placed<br>on cfg_interrupt_msi_tph_st_tag[7:0].                              |  |  |  |  |  |  |
| cfg_interrupt_msi<br>_tph_type[1:0]                |                                                       |              | Configuration Interrupt MSI TPH Type: When cfg_interrupt _msi_tph_present is High, these bits indicate the two-bit type associated with the hint.                                                                              |  |  |  |  |  |  |
| cfg_interrupt_msi<br>_vf_enable                    |                                                       | Input        | <b>Configuration Interrupt MSI Virtual Function</b><br><b>Enable:</b> Indicates MSI messaging is enabled, per<br>virtual function.                                                                                             |  |  |  |  |  |  |

# Chapter 4: Register Space

This chapter provides the memory map and register descriptions for the register space of the PCIe Interrupt Controller Core. The memory map is provided in Table 4-1.

| Table 4-1: Register Space Memory Map |                                          |       |                       |  |  |  |  |  |  |
|--------------------------------------|------------------------------------------|-------|-----------------------|--|--|--|--|--|--|
| Register Name                        | AddressAccessDescription(Base Address +) |       |                       |  |  |  |  |  |  |
| Interrupt Enable<br>Register         | 0x0                                      | R/W   | Interrupt enable bits |  |  |  |  |  |  |
| Interrupt Flag Register              | 0x4                                      | R/Clr | Interrupt flag bits   |  |  |  |  |  |  |

## 4.1 Interrupt Enable Register

The bits in the interrupt enable register are used to enable (or disable) the generation of interrupts based on the condition of certain circuit elements, known as interrupt sources. When a bit in this register associated with a given interrupt source is High, an interrupt will be generated by the rising edge of that interrupt source. This register is described in Table 4-2.

|      | Table 4-2: Interrupt Enable Register (Base Address + 0x0) |               |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|------|-----------------------------------------------------------|---------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bits | Field<br>Name                                             | Default Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| 31:0 | int_src                                                   | 0x0000000     | R/W            | Interrupt Sources: Each of the bits in this register<br>corresponds to an incoming interrupt source. Bit 0<br>corresponds to interrupt source input[0] and bit 31 to<br>interrupt input[31]. When the number of interrupt sources<br>is less than 32, the remaining bits of this register are<br>assigned with their default values. These bits are used to<br>enable/disable the corresponding interrupt source.<br>0 = Disable interrupt<br>1 = Enable interrupt |  |  |

# 4.2 Interrupt Flag Register

The Interrupt Flag Register has read/clear access associated with each interrupt condition (the same bit association as the Interrupt Enable Register). When reset, this register has all bits set to '0' (cleared). Each flag bit in this register latches an interrupt occurrence. A '1' in any flag bit in this register indicates that an interrupt has occurred. To clear the flag bits, write '1's to the desired bits. This register is described on Table 4-3.

|      | Table 4-3: Interrupt Flag Register (Base Address + 0x4) |               |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|------|---------------------------------------------------------|---------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bits | Field<br>Name                                           | Default Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| 31:0 | int_src                                                 | 0x0000000     | R/W            | Interrupt Sources: Each of the bits in this register<br>corresponds to an incoming interrupt source. Bit 0<br>corresponds to interrupt source input[0] and bit 31 to<br>interrupt input[31]. When the number of interrupt sources<br>is less than 32, the remaining bits of this register are<br>assigned with their default values. These bits indicate the<br>corresponding interrupt flag.<br><b>Read:</b><br>0 = No interrupt<br>1 = Interrupt latched<br><b>Clear:</b> 1 = Clear latch |  |  |

# Chapter 5: Designing with the Core

This chapter includes guidelines and additional information to facilitate designing with the PCIe Interrupt Controller Core.

### 5.1 General Design Guidelines

The PCIe Interrupt Controller core provides the required logic to generate the Legacy and MSI interrupt request signals required by the Xilinx Gen3 PCIe core. The interrupt sources from the user design are combined to generate an interrupt control for the PCIe core. For details on the configuration interrupt controller interface of the Xilinx PCIe core, refer to the Product Guide (*Xilinx Gen4 Integrated Block for PCI Express IP Core Product Guide*).

### 5.2 Clocking

Main Clock: aclk

This clock will be the User Interface clock (**user\_clk**) output of the Xilinx PCIe core. The Xilinx PCIe core's user clock output is 250MHz. This clock is used to clock all the ports on the PCIe Interrupt Controller core.

#### 5.3 Resets

#### Main reset: aresetn

This is an active low synchronous reset associated with the **aclk**.

### 5.4 Interrupts

This core has edge-type (rising edge-triggered) interrupt inputs. They are synchronous with the **aclk**. On the rising edge of any interrupt signal, a one-clock-cycle wide pulse is generated on it's internal interrupt signal. Each interrupt event is stored in the Interrupt Flag register, accessible on the **s\_axi\_csr** bus.

The Interrupt Flag Register latches the occurrence of each interrupt, in a bit that retains its state until explicitly cleared. The interrupt flags can be cleared by writing '1' to the associated bit's location. All interrupt sources that are enabled (via the Interrupt Enable Register) are "OR ed" onto the internal interrupt signal. The Legacy or MSI interrupt signals are generated and transmitted to the Xilinx PCIe core based on the internal interrupt signal.

### **5.4 Interrupts** (continued)

- **NOTE:** All interrupt sources are latched in the interrupt flag register, even when an interrupt source is not enabled to create an interrupt.
- **NOTE:** Because this core uses edge-triggered interrupts, the fact that an interrupt condition may remain active after servicing will not cause the generation of a new interrupt. A new interrupt will only be generated by another rising edge on an interrupt source.

### 5.5 Interface Operation

**CSR Interface:** This is the Control/Status Register Interface and is associated with **aclk**. It is a standard AXI4-Lite Slave interface. See Chapter 4 for the Register Space memory map, which provides more details on the registers that can be accessed through this interface.

### 5.6 **Programming Sequence**

This section briefly describes the programming sequence of registers in the PCIe Interrupt Controller Core.

- 1) Ensure that the Interrupt Flag Register is cleared.
- 2) Enable the required interrupt sources to generate an interrupt.
- 3) Based on the Interrupt mode, Legacy or MSI signals are transmitted.
- 4) Clear the Interrupt Flag Register.

### 5.7 Timing Diagrams

The timing diagrams for the PCIe Interrupt Controller core are shown in Figures 5-1 and 5-2. These timing diagrams were obtained by running the simulation of the test bench of the core in Vivado VSim environment. These timing diagrams depict the functionality of the core for Legacy and MSI Interrupt modes.

## 5.7 Timing Diagrams (continued)





Figure 5-2: PCI Express Interrupt Controller Core Simulation Output - MSI Mode

| Name                                   | Value                                   | 13   | 0,000 ps | 140,000 1  | ps  1  | 50,000 p | s      | 160,000 | ps     | 170,000 ps                              | 180,000 ps      | 190,000 ps | 200,000 ps                              | 210,000 ps | 220  |
|----------------------------------------|-----------------------------------------|------|----------|------------|--------|----------|--------|---------|--------|-----------------------------------------|-----------------|------------|-----------------------------------------|------------|------|
| 1∰ adk                                 | 1                                       | i ti |          |            |        |          |        |         |        |                                         |                 |            |                                         |            |      |
| 🖟 aresetn                              | 1                                       |      |          |            |        |          | _      |         |        |                                         |                 |            |                                         |            | F    |
| 🛛 🐳 s_axi_csr_awaddr[3:0]              | 0000                                    |      |          | 0100       |        | X        |        |         |        |                                         | 000             |            | X                                       | 0100       |      |
| 🖬 📲 s_axi_csr_awprot[2:0]              | 000                                     |      |          |            |        |          |        |         |        | 000                                     |                 |            |                                         |            |      |
| 🖟 s_axi_csr_awvalid                    | 0                                       |      |          |            |        |          |        |         |        |                                         |                 |            |                                         |            | 1    |
| ₩ s_axi_csr_awready                    | 0                                       |      |          |            |        |          |        |         |        |                                         |                 |            |                                         |            |      |
| 🖬 📲 s_axi_csr_wdata[31:0]              | 111111111111111111111111111111111111111 |      |          |            |        |          |        |         | 11111  | 1111111111111111                        | 111111111111111 |            |                                         |            | F    |
| 🖬 📲 s_axi_csr_wstrb[3:0]               | 0000                                    | 000  | ο χ      | 1111       | X      | 000 X    | 1      | 111     | -χ     |                                         | 0000            |            | X                                       | 1111       | x T  |
| ₩ s_axi_csr_wvalid                     | 0                                       |      |          |            |        |          |        |         |        |                                         |                 |            |                                         |            | 1    |
| Us_s_axi_csr_wready                    | 0                                       |      |          |            |        |          |        |         | 1      |                                         |                 |            |                                         |            |      |
| 🖬 📲 s_axi_csr_bresp[1:0]               | 00                                      | =    |          |            |        |          |        |         |        | 00                                      |                 |            |                                         |            | +    |
| 🖟 s_axi_csr_bvalid                     | 0                                       |      |          |            |        |          |        |         |        |                                         |                 |            |                                         |            | +    |
| li∉s_axi_csr_bready                    | 0                                       |      |          |            |        | 1        |        |         | -      | 1                                       |                 |            |                                         |            | +    |
| 🛛 📲 int_in(31:0)                       | 000000000000000000000000000000000000000 | =    |          | 0000000000 | 000000 | 0000000  | 000000 | 00      |        | X 00 X                                  |                 | 0000000000 | 000000000000000000000000000000000000000 | 0000000    |      |
| 🖬 📲 msi_enable_out[3:0]                | 0001                                    | 0_ X |          |            |        |          |        |         |        | 00                                      | 01              |            |                                         |            |      |
| 🖬 📲 cfg_interrupt_msi_attr[2:0]        | 000                                     | -    |          |            |        |          |        |         |        | 000                                     |                 |            |                                         |            | +    |
| 🖪 📲 cfg_interrupt_msi_data[31:0]       | 000000000000000000000000000000000000000 |      |          |            |        |          |        |         | 00000  | 000000000000000000000000000000000000000 | 00000000000000  |            |                                         |            |      |
| 🖟 cfg_interrupt_msi_fail               | 0                                       |      |          |            |        |          |        |         |        |                                         |                 |            |                                         |            |      |
| 🖬 💐 cfg_interrupt_msi_enable[3:0]      | 0001                                    | 0_ X |          |            |        |          |        |         |        | 00                                      | 01              |            |                                         |            |      |
| 🛛 📲 cfg_interrupt_msiction_number[3:0] | 0000                                    |      |          |            |        |          |        |         |        | 0000                                    |                 |            |                                         |            |      |
| 🛛 📲 cfg_interrupt_msi_int[31:0]        | 000000000000000000000000000000000000000 |      |          |            | 00     | 00000000 | 00000  | 0000000 | 000000 | 00                                      |                 | X 00 X     | 0000000000                              |            | 0000 |
| 🎚 cfg_interrupt_msi_mask_update        | 0                                       |      |          |            |        |          |        |         |        |                                         |                 |            |                                         |            |      |
| 🛛 💐 cfg_interrupt_msi_mmenable[11:0]   | 00000000000                             |      |          |            |        |          |        |         |        | 00000000                                | 000             |            |                                         |            |      |
| 🖬 📲 cfg_interrupt_msiding_status[31:0] | 000000000000000000000000000000000000000 |      |          |            |        |          |        |         | 00000  | 000000000000000000000000000000000000000 | 00000000000000  |            |                                         |            |      |
| 🎚 cfg_interrupt_msitatus_data_enable   | 0                                       |      |          |            |        |          |        |         |        |                                         |                 |            |                                         |            |      |
| 🖬 🔩 cfg_interrupt_msifunction_num[3:0] | 0000                                    |      |          |            |        |          |        |         |        | 0000                                    |                 |            |                                         |            |      |
| 🛛 📲 cfg_interrupt_msi_select[3:0]      | 0000                                    |      |          |            |        |          |        |         |        | 0000                                    |                 |            |                                         |            |      |
| ₩ cfg_interrupt_msi_sent               | 1                                       |      |          |            |        |          |        |         |        |                                         |                 |            |                                         |            |      |
| 🍇 cfg_interrupt_msi_tph_present        | 0                                       |      |          |            |        |          |        |         |        |                                         |                 |            |                                         |            |      |
| 🛛 📲 cfg_interrupt_msi_tph_st_tag[8:0]  | 00000000                                |      |          |            |        |          |        |         |        | 0000000                                 | po              |            |                                         |            |      |
| 🛛 📲 cfg_interrupt_msi_tph_type[1:0]    | 00                                      |      |          |            |        |          |        |         |        | 00                                      |                 |            |                                         |            |      |
| 🛛 🐭 cfg_interrupt_msi_vf_enable[7:0]   | 00000000                                |      |          |            |        |          |        |         |        | 000000                                  | 0               |            |                                         |            |      |
| 1& num_interrupt_sources               | 100000                                  |      |          |            |        |          |        |         |        | 10000                                   |                 |            |                                         |            |      |
| 1ª ku                                  | 1                                       |      |          |            |        |          |        |         |        | 1                                       |                 |            |                                         |            |      |

This page is intentionally blank

# Chapter 6: Design Flow Steps

### 6.1 Pentek IP Catalog

This chapter describes customization and generation of the Pentek PCIe Interrupt Controller Core. It also includes simulation, synthesis, and implementation steps that are specific to this IP core. This core can be generated from the Vivado IP Catalog when the Pentek IP Repository has been installed. It will appear in the IP Catalog list as **px\_pcie\_irq\_ctlr\_v1\_0** as shown in Figure 6-1.

| Cores In     | terfaces                            | <u>S</u> earch: Q,→ |            |          |    |
|--------------|-------------------------------------|---------------------|------------|----------|----|
| Name         | ^1                                  | AXI4                | Status     | License  |    |
|              | <pre>px_lvl_trans_xdk_v1_0</pre>    |                     | Production | Included | ~  |
|              | <pre>px_pcie2axil_v1_0</pre>        | AXI4, AXI4-Stream   | Production | Included |    |
| 1 17         | <pre>px_pcie3_cfg_ctl_v1_0</pre>    |                     | Production | Included |    |
| 逐            | px_pcie_irq_ctlr_v1_0               | AXI4                | Production | Included |    |
|              | px_pcie_link_stat_v1_0              | AXI4-Stream         | Production | Included |    |
| -            | px_pcie_rqrc_gskt_v1_0              | AXI4-Stream         | Production | Included |    |
| <b>.</b>     | px_pwron_rst_v1_0                   |                     | Production | Included |    |
|              | px_s_axil_plc_hldr_v1_0             | AXI4                | Production | Included | v  |
| <            |                                     |                     |            | >        | ŝ. |
| etails       |                                     |                     |            |          |    |
| Name:        | px_pcie_irq_ctlr_v1_0               |                     |            |          | ^  |
| Version:     | 1.0 (Rev. 22)                       |                     |            |          |    |
| Interfaces:  | AXI4                                |                     |            |          |    |
| Description: | AXI4-Lite PCIE Gen3 Interrupt Contr | oller               |            |          |    |
| Status:      | Production                          |                     |            |          |    |
| License:     | Included                            |                     |            |          |    |
| Change Log:  | View Change Log                     |                     |            |          | Т  |
| Vendor:      | Pentek, Inc.                        |                     |            |          |    |

Figure 6-1: PCI Express Interrupt Controller Core in Pentek IP Catalog

### 6.1 **Pentek IP Catalog (continued)**

When you select the **px\_pcie\_irq\_ctlr\_v1\_0** core, a screen appears that shows the core's symbol and the core's parameters (see Figure 6-2). The core's symbol is the box on the left side.



| E Customize IP                                                                                                          | >                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>px_pcie_irq_ctlr_v1_0 (1.0)</pre>                                                                                  | A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 🎁 Documentation 📄 IP Location 🧔 Switch to Default                                                                       | ts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Show disabled ports                                                                                                     | Component Name px_pcie_irq_ctlr_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| -j-s_axi_csr pcie3_cfg_interrupt -j-<br>aclk pcie3_cfg_interrupt_msi -j-<br>aresetn msi_enable_out[3:0]<br>int_in[31:0] | Number of Interrupt Sources       32       [1 - 32]         Select FPGA Type       Image: Comparison of the second |
|                                                                                                                         | < > > OK Cancel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

### 6.2 User Parameters

The user parameters of this IP core are described in 2.5 of this user manual.

## 6.3 Generating Output

For more details about generating and using IP in the Vivado Design Suite, refer to the *Vivado Design Suite User Guide - Designing with IP*.

### 6.4 Constraining the Core

This section contains information about constraining the PCIe Interrupt Controller Core in Vivado Design Suite.

#### **Required Constraints**

The XDC constraints are not provided with the PCIe Interrupt Controller Core. Clock constraints can be applied in the top-level module of the user design.

#### Device, Package, and Speed Grade Selections

This IP works for the Kintex Ultrascale and Virtex-7 FPGAs.

#### **Clock Frequencies**

The clock frequency (aclk) for this IP core is 250 MHz.

#### **Clock Management**

This section is not applicable for this IP core.

#### **Clock Placement**

This section is not applicable for this IP core.

#### **Banking and Placement**

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.

## 6.5 Simulation

The PCIe Interrupt Controller IP has a test bench which generates the output waveforms using Vivado VSim environment. The test bench is designed to run at 250 MHz input clock frequency with 32 interrupt sources. It is designed for a Kintex Ultrascale FPGA.

The test bench first generates Legacy interrupt signals by disabling the MSI mode  $(cfg_interupt_msi_enable[0] = `0`)$  and then generates MSI signals by enabling the MSI mode  $(cfg_interupt_msi_enable[0] = `1`)$ . The programming procedure is the same as described in Section 5.6. When run, the simulation produces the results shown in Figure 6-3.

### Figure 6-3: PCI Express Interrupt Controller Core Test Bench Simulation Output



### 6.6 Synthesis and Implementation

For details about synthesis and implementation see the *Vivado Design Suite User Guide* - *Designing with IP*.