# **IP CORE MANUAL**



# PCI Express to AXI4-Lite Bridge IP

px\_pcie2axil



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

| Date     | <u>Version</u> |                 |  |
|----------|----------------|-----------------|--|
| 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

| 1.1 | Functional Description                                             | 7 |
|-----|--------------------------------------------------------------------|---|
|     | Figure 1-1: PCI Express to AXI4-Lite Bridge Core Interfaces        |   |
|     | Figure 1-2: PCI Express to AXI4-Lite Bridge Core Interface Example | 8 |
| 1.2 | Applications                                                       | 8 |
| 1.3 | System Requirements                                                |   |
| 1.4 | Licensing and Ordering Information                                 | 8 |
| 1.5 | Contacting Technical Support                                       | 9 |
|     | Documentation                                                      |   |

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

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

## Chapter 3: Port Descriptions

| 3.1 | AXI4-Lite Core Interfaces |                                                                  |    |
|-----|---------------------------|------------------------------------------------------------------|----|
|     | Table 3                   | 8-1: AXI4-Lite Interface Port Descriptions                       | 13 |
| 3.2 | AXI4-S                    | Stream Core Interfaces                                           | 16 |
|     | 3.2.1                     | PCIe Completer Request (CQ) Interface                            | 16 |
|     |                           | Table 3-2: PCIe Completer Request Interface Port Descriptions    | 16 |
|     | 3.2.2                     | PCIe Completer Completion (CC) Interface                         | 17 |
|     |                           | Table 3-3: PCIe Completer Completion Interface Port Descriptions | 17 |
| 3.3 | I/O Sig                   | nals                                                             | 19 |
|     | Table 3                   | 3-4: I/O Signals                                                 | 19 |

# Table of Contents

### Page

## Chapter 4: Designing with the Core

| 4.1 | General Design Guidelines                                          |    |  |  |
|-----|--------------------------------------------------------------------|----|--|--|
|     | 4.1.1 Address Translation                                          |    |  |  |
|     | Figure 4-1: PCI Express to AXI4-Lite Bridge Core Interface Example |    |  |  |
| 4.2 | Clocking                                                           |    |  |  |
| 4.3 | Resets                                                             |    |  |  |
| 4.4 | Interrupts                                                         |    |  |  |
| 4.5 | •                                                                  |    |  |  |
| 4.6 | Programming Sequence                                               |    |  |  |
| 4.7 | Timing Diagrams                                                    |    |  |  |
|     | Figure 4-2: PCI Express to AXI4-Lite Bridge Core- Write Operation  |    |  |  |
|     | Figure 4-3: PCI Express to AXI4-Lite Bridge Core- Read Operation   | 24 |  |  |

### Chapter 5: Design Flow Steps

|     | Figure 5-1: PCI Express to AXI4-Lite Bridge Core in Pentek IP Catalog         | 25 |
|-----|-------------------------------------------------------------------------------|----|
|     | Figure 5-2: PCI Express to AXI4-Lite Bridge Core IP Symbol                    |    |
| 5.2 | User Parameters                                                               |    |
| 5.3 | Generating Output                                                             |    |
| 5.4 | Constraining the Core                                                         | 27 |
| 5.5 | Simulation                                                                    |    |
|     | Figure 5-3: PCI Express to AXI4-Lite Bridge Core Test Bench Simulation Output |    |
| 5.6 | Synthesis and Implementation                                                  | 29 |

## **IP** Facts

### Description

Pentek's Navigator<sup>TM</sup> PCI Express (PCIe<sup>®</sup>) to AXI4-Lite Bridge Core serves as a bridge between the Completer Interfaces of the Xilinx<sup>®</sup> Gen3 Integrated Block for PCI Express IP Core and an AXI4-Lite Interface.

This core complies with the ARM<sup>®</sup> AMBA<sup>®</sup> AXI4 Specification. This user manual defines the hardware interface, software interface, and parameterization options for the PCI Express to AXI4-Lite Bridge Core.

### Features

- One dword memory read and write requests
- Five 32-bit Base Address Registers (BARs)
- Address Translation from Transaction Layer Packet (TLP) header address to AXI4 addressing
- Supports address-aligned mode only
- Supports shutdown of completer completion interface and ensures data transfer is completed before shutdown

| Table 1-1: IP Facts Table                 |                                                     |  |  |  |
|-------------------------------------------|-----------------------------------------------------|--|--|--|
| Core Specifics                            |                                                     |  |  |  |
| Supported Design<br>Family <sup>a</sup>   | Kintex <sup>®</sup> Ultrascale                      |  |  |  |
| Supported User<br>Interfaces              | AXI4-Lite and AXI4-<br>Stream                       |  |  |  |
| Resources                                 | See Table 2-1                                       |  |  |  |
| Provided with the Core                    |                                                     |  |  |  |
| 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                   | N/A                                                 |  |  |  |
| 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 Xilinx Gen3 Integrated Block for PCI Express IP Core provides only AXI4-Stream user interfaces, and requires a bridge to access the AXI4-Lite Interface compliant cores. The PCIe to AXI4-Lite Bridge Core is used to serve this purpose, and uses only the Completer Request (CQ) and Completer Completion (CC) Interfaces of the Xilinx PCIe Core.

