# LogiCORE IP AXI External Peripheral Controller (EPC) (v1.00.a)

DS809 July 25, 2012

**Product Specification** 

# Introduction

This specification defines the architecture and interface requirements for the Xilinx<sup>®</sup> LogiCORE<sup>TM</sup> IP External Peripheral Controller (AXI EPC IP Core). The controller supports data transfers between the AXI4 (Advanced eXtensible Interface) and the external synchronous and/or asynchronous peripheral devices such as USB and LAN devices, which have processor interface.

Examples of peripheral devices supported by the AXI EPC include the 10/100 non-PCI Ethernet single chip (SMSC LAN91C111) from SMSC and CY7C67300 USB Controller from Cypress Semiconductor devices.

## **Features**

- Connects as a 32-bit slave on AXI4-Lite Slave
- Byte enable support
- Parameterized support of up to four external peripheral devices with each device configured with separate base address and high address range
- Supports both synchronous and asynchronous access modes of peripheral devices with the support for a separate clock domain for synchronous peripheral devices
- Supports both multiplexed and non-multiplexed address and data buses
- The data width of peripheral devices is independently configured to 8-bit, 16-bit or 32-bit with the provision to enable data width matching when the AXI data width is greater than that of peripheral device
- Configurable timing parameters for peripheral bus interface
- Tested with the SMSC LAN91C111 and the Cypress CY7C67300 USB Controller device