The Completer Request (m\_axis\_cq) and Completer Completion (s\_axis\_cc) Interfaces of the Xilinx PCIe Core are connected to the Completer Request (s\_axis\_cq) and Completer Completion (m\_axis\_cc) Interfaces of the PCIe to AXI4-Lite Bridge Core, respectively. The CQ interface (m\_axis\_cq) of the Xilinx PCIe Core provides memory read and write requests from the PCIe host, which are decoded by the PCIe to AXI4-Lite Bridge Core, and translated to the AXI4-Lite Master Interface. Memory write requests from the host are translated to the AXI4-Lite Write Address Channel and Write Data Channel transactions. Memory read requests from the host are translated to the AXI4-Lite Read Address Channel and Read Data channel transactions. A completion TLP is created on the CC Interface (m\_axis\_cc) of the PCIe to AXI4-Lite Bridge Core with the payload received from the target AXI4-Lite Slave on the Read Data channel.

Figure 1-1 shows the CC and CQ interface connections from the Xilinx PCIe Core to the PCIe to AXI4-Lite Bridge Core, using Vivado IP Integrator.



### Figure 1-1: PCI Express to AXI4-Lite Bridge Core Interfaces

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

Figure 1-1 shows an example application for the PCIe to AXI4-Lite Bridge core. The Completer Interfaces of the Xilinx PCIe Core are connected to the Pentek AXI I2C Bus Interface Core through the PCIe to AXI4-Lite Bridge Core, for accessing the I2C Bus from the PCIe Link.





### 1.2 Applications

The PCIe to AXI4-Lite Bridge Core can be used to connect the Completer Interfaces of the Xilinx Gen3 Integrated Block for PCI Express IP Core to any AXI4-Lite Interface compliant 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 Gen 3 Integrated Block for PCI Express IP Core

This page is intentionally blank

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

### 2.1 Standards

The PCI Express to AXI4-Lite Bridge Core has bus interfaces that comply with the *ARM AMBA AXI4-Lite Protocol Specification* and the *AMBA AXI4-Stream Protocol Specification*.

### 2.2 Performance

The performance of the PCIe to AXI4-lite Bridge 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 to AXI4-lite Bridge 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 PCI Express to AXI4-Lite Bridge 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                                       | 441    |  |  |
| Flip-Flops                                 | 601    |  |  |

**NOTE:** Actual utilization may vary based on the user design in which the PCIe to AXI4-lite Bridge Core is incorporated.

### 2.4 Limitations and Unsupported Features

- The PCIe to AXI4-Lite Bridge Core does not support the Requester Interfaces of the Xilinx PCIe Core.
- This core does not support 64-bit AXI4-Lite Interfaces.
- This core supports only 256-bit address-aligned mode of the Xilinx PCIe Core.

### 2.5 Generic Parameters

The generic parameters of the PCI Express to AXI4-Lite Bridge 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_addr_bits                 | Integers             | <b>Number of Address Bits:</b> This parameter defines the address width of the AXI4-Lite Slave Interface for both read and write channels. It can range from 3 to 32. |  |
| bar0_size_bits                |                      | <b>BARx Address Size Bits:</b> The number of bits required to access the BARx address space where $x = 0,1,2,3,4,5$ .                                                 |  |
| bar1_size_bits                |                      | access the DATX address space where $x = 0, 1, 2, 3, 4, 3$ .                                                                                                          |  |
| bar2_size_bits                | -                    |                                                                                                                                                                       |  |
| bar3_size_bits                |                      |                                                                                                                                                                       |  |
| bar4_size_bits                |                      |                                                                                                                                                                       |  |
| bar5_size_bits                |                      |                                                                                                                                                                       |  |
| bar0_addr_translation         | std_logic_<br>vector | <b>BARx Address Translation:</b> Base address from where the BARx address from the TLP will translate to an AXI4 Address                                              |  |
| bar1_addr_translation         | VECIOI               | where $x = 0, 1, 2, 3, 4, 5$ .                                                                                                                                        |  |
| bar2_addr_translation         | -                    |                                                                                                                                                                       |  |
| bar3_addr_translation         |                      |                                                                                                                                                                       |  |
| bar4_addr_translation         |                      |                                                                                                                                                                       |  |
| bar5_addr_translation         |                      |                                                                                                                                                                       |  |

## **Chapter 3: Port Descriptions**

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

- AXI4-Lite Core Interfaces
- AXI4-Stream Core Interfaces
- I/O Signals

### 3.1 AXI4-Lite Core Interfaces

The PCI Express to AXI4-Lite Bridge Core has a 32-bit AXI4-Lite Master Interface, used to transfer data from the Completer Interfaces of the Xilinx PCIe Core to target AXI4-Lite Slave Interfaces.

Table 3-1 defines the ports in the AXI4-Lite Master Interface of the PCIe to AXI4-Lite Bridge Core. See the *AMBA AXI4-Lite Specification* for more details on operation of the AXI4-Lite interfaces.

| Table 3-1: AXI4-Lite Interface Port Descriptions |           |                   |                                                                                                                                                                                                                                                                                                     |  |
|--------------------------------------------------|-----------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Port                                             | Direction | Width             | Description                                                                                                                                                                                                                                                                                         |  |
| m_axi_awaddr                                     | Output    | num_addr_<br>bits | Write Address: Address used for write operations. It<br>must be valid when m_axi_awvalid is asserted and<br>must be held until m_axi_awready is asserted by the<br>slave. The address width is equal to the generic<br>parameter (num_addr_bits) defined by the user while<br>customizing the core. |  |
| m_axi_awprot                                     |           | 3                 | <b>Protection:</b> The PCIe to AXI4-Lite Bridge Core always outputs "000".                                                                                                                                                                                                                          |  |
| m_axi_awvalid                                    |           | 1                 | Write Address Valid: This input must be asserted to indicate that a valid write address is available on <b>m_axi_awaddr</b> . The <b>m_axi_awvalid</b> signal must remain asserted until the rising clock edge after the assertion of <b>m_axi_awready</b> .                                        |  |
| m_axi_awready                                    | Input     |                   | Write Address Ready: This input from the slave<br>indicates the readiness of the slave to accept the write<br>address.The address is latched when <b>m_axi_awvalid</b><br>and <b>m_axi_awready</b> are high on the same cycle.                                                                      |  |

| Table 3-1: AXI4-Lite Interface Port Descriptions (Continued) |           |       |                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|--------------------------------------------------------------|-----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Port                                                         | Direction | Width | Description                                                                                                                                                                                                                                                                                                                                                                                       |  |
| m_axi_wdata                                                  | Output    | 32    | Write Data: This data will be written to the address specified by m_axi_awaddr when m_axi_wvalid and m_axi_wready are both asserted.                                                                                                                                                                                                                                                              |  |
| m_axi_wstrb                                                  |           | 4     | Write Strobes: This signal, when asserted, indicates<br>the number of bytes of valid data on the <b>m_axi_wdata</b><br>signal. Each of these bits, when asserted, indicate that<br>the corresponding byte of <b>m_axi_wdata</b> contains valid<br>data. Bit 0 corresponds to the least significant byte, and<br>bit 3 to the most significant.                                                    |  |
| m_axi_wvalid                                                 |           | 1     | Write Valid: This signal must be asserted to indicate that the write data is valid during the write operation. The value on m_axi_wdata is written into the register at address m_axi_awaddr when m_axi_wready and m_axi_wvalid are high on the same cycle.                                                                                                                                       |  |
| m_axi_wready                                                 | Input     |       | Write Ready: This signal is asserted by the slave when<br>it is ready to accept data. The value on m_axi_wdata is<br>written into the register at address m_axi_awaddr by<br>the core when m_axi_wready and m_axi_wvalid are<br>high on the same cycle, assuming that the address has<br>already or simultaneously been submitted.                                                                |  |
| m_axi_bresp                                                  | Input     | 2     | <ul> <li>Write Response: The slave indicates success or failure of a write transaction through this signal, which is valid when m_axi_bvalid is asserted;</li> <li>00 = Success of normal access</li> <li>01 = Success of exclusive access</li> <li>10 = Slave error</li> <li>11 = Decode error</li> <li>Note: For more details about this signal refer to the AMBA AXI Specification.</li> </ul> |  |
| m_axi_bready                                                 | Output    | 1     | Write Response Ready: This signal is asserted by the PCIe to AXI4-Lite Bridge Core when it is ready to accept the Write Response.                                                                                                                                                                                                                                                                 |  |
| m_axi_bvalid                                                 | Input     |       | Write Response Valid: This signal is asserted by the slave when the write operation is complete and the Write Response is valid. It is held until <b>m_axi_bready</b> is asserted by the PCIe to AXI4-Lite Bridge Core.                                                                                                                                                                           |  |