| Lo                                                           | LogiCORE IP Facts Table                                                                                                                                                                                                             |  |  |  |  |
|--------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                                                              | Core Specifics                                                                                                                                                                                                                      |  |  |  |  |
| Supported Device<br>Family <sup>(1)</sup>                    | Zynq <sup>™</sup> -7000 <sup>(2)</sup> , Virtex <sup>®</sup> -7 <sup>(3)</sup> , Kintex <sup>™</sup> -7 <sup>(3)</sup> ,<br>Artix <sup>™</sup> -7 <sup>(3)</sup> , Virtex-6 <sup>(4)</sup> , Spartan <sup>®</sup> -6 <sup>(5)</sup> |  |  |  |  |
| Supported User<br>Interface                                  | AXI4-Lite                                                                                                                                                                                                                           |  |  |  |  |
| Resources                                                    | See Table 5 through Table 9                                                                                                                                                                                                         |  |  |  |  |
|                                                              | Provided with Core                                                                                                                                                                                                                  |  |  |  |  |
| Design File                                                  | ISE®: VHDL<br>Vivado™: RTL                                                                                                                                                                                                          |  |  |  |  |
| Example Design                                               | Not Provided                                                                                                                                                                                                                        |  |  |  |  |
| Test Bench                                                   | Not Provided                                                                                                                                                                                                                        |  |  |  |  |
| Constraints File                                             | None                                                                                                                                                                                                                                |  |  |  |  |
| Simulation Model                                             | None                                                                                                                                                                                                                                |  |  |  |  |
| Supported S/W<br>Driver                                      | N/A                                                                                                                                                                                                                                 |  |  |  |  |
| Т                                                            | ested Design Flows <sup>(6)</sup>                                                                                                                                                                                                   |  |  |  |  |
| Design Entry                                                 | Xilinx Platform Studio (XPS)<br>Vivado Design Suite <sup>(7)</sup>                                                                                                                                                                  |  |  |  |  |
| Simulation                                                   | Mentor Graphics ModelSim                                                                                                                                                                                                            |  |  |  |  |
| Synthesis Xilinx Synthesis Technology (XS<br>Vivado Synthesi |                                                                                                                                                                                                                                     |  |  |  |  |
| Support                                                      |                                                                                                                                                                                                                                     |  |  |  |  |
| Provided by Xilinx@ www.xilinx.com/support                   |                                                                                                                                                                                                                                     |  |  |  |  |

#### Notes:

- 1. For a complete list of supported derivative devices, see the Embedded Edition Derivative Device Support.
- Supported in ISE Design Suite implementations only.
   For more information on the 7 series devices, see the
- 7 Series FPGAs Overview [Ref 6].
  4. For more information on the Virtex-6 devices, see the
- For more information on the virtex-6 devices, see the Virtex-6 Family Overview [Ref 5].
- 5. For more information on the Spartan-6 devices, see the *Spartan-6 Family Overview* [Ref 4].
- 6. For the supported versions of the tools, see the <u>Xilinx</u> <u>Design Tools: Release Notes Guide</u>.
- 7. Supports only 7 series devices.

<sup>©</sup> Copyright 2011–2012 Xilinx, Inc. Xilinx, the Xilinx logo, Artix, ISE, Kintex, Spartan, Virtex, Vivado, Zynq, and other designated brands included herein are trademarks of Xilinx in the United States and other countries. All other trademarks are the property of their respective owners.

# **Functional Description**

The AXI External Peripheral Controller (AXI EPC) interface diagram shown in Figure 1 depicts the overall interfaces of the core design.



Figure 1: AXI EPC Interface Diagram

The AXI EPC IP Core design provides a general purpose interface to external peripheral devices and the AXI4. It is a AXI4 slave device. The AXI EPC IP Core can be configured to provide support for multiple external peripherals (non-memory peripherals like USB, LAN, and so on) up to a maximum of four devices and each device is independently configured to respond either in synchronous or in asynchronous mode. The timing parameters governing the access cycles such as setup/hold time, cycle access time, and cycle recovery time are configured by the user. It receives read or write operation commands from the AXI4 and generates a corresponding access cycle to one of the four peripheral devices. Xilinx recommends that peripherals such as LAN and USB, which have embedded interfaces, be used with the core.

The AXI EPC IP Core is comprised of the following modules:

- AXI4-Lite Interface Module
- EPC CORE

## **AXI4-Lite Interface Module**

The AXI4-Lite Interface Module provides an interface between the EPC CORE and the AXI4. The AXI4-Lite interface module implements the basic functionality of the AXI4 interface operation and performs the necessary protocol and timing translation between the AXI4 and the IPIC interface.

## **EPC CORE**

The EPC CORE provides an interface between the IPIC interface and the external peripheral devices. The EPC CORE consists of the logic necessary to convert the access cycles on the IPIC interface to the corresponding access cycles on the peripheral bus adhering to the device specific timing parameters.

The block diagram for the AXI EPC is shown in Figure 2.



Figure 2: AXI EPC Block Diagram

The AXI EPC core consists of the following:

- AXI4-Lite Interface Module Provides the address decoding logic and necessary interface between AXI4 and EPC core signals
- IPIC IF Decode Module Provides decoding of IPIC signals of AXI4-Lite Interface Module and synchronization of control signals
- Sync Control Module Implements the state machine which controls the synchronous interface
- Async Control Module Implements the state machine which controls the asynchronous interface including the asynchronous timing parameters
- Data Steer Module Provides the data bus width matching and data steering logic
- Address Generation Module Provides the generation of the lower address bits
- Access MUX Module Provides the multiplexing of address, data, and other control signals

A detailed description of these modules is provided in the following sections.

#### **IPIC IF Decode Module**

The IPIC IF Decode module implements the interface to the AXI. It also configures the EPC CORE and interfaces to the Async Control module and Sync Control module by driving the necessary control signals based on user parameter settings.

#### Sync Control and Async Control Modules

In Figure 2 the Sync Control and Async Control modules depict the synchronous and asynchronous paths of the EPC CORE. This ensures that the read and write accesses to the external device(s) adheres to the specific timing parameters defined for the external device(s). Implementation of the Sync Control and Async Control modules is dependent on the parameter C\_PRHx\_SYNC. If synchronous and asynchronous external peripheral devices exist simultaneously, both the Sync Control and Async Control modules are implemented.

The Sync Control module operates either on the AXI clock (S\_AXI\_Clk) or on the external peripheral clock (PRH\_Clk) depending on the generic C\_PRH\_CLK\_SUPPORT. If C\_PRH\_CLK\_SUPPORT = 1, then the Sync Control module operates on external device peripheral clock (PRH\_Clk) that is different from the AXI clock. Peripheral clock (PRH\_Clk) frequency should always be less than the AXI clock frequency. If more than one device is synchronous, then the frequency for the PRH\_Clk should be chosen as the minimum of the operating frequencies of those devices. The IPIC control signals that are inputs to the Sync Control module are synchronized to the PRH\_Clk in the IPIC IF Decode module to indicate the start of a transaction. Similarly, the control signals from the Sync Control module to the IPIC interface such as data acknowledge are synchronized to the AXI clock in the IPIC IF Decode module. If C\_PRH\_CLK\_SUPPORT = 0, the Sync Control module operates on the AXI clock and the IPIC Decode module interface does not perform synchronization of control signals.

The Async Control module operates on the AXI clock only. This module generates the control signals to the initiate read and write access cycles to the external peripheral device based on the asynchronous timing parameters set by the user.

#### **Data Steer and Address Generation Modules**

The data bus of the external device must be less than or equal to the AXI data width and can be 8, 16, or 32 bits. When the width of the external peripheral data bus is less than that of AXI and if C\_PRHx\_DWIDTH\_MATCH = 1 for a particular device, then the Data Steer Module generates multiple read or write cycles to the external device to match a single access on the AXI.

To map a single 32-bit AXI access to multiple 8-bit or 16-bit accesses, the lower bits of the address bus are internally generated within the Address Generation module to provide the correct address to the external peripheral device. The address bus increments as each transaction completes.

For example, if the external device is 8 bits wide, four read or write cycles to the device are performed to match a single 32-bit read or write transaction of AXI. For a write cycle, the first byte of the AXI data bus (S\_AXI\_WDATA[7:0]) is presented on the peripheral data bus (PRH\_Data[0:7]). When the external device accepts the transaction, a new write cycle is generated and the second byte of the AXI data bus (S\_AXI\_WDATA[17:8]) is presented on the peripheral data bus (PRH\_Data[0:7]) and so on. When the last byte of the AXI data bus (S\_AXI\_WDATA[17:8]) is accepted by the peripheral, the data acknowledge signal is generated and sent to the AXI4-Lite Interface module to indicate that the access is complete on the peripheral interface.

Similarly, for a read cycle, when the external device indicates it is ready to complete the transaction, the data on the peripheral data bus (PRH\_Data[0:7]) is internally registered as the first byte to be presented to AXI data bus (S\_AXI\_RDATA[7:0]) followed by initiation of new read cycle on the peripheral interface. The second read access on the peripheral data bus (PRH\_Data[0:7]) is internally registered as the second byte to be presented to AXI data

bus (S\_AXI\_RDATA[15:8]) and so on. When all four bytes are read from the external device, an acknowledge is generated to the AXI4-Lite Interface module to indicate that the data is ready to be transferred to AXI data bus.

When support for data width match is enabled for any of the external devices, then the access to that device should respect data alignment that is a half word access should be aligned to a 16-bit boundary and a word access should be aligned to a 32-bit boundary.

#### Access MUX Module

The interface to the external peripherals supports both multiplexed and non-multiplexed address and data bus to the external devices. The Access MUX module controls the multiplexing of the peripheral address and data buses based on the parameter C\_PRHx\_BUS\_MULTIPLEX. If C\_PRHx\_BUS\_MULTIPLEX = 1, the address and the data bus are multiplexed and presented to the corresponding external device on PRH\_Data bus. The address is valid on the PRH\_Data bus as long as the address strobe is active (PRH\_ADS). This access is performed in two phases (address phase and data phase). The data phase is followed by the address phase. If C\_PRHx\_BUS\_MULTIPLEX = 0, the address and data are presented to the device on separate buses (PRH\_Addr bus and PRH\_Data bus) and the access cycle contains only one phase.

# **Design Parameters**

To allow the user to create the AXI EPC that is uniquely tailored for the user's system, certain features can be parameterized in the AXI EPC design. Some of these parameters control the interface to the AXI while others control the interface to the peripheral devices. This allows the user to have a design that utilizes only the minimum resources required by the system and runs at the best possible performance.

The features that are parameterizable in the AXI EPC core are shown in Table 1.

#### **Inferred Parameters**

In addition to the parameters listed in Table 1, there are also parameters that are inferred for each AXI interface in the Embedded Development Kit (EDK) tools. Through the design, these EDK-inferred parameters control the behavior of the AXI Interconnect.

For a complete list of the interconnect settings related to the AXI interface, see DS768, *LogiCORE IP AXI Interconnect Data Sheet*.

| Generic               | Feature/Description     | Parameter Name                           | Allowable Values                 | Default<br>Value | VHDL<br>Type |
|-----------------------|-------------------------|------------------------------------------|----------------------------------|------------------|--------------|
|                       | ·                       | System Paramet                           | er                               |                  |              |
| G1 Target FPGA family |                         | C_FAMILY                                 | Spartan-6, Virtex-6              | Virtex-6         | string       |
|                       |                         | AXI Parameters                           | 5                                |                  |              |
| G2                    | AXI address bus width   | C_S_AXI_ADDR_WIDTH                       | 32                               | 32               | integer      |
| G3                    | AXI data bus width      | C_S_AXI_DATA_WIDTH                       | 32                               | 32               | integer      |
|                       |                         | AXI EPC Interface Par                    | ameters                          |                  |              |
| G4                    | AXI clock period        | C_S_AXI_CLK_PERIOD_<br>PS <sup>(1)</sup> | Integer number of picoseconds    | 10000            | integer      |
| G5                    | Peripheral clock period | C_PRH_CLK_PERIOD_<br>PS <sup>(24)</sup>  | Integer number of<br>picoseconds | 20000            | integer      |

Table 1: AXI EPC IP Core Design Parameters

| Generic Feature/Description |                                                                                                                                  | Parameter Name                                                                                                                                                                                    | Allowable Values                                                                                                                                          | Default<br>Value                       | VHDL<br>Type         |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|----------------------|
| G6                          | Number of peripherals                                                                                                            | C_NUM_PERIPHERALS                                                                                                                                                                                 | 1 to 4                                                                                                                                                    | 1                                      | integer              |
| G7                          | Maximum of address bus<br>width of all external<br>peripherals                                                                   | C_PRH_MAX_AWIDTH                                                                                                                                                                                  | 3 to 32                                                                                                                                                   | 32                                     | integer              |
| G8                          | Maximum of data bus width of all external peripherals                                                                            | C_PRH_MAX_DWIDTH                                                                                                                                                                                  | 8, 16, 32                                                                                                                                                 | 32                                     | integer              |
| G9                          | Maximum of data bus width<br>of all peripherals and<br>address bus with of<br>peripherals employing<br>address/data multiplexing | C_PRH_MAX_<br>ADWIDTH <sup>(2)</sup>                                                                                                                                                              | 8 to 32                                                                                                                                                   | 32                                     | integer              |
| G10                         | Peripheral clock support                                                                                                         | C_PRH_CLK_<br>SUPPORT <sup>(1)</sup>                                                                                                                                                              | 0 = Peripheral device<br>interface operates at the<br>AXI clock<br>1 = Peripheral device<br>interface operates at<br>external peripheral clock            | 0                                      | integer              |
| G11                         | AXI burst support                                                                                                                | C_PRH_BURST_<br>SUPPORT <sup>(3)</sup>                                                                                                                                                            | 0 = No burst support from<br>AXI                                                                                                                          | 0                                      | integer              |
|                             |                                                                                                                                  | AXI EPC Peripheral Add                                                                                                                                                                            | ress Space                                                                                                                                                |                                        | I                    |
| G12                         | External peripheral base address                                                                                                 | C_PRHx_BASEADDR <sup>(4)</sup>                                                                                                                                                                    | Valid address <sup>(5)(6)</sup>                                                                                                                           | User must<br>set values <sup>(6)</sup> | std_logic_<br>vector |
| G13                         | External peripheral high address                                                                                                 | C_PRHx_HIGHADDR <sup>(4)</sup>                                                                                                                                                                    | Valid address <sup>(5)(6)</sup>                                                                                                                           | User must<br>set values <sup>(6)</sup> | std_logic_<br>vector |
|                             | A                                                                                                                                | XI EPC Peripheral Interfac                                                                                                                                                                        | e Parameters                                                                                                                                              | 1                                      |                      |
| G14                         | Support for access to FIFO<br>within the external<br>peripheral                                                                  | C_PRHx_FIFO_<br>ACCESS <sup>(4)</sup>                                                                                                                                                             | 0 = No support for the<br>external peripheral FIFO<br>access<br>1 = Access to FIFO<br>structures within the<br>external peripheral<br>device is supported | 0                                      | integer              |
| G15                         | External peripheral FIFO<br>offset from peripheral base<br>address                                                               | C_PRHx_FIFO_<br>OFFSET <sup>(4)(8)(9)</sup>                                                                                                                                                       | Any valid offset within the<br>base and high address<br>range assigned to the<br>peripheral device                                                        | 0                                      | integer              |
| G16                         | Address bus width of<br>peripherals                                                                                              | C_PRHx_AWIDTH <sup>(4)</sup>                                                                                                                                                                      | 3 to 32                                                                                                                                                   | 32                                     | integer              |
| G17                         | Data bus width of peripherals                                                                                                    | C_PRHx_DWIDTH <sup>(4)</sup>                                                                                                                                                                      | 8, 16, or 32                                                                                                                                              | 32                                     | integer              |
| G18                         | Support for data width match<br>when the peripheral device<br>data width is less than the<br>AXI data width                      | 0 = No multiple cycles on<br>the peripheral interface<br>for single AXI read or<br>write cycle<br>1 = Run multiple cycles<br>on the peripheral<br>interface for single AXI<br>read or write cycle | 0                                                                                                                                                         | integer                                |                      |

Table 1: AXI EPC IP Core Design Parameters (Cont'd)

| Generic                                                                                                                                                                                           | Feature/Description                                                                                                                                   | Parameter Name                                  | Allowable Values                                                                                                              | Default<br>Value                                                                          | VHDL<br>Type |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|--------------|
| G19                                                                                                                                                                                               | Peripheral access mode                                                                                                                                | C_PRHx_SYNC <sup>(1)(4)</sup>                   | 0 = External device is<br>asynchronous<br>1 = External device is<br>synchronous                                               | 1                                                                                         | integer      |
| G20                                                                                                                                                                                               | G20 Peripheral bus type C_PRHx_BUS_<br>MULTIPLEX <sup>(4)</sup>                                                                                       |                                                 | 0 = External device has<br>separate address and<br>data bus<br>1 = External device has<br>multiplexed address and<br>data bus | 0                                                                                         | integer      |
|                                                                                                                                                                                                   | 1                                                                                                                                                     | AXI EPC Timing Pa                               | arameters                                                                                                                     |                                                                                           |              |
| G21 Address bus (PRH_Addr)<br>setup with respect to rising<br>edge of address strobe<br>(PRH_ADS) or falling edge<br>of read/write (PRH_Rd_n/<br>PRH_Wr_n) C_PRHx_ADDR_<br>TSU <sup>(4)(11)</sup> |                                                                                                                                                       | Integer number of picoseconds                   | User must<br>set<br>values. <sup>(12)</sup><br>See<br>targeted<br>device's<br>data sheet.                                     | integer                                                                                   |              |
| G22                                                                                                                                                                                               | Address bus (PRH_Addr)<br>hold with respect to falling<br>edge of address strobe<br>(PRH_ADS) or rising edge<br>of read/write (PRH_Rd_n/<br>PRH_Wr_n) | C_PRHx_ADDR_<br>TH <sup>(4)</sup> (13)(17)(20)  | Integer number of picoseconds                                                                                                 | User must<br>set<br>values. <sup>(12)</sup><br>See<br>targeted<br>device's<br>data sheet. | integer      |
| G23                                                                                                                                                                                               | Minimum pulse width of address strobe (PRH_ADS)                                                                                                       | C_PRHx_ADS_<br>WIDTH <sup>(4)</sup>             | Integer number of picoseconds                                                                                                 | User must<br>set<br>values. <sup>(12)</sup><br>See<br>targeted<br>device's<br>data sheet. | integer      |
| G24                                                                                                                                                                                               | Chip select (PRH_CS_n)<br>setup with respect to falling<br>edge of read/write<br>(PRH_Rd_n/ PRH_Wr_n)                                                 | C_PRHx_CSN_<br>TSU <sup>(4)(11)</sup>           | Integer number of picoseconds                                                                                                 | User must<br>set<br>values. <sup>(14)</sup><br>See<br>targeted<br>device's<br>data sheet. | integer      |
| G25                                                                                                                                                                                               | Chip select (PRH_CS_n)<br>hold with respect to rising<br>edge of read/write<br>(PRH_Rd_n/ PRH_Wr_n)                                                   | C_PRHx_CSN_<br>TH <sup>(4)(17)(20)</sup>        | Integer number of picoseconds                                                                                                 | User must<br>set<br>values. <sup>(14)</sup><br>See<br>targeted<br>device's<br>data sheet. | integer      |
| G26                                                                                                                                                                                               | Minimum pulse width of<br>write signal (PRH_Wr_n)                                                                                                     | C_PRHx_WRN_<br>WIDTH <sup>(4)(15)(16)(17)</sup> | Integer number of picoseconds                                                                                                 | User must<br>set<br>values. <sup>(14)</sup><br>See<br>targeted<br>device's<br>data sheet. | integer      |

Table 1: AXI EPC IP Core Design Parameters (Cont'd)

| Table | 1: AXI EPC IP | <b>Core Design</b> | Parameters | (Cont'd) |
|-------|---------------|--------------------|------------|----------|
|-------|---------------|--------------------|------------|----------|

| Generic | Feature/Description                                                                     | Parameter Name                                  | Allowable Values              | Default<br>Value                                                                          | VHDL<br>Type |  |
|---------|-----------------------------------------------------------------------------------------|-------------------------------------------------|-------------------------------|-------------------------------------------------------------------------------------------|--------------|--|
| G27     | Cycle time of write signal<br>(PRH_Wr_n)                                                | C_PRHx_WR_<br>CYCLE <sup>(4)(16)(17)</sup>      | Integer number of picoseconds | User must<br>set<br>values. <sup>(14)</sup><br>See<br>targeted<br>device's<br>data sheet. | integer      |  |
| G28     | Data bus (PRH_Data) setup<br>with respect to falling edge<br>of write signal (PRH_Wr_n) | C_PRHx_DATA_<br>TSU <sup>(4)(15)</sup>          | Integer number of picoseconds | User must<br>set<br>values. <sup>(14)</sup><br>See<br>targeted<br>device's<br>data sheet. | integer      |  |
| G29     | Data bus (PRH_Data) hold<br>with respect to rising edge of<br>write signal (PRH_Wr_n)   | C_PRHx_DATA_<br>TH <sup>(4)(17)</sup>           | Integer number of picoseconds | User must<br>set<br>values. <sup>(14)</sup><br>See<br>targeted<br>device's<br>data sheet. | integer      |  |
| G30     | Minimum pulse width of read signal (PRH_Rd_n)                                           | C_PRHx_RDN_<br>WIDTH <sup>(4)(18)(19)(20)</sup> | Integer number of picoseconds | User must<br>set<br>values. <sup>(14)</sup><br>See<br>targeted<br>device's<br>data sheet. | integer      |  |
| G31     | Cycle time of read signal<br>(PRH_Rd_n)                                                 | C_PRHx_RD_<br>CYCLE <sup>(4)(19)(20)</sup>      | Integer number of picoseconds | User must<br>set<br>values. <sup>(14)</sup><br>See<br>targeted<br>device's<br>data sheet. | integer      |  |
| G32     | Data bus (PRH_Data)<br>validity from falling edge of<br>read signal (PRH_Rd_n)          | C_PRHx_DATA_<br>TOUT <sup>(4)(18)</sup>         | Integer number of picoseconds | User must<br>set<br>values. <sup>(14)</sup><br>See<br>targeted<br>device's<br>data sheet. | integer      |  |
| G33     | Data bus (PRH_Data) high<br>impedance from rising edge<br>of read (PRH_Rd_n)            | C_PRHx_DATA_<br>TINV <sup>(4)(20)</sup>         | Integer number of picoseconds | User must<br>set<br>values. <sup>(14)</sup><br>See<br>targeted<br>device's<br>data sheet. | integer      |  |

| Table 1: AXI EPC IP Core Design Parameters (Con | nťd) |
|-------------------------------------------------|------|
|-------------------------------------------------|------|

| Generic | Feature/Description                                                                                  | Parameter Name                              | Allowable Values              | Default<br>Value                                                                          | VHDL<br>Type |
|---------|------------------------------------------------------------------------------------------------------|---------------------------------------------|-------------------------------|-------------------------------------------------------------------------------------------|--------------|
| G34     | Device ready (PRH_Rdy)<br>validity from the falling edge<br>of read or write (PRH_Rd_n/<br>PRH_Wr_n) | C_PRHx_RDY_<br>TOUT <sup>(4)(21)(23)</sup>  | Integer number of picoseconds | User must<br>set<br>values. <sup>(14)</sup><br>See<br>targeted<br>device's<br>data sheet. | integer      |
| G35     | Maximum period of device<br>ready signal (PRH_Rdy) to<br>wait before device timeout                  | C_PRHx_RDY_<br>WIDTH <sup>(4)(22)(23)</sup> | Integer number of picoseconds | User must<br>set<br>values. <sup>(23)</sup><br>See<br>targeted<br>device's<br>data sheet. | integer      |

#### Table 1: AXI EPC IP Core Design Parameters (Cont'd)

| Gen         | eric     | Feature/Description                 | Parameter Name                                                                 | Allowable Values                       | Default<br>Value  | VHDL<br>Type      |
|-------------|----------|-------------------------------------|--------------------------------------------------------------------------------|----------------------------------------|-------------------|-------------------|
| Note        | s:       |                                     |                                                                                |                                        |                   |                   |
| I. 1        | The gen  | eric C_PRH_CLK_SUPPORT is           | relevant only when the device is o                                             | configured for synchronous acc         | ess (that is, C   | PRHx_SYNC         |
|             |          |                                     | us, then the frequency for the peri                                            |                                        |                   |                   |
| t           | he oper  | ating frequencies of those device   | es.                                                                            |                                        |                   |                   |
|             |          |                                     | s the size of the data bus. For all r                                          |                                        |                   |                   |
| t           | he max   | imum of data bus width of all exte  | rnal devices (that is, C_PRH_MA)                                               | K_ADWIDTH equals C_PRH_M               | IAX_DWIDTH).      | . However, if a   |
|             |          |                                     | ed address and data bus, then C_l<br>ss bus of device(s) employing mul         |                                        |                   | naximum of da     |
|             |          |                                     | upport the burst transactions to/fro                                           |                                        |                   |                   |
|             |          |                                     | the peripheral device and takes a                                              |                                        | UM PERIPHEI       | RALS - 1.         |
|             |          |                                     | four peripheral devices. The add                                               |                                        |                   |                   |
|             |          | x_BASEADDR and C_PRHx_HIC           |                                                                                |                                        | g                 |                   |
|             |          |                                     | DDR and C_PRHx_HIGHADDR r                                                      |                                        |                   |                   |
|             |          |                                     | nge = 2 <sup>m</sup> ). Further, the "m" least sig                             |                                        | EADDR must be     | e zero. The ba    |
|             |          |                                     | erent peripherals must be mutually                                             |                                        |                   | reported)         |
|             |          |                                     | at the actual value is set (that is, it<br>1 if the support for access to FIFC |                                        |                   |                   |
|             |          |                                     | et of the external peripheral FIFO                                             |                                        |                   |                   |
|             |          |                                     | of the peripheral device. If C_PRHx                                            |                                        |                   |                   |
|             |          | valid offset within the address rai |                                                                                | / _                                    |                   |                   |
| 0. ]        | The gen  | eric C_PRHx_DWIDTH_MATCH            | is relevant only when the width of                                             | the peripheral data (PRH_Dat           | a) bus is less th | an the AXI d      |
|             |          |                                     | Hx_DWIDTH_MATCH must be se                                                     |                                        |                   | the law of the st |
| 1. <i>F</i> |          | setup time is with respect to fall  | ing edge of address strobe (PRH_<br>st be set both in synchronous and          | ADS) If the address and the da         | ata bus are mu    | tiplexed (that    |
|             |          |                                     | Vr_n/PRH_Rd_n), if the device is                                               |                                        |                   |                   |
|             | asynchr  |                                     |                                                                                |                                        |                   |                   |
|             |          |                                     | d if the address and the data bus a                                            |                                        | x_BUS_MULTI       | PLEX = 1). T      |
|             |          |                                     | ynchronous and asynchronous de                                                 |                                        |                   |                   |
|             |          |                                     | g edge of address strobe (PRH_A                                                |                                        |                   |                   |
|             |          |                                     | st be set both in synchronous and<br>/r_n/PRH_Rd_n) if the address ar          |                                        |                   |                   |
|             |          | asynchronous.                       |                                                                                |                                        |                   |                   |
|             |          |                                     | de of the peripherals is asynchror                                             | nous (that is, C_PRHx_SYNC =           | = 0). If the acce | ess mode of th    |
|             |          |                                     | Hx_SYNC = 1, then the zero shoul                                               |                                        |                   |                   |
|             |          |                                     | maximum of C_PRHx_WRN_WIE                                                      |                                        |                   |                   |
|             |          |                                     | st be smaller than C_PRHx_WR_                                                  | CYCLE. The C_PRHx_WR_C                 | CLE time is co    | onsidered for     |
|             |          | eriod between consecutive writes    | s.<br>mode, write recovery time is the r                                       |                                        |                   | TU TU             |
|             |          |                                     | h time (that is, C_PRHx_WR_CYC                                                 |                                        |                   |                   |
| r           | nultiple | xed address and data bus, then t    | he write recovery time is the maxi                                             | mum of C_PRHx_CSN_TH, C                | PRHx_DATA_        | TH, and           |
|             |          | r_n high time.                      |                                                                                |                                        |                   |                   |
|             |          |                                     | maximum of C_PRHx_RDN_WID                                                      |                                        |                   |                   |
|             |          |                                     | st be smaller than C_PRHx_RD_0                                                 | CYCLE. The C_PRHx_RD_CY                | CLE time is cor   | nsidered for t    |
|             |          | eriod between consecutive reads     |                                                                                |                                        |                   | NON TH            |
| 0. I        | 2  PRH   | x DATA TINV and PRH Rd n h          | igh time (that is, C_PRHx_RD_C)                                                | CLE minus C. PRHx RDN W                | IDTH) If the p    | erinheral use     |
|             |          |                                     | he read recovery time is the maxin                                             |                                        |                   |                   |
| F           | PRH_R    | d_n high time.                      |                                                                                |                                        |                   |                   |
|             |          |                                     | DY_TOUT) must be set as the ma                                                 | ximum of the device ready valu         | ues specified fo  | r read and w      |
|             |          | ions for that device.               |                                                                                | denotes a fith and a discussion of the |                   |                   |
| 2. [        | Jevice i | eady pulse width (C_PRHx_RD)        | Y_WIDTH) must be set as the max<br>I write transactions starts from the        | kimum of the device ready value        | es specified for  | read and wri      |
| (           | PRH C    | S n) in synchronous non multipl     | ex mode and asynchronous mode                                                  | h synchronous multiplex mo             | de, the transac   | tion (address     |
| r n         | bhase. c | data Phase) starts from the falling | g edge and ends with raising edge                                              | of chip select (PRH CS n).             | ,                 |                   |
| 3. İ        | Device r | eadv validitv (C PRHx RDY TO        | OUT) period must be less than devi                                             | ice ready signal width (C PRH          | x_RDY_WIDTH       | I). Device rea    |
| S           | signal w | idth (C_PRHx_RDY_WIDTH) mu          | ist be set for both synchronous an                                             | d asynchronous access mode             | to prevent the    | device from       |