| Ta            | able 3-1: A) | (I4-Lite Interf | ace Port Descriptions (Continued)                                                                                                                                                                                                                                                                                                                                            |
|---------------|--------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port          | Direction    | Width           | Description                                                                                                                                                                                                                                                                                                                                                                  |
| m_axi_araddr  | Output       | 6               | <b>Read Address:</b> Address used for read operations. It must be valid when <b>m_axi_arvalid</b> is asserted and must be held until <b>m_axi_arready</b> is asserted by the slave.                                                                                                                                                                                          |
| m_axi_arprot  |              | 3               | <b>Protection:</b> These bits are always set to "000" by the PCIe to AXI4-Lite Bridge Core.                                                                                                                                                                                                                                                                                  |
| m_axi_arvalid |              | 1               | <b>Read Address Valid:</b> This input is asserted to indicate that a valid read address is available on <b>m_axi_araddr</b> . The slave asserts <b>m_axi_arready</b> when it is ready to accept the Read Address. The <b>m_axi_arvalid</b> signal must remain asserted until the rising clock edge after the assertion of <b>m_axi_arready</b> .                             |
| m_axi_arready | Input        |                 | <b>Read Address Ready:</b> This output is asserted by the slave when it is ready to accept the read address. The address is latched when <b>m_axi_arvalid</b> and <b>m_axi_arready</b> are high on the same cycle.                                                                                                                                                           |
| m_axi_rdata   |              | 32              | <b>Read Data:</b> This value is the data read from the address specified by the <b>m_axi_araddr</b> when <b>m_axi_arvalid</b> and <b>m_axi_arready</b> are high on the same cycle.                                                                                                                                                                                           |
| m_axi_rresp   |              | 2               | <b>Read Response:</b> The slave indicates success or<br>failure of a read transaction through this signal, which is<br>valid when <b>m_axi_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<br><i>AMBA AXI Specification</i> . |
| m_axi_rvalid  |              | 1               | <b>Read Data Valid:</b> This signal is asserted by the slave<br>when the read is complete and the read data is<br>available on <b>m_axi_rdata</b> . It is held until <b>m_axi_rready</b><br>is asserted by the PCIe to AXI4-Lite Bridge Core.                                                                                                                                |
| m_axi_rready  | Output       |                 | <b>Read Data Ready:</b> This signal is asserted by the PCIe to AXI4-Lite Bridge Core when it is ready to accept the Read Data.                                                                                                                                                                                                                                               |

### **3.2 AXI4-Stream Core Interfaces**

The PCIe to AXI4-Lite Bridge Core has the following types of AXI4-Stream Interfaces, used to transfer and receive data streams.

- PCIe Completer Request (CQ) Interface: The interface through which all the memory read and write requests from the PCIe host are received. This interface is directly compatible with the Xilinx PCIe Core's Completer Request Interface in address-aligned mode.
- PCIe Completer Completion (CC) Interface: The interface through which completion TLPs for the memory read requests are transferred from the user design to the Xilinx PCIe Core. This interface is directly compatible with the Xilinx PCIe Core's Completer Completion Interface in address-aligned mode.

### **3.2.1** PCIe Completer Request (CQ) Interface

The PCIe Completer Request Interface is an AXI4-Stream Slave interface that is used to receive memory read and write requests from the Xilinx PCIe Core.

Table 3-2 defines the ports in the PCIe Completer Request Interface of the PCIe to AXI4-Lite Bridge Core. See the Completer Request section of the *Xilinx Gen3 Integrated Block for PCI Express product guide* for more details.

| Tab              | e 3-2: PCle | e Compl | eter Request Interface Port Descriptions                                                                                                                                                                                                                                                            |
|------------------|-------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port             | Direction   | Width   | Description                                                                                                                                                                                                                                                                                         |
| s_axis_cq_tdata  | Input       | 256     | <b>Completer Request Data Bus:</b> This input contains the completer request data from the Xilinx PCIe Core. It has a fixed width of 256 bits and is therefore only compatible with the 256-bit wide version of the Xilinx PCIe Core. This core assumes the data to be in the address-aligned mode. |
| s_axis_cq_tlast  |             | 1       | <b>TLAST Indication for the Completer Request Data</b> : The Xilinx PCIe Core asserts this signal in the last cycle of a TLP to indicate the end of a packet.                                                                                                                                       |
| s_axis_cq_tvalid |             |         | <b>Completer Request Data Valid:</b> The Xilinx PCIe Core asserts this signal to indicate valid data on the <b>s_axis_cq_tdata</b> bus. The Xilinx PCIe Core keeps this signal High during the transfer of a packet.                                                                                |
| s_axis_cq_tuser  |             | 85      | <b>Completer Request User Data:</b> This signal contains the sideband information for the TLP being received. This signal is valid when <b>s_axis_cq_tvalid</b> is High.                                                                                                                            |

| Table 3-2:       | PCle Com  | pleter R | equest Interface Port Descriptions (Continued)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------|-----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port             | Direction | Width    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| s_axis_cq_tkeep  | Input     | 8        | <b>TKEEP Indication for the Completer Request Data:</b> The assertion of bit <i>i</i> of this bus during a transfer indicates that dword <i>i</i> (in this case a dword is 32 bits) of the <b>s_axis_cq_tdata</b> bus contains valid data. This bit is set to 1 contiguously for all dwords, starting from the first dword of the descriptor to the last dword of the payload. Thus, <b>s_axis_cq_tdata</b> is set to all 1s in all beats of a packet, except in the final beat when the total size of the packet is not a multiple of the width of data bus.                                              |
| s_axis_cq_tready | Output    | 1        | <b>Completer Request Ready:</b> This signal is asserted by the PCIe to AXI4-Lite Bridge Core to indicate that it is ready to accept the data from the Xilinx PCIe Core. Data is received across the interface when both <b>s_axis_cq_tready</b> and <b>s_axis_cq_tready</b> and <b>s_axis_cq_traid</b> are High on the same cycle. If the PCIe to AXI4-Lite Bridge Core deasserts the ready signal when <b>s_axis_cq_tvalid</b> is High, the Xilinx PCIe Core completer request interface maintains the data on the bus and keeps the valid signal asserted until this core has asserted the ready signal. |

### **3.2.2** PCIe Completer Completion (CC) Interface

The PCIe Completer Completion Interface is an AXI4-Stream Master Interface that is used to send completer memory read completions to the Xilinx PCIe Core.

Table 3-3 defines the ports in the PCIe Completer Completion Interface of the PCIe to AXI4-Lite Bridge Core. See the Completer Completion section of the *Xilinx Gen3 Integrated Block for PCI Express product guide* for more details.

| Table           | 3-3: PCle ( | Complet     | ter Completion Interface Port Descriptions                                                                                                                                                                                                                                                               |
|-----------------|-------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port            | Direction   | Description |                                                                                                                                                                                                                                                                                                          |
| m_axis_cc_tdata | Output      | 256         | <b>Completer Completion Data Bus:</b> This is the Completer completion data from the PCIe to AXI4-Lite Bridge Core to the Xilinx PCIe Core. It has a fixed width of 256 bits and therefore it is compatible only with the 256-bit wide version of the Xilinx PCIe Core and assumes address-aligned mode. |
| m_axis_cc_tlast |             | 1           | <b>TLAST Indication for the Completer Completion Data:</b> The PCIe to AXI4-Lite Bridge Core asserts this signal in the last cycle of a TLP to indicate the end of a packet.                                                                                                                             |

| Table 3-3: P     | Cle Compl | eter Co | mpletion Interface Port Descriptions (Continued)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------|-----------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port             | Direction | Width   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| m_axis_cc_tvalid | Output    | 1       | <b>Completer Completion Data Valid:</b> The PCIe to AXI4-Lite<br>Bridge Core asserts this signal to indicate valid data on the<br><b>m_axis_cc_tdata</b> bus. This signal is kept High during the<br>transfer of a packet.                                                                                                                                                                                                                                                                                                                                                                  |
| m_axis_cc_tuser  |           | 33      | <b>Completer Completion User Data:</b> This signal contains the sideband information for the TLP being transferred. This signal is valid when <b>m_axis_cc_tvalid</b> is High.                                                                                                                                                                                                                                                                                                                                                                                                              |
| m_axis_cc_tkeep  |           | 8       | <b>TKEEP Indication for the Completer Completion Data:</b> The assertion of bit <i>i</i> of this bus during a transfer indicates that dword <i>i</i> (in this case a dword is 32 bits) of the <b>m_axis_cc_</b><br><b>tdata</b> bus contains valid data. This bit is set to 1 contiguously for all dwords, starting from the first dword of the descriptor to the last dword of the payload. Thus, <b>m_axis_cc_tdata</b> is set to all 1s in all beats of a packet, except in the final beat when the total size of the packet is not a multiple of the width of the data bus.             |
| m_axis_cc_tready | Input     | 4       | <b>Completer Completion Ready:</b> This signal is asserted by the Xilinx PCIe Core to indicate that it is ready to accept the data. Data is transferred across the interface when both <b>m_axis_cc_tready</b> and <b>m_axis_cc_tvalid</b> are High on the same cycle. If the Xilinx PCIe Core deasserts the ready signal when <b>m_axis_cc_tvalid</b> is High, the PCIe to AXI4-Lite Bridge Core maintains the data on the bus and keeps the valid signal asserted, but data transfers are held off until the Xilinx PCIe core has re-asserted the ready signal, and transfers may resume. |

## 3.3 I/O Signals

The I/O port/signal descriptions of the top level module of the PCI Express to AXI4-Lite Bridge Core are discussed in Table 3-4.

|                   |           | Table     | 3-4: I/O Signals                                                                                                                                                                                                                 |
|-------------------|-----------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port/ Signal Name | Туре      | Direction | Description                                                                                                                                                                                                                      |
| user_clk          | std_logic | Input     | User Clock (250 MHz): Connect to the user_clk of the Xilinx PCIe Core.                                                                                                                                                           |
| user_reset        |           |           | Reset: Active High. Synchronous with user_clk.                                                                                                                                                                                   |
| user_Ink_up       |           |           | Link Status: Active High. Indicates whether the Xilinx PCIe Core is linked up with a host device.                                                                                                                                |
| aresetn           |           | Output    | <b>Reset:</b> Active low. This reset is defined based on<br>user_reset and user_Ink_up. It is held Low until<br>user_reset is deasserted, and user_Ink_up is asserted.                                                           |
| cc_shutdown_rqst  |           | Input     | Completer Completion Interface Shutdown Request:<br>Active High.                                                                                                                                                                 |
| cc_shutdown_ok    |           | Output    | <b>Completer Completion Interface Shutdown OK:</b> Active High. Indicates the response for a shutdown request. The PCIe to AXI4-Lite Bridge Core asserts this signal when all the current transactions in progress are complete. |

This page is intentionally blank

## Chapter 4: Designing with the Core

This chapter includes guidelines and additional information to facilitate designing with the PCI Express to AXI4-Lite Bridge Core.

### 4.1 General Design Guidelines

The PCIe to AXI4-Lite Bridge Core provides the required logic to bridge the CC and CQ Interfaces of the Xilinx PCIe Core to the AXI4-Lite Interface. The user can customize the PCIe to AXI4-Lite Bridge Core by defining the generic parameters as described in Section 2.5. The data width of the AXI4-Lite Master Interface is fixed to 32 bits, and the data width of the CC and CQ interfaces is fixed to 256 bits. The data width of the AXI4-Stream interfaces of the PCIe to AXI4-Lite Bridge Core must match the CC and CQ interfaces' data widths of the Xilinx PCIe Core.

The PCIe to AXI4-Lite Bridge Core responds with Unsupported Request (UR) status for an unsupported request received on the Completer Request Interface from the Xilinx PCIe Core. It responds with a three-dword completion descriptor followed by the request that generated the completion. For more details on unsupported requests please refer to the *Xilinx Gen3 Integrated Block for PCI Express product guide*.

### 4.1.1 Address Translation

The address from the TLP is provided in the CQ descriptor from the Xilinx PCIe Core. The address is provided in the dwords 0 and 1 as shown in the Figure 4-1. The address provided in the descriptor comes directly from the PCI Express TLP.

The address translation takes place based on the generic parameters defined by the user. The BAR address translation value provides the Base Address from where a BAR hit will translate, in the AXI4-Lite address space. The address size defined by the **num\_addr\_bits** generic parameter determines the address width of the AXI4-Lite Interface. The BAR address size is used to mask the additional bits of the TLP address to match the address width defined by the **num\_addr\_bits** parameter. The resultant address is thus determined using the masked address and the BAR address translation.

## Page 22

## 4.1 General Design Guidelines (continued)

### 4.1.1 Address Translation (continued)

### Figure 4-1: PCI Express to AXI4-Lite Bridge Core Interface Example



### 4.2 Clocking

### Main Clock: user\_clk

The 250 MHz user clock is used to clock all the ports on the PCIe to AXI4-Lite Bridge Core.

### 4.3 Resets

### Main reset: user\_reset

This is a synchronous reset associated with the **user\_clk**. This reset along with the **user\_lnk\_up** is used to derive the reset for the PCIe to AXI4-Lite Bridge Core.

### 4.4 Interrupts

This section is not applicable to this IP core.

### 4.5 Interface Operation

**AXI4-Lite Interface:** This core includes an AXI4-Lite Master interface which is described in **Section 3.1**.

**PCIe Completer Request Interface:** This interface is associated with the **user\_clk**. It is an AXI4-Stream Slave Interface directly compatible with the Xilinx PCIe Core's Completer Request Bus when the Xilinx PCIe Core is set up in the address-aligned mode with a 256-bit wide data bus. For details about this interface's bit definitions refer to Section 3.2.1.

**PCIe Completer Completion Interface:** This interface is associated with the user\_clk. It is an AXI4-Stream Master Interface directly compatible with the Xilinx PCIe core's Completer Completion Bus when the Xilinx PCIe Core is set up in the address-aligned mode with a 256-bit wide data bus. For details about this interface's bit definitions refer to Section 3.2.2.

### 4.6 **Programming Sequence**

This section is not applicable to this IP core.

### 4.7 Timing Diagrams

The timing diagrams for the PCI Express to AXI4-Lite Bridge Core are obtained by running the simulation of the test bench for the core in Vivado VSim environment. These timing diagrams depict the functionality of the core for memory read and write operations. A detailed explanation of the test bench is in Section 5.5 of this user manual. The Figures 4-2 and 4-3 show the write and read operation timing respectively.

| Name                       | Value                                   | 0 ns       |               | 2    | 0 ns |       |      | 40 n |       |       | 60 3 | ns .  |       | 80 n | s .   |                   | 100 r | <b>15</b> . |    | 120 | ns .  |          | 140 | ns      |
|----------------------------|-----------------------------------------|------------|---------------|------|------|-------|------|------|-------|-------|------|-------|-------|------|-------|-------------------|-------|-------------|----|-----|-------|----------|-----|---------|
| 1∰ user_dk                 | 0                                       | <b>T</b> T | ττ            | ίĦ   | ΠĒ   | ίŤ    | п'n  | Ħ    | ΗĤ    | ΠŤ    | tt   | ПГ    |       | h    | пh    | ΠÌ                |       | tt          | ΠĒ | h   | ΗÌ    | ίij      | Ť   | nni     |
| 🐚 aresetn                  | 1                                       |            | and the state | -    |      |       |      |      |       |       |      |       |       |      |       | The second second |       |             |    |     |       |          |     |         |
| ₩ cc_shutdown_ok           | 0                                       |            |               |      |      |       |      |      |       |       |      |       |       |      |       |                   |       |             |    |     |       |          |     |         |
| 🛛 📲 s_axis_cq_tdata[255:0] | 000000000000000000000000000000000000000 |            | (             | 0000 | 0000 | 00000 | 0000 | 0000 | 00000 | 00000 | 0000 | 00000 | 00000 | 0000 | 00000 | 00000             | 000   |             | X  |     | 0)    | 00000    | 000 | 0000000 |
| 🖬 📲 s_axis_cq_tuser[84:0]  | 00000000000100000000000000000000000000  |            |               |      |      |       |      | 0(   | 00000 | 00000 | 0000 | 00000 | 00    |      |       |                   |       |             |    | Εx  | 00_ ) |          |     |         |
| 14 s_axis_cq_tlast         | 1                                       |            |               |      |      |       |      |      |       |       |      |       |       |      |       |                   |       |             |    |     |       | 1        |     |         |
| 🖬 📲 s_axis_cq_tkeep[7:0]   | ff                                      |            |               |      |      |       |      |      |       | 0     | φ.   |       |       |      |       |                   |       |             | X  | ٢x. | X     |          |     | f       |
| 1 s_axis_cq_tvalid         | 1                                       |            |               |      |      |       |      |      |       |       |      |       |       |      |       |                   |       |             |    |     |       |          |     |         |
| 🍇 s_axis_cq_tready         | 0                                       |            |               |      |      |       |      |      |       |       |      |       |       |      |       |                   |       |             |    |     | 1     |          |     |         |
| 🖬 📲 m_axi_awaddr(31:0)     | 0000000                                 |            |               |      |      |       |      |      |       |       | 0000 | υυυυ  |       |      |       |                   |       |             |    |     |       |          |     |         |
| 🖬 📲 m_axi_awprot[2:0]      | 0                                       |            |               |      |      |       |      |      |       |       |      |       |       |      |       |                   |       |             |    |     | 0     |          |     |         |
| 🕼 m_axi_awvalid            | 0                                       |            |               |      |      |       |      |      |       |       |      |       |       |      |       |                   |       |             |    |     | -     |          |     |         |
| ¼ m_axi_awready            | 0                                       |            |               |      |      |       |      | 8    |       |       | -    |       |       |      |       |                   |       |             |    |     |       |          |     |         |
| 🖬 💐 m_axi_wdata[31:0]      | 12345678                                |            |               |      |      |       |      | i.   |       |       | φυυυ | υυυυ  |       |      |       |                   |       |             |    |     |       |          |     |         |
| 🗉 📲 m_axi_wstrb[3:0]       | f                                       |            |               |      |      |       |      |      |       |       | τ    | l     |       |      |       |                   |       |             |    |     |       |          |     |         |
| ₩ m_axi_wvalid             | 0                                       |            |               |      |      |       |      |      |       |       |      |       |       |      |       | _                 | _     |             |    |     | _     |          |     |         |
| 🎼 m_axi_wready             | 0                                       |            |               |      |      |       |      |      |       |       | _    |       |       |      |       |                   |       |             |    |     |       | <u> </u> |     |         |
| 🖬 📲 m_axi_bresp[1:0]       | 0                                       |            |               |      |      |       |      |      |       |       |      | U     |       |      |       |                   |       |             |    |     |       |          | X   |         |
| 🗤 m_axi_bvalid             | 1                                       |            |               |      |      |       |      |      |       | _     |      |       |       |      |       |                   |       |             |    |     |       |          |     |         |
| 👍 m_axi_bready             | 1                                       |            |               |      |      |       |      | _    |       |       |      |       |       |      |       |                   |       |             |    |     |       |          |     | 1       |

Figure 4-2: PCI Express to AXI4-Lite Bridge Core- Write Operation

## 4.7 Timing Diagrams (continued)



Figure 4-3: PCI Express to AXI4-Lite Bridge Core- Read Operation

## Chapter 5: Design Flow Steps

### 5.1 Pentek IP Catalog

This chapter describes customization and generation of the Pentek PCI Express to AXI4-Lite Bridge 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\_pcie2axil\_v1\_0** as shown in Figure 5-1.

| Cores In     | terfaces                             | Search: Q-          |            |           |
|--------------|--------------------------------------|---------------------|------------|-----------|
| Name         | ~1                                   | AXI4                | Status     | License   |
| 2   -        | px_dma_ppkt2pcie_v0_01               | AXI4, AXI4-Stream   | Production | Include A |
|              | <pre>px_dma_ppkt2pcie_v1_0</pre>     | AXI4, AXI4-Stream   | Production | Include   |
|              | <pre></pre>                          | AXI4                | Production | Include   |
|              | px_lvl_trans_xck_v1_0                |                     | Production | Include   |
|              | <pre>px_pcie2axil_v1_0</pre>         | AXI4, AXI4-Stream   | Production | Include   |
|              | px_pcie3_cfg_ctl_v1_0                |                     | Production | Include   |
|              | px_pcie_irq_ctlr_v1_0                | AXI4                | Production | Include   |
| 9 W          | • px_pcie_link_stat_v1_0             | AXI4-Stream         | Production | Include   |
|              | • px_pcie_rqrc_gskt_v1_0             | AXI4-Stream         | Production | Include V |
| •            |                                      |                     |            | >         |
| etails       |                                      |                     |            |           |
| Name:        | px_pcie2axil_v1_0                    |                     |            | ^         |
| Version:     | 1.0 (Rev. 30)                        |                     |            |           |
| Interfaces:  | AXI4, AXI4-Stream                    |                     |            |           |
| Description: | PCI Express to AXI4-Lite Bridge (Add | dress Aligned Mode) |            |           |
| Status:      | Production                           |                     |            |           |
| License:     | Included                             |                     |            |           |
| Change Log:  | View Change Log                      |                     |            |           |
| Vendor:      | Pentek, Inc.                         |                     |            | ~         |

Figure 5-1: PCI Express to AXI4-Lite Bridge Core in Pentek IP Catalog

### 5.1 Pentek IP Catalog (continued)

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

| Customize IP                                     |                                                                                                 |               | ×          |
|--------------------------------------------------|-------------------------------------------------------------------------------------------------|---------------|------------|
| px_pcie2axil_v1_0 (1.0)                          |                                                                                                 |               | 1          |
| Documentation 📄 IP Location 🧔 Switch to Defaults |                                                                                                 |               |            |
| Show disabled ports                              | Component Name px_pcie2axil_0                                                                   |               | 0          |
|                                                  | This Core Is Compatible with the Ger<br>set to 256-bit AXI-S interface and Av<br>Mode Selected. |               |            |
|                                                  | Number of Address Bits                                                                          | 28 📀          | ] [3 - 32] |
|                                                  | Bar 0 AXI Address Translation                                                                   | 0x0000000 (i) |            |
|                                                  | Bar 0 Size (Number of Address Bits)                                                             | 16 🕓          | [3 - 32]   |
|                                                  | Bar 1 AXI Address Translation                                                                   | 0x10000000 🛞  |            |
| 금                                                | Bar 1 Size (Number of Address Bits)                                                             | 16 🛞          | [3 - 32]   |
| user_reset m_axis_cc 中<br>aresetno               | Bar 2 AXI Address Translation                                                                   | 0x20000000 🛞  |            |
| user_Ink_up                                      | Bar 2 Size (Number of Address Bits)                                                             | 16 (          | [3 - 32]   |
| cc_shutdown_rqst                                 | Bar3 AXI Address Translation                                                                    | 0x30000000 🛞  |            |
|                                                  | Bar 3 Size (Number of Address Bits)                                                             | 16 🕓          | [3 - 32]   |
|                                                  | Bar 4 AXI Address Translation                                                                   | 0x40000000 🛞  |            |
|                                                  | Bar 4 Size (Number of Address Bits)                                                             | 16 🕓          | [3 - 32]   |
|                                                  | Bar 5 AXI Address Translation                                                                   | 0x5000000 🛞   |            |
|                                                  | Bar 5 Size (Number of Address Bits)                                                             | 16 🔕          | ] [3 - 32] |
|                                                  | <                                                                                               |               | >          |
|                                                  |                                                                                                 | ОК            | Cancel     |

### Figure 5-2: PCI Express to AXI4-Lite Bridge Core IP Symbol

## 5.2 User Parameters

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

### 5.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*.

### 5.4 Constraining the Core

This section contains information about constraining the PCI Express to AXI4-Lite Bridge Core in Vivado Design Suite.

#### **Required Constraints**

The XDC constraints are not provided with the PCI Express to AXI4-Lite Bridge 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 FPGAs.

#### **Clock Frequencies**

The clock frequency (user\_clk) 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.

### 5.5 Simulation

The PCI Express to AXI4-Lite Bridge Core has a test bench which generates the output waveforms using the Vivado VSim environment.

The test bench is designed to run at 250 MHz input clock frequency. It performs both memory read and memory write operations. The read/write requests from the PCIe host are received across the Completer Request Interface. During write operations, this core writes data to the specified address by translating the write request into AXI4-Lite Interface format. During read operations, this core reads data from the target AXI4-Lite Slave through the AXI4-Lite Master Interface and generates completion packets which are transferred through the Completer Completion Interface to the PCIe host. This testbench performs three write, and three read operations. When run, the simulation produces the results shown in Figure 5-3.

### Figure 5-3: PCI Express to AXI4-Lite Bridge Core Test Bench Simulation Output

|                            |                                         |               |         |                     | 210,00              | 00 ps   |         |         |          |             |
|----------------------------|-----------------------------------------|---------------|---------|---------------------|---------------------|---------|---------|---------|----------|-------------|
| Name                       | Value                                   | 0 ps          | 100,000 | ) <del>ນ</del> ຣ  2 | 00,000              | ່ນຮ     | 300,000 | ) ຫຣ    | 400,000  | ps 500,     |
| ₩ user_dk                  | 1                                       |               |         |                     |                     | Liin    |         | Linn    |          |             |
| U aresetn                  | 1                                       |               | -       |                     |                     |         |         |         |          |             |
| 🌆 cc_shutdown_ok           | 0                                       |               |         |                     |                     |         |         |         |          |             |
| 🖬 📲 s_axis_cq_tdata[255:0] | 000000000000000000000000000000000000000 | 000000000000  | a ) ( o | 000 X 00            | 000 )               | 000     | 0000    | X 0000  | 00000000 | 00000000000 |
| 🖬 📲 s_axis_cq_tuser[84:0]  | 00000000000100000000ff                  | 000000000000  | a. 🖉 o  | 00000000            | 010                 | 000     |         |         | 00       | 00000000001 |
| 🕼 s_axis_cq_tlast          | 0                                       |               |         |                     |                     | 1       | 0       |         |          |             |
| 🖬 💐 s_axis_cq_tkeep[7:0]   | ff                                      | 00            |         | ff 1                | ff )                | ff      | 11      | f f     | X        |             |
| 🕼 s_axis_cq_tvalid         | 1                                       |               |         |                     |                     | 1       |         |         |          |             |
| 🕼 s_axis_cq_tready         | 0                                       | 1             |         | Π                   | L 1                 | 1       | n"      | Π       | П        |             |
| 🛚 🔣 m_axis_cc_tdata[255:0] | 12345678123456781234567                 | 0000000000000 | 0000000 | 000000 )            | 0000                | 0000000 | 0000000 | 000 🖹   | 0000     | 0 0000000   |
| 🗄 📲 m_axis_cc_tuser[32:0]  | 000000000                               | k             |         |                     |                     |         | 00      | 0000000 |          |             |
| 🕼 m_axis_cc_tlast          | 1                                       |               |         |                     | 1                   |         |         | n       |          | 0           |
| 🖬 📲 m_axis_cc_tkeep[7:0]   | 01                                      | K             | ff      |                     | $\overline{\alpha}$ |         | f f     | X       | (ff)     |             |
| 🌆 m_axis_cc_tvalid         | 1                                       | 1             |         |                     | 1                   |         |         | Î       |          |             |
| 🖬 📲 m_axis_cc_tready[3:0]  | f                                       |               |         |                     |                     |         |         | f       |          |             |
| 🖬 💐 m_axi_awaddr[31:0]     | 00000000                                | 00000000      | X       | 000000              | 00                  | X 0000  | hχ=     |         |          | 00000       |
| 🖬 📲 m_axi_awprot[2:0]      | 0                                       |               |         |                     |                     |         |         | 0       |          |             |
| 🗤 m_axi_awvalid            | 0                                       |               |         |                     |                     |         |         |         |          |             |
| 🌆 m_axi_awready            | 0                                       |               | 1       |                     |                     | 1       | 1       |         |          |             |
| 🖬 📲 m_axi_wdata[31:0]      | 12345678                                | 0000000       | X       | 123455              | 8                   | X 8765  | X       |         |          | a5a5a       |
| 🖬 💐 m_axi_wstrb[3:0]       | f                                       | U             | Fr      |                     |                     |         |         |         | f        |             |
| 🕼 m_axi_wvalid             | 0                                       |               |         |                     |                     |         |         |         | 1        |             |
| 🗤 m_axi_wready             | 0                                       |               | 1       |                     |                     | 1       | 1       |         |          |             |
| 🖬 📲 m_axi_bresp[1:0]       | 0                                       | U             | τ X     |                     |                     |         | -       |         | 0        |             |
| 🕼 m_axi_bvalid             | 0                                       |               | 1 î     |                     |                     | П       | П       |         |          |             |
| 1 m_axi_bready             | 0                                       |               | 1       |                     |                     | n       | n       |         |          |             |
| m_axi_araddr[31:0]         | 00000000                                | 00000         | 000     | X                   |                     | 0000000 |         | X 0000  | 0020 X   |             |
| m_axi_arprot[2:0]          | 0                                       | k             |         | $\rightarrow$       |                     |         |         | 0       |          |             |
| 1/2 m_axi_arvalid          | 0                                       |               |         |                     |                     |         |         |         |          |             |
| 1 m_axi_arready            | 0                                       |               |         | 1                   |                     |         |         | 1       |          |             |
| m_axi_rdata[31:0]          | 12345678                                |               | 00000   |                     |                     | 123456  | 78      | 711     | 111111X  |             |
| m_axi_rresp[1:0]           | 0                                       |               | u       |                     |                     |         |         |         |          | 0           |
| W m_axi_rvalid             | 0                                       |               |         |                     |                     |         |         | П       | П        |             |
| 1 m_axi_rready             | 0                                       |               |         |                     |                     |         |         |         |          |             |

## 5.6 Synthesis and Implementation

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

This page is intentionally blank