holding the AXI indefinitely. 24. C\_PRH\_CLK\_PERIOD\_PS should be greater than C\_S\_AXI\_CLK\_PERIOD\_PS and is valid only when C\_PRH\_CLK\_SUPPORT is set.

# I/O Signals

The AXI EPC IP Core I/O signals are listed and described in Table 2.

Table 2: AXI EPC IP Core I/O Signal Description

| Port                      | Signal Name                               | Interface   | Signal<br>Type | Initial<br>State | Description                                                                                                                                                                           |  |  |
|---------------------------|-------------------------------------------|-------------|----------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                           |                                           | S           | ystem Sig      | gnals            |                                                                                                                                                                                       |  |  |
| P1                        | S_AXI_ACLK                                | AXI         | I              | -                | AXI clock                                                                                                                                                                             |  |  |
| P2                        | S_AXI_ARESETN                             | AXI         | I              | -                | AXI reset. Active-Low.                                                                                                                                                                |  |  |
|                           |                                           | AXI Write A | ddress Cl      | hannels S        | ignals                                                                                                                                                                                |  |  |
| P3                        | S_AXI_AWADDR[C_S_AXI_AD<br>DR_WIDTH-1:0]  | AXI         | I              | -                | AXI Write address. The write address bus gives the address of the write transaction.                                                                                                  |  |  |
| P4                        | S_AXI_AWVALID                             | AXI         | 1              | -                | Write address valid. This signal indicates that valid write address is available.                                                                                                     |  |  |
| P5                        | S_AXI_AWREADY                             | AXI         | 0              | 0x0              | Write address ready. This signal indicates that the slave is ready to accept an address.                                                                                              |  |  |
| AXI Write Channel Signals |                                           |             |                |                  |                                                                                                                                                                                       |  |  |
| P6                        | S_AXI_WDATA[C_S_AXI_DATA_<br>WIDTH - 1:0] | AXI         | I              | -                | Write data                                                                                                                                                                            |  |  |
| P7                        | S_AXI_WSTB[C_S_AXI_DATA_<br>WIDTH/8-1:0]  | AXI         | 1              | -                | Write strobes. This signal indicates which byte lanes to update in memory. <sup>(1)</sup>                                                                                             |  |  |
| P8                        | S_AXI_WVALID                              | AXI         | I              | -                | Write valid. This signal indicates that valid write data and strobes are available.                                                                                                   |  |  |
| P9                        | S_AXI_WREADY                              | AXI         | 0              | 0x0              | Write ready. This signal indicates that the slave can accept the write data.                                                                                                          |  |  |
|                           |                                           | AXI Write R | esponse (      | Channel S        | ignals                                                                                                                                                                                |  |  |
| P10                       | S_AXI_BRESP[1:0]                          | AXI         | 0              | 0x0              | Write response. This signal indicates the status<br>of the write transaction.<br>00 = OKAY<br>10 = SLVERR                                                                             |  |  |
| P11                       | S_AXI_BVALID                              | AXI         | 0              | 0x0              | Write response valid. This signal indicates that a valid write response is available.                                                                                                 |  |  |
| P12                       | S_AXI_BREADY                              | AXI         | I              | -                | Response ready. This signal indicates that the master can accept the response information.                                                                                            |  |  |
|                           |                                           | AXI Read A  | ddress C       | hannel Si        | gnals                                                                                                                                                                                 |  |  |
| P13                       | S_AXI_ARADDR[C_S_AXI_ADD<br>R_WIDTH -1:0] | AXI         | I              | -                | Read address. The read address bus gives the address of a read transaction.                                                                                                           |  |  |
| P14                       | S_AXI_ARVALID                             | AXI         | 1              | -                | Read address valid. This signal indicates, when<br>HIGH, that the read address is valid and<br>remains stable until the address<br>acknowledgement signal, S_AXI_ARREADY, is<br>high. |  |  |
| P15                       | S_AXI_ARREADY                             | AXI         | 0              | 0x1              | Read address ready. This signal indicates that the slave is ready to accept an address.                                                                                               |  |  |

### Table 2: AXI EPC IP Core I/O Signal Description (Cont'd)

| Port            | Signal Name                                         | Interface | Signal<br>Type | Initial<br>State | Description                                                                                                                 |  |  |
|-----------------|-----------------------------------------------------|-----------|----------------|------------------|-----------------------------------------------------------------------------------------------------------------------------|--|--|
|                 |                                                     | AXI Read  | I Data Cha     | annel Sig        | nals                                                                                                                        |  |  |
| P16             | S_AXI_RDATA[C_S_AXI_DATA_<br>WIDTH -1:0]            | AXI       | 0              | 0x0              | Read data                                                                                                                   |  |  |
| P17             | S_AXI_RRESP[1:0]                                    | AXI       | 0              | 0x0              | Read response. This signal indicates the status<br>of the read transfer.<br>00 = OKAY<br>10 = SLVERR                        |  |  |
| P18             | S_AXI_RVALID                                        | AXI       | 0              | 0x0              | Read valid. This signal indicates that the required read data is available and the read transfer can complete.              |  |  |
| P19             | S_AXI_RREADY                                        | AXI       | I              | -                | Read ready. This signal indicates that the master can accept the read data and response information.                        |  |  |
| AXI EPC Signals |                                                     |           |                |                  |                                                                                                                             |  |  |
| P20             | PRH_Clk <sup>(1)</sup>                              | EPC       | I              | -                | External peripheral clock input                                                                                             |  |  |
| P21             | PRH_Rst                                             | EPC       | I              | -                | External peripheral reset input                                                                                             |  |  |
| P22             | PRH_CS_n[0:C_NUM_<br>PERIPHERALS - 1]               | EPC       | 0              | 1                | External peripheral chip select.<br>Active-Low signal                                                                       |  |  |
| P23             | PRH_Addr[0:C_PRH_<br>MAX_AWIDTH - 1] <sup>(2)</sup> | EPC       | 0              | -                | External peripheral address bus                                                                                             |  |  |
| P24             | PRH_ADS                                             | EPC       | 0              | 0                | External peripheral address strobe in case of multiplexed address and data bus.<br>Active-High signal                       |  |  |
| P25             | PRH_BE[0:C_PRH_<br>MAX_DWIDTH/8 - 1]                | EPC       | 0              | -                | External peripheral byte enables                                                                                            |  |  |
| P26             | PRH_RNW                                             | EPC       | 0              | 1                | External peripheral read/write signal for synchronous access mode                                                           |  |  |
| P27             | PRH_Rd_n                                            | EPC       | 0              | 1                | External peripheral read signal for<br>asynchronous access mode.<br>Active-Low signal                                       |  |  |
| P28             | PRH_Wr_n                                            | EPC       | 0              | 1                | External peripheral write signal for<br>asynchronous access mode.<br>Active-Low signal                                      |  |  |
| P29             | PRH_Burst                                           | EPC       | 0              | 0                | Burst cycle indication to external peripheral.<br>Active-High signal                                                        |  |  |
| P30             | PRH_Rdy[0:C_NUM_<br>PERIPHERALS - 1]                | EPC       | I              | -                | Peripheral ready signal. This signal is used by<br>the external peripheral to extend the transaction.<br>Active-High signal |  |  |
| P31             | PRH_Data_I[0:<br>C_PRH_MAX_ADWIDTH - 1]             | EPC       | I              | -                | External peripheral input data bus                                                                                          |  |  |
| P32             | PRH_Data_O[0:<br>C_PRH_MAX_ADWIDTH - 1]             | EPC       | 0              | -                | External peripheral output data bus                                                                                         |  |  |

| Port   | Signal Name                             | Interface | Signal<br>Type | Initial<br>State | Description                                             |  |  |  |
|--------|-----------------------------------------|-----------|----------------|------------------|---------------------------------------------------------|--|--|--|
| P33    | PRH_Data_T[0:<br>C_PRH_MAX_ADWIDTH - 1] | EPC       | 0              | -                | 3-state control for external peripheral output data bus |  |  |  |
| Notes: |                                         |           |                |                  |                                                         |  |  |  |

1. PRH\_Clk is utilized only when C\_PRH\_CLK\_SUPPORT = 1 and the interface to the external peripheral is synchronous.

2. External peripheral devices are considered as byte addressable irrespective of the data bus width.

# Parameter – I/O Signal Dependencies

The dependencies between the AXI EPC design parameters and the I/O ports are shown in Table 3. The width of the AXI EPC signals depend on some of the parameters. In addition, when certain features are parameterized out of the design, the related logic is no longer a part of the design. The unused input signals and unrelated output signals are set to a specified value.

| Generic<br>or Port | Name                                         | Affects                       | Depends | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|--------------------|----------------------------------------------|-------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Design Parameters  |                                              |                               |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| G2                 | C_S_AXI_ADDR_<br>WIDTH                       | P3, P13                       | -       | Affects the number of bits in address bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| G3                 | C_S_AXI_DATA_W<br>IDTH                       | P6, P7,<br>P16                | G6      | Affects the number of bits in address bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| G6                 | C_NUM_<br>PERIPHERALS                        | P22, P30                      | P31-    | The number of peripherals in the system determines the number<br>of chip select signals driven. The number of device ready inputs<br>decoded by the AXI external peripheral controller.                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
| G7                 | C_PRH_MAX_<br>AWIDTH                         | P23                           | P24-    | The width of the peripheral address bus is set to the maximum of address bus width of all peripheral devices                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| G8                 | C_PRH_MAX_<br>DWIDTH                         | P25                           | -       | The number of byte enables for the peripheral data bus is determined by the maximum of data bus width of the peripheral devices                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| G9                 | C_PRH_MAX_<br>ADWIDTH                        | P31, P32,<br>P33              | P34-    | The width of the peripheral input data bus, peripheral output data<br>bus, and the peripheral output data bus 3-state control are<br>determined by the maximum of data bus width of all peripherals.<br>The address bus width of peripherals employing address/data<br>bus multiplexing.                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| G10                | C_PRH_CLK_<br>SUPPORT                        | P20                           | -       | If C_PRH_CLK_SUPPORT = 0, then all external devices operate<br>on AXI clock. The input PRH_Clk must be driven high externally.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| G18                | C_PRHx_DWIDTH<br>_MATCH                      | P29                           | -       | If the device is configured for synchronous mode with data width<br>matching enabled, then PRH_Burst is driven high until all but the<br>last byte of data is flushed to the device. For asynchronous mode<br>and synchronous mode with data width match disabled,<br>PRH_Burst is driven low.                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| G19                | C_PRHx_SYNC                                  | P20, P26,<br>P27, P28,<br>P29 | P30-    | <ul> <li>If the device is configured for asynchronous mode:</li> <li>With peripheral clock support, the peripheral clock input<br/>(PRH_Clk) must be driven high externally</li> <li>PRH_RNW is driven high as PRH_Rd_n and PRH_Wr_n<br/>should be used as read and write strobe</li> <li>With data width matching enabled, the AXI EPC drives<br/>PRH_Burst to its default low</li> <li>If the device is configured for synchronous mode:</li> <li>The AXI EPC drives PRH_Rd_n and PRH_Wr_n outputs to<br/>their default state of high because PRH_RNW output is used<br/>as read/write strobe</li> </ul> |  |  |  |  |
| G20                | C_PRHx_BUS_<br>MULTIPLEX                     | P24                           | -       | PRH_ADS is driven low if the device does not use multiplexed address and data bus (that is, C_PRHx_BUS_MULTIPLEX = 0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
|                    |                                              |                               | I/C     | ) Signals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| P3                 | S_AXI_AWADDR[C<br>_S_AXI_ADDR_<br>WIDTH-1:0] | -                             | G2      | Port width depends on the generic C_S_AXI_ADDR_WIDTH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| P6                 | S_AXI_WDATA[C_<br>S_AXI_DATA_<br>WIDTH-1:0]  | -                             | G3      | Port width depends on the generic C_S_AXI_DATA_WIDTH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |

| Table 3: AXI EPC IP Core Parameter - | I/O Signal Dependencies (Cont'd) |
|--------------------------------------|----------------------------------|
|--------------------------------------|----------------------------------|

| Generic<br>or Port | Name                                          | Affects | Depends  | Description                                                                                                                                                                                                                                                                                                                         |  |
|--------------------|-----------------------------------------------|---------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| P7                 | S_AXI_WSTB[C_S<br>_AXI_DATA_<br>WIDTH/8-1:0]  | -       | G3       | Port width depends on the generic C_S_AXI_DATA_WIDTH                                                                                                                                                                                                                                                                                |  |
| P13                | S_AXI_ARADDR[C<br>_S_AXI_ADDR_<br>WIDTH -1:0] | -       | G2       | Port width depends on the generic C_S_AXI_ADDR_WIDTH                                                                                                                                                                                                                                                                                |  |
| P16                | S_AXI_RDATA[C_S<br>_AXI_DATA_WIDT<br>H -1:0]  | -       | G3       | Port width depends on the generic C_S_AXI_DATA_WIDTH                                                                                                                                                                                                                                                                                |  |
| P20                | PRH_Clk                                       | -       | G10, G19 | PRH_Clk is selected as operating clock only if the device is configured for synchronous mode with peripheral clock support (that is, C_PRHx_SYNC = 1 and C_PRH_CLK_SUPPORT = 1).                                                                                                                                                    |  |
|                    |                                               |         |          | Asynchronous interface always operates on AXI_Clk. Therefore, if no device is configured for synchronous mode with peripheral clock support enabled, then the input PRH_Clk must be driven high.                                                                                                                                    |  |
| P22                | PRH_CS_n                                      | -       | G6       | The number of chip select signals driven by the AXI external peripheral controller is determined by the C_NUM_PERIPHERALS parameter                                                                                                                                                                                                 |  |
| P23                | PRH_Addr                                      | -       | G7       | The width of the peripheral address bus is determined by the C_PRH_MAX_AWIDTH parameter                                                                                                                                                                                                                                             |  |
| P24                | PRH_ADS                                       | -       | G20      | PRH_ADS is driven low if the device does not use multiplexed address and data bus (that is, C_PRHx_BUS_MULTIPLEX = 0)                                                                                                                                                                                                               |  |
| P25                | PRH_BE                                        | -       | G8       | The number of byte enables for the peripheral data bus is determined by the C_PRH_MAX_DWIDTH parameter                                                                                                                                                                                                                              |  |
| P26                | PHR_RNW                                       | -       | G19      | If the device is synchronous (that is, C_PRHx_SYNC = 1), then PRH_RNW should be used as the read/write control signal. For asynchronous mode of operation, PRH_RNW is driven high.                                                                                                                                                  |  |
| P27                | PRH_Rd_n                                      | -       | G19      | If the device is asynchronous (that is, C_PRHx_SYNC = 0), then PRH_Rd_n should be used as the read strobe. For synchronous mode of operation, PRH_Rd_n is driven high.                                                                                                                                                              |  |
| P28                | PRH_Wr_n                                      | -       | G19      | If the device is asynchronous (that is, C_PRHx_SYNC = 0), then PRH_Wr_n should be used as the write strobe. For synchronous mode of operation, PRH_Wr_n is driven high.                                                                                                                                                             |  |
| P29                | PRH_Burst                                     | -       | G18, G19 | If the device is synchronous with data width matching enabled<br>(that is, C_PRHx_SYNC = 1 and C_PRHx_DWIDTH_MATCH<br>= 1), then PRH_Burst is driven high until all but the last byte of<br>data is flushed to the device. For asynchronous mode and<br>synchronous mode with data width match disabled, PRH_Burst is<br>driven low |  |
| P30                | PRH_Rdy                                       | -       | G6       | The number of device ready inputs decoded by the AXI external peripheral controller is determined by the C_NUM_PERIPHERALS parameter                                                                                                                                                                                                |  |

| Generic<br>or Port | Name       | Affects | Depends | Description                                                                                                                                 |
|--------------------|------------|---------|---------|---------------------------------------------------------------------------------------------------------------------------------------------|
| P31                | PRH_Data_I | -       | G9      | The peripheral input data bus width of AXI external peripheral controller is determined by the C_PRH_MAX_ADWIDTH parameter                  |
| P32                | PRH_Data_O | -       | G9      | The peripheral output data bus width of AXI external peripheral controller is determined by the C_PRH_MAX_ADWIDTH parameter                 |
| P33                | PRH_Data_T | -       | G9      | The peripheral output data bus 3-state control width of AXI external peripheral controller is determined by the C_PRH_MAX_ADWIDTH parameter |

Table 3: AXI EPC IP Core Parameter – I/O Signal Dependencies (Cont'd)

## **Allowable Parameter Combinations**

When the peripheral devices are configured in non-multiplexed mode, the C\_PRH\_MAX\_AWIDTH should be the maximum of C\_PRHx\_AWIDTH of all peripherals in the system (that is, if C\_NUM\_PERIPHERALS is 2), then C\_PRH\_MAX\_AWIDTH should be maximum of C\_PRH0\_AWIDTH and C\_PRH1\_AWIDTH.

C\_PRH\_MAX\_DWIDTH should be the maximum of C\_PRHx\_DWIDTH of all peripherals in the system (that is, if C\_NUM\_PERIPHERALS is 2), then C\_PRH\_MAX\_DWIDTH should be maximum of C\_PRH0\_DWIDTH and C\_PRH1\_DWIDTH.

If any of the peripheral devices are configured for a multiplexed address and data buses, then the parameter C\_PRH\_MAX\_ADWIDTH should be set as the maximum of the data bus and address bus of the device(s) employing a multiplexed address and data bus. If all devices employ non-multiplexed address and data buses, then C\_PRH\_MAX\_ADWIDTH reflects the maximum of data bus width of all external devices. Therefore, for any configuration the parameter C\_PRH\_MAX\_ADWIDTH should be greater than or equal to C\_PRH\_MAX\_DWIDTH.

The generic C\_PRH\_CLK\_SUPPORT is relevant only when the devices are configured for the synchronous access (that is, C\_PRHx\_SYNC = 1). If more than one of the devices are synchronous, then the frequency for the peripheral clock should be chosen as the minimum of the operating frequencies of those devices.

The range specified by C\_PRHx\_BASEADDR and C\_PRHx\_HIGHADDR parameters must comprise a contiguous range and the size of the range must be a power of two (that is, size of range = 2<sup>m</sup>). Furthermore, the "m" least significant bits of C\_PRHx\_BASEADDR must be zero. The base and high address range assigned to different peripherals must be mutually exclusive. No default value is specified for C\_PRHx\_BASEADDR and C\_PRHx\_HIGHADDR to enforce that the user configures these parameters with the actual values. If the values are not set for C\_PRHx\_BASEADDR and C\_PRHx\_HIGHADDR, a compiler error is generated.

To access FIFO like structures within the external peripheral devices, C\_PRHx\_FIFO\_ACCESS must be set to 1. When FIFO access is enabled, C\_PRHx\_FIFO\_OFFSET specifies the offset of the FIFO in terms of number of byte locations from the base address (C\_PRHx\_BASEADDR) of the peripheral and should be set to an offset that lies within the address range assigned to the peripheral device (that is, C\_PRHx\_BASEADDR + C\_PRHx\_FIFO\_OFFSET  $\leq$  C\_PRHx\_HIGHADDR). Furthermore, the FIFO offset should be within the range addressable by the address bus (that is, C\_PRHx\_FIFO\_OFFSET  $< 2^n$  where n = C\_PRHx\_AWIDTH).

The width of the read/write strobe must be less than the cycle time of the corresponding access (that is, C\_PRHx\_WRN\_WIDTH < C\_PRHx\_WR\_CYCLE and C\_PRHx\_RDN\_WIDTH < C\_PRHx\_RD\_CYCLE). The value of device ready validity period must be less than the read/write strobe width and the maximum pulse width of the device ready signal (that is, C\_PRHx\_RDY\_TOUT < minimum of C\_PRHx\_WRN\_WIDTH,

C\_PRHx\_RDN\_WIDTH, and C\_PRHx\_RDY\_WIDTH). The time period between two consecutive writes (when the data width matching is enabled) is decided by maximum of (C\_PRHx\_WR\_CYCLE - C\_PRHx\_WRN\_WIDTH), C\_PRHx\_CSN\_TH, and C\_PRHx\_DATA\_TH parameters. Similar calculation is applicable for consecutive reads.

Make sure that the user has configured the timing parameters properly while using AXI EPC IP Core at different frequencies on various FPGA devices.

# **Design Considerations**

The AXI EPC IP Core is AXI slave device. It receives read or write instructions from the processor and generates a corresponding access cycle on the peripheral interface. Examples of read and write accesses are illustrated in the Timing Diagrams section. The user must take the following considerations into account while designing with the AXI EPC.

## **Timing Parameters in Async Mode of Operation**

Internally in the AXI EPC IP Core, the timing parameters are inter-related and some calculation is done based upon the values provided by the user. In the asynchronous mode of operation, the following parameters are used:

- C\_PRHx\_ADDR\_TSU Address set up time
- C\_PRHx\_ADDR\_TH Address hold time
- C\_PRHx\_ADS\_WIDTH Address strobe width
- C\_PRHx\_CSN\_TSU Chip select set up time
- C\_PRHx\_CSN\_TH Chip select hold time
- C\_PRHx\_WRN\_WIDTH Write control width time
- C\_PRHx\_WR\_CYCLE Write cycle time (that is, time between two consecutive writes)
- C\_PRHx\_DATA\_TSU Data set up time
- C\_PRHx\_DATA\_TH Data hold time
- C\_PRHx\_RDN\_WIDTH Read control width time
- C\_PRHx\_RD\_CYCLE Read cycle time (that is, time between two consecutive reads)
- C\_PRHx\_DATA\_TOUT Time taken by the data to be out at read condition
- C\_PRHx\_DATA\_TINV Data line 3-state after the read control signal is de-activated
- C\_PRHx\_RDY\_TOUT Time for device ready signal to go high, after device is selected
- C\_PRHx\_RDY\_WIDTH Maximum time until the AXI EPC IP Core can wait for device to be ready

These parameters are linked in the design as follows:

- Address hold time Parameter is calculated as: (C\_PRHx\_ADDR\_TH/C\_BUS\_CLOCK\_PERIOD\_PS)
- Chip select/Data/Address hold time Three parameters are used to calculate the hold time as: ((max2(max2(C\_PRHx\_DATA\_TH,C\_PRHx\_CSN\_TH),C\_PRHx\_ADDR\_TH)/ C\_BUS\_CLOCK\_PERIOD\_PS)
- Read control signal width time Parameter is calculated as: (C\_PRHx\_RDN\_WIDTH/C\_BUS\_CLOCK\_PERIOD\_PS)
- Write control signal width time Parameter is calculated as: (C\_PRHx\_WRN\_WIDTH/C\_BUS\_CLOCK\_PERIOD\_PS)

- Address strobe signal width time Three parameters are used to calculate the address strobe width as: ((max2(max2(C\_PRHx\_ADDR\_TSU, C\_PRHx\_ADS\_WIDTH), C\_PRHx\_CSN\_WIDTH)/C\_BUS\_CLOCK\_PERIOD\_PS)
- Write recovery time for non-multiplexed case is calculated as: ((max2(max2(C\_PRHx\_CSN\_TH, C\_PRHx\_DATA\_TH),max2(C\_PRHx\_ADDR\_TH,PRH\_Wr\_nx))/C\_BUS\_CLOCK\_PERIOD\_PS) Where PRH\_Wr\_nx = (C\_PRHx\_WR\_CYCLE - C\_PRHx\_WRN\_WIDTH)
- Read recovery time for non-multiplexed case is calculated as: ((max2(max2(C\_PRHx\_CSN\_TH, C\_PRHx\_DATA\_TINV),max2(C\_PRHx\_ADDR\_TH,PRH\_Rd\_nx))/C\_BUS\_CLOCK\_PERIOD\_PS)
- Write recovery time for multiplexed case is calculated as: ((max2(C\_PRHx\_CSN\_TH, C\_PRHx\_DATA\_TH),PRH\_Wr\_nx))/C\_BUS\_CLOCK\_PERIOD\_PS) Where PRH\_Wr\_nx = (C\_PRHx\_WR\_CYCLE - C\_PRHx\_WRN\_WIDTH)
- Read recovery time for multiplexed case is calculated as: ((max2(C\_PRHx\_CSN\_TH, C\_PRHx\_DATA\_TINV),PRH\_Rd\_nx))/C\_BUS\_CLOCK\_PERIOD\_PS) Where PRH\_Rd\_nx = (C\_PRHx\_RD\_CYCLE - C\_PRHx\_RDN\_WIDTH)
- Device Ready signal time Parameter is calculated as: (C\_PRHx\_RDY\_TOUT/C\_BUS\_CLOCK\_PERIOD\_PS)
- Maximum time for Device Ready signal to be active Parameter is calculated as: (C\_PRHx\_RDY\_WIDTH/C\_BUS\_CLOCK\_PERIOD\_PS)

Some of the calculations are repeated for different uses for internal purpose. There are some dummy states included in between the states to meet the design requirements. The user should make sure that these timing parameter value calculations do not exceed the AXI timeout value (C\_DPHASE\_TIMEOUT) if C\_DPHASE\_TIMEOUT > 0.

Table 4 indicates the ranges for the mentioned parameters.

| Parameter Name   | Timing Param | Timing Parameter's Range |               |  |  |  |  |
|------------------|--------------|--------------------------|---------------|--|--|--|--|
| C_PRHx_ADDR_TSU  | 6000 (set 1) | 20000 (set 2)            | 40000 (set 3) |  |  |  |  |
| C_PRHx_ADDR_TH   | 6000         | 20000                    | 30000         |  |  |  |  |
| C_PRHx_ADS_WIDTH | 10000        | 20000                    | 40000         |  |  |  |  |
| C_PRHx_CSN_TSU   | 6000         | 20000                    | 40000         |  |  |  |  |
| C_PRHx_CSN_TH    | 6000         | 20000                    | 30000         |  |  |  |  |
| C_PRHx_WRN_WIDTH | 15000        | 30000                    | 30000         |  |  |  |  |
| C_PRHx_WR_CYCLE  | 30000        | 60000                    | 60000         |  |  |  |  |
| C_PRHx_DATA_TSU  | 10000        | 20000                    | 30000         |  |  |  |  |
| C_PRHx_DATA_TH   | 5000         | 20000                    | 30000         |  |  |  |  |
| C_PRHx_RDN_WIDTH | 15000        | 30000                    | 30000         |  |  |  |  |
| C_PRHx_RD_CYCLE  | 30000        | 60000                    | 60000         |  |  |  |  |
| C_PRHx_DATA_TOUT | 5000         | 5000                     | 15000         |  |  |  |  |
| C_PRHx_DATA_TINV | 10000        | 15000                    | 25000         |  |  |  |  |

| Parameter Name   | Timing Parameter's Range |                          |                          |  |  |
|------------------|--------------------------|--------------------------|--------------------------|--|--|
| C_PRHx_RDY_TOUT  | 10000 <sup>(set 1)</sup> | 50000 <sup>(set 2)</sup> | 60000 <sup>(set 3)</sup> |  |  |
| C_PRHx_RDY_WIDTH | 50000                    | 100000                   | 120000                   |  |  |

Notes:

1. The above range of timing parameters (set 1) are used for internal device utilization and while testing on USB and LAN. While using the parameters, care has been taken that all parameters of same set are used.

2. The above timing sets (set 2 and set 3) are just an example of how the timing parameters can be given to AXI EPC IP Core. The user can have different timing parameter values as per the targeted device's data sheet. In such cases, note the calculation given above.

## **FIFO Transactions**

When C\_PRHx\_FIFO\_ACCESS = 1, the AXI EPC IP Core supports access to FIFOs within the external peripheral devices. When the FIFO within the external device is accessed, then the peripheral address bus (PRH\_Addr) must remain constant representing the FIFO address within the address range assigned to the peripheral device. When data width matching is enabled and the access corresponds to the FIFO, the AXI EPC IP Core does not increment the peripheral address (PRH\_Addr) bus.

## **Abnormal Terminations**

If PRH\_Rdy is deasserted for more than the maximum period as specified by C\_PRHx\_RDY\_WIDTH, then the AXI EPC terminates the current access to the external device and signals slave error to the AXI master by asserting either S\_AXI\_BRESP or S\_AXI\_RRESP on the AXI. In this case, the access to the external device is terminated abnormally. Therefore, the external device can be in an indeterminate state and the exceptions should be handled appropriately at the system level.

## **Interrupt Handling**

If the external device has interrupt capability, then the interrupt outputs of the external device should be connected directly to the system interrupt controller.

## Device Ready Signal (PRH\_Rdy Signal)

The AXI EPC IP Core read/write access cycles are executed only when the external device assert the device ready signal (PRH\_Rdy).

As the PRH\_Rdy signal becomes active, this indicates that the peripheral device is ready for communication. After the PRH\_Rdy goes active, it is expected that it remains in the same active state until that particular transaction is completed by the AXI EPC IP Core. If the AXI EPC IP Core is implemented with data width match enabled, then the activeness of the PRH\_Rdy signal is always checked for every transaction, regardless of it being active throughout the transaction.

The user should see the data sheet of the external peripheral, to define the value of PRH\_Rdy time period (that is, C\_PRHx\_RDY\_TOUT parameter value should be filled based on the mentioned information). It is also expected that the user provides maximum waiting period for PRH\_Rdy signal. This waiting period is indicated by C\_PRHx\_RDY\_WIDTH parameter. The C\_PRHx\_RDY\_TOUT parameter value should be less than the C\_PRHx\_RDY\_WIDTH parameter value. The C\_PRHx\_RDY\_WIDTH time period should be lower than the AXI IPIF timeout value if C\_DPHASE\_TIMEOUT > 0 (that is, C\_PRHx\_RDY\_TOUT < C\_PRHx\_RDY\_WIDTH < C\_DPHASE\_TIMEOUT). Starting from the falling edge of the PRH\_WR\_n or, PRH\_RD\_n signal, the internal counter for C\_PRHx\_RDY\_TOUT and C\_PRHx\_RDY\_WIDTH starts. The AXI EPC IP Core expects that the PRH\_Rdy signal

should appear before any of these timer ends. If the PRH\_Rdy does not become active before the C\_PRHx\_RDY\_TOUT counter ends, then the AXI EPC IP Core waits until the end of C\_PRHx\_RDY\_WIDTH counter. In case PRH\_Rdy becomes active, then internal state machine proceeds to complete the further process steps. If PRH\_Rdy does not become active even before the C\_PRHx\_RDY\_WIDTH ends, the AXI EPC IP Core generates an error and terminate the transaction. The user can re-initiate the same transaction later on.

Figure 3 shows the diagrammatic representation of how the async state machine reacts with the PRH\_Rdy signal. Consider this figure as representation only. In actual design, there are some dummy states added to meet the design requirements. In case of asynchronous reset to the core, all states go to IDLE by default.

If the external peripheral device does not have a device ready signal, then the PRH\_Rdy input of the AXI EPC for that particular device must be tied to logic high.



Figure 3: Diagrammatic Representation of Async State Machine Flow

## Peripheral Data Bus Mapping

The peripheral data bus (PRH\_Data) uses big endian bit labelling (that is, bit-0 is Most Significant Bit (MSB) and bit-31 is Least Significant Bit (LSB) for a 32-bit bus) and is sized according to the C\_PRH\_MAX\_ADWIDTH parameter. Peripherals that have smaller widths should connect to this bus starting at bit-0 (MSB). For example, if three external devices are present in the system with data bus width of 8, 16, and 32 bits, the 8-bit device should connect to PRH\_Data[0:7], the 16-bit wide peripheral should connect to PRH\_Data[0:15], and the 32-bit peripheral should connect to PRH\_Data[0:31].

Word Byte address n+2 n n+1 n+3 0 Byte label 1 2 3 Byte significance MS Byte LS Byte Bit label 0 31 Bit significance MS Bit LS Bit Halfword Byte address n n+1 0 Byte label 1 Byte significance MS Byte LS Byte Bit label 0 15 Bit significance MS Bit LS Bit Byte Byte address n 0 Byte label Byte significance MS Byte Bit label 0 7 Bit significance MS Bit LS Bit

The bit and byte labeling for the big endian data types is shown in Figure 4.

Figure 4: AXI EPC Big Endian Data Type

## **Unsupported Features**

Many peripheral devices have the device specific input/output ports such as status, remote reset, remote wake-up, and interrupts. The AXI EPC IP Core does not have any provision to support these device specific input/output ports. Therefore, if the external device has any such device specific ports, then these input/output ports can be connected directly to system general purpose input output controller or to the system interrupt controller. If the external device has interrupt capability, then the interrupt outputs of the external device should be connected directly to the system interrupt controller.

Many peripheral devices support DMA capability. However, the AXI EPC IP Core is a AXI slave device and does not support DMA operations from the external peripheral devices.

The current version of the AXI EPC IP Core does not support burst transactions to/from the AXI. Consequently, the parameter C\_PRH\_BURST\_SUPPORT must be always assigned to 0.

# **External Peripheral Connections**

The AXI EPC IP Core interface to the external device is based upon the width of the AXI data bus, address and data width of the peripheral subsystem, number of peripherals in the system, address/data multiplex support, mode of operation (synchronous or asynchronous) and if synchronous device, the operating clock for the synchronous datapath.

## **Determining Address and Data Width**

The address bus width of the peripheral subsystem is the maximum width of the address bus of all peripheral devices connected to the AXI EPC IP Core. If all devices employ non-multiplexed address and data bus, the data bus width of the peripheral subsystem is the maximum of the data bus width of all external devices. If any of the devices are configured for multiplexed address and data bus, then the data bus width of the peripheral subsystem should be set as the maximum of the data bus and the address bus of the device(s) employing a multiplexed address and data bus.

## **Endian Considerations**

The peripheral address and data bus of the AXI EPC IP Core is labeled with big endian bit labeling (D0 is the MSB and D31 is the LSB for a 32-bit bus) while most peripheral devices are either endian agnostic (that is, they can be connected either way or little endian (D31 is the MSB and D0 is the LSB for a 32-bit data bus)). Caution must be exercised with the connection to the external peripheral devices to avoid incorrect data and address connections. See Data Steer and Address Generation Modules for a data steering example.

## **Clock Generation**

When connecting to a synchronous external device, the AXI EPC IP Core can operate either on the AXI clock (S\_AXI\_ACLK) or on a peripheral clock (PRH\_Clk). The operating clock for the synchronous interface is based on the generic C\_PRH\_CLK\_SUPPORT. If C\_PRH\_CLK\_SUPPORT = 1, the peripheral clock is used else the AXI clock is used. The external devices connected to the AXI EPC IP Core determines the operating frequency of the peripheral clock. The minimum of the operating frequencies of various devices connected to AXI EPC IP Core should be used as the operating frequency of the peripheral clock (PRH\_Clk).

Figure 5 illustrates a block diagram of one of the methods for generating a device specific clock source using two DCMs. The DCM modules are located within the FPGA but are external to the AXI EPC IP Core. An external clock source is used to generate the AXI clock (S\_AXI\_ACLK) to the AXI EPC. The device clock source (PRH\_Clk) is also generated from the same DCM (DCM0) using the CLKFX output and must be routed on the board to be fed back to the FPGA. The parameters of DCM0 like C\_CLKFX\_MULTIPLY and C\_CLKFX\_DIVIDE should be set according to the required frequency output at CLKFX pin of DCM0. Another DCM (DCM1) is used to synchronize the device peripheral clock to the PRH\_Clk signal of AXI\_EPC.



Figure 5: External Peripherals Clocked by FPGA Output with Feedback

## **Example Peripheral Connections**

#### Example: SMSC LAN91C111 10/100 Non-PCI Ethernet Single Chip MAC + PHY

An example peripheral device supported by the AXI EPC IP Core is the SMSC 10/100 non-PCI Ethernet Single Chip MAC + PHY LAN91C111. The AXI EPC IP Core allows AXI masters to access the device both in synchronous and asynchronous mode. The device connections for synchronous and asynchronous mode of operations are outlined in the Asynchronous Mode and Synchronous Mode sections.

#### Asynchronous Mode

Figure 6 illustrates the SMSC LAN91C111 connections to the AXI EPC IP Core in asynchronous mode with non-multiplexed address and data buses. In asynchronous mode, the input clock source (PRH\_Clk) to the external device must be tied to Vcc. When the SMSC LAN91C111 is accessed through the asynchronous mode, the rising edge of PRH\_Rd\_n and PRH\_Wr\_n signals are used to control the read and the write operations, respectively. As the device uses Asynchronous Ready (ARDY) signal to indicate its readiness in asynchronous mode. This signal is connected to the PRH\_Rdy input of the AXI EPC IP Core. Since the address and the data buses are not multiplexed, PRH\_ADS is driven low by the AXI EPC IP Core. The timing parameters should be set according to the SMSC LAN91C111 Async mode specifications.

The following parameter settings apply for the connections shown in Figure 6.

- C\_PRH\_CLK\_SUPPORT = 0
- $C_{PRH0}_{AWIDTH} = 16$
- C\_PRH0\_DWIDTH = 32
- C\_PRH0\_SYNC = 0
- C\_PRH0\_DWIDTH\_MATCH = 0
- C\_PRH0\_BUS\_MULTIPLEX = 0



Figure 6: SMSC LAN91C111 Connection to AXI EPC IP Core in Asynchronous Mode

#### External FPGA Logic

Special attention must be given while interfacing the AXI EPC IP Core to the SMSC LAN91C111 in asynchronous mode. The AXI EPC IP Core drives the PRH\_BE active-High while the SMSC LAN91C111 requires the input byte enable to be active-Low. To match this requirement, external FPGA logic is required to invert the PRH\_BE signals before they are interfaced with the byte enable signals of the SMSC LAN91C111.

#### Synchronous Mode

Figure 7 illustrates the example for SMSC LAN91C111 connection to the AXI EPC IP Core in synchronous VL Bus mode with non-multiplexed address and data buses. In synchronous mode, the device requires an input clock source to the LCLK pin with a maximum operating frequency of 50 MHz. The local clock generated by the DCM for the peripheral interface must be routed to the LCLK input of SMSC LAN91C111 and PRH\_Clk of AXI EPC IP Core. When the device is accessed, PRH\_RNW is used as the control signal to indicate a read/write access. When PRH\_RNW is high, it indicates a read operation and when low, it indicates a write operation. The SMSC LAN91C111 uses nSRDY signal to indicate the device readiness. This signal is connected to PRH\_Rdy input of the AXI\_EPC. As the address and the data bus are not multiplexed, PRH\_ADS is driven low.

The following parameter settings apply for the connections shown in Figure 7.

- C\_PRH\_CLK\_SUPPORT = 1
- $C_{PRH0}_{AWIDTH} = 16$
- C\_PRH0\_DWIDTH = 32
- C\_PRH0\_SYNC = 1
- C\_PRH0\_DWIDTH\_MATCH = 0
- C\_PRH0\_BUS\_MULTIPLEX = 0



Figure 7: SMSC LAN91C111 Connection to AXI EPC IP Core in Synchronous Mode

#### External FPGA Logic

The SMSC LAN91C111 device requires two inputs, nCYCLE and nRDYRTN, to control synchronous operation. The definition of these signals is outside the scope of this document and can be found in the documents listed in the References section. The nCYCLE and nRDYRTN signals are generated in external FPGA logic. nCYCLE can be generated from PRH\_CS\_n and is driven low for a single clock cycle on a high to low transition on PRH\_CS\_n. nRDYRTN is the registered value of the nSRDY signal.

In case of synchronous multiplexing mode, the generation of nCYCLE signal is little different. The PRH\_CS\_*n* signal is generated twice from the core, first during the address phase and second time during the data phase. User should take care while writing the logic for nCYCLE signal generation in external FPGA logic. The nCYCLE should be generated in data phase when there is PRH\_CS\_*n* asserted and PRH\_ADS is not present.

#### **Design Considerations**

When the AXI EPC IP Core is interfaced to the SMSC LAN91C111 with data width match enabled (C\_PRHx\_DWIDTH\_MATCH = 1) and the internal SRAM of the peripheral is being accessed, the device has to be configured in the address auto increment mode. Address auto increment mode can be configured by setting "AUTO INCR" bit in the Bank 2 Pointer Register of SMSC LAN91C111. More information can be obtained by referring to the registers of Bank 2 in the SMSC LAN91C111 data sheet. See the References section.

# Example: Cypress Semiconductor's CY7C67300 EZ-Host Programmable Embedded USB Host/Peripheral Controller

The Cypress Semiconductor's CY7C67300 EZ-Host<sup>™</sup> Programmable Embedded USB Host/Peripheral Controller is another example of a peripheral device supported by the AXI EPC IP Core. Since the Cypress USB controller operates in asynchronous mode, the AXI EPC IP Core must be configured to support asynchronous mode operation.

#### Asynchronous Mode

Figure 8 illustrates the CY7C67300 USB Controller connection to the AXI EPC IP Core in asynchronous mode with non-multiplexed address and data buses. This interface is tested in hardware.

The following parameter settings apply for the connection shown in Figure 8.

- C\_PRH\_CLK\_SUPPORT = 0
- C\_PRH0\_AWIDTH = 4
- $C_{PRH0}_{DWIDTH} = 16$
- C\_PRH0\_SYNC = 0
- C\_PRH0\_DWIDTH\_MATCH = 1
- C\_PRH0\_BUS\_MULTIPLEX = 0

#### Configuration of CY7C67300 USB Controller

The CY7C67300 USB Controller is configured as a Host Processor Interface (HPI). The boot-up sequence code for the CY7C67300 USB Controller in this particular example is present on the external CompactFlash memory device and is accessed through the AXI SYSACE interface. This code is downloaded to the CY7C67300 USB Controller through the HPI interface. After this boot-up sequence is executed by the CY7C67300 USB Controller, it becomes ready to operate in normal HPI mode with the external host controller (AXI EPC IP Core). The AXI EPC address bits which corresponds to word boundary are only used in the 2-bit address bus interface with the Cypress Semiconductor's USB device.



Figure 8: CY7C67300 USB Controller Connection to AXI EPC in Asynchronous Mode

#### External FPGA Logic

In the interface diagram example shown in Figure 8, the AXI EPC IP Core, as well as the AXI SYSACE share the interface for data, address and control lines on the board. This requires external multiplex logic to be placed outside of IP cores in the FPGA. The AXI EPC IP Core control signals PRH\_RD\_n and PRH\_WR\_n are MUXed with the MEM\_CEN and MEM\_WEN signals of the AXI SYSACE. When CY7C67300 USB Controller is accessed through the asynchronous mode, the rising edge of sysace\_epc\_rd\_n and sysace\_epc\_wr\_n signals are used to control the read and the write operations respectively. See the References section for more information on AXI SYSACE.

# **Design Constraints**

## **Timing Constraints**

Timing constraints must be placed on the system clock and the peripheral clock, setting the frequency to meet the bus timing requirements. An example is shown in Figure 9.

Following constraint must be placed on the system clock:

NET S\_AXI\_ACLK TNM\_NET = S\_AXI\_ACLK; TIMESPEC TS\_S\_AXI\_ACLK = PERIOD S\_AXI\_ACLK 5 ns HIGH 50%;

If C\_PRH\_CLK\_SUPPORT=1, then the following constraint must be placed on the peripheral clock:

NET PRH\_Clk TNM\_NET = PRH\_Clk; TIMESPEC TS\_PRH\_Clk = PERIOD PRH\_Clk 10 ns HIGH 50%; NET "S\_AXI\_ACLK" TNM\_NET = FFS "GRP\_S\_AXI\_ACLK"; NET "PRH\_Clk" TNM\_NET = FFS "GRP\_PRH\_Clk "; TIMESPEC "TS\_AXI\_PRHCLK\_FALSE\_PATH" = FROM "GRP\_S\_AXI\_ACLK " TO " GRP\_PRH\_Clk" TIG; TIMESPEC "TS\_PRHCLK\_AXI\_FALSE\_PATH" = FROM " GRP\_PRH\_Clk" TO " GRP\_S\_AXI\_ACLK " TIG;

Figure 9: AXI EPC Timing Constraints

# **Design Implementation**

## **Timing Diagrams**

The timing diagrams in the figures show various AXI transactions and the resulting access cycles on the peripheral interface. Timing diagrams are not shown for all possible combinations of generics and the resulting access cycles. However, the timing diagrams shown are sufficient for the basic understanding of various access cycles supported by the AXI EPC IP Core.



*Figure 10:* Synchronous Write-Read Transactions to Device Memory When Bus is Not Multiplexed and Data Width Matching is Disabled (C\_PRH\_CLK\_SUPPORT = 0), Assuming the Peripheral Device is Ready



Figure 11: Synchronous Write and Read Transactions to Device Memory When Bus is Multiplexed and Data Width Matching is Enabled (C\_PRH\_CLK\_SUPPORT = 0)



Figure 12: Synchronous Read and Write Transactions to Device Memory When Bus is Not Multiplexed and Data Width Matching is Enabled (C\_PRH\_CLK\_SUPPORT = 0)



*Figure 13:* Synchronous Read and Write Transactions to Device Memory When Bus is Multiplexed and Data Width Matching is Disabled (C\_PRH\_CLK\_SUPPORT = 0)



*Figure 14:* Asynchronous Write-Read Transactions to Device Memory When Bus is Not Multiplexed and Data Width Matching is Disabled (C\_PRH\_CLK\_SUPPORT = 0)



Figure 15: Asynchronous Read and Write Transactions to Device Memory When Bus is Multiplexed and Data Width Matching is Enabled (C\_PRH\_CLK\_SUPPORT = 0)



*Figure 16:* Asynchronous Read and Write Transactions to Device Memory When Bus is Not Multiplexed and Data Width Matching is Enabled



*Figure 17:* Asynchronous Read and Write Transactions to Device Memory When Bus is Multiplexed and Data Width Matching is Disabled

#### Scenario When the External Device is Not Ready for Transaction

In scenarios where the AXI EPC IP Core has initiated the transaction, but the external peripheral is not ready (PRH\_Rdy signal is not activated), the control signals from the core is extended until the internal C\_PRHx\_RDY\_WIDTH counter expires. The core completes the transaction with error signal generation.

## **Target Technology**

The intended target technology is listed in the Supported Device Family field of the LogiCORE IP Facts Table.

#### **Device Utilization and Performance Benchmarks**

#### **Core Performance**

Because the AXI EPC module is used with other design modules in the FPGA, the utilization and timing numbers reported in this section are estimates. When the AXI EPC module is combined with other designs, the utilization of FPGA resources and timing of the AXI EPC IP Core design varies from the results reported here.

The AXI EPC IP Core resource utilization for various parameter combinations measured with Virtex-7 as the target device are detailed in Table 5.

|                   | Parameter Values (Other Parameters at Default Value) |               |               |             |                      | Devic               | e Resou | rces              | Performance |                        |
|-------------------|------------------------------------------------------|---------------|---------------|-------------|----------------------|---------------------|---------|-------------------|-------------|------------------------|
| C_NUM_PERIPHERALS | C_PRH_CLK_SUPPORT                                    | C_PRHx_AWIDTH | C_PRHx_DWIDTH | C_PRHx_SYNC | C_PRHx_BUS_MULTIPLEX | C_PRHx_DWIDTH_MATCH | Slices  | Slice Flip- Flops | LUTs        | F <sub>Max</sub> (MHz) |
| 1                 | 0                                                    | 3             | 32            | 0           | 0                    | 0                   | 54      | 153               | 109         | 285.796                |
| 2                 | 0                                                    | 12,12         | 32,32         | 0,0         | 0,1                  | 0,0                 | 82      | 187               | 182         | 201.939                |
| 2                 | 1                                                    | 12,12         | 32,32         | 1,1         | 0,1                  | 0,0                 | 63      | 150               | 135         | 217.77                 |
| 3                 | 0                                                    | 6,12,12       | 32,16,8       | 0,0,0       | 0,0,0                | 1,1,1               | 63      | 123               | 132         | 239.866                |
| 3                 | 0                                                    | 12,12,12      | 32,16,8       | 1,1,1       | 0,0,0                | 1,1,1               | 135     | 179               | 323         | 200.844                |
| 3                 | 1                                                    | 12,12,12      | 32,16,8       | 1,1,1       | 1,1,1                | 1,1,1               | 116     | 156               | 296         | 201.329                |
| 4                 | 0                                                    | 12,12,12,12   | 16,8,16,32    | 0,0,0,0     | 0,0,0,0              | 1,1,1,1             | 133     | 171               | 334         | 217.25                 |
| 4                 | 0                                                    | 12,12,12,12   | 32,8,32,8     | 0,0,0,0     | 0,0,0,0              | 0,0,0,0             | 143     | 187               | 332         | 207.426                |

| Table 5: Performance and Resource Utilization Benchmarks for Virtex-7 FPGA | (XC7V855T-FFG1157-3)                                                    |
|----------------------------------------------------------------------------|-------------------------------------------------------------------------|
| Table 5. Ferrormance and Resource of inzation benchmarks for virtex-7 FFGA | $(\Lambda \cup I \vee 0 \cup \cup I = \Gamma \cup I \cup I \cup I = 0)$ |

#### Notes:

The bus multiplex timing parameters and asynchronous timing parameters are set to typical values for all devices. The values used for various timing parameters are as follows:

- C\_PRHx\_ADDR\_TSU = 6 ns
- C\_PRHx\_ADDR\_TH = 6 ns
- C\_PRHx\_ADS\_WIDTH = 10 ns
- C\_PRHx\_CSN\_TSU = 6 ns
- $C_{PRHx}_{CSN}_{TH} = 6 \text{ ns}$
- C\_PRHx\_WRN\_WIDTH = 15 ns
- C\_PRHx\_WR\_CYCLE = 30 ns
- C\_PRHx\_DATA\_TSU = 10 ns
- C\_PRHx\_DATA\_TH = 5 ns
- C\_PRHx\_RDN\_WIDTH = 15 ns
- C\_PRHx\_RD\_CYCLE = 30 ns
- C\_PRHx\_DATA\_TOUT = 5 ns
- C\_PRHx\_DATA\_TINV = 10 ns
- C\_PRHx\_RDY\_TOUT = 10 ns
- C\_PRHx\_RDY\_WIDTH = 50 ns

The AXI EPC IP Core resource utilization for various parameter combinations measured with Kintex-7 and Zynq-7000 as the target devices are detailed in Table 6.

|                   | Parameter Values (Other Parameters at Default Value) |               |               |             |                      |                     | Devic  | e Resou           | rces | Performance            |
|-------------------|------------------------------------------------------|---------------|---------------|-------------|----------------------|---------------------|--------|-------------------|------|------------------------|
| C_NUM_PERIPHERALS | C_PRH_CLK_SUPPORT                                    | C_PRHx_AWIDTH | C_PRHx_DWIDTH | C_PRHx_SYNC | C_PRHx_BUS_MULTIPLEX | C_PRHx_DWIDTH_MATCH | Slices | Slice Flip- Flops | LUTs | F <sub>Max</sub> (MHz) |
| 1                 | 0                                                    | 3             | 32            | 0           | 0                    | 0                   | 59     | 153               | 108  | 239.234                |
| 2                 | 0                                                    | 12,12         | 32,32         | 0,0         | 0,1                  | 0,0                 | 81     | 187               | 194  | 204.583                |
| 2                 | 1                                                    | 12,12         | 32,32         | 1,1         | 0,1                  | 0,0                 | 63     | 150               | 135  | 222.965                |
| 3                 | 0                                                    | 6,12,12       | 32,16,8       | 0,0,0       | 0,0,0                | 1,1,1               | 62     | 123               | 132  | 223.764                |
| 3                 | 0                                                    | 12,12,12      | 32,16,8       | 1,1,1       | 0,0,0                | 1,1,1               | 139    | 179               | 323  | 223.015                |
| 3                 | 1                                                    | 12,12,12      | 32,16,8       | 1,1,1       | 1,1,1                | 1,1,1               | 116    | 156               | 296  | 219.491                |
| 4                 | 0                                                    | 12,12,12,12   | 16,8,16,32    | 0,0,0,0     | 0,0,0,0              | 1,1,1,1             | 132    | 171               | 333  | 234.082                |
| 4                 | 0                                                    | 12,12,12,12   | 32,8,32,8     | 0,0,0,0     | 0,0,0,0              | 0,0,0,0             | 150    | 187               | 333  | 212.089                |

| Table 6: Performance and Resource | Utilization Benchmarks for Kintex- | 7 FPGA <sup>1</sup> and Zvng-7000 Device |
|-----------------------------------|------------------------------------|------------------------------------------|
|                                   |                                    |                                          |

#### Notes:

The bus multiplex timing parameters and asynchronous timing parameters are set to typical values for all devices. The values used for various timing parameters are as follows:

- C\_PRHx\_ADDR\_TSU = 6 ns
- C\_PRHx\_ADDR\_TH = 6 ns
- C\_PRHx\_ADS\_WIDTH = 10 ns
- C\_PRHx\_CSN\_TSU = 6 ns
- $C_{PRHx}_{CSN}_{TH} = 6 \text{ ns}$
- C\_PRHx\_WRN\_WIDTH = 15 ns
- C\_PRHx\_WR\_CYCLE = 30 ns
- C\_PRHx\_DATA\_TSU = 10 ns
- C\_PRHx\_DATA\_TH = 5 ns
- C\_PRHx\_RDN\_WIDTH = 15 ns
- C\_PRHx\_RD\_CYCLE = 30 ns
- C\_PRHx\_DATA\_TOUT = 5 ns
- C\_PRHx\_DATA\_TINV = 10 ns
- C\_PRHx\_RDY\_TOUT = 10 ns
- C\_PRHx\_RDY\_WIDTH = 50 ns

1. Kintex-7 (XC7K410T-FFG676-3)

The AXI EPC IP Core resource utilization for various parameter combinations measured with Artix-7 and Zynq-7000 as the target devices are detailed in Table 7.

|                   | Parameter Values (Other Parameters at Default Value) |               |               |             |                      |                     | Devic  | e Resou           | rces | Performance            |
|-------------------|------------------------------------------------------|---------------|---------------|-------------|----------------------|---------------------|--------|-------------------|------|------------------------|
| C_NUM_PERIPHERALS | C_PRH_CLK_SUPPORT                                    | C_PRHx_AWIDTH | C_PRHx_DWIDTH | C_PRHx_SYNC | C_PRHx_BUS_MULTIPLEX | C_PRHx_DWIDTH_MATCH | Slices | Slice Flip- Flops | LUTs | F <sub>Max</sub> (MHz) |
| 1                 | 0                                                    | 3             | 32            | 0           | 0                    | 0                   | 59     | 153               | 111  | 257.334                |
| 2                 | 0                                                    | 12,12         | 32,32         | 0,0         | 0,1                  | 0,0                 | 94     | 187               | 207  | 202.143                |
| 2                 | 1                                                    | 12,12         | 32,32         | 1,1         | 0,1                  | 0,0                 | 59     | 149               | 139  | 215.378                |
| 3                 | 0                                                    | 6,12,12       | 32,16,8       | 0,0,0       | 0,0,0                | 1,1,1               | 59     | 123               | 130  | 212.224                |
| 3                 | 0                                                    | 12,12,12      | 32,16,8       | 1,1,1       | 0,0,0                | 1,1,1               | 122    | 178               | 317  | 188.111                |
| 3                 | 1                                                    | 12,12,12      | 32,16,8       | 1,1,1       | 1,1,1                | 1,1,1               | 110    | 155               | 296  | 217.817                |
| 4                 | 0                                                    | 12,12,12,12   | 16,8,16,32    | 0,0,0,0     | 0,0,0,0              | 1,1,1,1             | 126    | 171               | 334  | 164.799                |
| 4                 | 0                                                    | 12,12,12,12   | 32,8,32,8     | 0,0,0,0     | 0,0,0,0              | 0,0,0,0             | 131    | 185               | 326  | 186.359                |

| Table 7: Performance and Resource Utilization Benchmarks for Artix-7 FPG | <sup>1</sup> and Zynq-7000 Device |
|--------------------------------------------------------------------------|-----------------------------------|
|--------------------------------------------------------------------------|-----------------------------------|

#### Notes:

The bus multiplex timing parameters and asynchronous timing parameters are set to typical values for all devices. The values used for various timing parameters are as follows:

- C\_PRHx\_ADDR\_TSU = 6 ns
- C\_PRHx\_ADDR\_TH = 6 ns
- C\_PRHx\_ADS\_WIDTH = 10 ns
- C\_PRHx\_CSN\_TSU = 6 ns
- $C_{PRHx}_{CSN}_{TH} = 6 \text{ ns}$
- C\_PRHx\_WRN\_WIDTH = 15 ns
- C\_PRHx\_WR\_CYCLE = 30 ns
- C\_PRHx\_DATA\_TSU = 10 ns
- C\_PRHx\_DATA\_TH = 5 ns
- C\_PRHx\_RDN\_WIDTH = 15 ns
- C\_PRHx\_RD\_CYCLE = 30 ns
- C\_PRHx\_DATA\_TOUT = 5 ns
- C\_PRHx\_DATA\_TINV = 10 ns
- C\_PRHx\_RDY\_TOUT = 10 ns
- C\_PRHx\_RDY\_WIDTH = 50 ns

1. Artix-7 FPGA (XC7A355TDIE)

The AXI EPC IP Core resource utilization for various parameter combinations measured with Virtex-6 as the target device are detailed in Table 8.

|                   | Parameter Values (Other Parameters at Default Value) |               |               |             |                      |                     | Devic  | e Resou           | rces | Performance            |
|-------------------|------------------------------------------------------|---------------|---------------|-------------|----------------------|---------------------|--------|-------------------|------|------------------------|
| C_NUM_PERIPHERALS | C_PRH_CLK_SUPPORT                                    | C_PRHx_AWIDTH | C_PRHx_DWIDTH | C_PRHx_SYNC | C_PRHx_BUS_MULTIPLEX | C_PRHx_DWIDTH_MATCH | Slices | Slice Flip- Flops | LUTs | F <sub>Max</sub> (MHz) |
| 1                 | 0                                                    | 3             | 32            | 0           | 0                    | 0                   | 48     | 153               | 100  | 275                    |
| 2                 | 0                                                    | 12,12         | 32,32         | 0,0         | 0,1                  | 0,0                 | 83     | 187               | 208  | 222                    |
| 2                 | 1                                                    | 12,12         | 32,32         | 1,1         | 0,1                  | 0,0                 | 53     | 121               | 128  | 216                    |
| 3                 | 0                                                    | 6,12,12       | 32,16,8       | 0,0,0       | 0,0,0                | 1,1,1               | 114    | 179               | 317  | 213                    |
| 3                 | 0                                                    | 12,12,12      | 32,16,8       | 1,1,1       | 0,0,0                | 1,1,1               | 113    | 160               | 299  | 205                    |
| 3                 | 1                                                    | 12,12,12      | 32,16,8       | 1,1,1       | 1,1,1                | 1,1,1               | 119    | 169               | 326  | 201                    |
| 4                 | 0                                                    | 12,12,12,12   | 16,8,16,32    | 0,0,0,0     | 0,0,0,0              | 1,1,1,1             | 119    | 189               | 347  | 232                    |
| 4                 | 0                                                    | 12,12,12,12   | 32,8,32,8     | 0,0,0,0     | 0,0,0,0              | 0,0,0,0             | 77     | 173               | 213  | 326                    |

| Table 8: Performance and Resource Utilization Benchmarks for Virtex-6 FPGA  | (XC6VI X130T-FF1156-1)                  |
|-----------------------------------------------------------------------------|-----------------------------------------|
| Table 0. I chormanice and resource offiziation benchmarks for virtex-off of | (////////////////////////////////////// |

#### Notes:

The bus multiplex timing parameters and asynchronous timing parameters are set to typical values for all devices. The values used for various timing parameters are as follows:

- C\_PRHx\_ADDR\_TSU = 6 ns
- C\_PRHx\_ADDR\_TH = 6 ns
- C\_PRHx\_ADS\_WIDTH = 10 ns
- C\_PRHx\_CSN\_TSU = 6 ns
- $C_PRHx_CSN_TH = 6 \text{ ns}$
- C\_PRHx\_WRN\_WIDTH = 15 ns
- C\_PRHx\_WR\_CYCLE = 30 ns
- C\_PRHx\_DATA\_TSU = 10 ns
- $C_{PRHx}_{DATA}_{TH} = 5 \text{ ns}$
- C\_PRHx\_RDN\_WIDTH = 15 ns
- C\_PRHx\_RD\_CYCLE = 30 ns
- C\_PRHx\_DATA\_TOUT = 5 ns
- C\_PRHx\_DATA\_TINV = 10 ns
- C\_PRHx\_RDY\_TOUT = 10 ns
- C\_PRHx\_RDY\_WIDTH = 50 ns

The AXI EPC IP Core resource utilization measured with Spartan-6 as the target device is shown in the following Table 9.

|                   | Parameter Values (Other Parameters at Default Value) |               |               |             |                      |                     | Devid  | e Resou           | irces | Performance            |
|-------------------|------------------------------------------------------|---------------|---------------|-------------|----------------------|---------------------|--------|-------------------|-------|------------------------|
| C_NUM_PERIPHERALS | C_PRH_CLK_SUPPORT                                    | C_PRHx_AWIDTH | C_PRHx_DWIDTH | C_PRHx_SYNC | C_PRHx_BUS_MULTIPLEX | C_PRHx_DWIDTH_MATCH | Slices | Slice Flip- Flops | LUTs  | F <sub>Max</sub> (MHz) |
| 1                 | 0                                                    | 3             | 32            | 0           | 0                    | 0                   | 55     | 153               | 98    | 178                    |
| 2                 | 0                                                    | 12,12         | 32,32         | 0,0         | 0,1                  | 0,0                 | 88     | 190               | 197   | 157                    |
| 2                 | 1                                                    | 12,12         | 32,32         | 1,1         | 0,1                  | 0,0                 | 63     | 124               | 129   | 141                    |
| 3                 | 0                                                    | 6,12,12       | 32,16,8       | 0,0,0       | 0,0,0                | 1,1,1               | 124    | 189               | 330   | 170                    |
| 3                 | 0                                                    | 12,12,12      | 32,16,8       | 1,1,1       | 0,0,0                | 1,1,1               | 103    | 167               | 298   | 158                    |
| 3                 | 1                                                    | 12,12,12      | 32,16,8       | 1,1,1       | 1,1,1                | 1,1,1               | 128    | 169               | 326   | 118                    |
| 4                 | 0                                                    | 12,12,12,12   | 16,8,16,32    | 0,0,0,0     | 0,0,0,0              | 1,1,1,1             | 131    | 197               | 343   | 158                    |
| 4                 | 0                                                    | 12,12,12,12   | 32,8,32,8     | 0,0,0,0     | 0,0,0,0              | 0,0,0,0             | 76     | 176               | 215   | 162                    |

| Table 9: Performance and Resource Utilization Benchmarks for Spa | rtan_6 EPGA (YC6SI YA5T_EGGA84_2) |
|------------------------------------------------------------------|-----------------------------------|
| Table 9. Ferrormance and Resource Offization Benchmarks for Spa  | (1000LA451-F00404-2)              |

#### Notes:

The bus multiplex timing parameters and asynchronous timing parameters are set to typical values for all devices. The values used for various timing parameters are as follows:

- C\_PRHx\_ADDR\_TSU = 6 ns
- C\_PRHx\_ADDR\_TH = 6 ns
- C\_PRHx\_ADS\_WIDTH = 10 ns
- C\_PRHx\_CSN\_TSU = 6 ns
- C\_PRHx\_CSN\_TH = 6 ns
- C\_PRHx\_WRN\_WIDTH = 15 ns
- C\_PRHx\_WR\_CYCLE = 30 ns
- C\_PRHx\_DATA\_TSU = 10 ns
- C\_PRHx\_DATA\_TH = 5 ns
- C\_PRHx\_RDN\_WIDTH = 15 ns
- C\_PRHx\_RD\_CYCLE = 30 ns
- C\_PRHx\_DATA\_TOUT = 5 ns
- C\_PRHx\_DATA\_TINV = 10 ns
- C\_PRHx\_RDY\_TOUT = 10 ns
- C\_PRHx\_RDY\_WIDTH = 50 ns

#### **System Performance**

To measure the system performance ( $F_{Max}$ ) of this core, axi\_epc\_v1\_00\_a core is added to the Spartan-6 and Virtex-6 series as the Device Under Test (DUT) as shown in Figure 18.



Figure 18: Virtex-6 and Spartan-6 Devices F<sub>Max</sub> Margin System

The target FPGA was then filled with logic to drive the LUT and BRAM utilization to approximately 70% and the I/O utilization to approximately 80%. Using the default tool options and the slowest speed grade for the target FPGA, the resulting target  $F_{Max}$  numbers are shown in Table 10.

Table 10: AXI EPC System Performance

| [           | 1                             |
|-------------|-------------------------------|
| Target FPGA | Target F <sub>Max</sub> (MHz) |
| Artix-7     | 110                           |
| Virtex-7    | 180                           |
| Kintex-7    | 180                           |
| Virtex-6    | 180                           |
| Spartan-6   | 110                           |

The target  $F_{Max}$  is influenced by the exact system and is provided for guidance. It is not a guaranteed value across all systems.

# References

To search for Xilinx documentation, go to www.xilinx.com/support.

- 1. DS583, XPS SYSACE (System ACE<sup>TM</sup>) Interface Controller
- 2. DS765, LogiCORE IP AXI4-Lite IPIF (v1.01.a) Data Sheet
- 3. DS768, LogiCORE IP AXI Interconnect Data Sheet
- 4. DS160, Spartan-6 Family Overview
- 5. DS150, Virtex-6 Family Overview
- 6. DS180, 7 Series FPGAs Overview
- 7. <u>UG814</u>, Vivado Design Suite Getting Started Guide
- 8. LAN91C111, 10/100 Non-PCI Ethernet Single Chip MAC + PHY Data Sheet, SMSC
- 9. <u>CY7C67300</u>, EZ-Host™ Programmable Embedded USB Host/Peripheral Controller Data Sheet, Cypress Semiconductor
- 10. ARM® AMBA® AXI4 Protocol Version: 2.0 Specification http://www.arm.com/products/system-ip/amba/amba-open-specifications.php

# **Technical Support**

Xilinx provides technical support at <u>www.xilinx.com/support</u> for this LogiCORE IP product when used as described in the product documentation. Xilinx cannot guarantee timing, functionality, or support of product if implemented in devices that are not defined in the documentation, if customized beyond that allowed in the product documentation, or if changes are made to any section of the design labeled DO NOT MODIFY.

See the IDS Embedded Edition Derivative Device Support web page (<u>www.xilinx.com/ise/embedded/ddsupport.htm</u>) for a complete list of supported derivative devices for this core.

# **Licensing and Ordering Information**

This Xilinx LogiCORE IP module is provided at no additional cost with the Xilinx Vivado Design Suite and ISE Design Suite Embedded Edition tools under the terms of the <u>Xilinx End User License</u>.

Information about this and other Xilinx LogiCORE IP modules is available at the <u>Xilinx Intellectual Property</u> page. For information on pricing and availability of other Xilinx LogiCORE IP modules and tools, contact your <u>local Xilinx sales representative</u>.

## **Revision History**

| Date     | Version | Revision                                                                                                                                                                                                                         |
|----------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 03/01/11 | 1.0     | Initial Xilinx release                                                                                                                                                                                                           |
| 06/22/11 | 2.0     | Updated for Xilinx tools v13.2. Added support for Artix-7, Virtex-7, and Kintex-7 devices.                                                                                                                                       |
| 07/25/12 | 3.0     | <ul> <li>Updated for Vivado and Zynq features with minor document updates for v14.2</li> <li>Added Peripheral clock frequency should always be less to Sync Control Module</li> <li>Added note to C_PRH_CLK_PERIOD_PS</li> </ul> |

# **Notice of Disclaimer**

The information disclosed to you hereunder (the "Materials") is provided solely for the selection and use of Xilinx products. To the maximum extent permitted by applicable law: (1) Materials are made available "AS IS" and with all faults, Xilinx 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) Xilinx 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 connection with, the Materials (including your use of the 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 or loss was reasonably foreseeable or Xilinx had been advised of the possibility of the same. Xilinx assumes no obligation to correct any errors 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 the Limited Warranties which can be viewed at <a href="http://www.xilinx.com/warranty.htm">http://www.xilinx.com/warranty.htm</a>; IP cores may be subject to warranty and support terms contained in a license issued to you by Xilinx. Xilinx 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 use of Xilinx products in Critical Applications: <a href="http://www.xilinx.com/warranty.htm#critapps">http://www.xilinx.com/warranty.htm#critapps</a>.