



# **XPS SYSACE (System ACE)** Interface Controller (v1.01a)

DS583 July 20, 2009 **Product Specification** 

## Introduction

The XPS System ACE Interface Controller (or, interchangeably, the XPS SYSACE) is the interface between the Processor Local Bus (PLB) and the Microprocessor Interface (MPU) of the System ACE<sup>TM</sup> Compact Flash solution peripheral. This module attaches to the PLB.

## **Features**

- Connects as a 32-bit slave on PLB V4.6 buses, which are 32, 64 or 128 bit wide
- The XPS SYSACE is used in conjunction with a System ACE Compact Flash Solution to provide a System ACE memory solution
- System ACE Microprocessor Interface (MPU)
  - Read/Write from or to a Compact Flash device
  - Supports both 8-bit and 16-bit data bus access modes

| LogiCORE™ Facts                     |                                             |                                 |  |
|-------------------------------------|---------------------------------------------|---------------------------------|--|
| С                                   | ore Specifics                               |                                 |  |
| Supported Device<br>Family          | See <u>EDK Support</u><br><u>Families</u> . | ted Device                      |  |
| Version of Core                     | xps_sysace                                  | v1.01a                          |  |
| Re                                  | sources Used                                |                                 |  |
|                                     | Min                                         | Max                             |  |
| Slices                              |                                             |                                 |  |
| LUTs                                | Refer to the Table 9, Table 10 and          | e 7, Table 8, Table<br>Table 11 |  |
| FFs                                 | , , , , , , , , , , , , , , , , , , , ,     |                                 |  |
| Block RAMs                          | N/A                                         |                                 |  |
| Special Features                    | N/A                                         |                                 |  |
| Provided with Core                  |                                             |                                 |  |
| Documentation Product Specification |                                             |                                 |  |
| Design File Formats                 | VHDL                                        |                                 |  |
| Constraints File                    | N/A                                         |                                 |  |
| Verification                        | N/A                                         |                                 |  |
| Instantiation Template              | N/A                                         |                                 |  |
| Additional Items                    | N/A                                         |                                 |  |
| Design                              | Tool Requiremen                             | nts                             |  |
| Xilinx Implementation<br>Tools      |                                             |                                 |  |
| Verification                        | See Tools for requ                          | uirements.                      |  |
| Simulation                          |                                             |                                 |  |
| Synthesis                           |                                             |                                 |  |
|                                     | Support                                     |                                 |  |
| Prov                                | ided by Xilinx, Inc.                        |                                 |  |

© 2007-2009 Xilinx, Inc. XILINX, the Xilinx logo, Virtex, Spartan, ISE 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 XPS SYSACE is composed of the PLB Interface module and the System ACE Interface Controller. The connections between the XPS System ACE Interface Controller, the PLB Interface module, and the Xilinx System ACE Controller device are shown in Figure 1

The XPS SYSACE provides the MPU interface to the Xilinx System ACE Controller Device. The Xilinx System ACE Controller device has multiple interfaces, including CompactFlash, MPU and JTAG. This allow for a highly flexible configuration solution. The MPU interface of the Xilinx System ACE Controller device is composed of a set of registers that provide a means for communicating with CompactFlash control logic, configuration control logic, and other resources in the Xilinx System ACE Controller device. Specifically, this interface can be used to read the identity of a CompactFlash device and read/write sectors. The XPS System ACE Interface Controller provides a means of communicating with the registers and data buffers that correspond to the CompactFlash device in the Xilinx System ACE Controller device, via the PLB. Refer to the System ACE Interface Controller Flash chip document mentioned in the Reference Documents section for detailed information on the operation of the MPU interface, the MPU interface register address map.

The XPS System ACE Interface Controller allows for the registers and data buffers of the Xilinx System ACE Controller device, to be accessed in a 8-bit and 16-bit data bus access mode. The two modes are differentiated by the means of the parameter C\_MEM\_WIDTH, as follows:

- 8-bit mode(C\_MEM \_WIDTH = 8): The registers are accessed in a 8-bit data bus access mode. In this
  mode, the registers of the Xilinx System ACE Controller device should be accessed via byte accesses
  only.
- 16-bit mode(C\_MEM\_WIDTH = 16): The registers are accessed in a 16-bit data bus access mode. In this mode, the registers of the Xilinx System ACE Controller device should be accessed via halfword accesses only.

For example, a typical register like the Bus Mode register, is accessed by addresses "00h" and "01h" in the 8-bit access mode. It would be accessed by address "00h" in the 16-bit access mode.

The software drivers use the C\_MEM\_WIDTH parameter to configure the Xilinx System ACE Bus Mode register (setting the Xilinx System ACE MPU data bus access width to the desired mode) and to access the registers with the proper type of transaction.





Notes:

- 1. SysACE\_MPD is formed in the IOB from SysACE\_MPD\_I, SysACE\_MPD\_0, and SysACE\_MPD\_T.
- 2. SysACE\_IRQ should be connected to the interrupt input of the processor.
- 3. SysACE\_Clk should be connected to a global clock buffer by the user.

Figure 1: XPS System ACE Interface Controller Block Diagram

## **PLB Interface Module**

PLB Interface Module provides an interface between XPS System ACE Interface Controller and the PLB. The PLB Interface Module implements the basic functionality of a PLB slave and does the necessary protocol and timing translation between the PLB and the IPIC interface. PLB Interface Module supports only single beat transactions.

## **System ACE Interface Controller**

The System ACE interface controller contains a controller state machine and logic to synchronize signals across the SPLB\_Clk and SysACE\_Clk domains as shown in Figure 2.





Figure 2: System ACE Interface Controller Diagram

The XPS System ACE Interface Controller core does not contain any internal registers or addressable memory space, therefore the mapping of PLB address bus is one-to-one with the System ACE address bus (SysACE\_MPA) as shown in Table 1.

Table 1: PLB Address Bus to System ACE Address Bus Mapping (done in IP core)

| PLB Address Bus   | System ACE Address Bus |
|-------------------|------------------------|
| PLB_ABus[25 : 31] | SysACE_MPA[6:0]        |

The Xilinx System ACE Compact Flash chip is a true little-endian device and the PLB is a big-endian bus. Therefore the XPS System ACE Interface Controller will do a bit-swap in each byte when connecting the PLB data bus to the System ACE data bus as shown in Table 2.

Table 2: PLB Data Bus to System ACE Data Bus Mapping (done in IP core)

| PLB Data Bus     | System ACE Data Bus |
|------------------|---------------------|
| PLB_DBus[8 : 15] | SysACE_MPD[15:8]    |
| PLB_DBus[0 : 7]  | SysACE_MPD[7:0]     |

Note however, that the XPS System ACE Interface Controller does not perform the byte swapping necessary to interface to a little-endian device when configured to use 16-bit mode. Therefore, the software drivers provided for this core will perform the necessary byte-swapping to correctly interface to the Xilinx System ACE Compact Flash chip as shown in Table 3.



| Byte | PLB Data Bus     | System ACE Data Bus |
|------|------------------|---------------------|
| MSB  | PLB_DBus[0 : 7]  | SysACE_MPD[15 : 8]  |
| LSB  | PLB_DBus[8 : 15] | SysACE_MPD[7:0]     |

Table 3: PLB Big Endian to System ACE Little Endian Conversion (done in software driver)

## Clocking - SYNC\_2\_CLKS Module

The controller state machine runs on the SysACE\_Clk. The IPIC signals indicating the start of a transaction are synchronized to the System ACE clock and used to start the state machine. All address, data and control signals that are output to the System ACE Compact Flash chip are synchronized to the SysACE\_Clk and registered in the FPGA IO registers using SysACE\_Clk to ensure a clean interface between this chip and the FPGA. Data from the System ACE Compact Flash chip is also registered in FPGA IO registers using SysACE\_Clk. It is then synchronized to the SPLB\_Clk for transmission on the bus. The frequency of the SysACE\_Clk must be less than the frequency of the SPLB\_Clk.

Note that the address and data (if a write transaction) from the PLB will stay stable during the entire bus transaction and therefore would not have to be synchronized and output using the SysACE\_Clk. This was done to provide a robust design, however, if the overall FPGA design is limited on resources, these synchronization registers could possibly be removed. The user is cautioned to analyze timing before removing these registers.

Also note that this core does not instantiate a global clock buffer for SysACE\_Clk. This is left for the user to instantiate based on the resource requirements of their system.

## System ACE Control state machine - MEM\_STATE\_MACHINE Module

The state machine in the System ACE Interface controller performs the specified transaction to the MPU interface of System ACE Compact Flash chip and is shown in Figure 3. This state machine is clocked by SysACE\_Clk and therefore outputs all System ACE control signals synchronous to this clock. The input control signals from the PLB Interface Module have been synchronized to the SysACE\_Clk in the sync\_2\_clocks module.



Figure 3: System ACE Interface Control State Machine



# **XPS System ACE Interface Controller I/O Signals**

The I/O signals for the XPS System ACE Interface Controller are listed and described in Table 4.

Table 4: XPS System ACE Interface Controller I/O Signals

| Port | Signal Name                            | Interface      | I/O | Initial<br>State | Description                                      |  |
|------|----------------------------------------|----------------|-----|------------------|--------------------------------------------------|--|
|      | System S                               | Signals        |     | •                |                                                  |  |
| P1   | SPLB_Clk                               | PLB            | I   | -                | PLB clock                                        |  |
| P2   | SPLB_Rst                               | PLB            | I   | -                | PLB reset, active high                           |  |
|      | PLB Interfac                           | e Signals      | 1   | I.               |                                                  |  |
| P3   | PLB_ABus[0 : C_SPLB_AWIDTH - 1]        | PLB            | I   | -                | PLB address bus                                  |  |
| P4   | PLB_PAValid                            | PLB            | I   | -                | PLB primary address valid                        |  |
| P5   | PLB_MasterID[0 : C_SPLB_MID_WIDTH - 1] | PLB            | ı   | -                | PLB current master identifier                    |  |
| P6   | PLB_RNW                                | PLB            | I   | -                | PLB read not write                               |  |
| P7   | PLB_BE[0 : C_SPLB_DWIDTH/8 - 1]        | PLB            | I   | -                | PLB byte enables                                 |  |
| P8   | PLB_Size[0:3]                          | PLB            | I   | -                | PLB size of requested transfer                   |  |
| P9   | PLB_type[0:2]                          | PLB            | I   | -                | PLB transfer type                                |  |
| P10  | PLB_wrDBus[0 : C_SPLB_DWIDTH - 1]      | PLB            | I   | -                | PLB write data bus                               |  |
|      | Unused PLB Inte                        | erface Signals | 3   | 1                |                                                  |  |
| P11  | PLB_UABus[0 : C_SPLB_AWIDTH - 1]       | PLB            | I   | -                | PLB Upper Address bits                           |  |
| P12  | PLB_SAValid                            | PLB            | I   | -                | PLB secondary address valid                      |  |
| P13  | PLB_rdPrim                             | PLB            | I   | -                | PLB secondary to primary read request indicator  |  |
| P14  | PLB_wrPrim                             | PLB            | I   | -                | PLB secondary to primary write request indicator |  |
| P15  | PLB_abort                              | PLB            | I   | -                | PLB abort bus request                            |  |
| P16  | PLB_busLock                            | PLB            | I   | -                | PLB bus lock                                     |  |
| P17  | PLB_MSize[0:1]                         | PLB            | I   | -                | PLB data bus width indicator                     |  |
| P18  | PLB_TAttribute[0 : 15]                 | PLB            | I   | -                | PLB transfer attribute                           |  |
| P19  | PLB_lockerr                            | PLB            | I   | -                | PLB lock error                                   |  |
| P20  | PLB_wrBurst                            | PLB            | I   | -                | PLB burst write transfer                         |  |
| P21  | PLB_rdBurst                            | PLB            | I   | -                | PLB burst read transfer                          |  |



Table 4: XPS System ACE Interface Controller I/O Signals (Contd)

| Port | Signal Name                           | Interface      | I/O  | Initial<br>State      | Description                          |
|------|---------------------------------------|----------------|------|-----------------------|--------------------------------------|
| P22  | PLB_wrPendReq                         | PLB            | I    | -                     | PLB pending bus write request        |
| P23  | PLB_rdPendReq                         | PLB            | I    | -                     | PLB pending bus read request         |
| P24  | PLB_rdPendPri[0 : 1]                  | PLB            | I    | -                     | PLB pending write request priority   |
| P25  | PLB_wrPendPri[0 : 1]                  | PLB            | I    | -                     | PLB pending read request priority    |
| P26  | PLB_reqPri[0 : 1]                     | PLB            | Ι    | -                     | PLB current request priority         |
|      | PLB Slave Inte                        | face Signals   |      |                       |                                      |
| P27  | SI_addrack                            | PLB            | 0    | 0                     | Slave address acknowledge            |
| P28  | SI_Ssize[0:1]                         | PLB            | 0    | 0                     | Slave data bus size                  |
| P29  | SI_wait PLB O 0                       |                | 0    | Slave wait            |                                      |
| P30  | SI_rearbitrate PLB O 0                |                | 0    | Slave bus rearbitrate |                                      |
| P31  | SI_wrDack                             | PLB            | 0    | 0                     | Slave write data acknowledge         |
| P32  | SI_wrComp                             | PLB            |      | 0                     | Slave write transfer complete        |
| P33  | SI_rdBus[0 : C_SPLB_DWIDTH - 1]       | PLB            | 0    | 0                     | Slave read data bus                  |
| P34  | SI_rdDack                             | PLB            | 0    | 0                     | Slave read data acknowledge          |
| P35  | SI_rdComp                             | PLB            | 0    | 0                     | Slave read transfer complete         |
| P36  | SI_Mbusy[0 : C_SPLB_NUM_MASTERS - 1]  | PLB            | 0    | 0                     | Slave busy                           |
| P37  | SI_MWrErr[0 : C_SPLB_NUM_MASTERS - 1] | PLB            | 0    | 0                     | Slave write error                    |
| P38  | SI_MRdErr[0 : C_SPLB_NUM_MASTERS - 1] | PLB            | 0    | 0                     | Slave read error                     |
|      | Unused PLB Slave                      | Interface Sigr | nals |                       |                                      |
| P39  | SI_wrBTerm                            | PLB            | 0    | 0                     | Slave terminate write burst transfer |
| P40  | SI_rdWdAddr[0 : 3]                    | PLB            | 0    | 0                     | Slave read word address              |
| P41  | SI_rdBTerm                            | PLB            | 0    | 0                     | Slave terminate read burst transfer  |
| P42  | SI_MIRQ[0:C_SPLB_NUM_MASTERS - 1]     | PLB            | 0    | 0                     | Master interrupt request             |
|      | System ACI                            | E Signals      |      |                       |                                      |



Table 4: XPS System ACE Interface Controller I/O Signals (Contd)

| Port | Signal Name                   | Interface          | I/O  | Initial<br>State | Description                                |  |
|------|-------------------------------|--------------------|------|------------------|--------------------------------------------|--|
| P43  | SysACE_Clk <sup>[1]</sup>     | System<br>Ace Core | I    | -                | System ACE Clock                           |  |
| P44  | SysACE_MPIRQ                  | System<br>Ace Core | I    | -                | System ACE Active high Interrupt Input     |  |
| P45  | SysACE_CEN                    | System<br>Ace Core | 0    | 1                | System ACE Chip<br>Enable                  |  |
| P46  | SysACE_OEN                    | System<br>Ace Core | - () |                  | System ACE Enable                          |  |
| P47  | SysACE_WEN                    | System<br>Ace Core | 0    | 1                | System ACE Write Enable                    |  |
| P48  | SysACE_MPA[6:0]               | System<br>Ace Core | 0    | 0                | System ACE Address                         |  |
| P49  | SysACE_MPD_I[C_MEM_WIDTH-1:0] | System<br>Ace Core | I    | -                | System ACE Data<br>Input                   |  |
| P50  | SysACE_MPD_O[C_MEM_WIDTH-1:0] | System<br>Ace Core | 0    | 0                | System ACE Data<br>Ouput                   |  |
| P51  | SysACE_MPD_T[C_MEM_WIDTH-1:0] | System<br>Ace Core | 0    | 1                | System ACE Data<br>Output enable           |  |
| P52  | SysACE_IRQ <sup>[2]</sup>     | System<br>Ace Core | 0    | 0                | System ACE Active<br>High Interrupt Output |  |

## Notes:

8

- 1. SPLB\_Clk frequency must be greater than or equal to SysACE\_Clk Frequency
- 2. This interrupt output is just a pass-through of the System ACE interrupt (SysACE\_MPIRQ) and should be connected to an interrupt controller or directly to the processor's interrupt input

# **XPS System ACE Interface Controller Design Parameters**

To allow the designer to obtain a XPS SYSACE core that is uniquely tailored for the designer's system, certain features can be parameterized. Some of these parameters control the interface to the PLB interface module while others provide information to minimize resource utilization. The features that can be parameterized in the XPS SYSACE are shown in Table 5.

Table 5: XPS System ACE Interface Controller Parameters

| Generic | Feature/Description                                           | Parameter Name | Allowable<br>Values          | Default<br>Value    | VHDL<br>Type         |  |  |
|---------|---------------------------------------------------------------|----------------|------------------------------|---------------------|----------------------|--|--|
|         | System Parameter                                              |                |                              |                     |                      |  |  |
| G1      | G1 Target FPGA family C_FAMILY See C_FAMILY parameter values. |                |                              |                     |                      |  |  |
|         | PLB Parameters                                                |                |                              |                     |                      |  |  |
| G2      | PLB System ACE Base<br>Address                                | C_BASEADDR     | Valid Address <sup>[1]</sup> | None [1]            | std_logic_<br>vector |  |  |
| G3      | PLB System ACE High<br>Address                                | C_HIGHADDR     | Valid Address <sup>[1]</sup> | None <sup>[1]</sup> | std_logic_<br>vector |  |  |

0

16

integer

integer



| Generic | Feature/Description                           | Parameter Name           | Allowable<br>Values                                                       | Default<br>Value | VHDL<br>Type |
|---------|-----------------------------------------------|--------------------------|---------------------------------------------------------------------------|------------------|--------------|
| G4      | PLB address width                             | C_SPLB_AWIDTH            | 32                                                                        | 32               | integer      |
| G5      | PLB data width                                | C_SPLB_DWIDTH            | 32, 64, 128                                                               | 32               | integer      |
| G6      | Selects point-to-point or shared bus topology | C_SPLB_P2P               | 0 = Shared Bus<br>Topology                                                | 0                | integer      |
| G7      | PLB Master ID Bus Width                       | C_SPLB_MID<br>_WIDTH     | log <sub>2</sub> (C_SPLB_<br>NUM_MASTERS)<br>with a minimum<br>value of 1 | 8                | integer      |
| G8      | Number of PLB Masters                         | C_SPLB_NUM<br>_MASTERS   | 1 - 16                                                                    | 3                | integer      |
| G9      | Width of the Slave Data Bus                   | C_SPLB_NATIVE<br>_DWIDTH | 32                                                                        | 32               | integer      |
|         | Sologte the transactions as                   | C SDI B SLIDDODT         | 0 = Supports only                                                         |                  |              |

Table 5: XPS System ACE Interface Controller Parameters (Contd)

#### Notes:

G10

G11

C\_SPLB\_SUPPORT

System ACE Parameters

C\_MEM\_WIDTH

BURSTS

single beat

transactions

8, 16

#### Allowable Parameter Combinations

Selects the transactions as

System ACE MPU Data Bus

Access Mode<sup>[2]</sup>

being single beat or burst

The address-range size of the XPS System ACE Interface Controller must be a power of 2. If the desired address-range size is represented by  $2^n$ , then the n least significant bits of the base address must be 0. C\_BASEADDR and C\_HIGHADDR must specify an address range whose size is at least 0x80, to cover the addressable registers and data buffer available in the Xilinx System Ace Compact Flash chip.

# XPS System ACE Interface Controller Parameter-Port Dependencies

The dependencies between the XPS System ACE Interface Controller design parameters and I/O signals are described in Table 6. In addition, when certain features are parameterized out of the design, the related logic will no longer be a part of the design. The unused input signals and related output signals are set to a specified value.

Table 6: XPS System ACE Interface Controller Parameter-Port Dependencies

| Generic or Port | Parameter     | Affects            | Depends | Relationship Description     |
|-----------------|---------------|--------------------|---------|------------------------------|
|                 |               | Design Para        | ameters |                              |
| G4              | C_SPLB_AWIDTH | P3                 | -       | Width of the PLB Address Bus |
| G5              | C_SPLB_DWIDTH | P7,<br>P10,<br>P33 | -       | Width of the PLB Data Bus    |

The range specified by C\_BASEADDR and C\_HIGHADDR must be sized and aligned to some power of 2, 2<sup>n</sup>. Then, the n least significant bits of C\_BASEADDR is zero. This range needs to encompass the addresses needed by the XPS SYSACE registers

<sup>2.</sup> Please refer to Xilinx DS080, System ACE Compact Flash Solution, for more information



Table 6: XPS System ACE Interface Controller Parameter-Port Dependencies (Contd)

| Generic<br>or Port | Parameter          | Affects          | Depends | Relationship Description                                  |
|--------------------|--------------------|------------------|---------|-----------------------------------------------------------|
| G7                 | C_SPLB_MID_DWIDTH  | P5               | G8      | Width of Master ID Bus                                    |
| G8                 | C_SPLB_NUM_MASTERS | P36,P37,<br>P38  | -       | The number of Master Devices connected to PLB bus         |
| G11                | C_MEM_WIDTH        | P49, P50,<br>P51 | -       | Width of the System ACE Data<br>Bus                       |
|                    |                    | I/O Sigr         | nals    |                                                           |
| P3                 | PLB_ABus           | -                | G4      | Width varies with the width of the PLB Address Bus        |
| P5                 | PLB_MasterID       | -                | G7      | Width varies with the MID width                           |
| P7                 | PLB_BE             | -                | G5      | Width varies with the width of the PLB Data Bus           |
| P10                | PLB_wrDBus         | -                | G5      | Width varies with the width of the PLB Data Bus           |
| P33                | SI_rdBus           | -                | G5      | Width varies with the width of the PLB Data Bus           |
| P36                | SI_MBusy           | -                | G8      | Width varies with the number of masters                   |
| P37                | SI_MWrErr          | -                | G8      | Width varies with the number of masters                   |
| P38                | SI_MRdErr          | -                | G8      | Width varies with the number of masters                   |
| P49                | SysACE_MPD_I       | -                | G11     | Width varies with the width of the<br>System ACE Data Bus |
| P50                | SysACE_MPD_O       | -                | G11     | Width varies with the width of the<br>System ACE Data Bus |
| P51                | SysACE_MPD_T       | -                | G11     | Width varies with the width of the<br>System ACE Data Bus |

# **XPS System ACE Timing Diagrams**

10

This section contains timing diagrams showing the register read and write accesses to the Xilinx System ACE Interface controller. Note that the System ACE clock is not driven from this core, it is an input to this core. Also note the byte swapping that occurs during the register accesses. The Figure 4 and Figure 5 show the 8-bit register write and read cycles.





Figure 4: XPS System ACE 8-bit Register Write



Figure 5: XPS System ACE 8-bit Register Read







Figure 6: XPS System ACE 16-bit Register Write



Figure 7: XPS System ACE 16-bit Register Read



# **Design Implementation**

## **Target Technology**

The target technology is an FPGA listed in **EDK Supported Device Families**.

## **Device Utilization and Performance Benchmarks**

## **Core Performance**

Since the XPS System ACE Controller will be used with other design modules in the FPGA, the utilization and timing numbers reported in this section are just estimates. When the XPS System ACE Interface Controller is combined with other designs in the system, the utilization of FPGA resources and timing will vary from the results reported here.

The XPS System ACE Interface Controller benchmarks are shown in Table 7, Table 8, Table 9, Table 10 and Table 11 for Virtex®-4, Virtex-5, Spartan®-3adsp, Virtex-6 and Spartan-6 FPGAs respectively.

Table 7: Performance and Resource Utilization Benchmarks for Virtex-4 (xc4vlx40-ff668-10)

| Parameter Values |            |            | Device Resources        |     |      | Performance                  |
|------------------|------------|------------|-------------------------|-----|------|------------------------------|
| C_MEM_WIDTH      | C_BASEADDR | C_HIGHADDR | Slices Slice Flip-Flops |     | LUTs | F <sub>max</sub><br>(in MHz) |
| 8                | 30000000   | 3FFFFFF    | 204                     | 287 | 147  | 145.815                      |
| 16               | 30000000   | 3FFFFFF    | 218                     | 313 | 148  | 145.603                      |

Table 8: Performance and Resource Utilization Benchmarks for Virtex-5 (xc5vlx30-ff676-1)

| Parameter Values |            |            | Device Reso         | Performance |                              |
|------------------|------------|------------|---------------------|-------------|------------------------------|
| C_MEM_WIDTH      | C_BASEADDR | C_HIGHADDR | Slice<br>Flip-Flops | LUTs        | F <sub>max</sub><br>(in MHz) |
| 8                | 3000000    | 3FFFFFF    | 287                 | 112         | 213.129                      |
| 16               | 3000000    | 3FFFFFF    | 311                 | 111         | 212.089                      |

Table 9: Performance and Resource Utilization Benchmarks for Spartan-3adsp (xc3sd3400a-fg676-4)

| Parameter Values |            | Device Resources |        |                     | Performance |                              |
|------------------|------------|------------------|--------|---------------------|-------------|------------------------------|
| C_MEM_WIDTH      | C_BASEADDR | C_HIGHADDR       | Slices | Slice<br>Flip-Flops | LUTs        | F <sub>max</sub><br>(in MHz) |
| 8                | 3000000    | 3FFFFFF          | 240    | 287                 | 117         | 124.301                      |
| 16               | 30000000   | 3FFFFFF          | 252    | 311                 | 109         | 102.828                      |



Table 10: Performance and Resource Utilization Benchmarks for Virtex-6 (xc6vlx130t-1-ff1156)

| Parameter Values |            |            | Device Resources |                     |      | Performance                  |
|------------------|------------|------------|------------------|---------------------|------|------------------------------|
| C_MEM_WIDTH      | C_BASEADDR | C_HIGHADDR | Slices           | Slice<br>Flip-Flops | LUTs | F <sub>max</sub><br>(in MHz) |
| 8                | 3000000    | 3FFFFFF    | 78               | 268                 | 188  | 257                          |
| 16               | 30000000   | 3FFFFFF    | 75               | 343                 | 233  | 267                          |

Table 11: Performance and Resource Utilization Benchmarks for Spartan-6 (xc6slx45t-2-fgg484)

| Parameter Values |            |            | Device Resources |                     |      | Performance                  |
|------------------|------------|------------|------------------|---------------------|------|------------------------------|
| C_MEM_WIDTH      | C_BASEADDR | C_HIGHADDR | Slices           | Slice<br>Flip-Flops | LUTs | F <sub>max</sub><br>(in MHz) |
| 8                | 30000000   | 3FFFFFF    | 74               | 268                 | 168  | 153                          |
| 16               | 30000000   | 3FFFFFF    | 83               | 344                 | 216  | 151                          |

## **System Performance**

To measure the system performance ( $F_{MAX}$ ) of this core, this core was added to a Virtex-4 system, a Virtex-5 system, and a Spartan-3ADSP system as the Device Under Test (DUT) as shown in Figure 8, Figure 9, and Figure 10.

Because the XPS SYSACE Controller core will be used with other design modules in the FPGA, the utilization and timing numbers reported in this section are estimates only. When this core is combined with other designs in the system, the utilization of FPGA resources and timing of the core design will vary from the results reported here.



Figure 8: Virtex-4 FX System





Figure 9: Virtex-5 FXT System



Figure 10: Spartan-3ADSP 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 15.

Table 12: XPS SYSACE Controller Core System Performance

| Target FPGA | Target F <sub>MAX</sub> (MHz) |
|-------------|-------------------------------|
| S3D3400 -4  | 100                           |
| V4FX60 -10  | 125                           |
| V5FXT70 -1  | 150                           |

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

# **Support**

DS583 July 20, 2009 <u>www.xilinx.com</u> 15



Xilinx provides technical support for this LogiCORE 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*.

## **Reference Documents**

The following documents contain reference information important to understanding the XPS Sysace Controller design:

- 1. IBM 128-Bit Processor Local Bus, Architecture Specifications, v4.6
- 2. System Ace: Configuration Solution for Xilinx FPGAs
- 3. DS080 System ACE Compact Flash Solution

# **Revision History**

| Date       | Version | Revision                                                                                                          |
|------------|---------|-------------------------------------------------------------------------------------------------------------------|
| 03/08/07   | 1.0     | Initial Xilinx release                                                                                            |
| 10/1/2007  | 1.2     | Added FMax Margin System Performance section; in Table 5, updated Generics G7 and G8 Default Values per CR442353. |
| 11/27/2007 | 1.3     | Added SP-3A DSP support.                                                                                          |
| 1/14/08    | 1.4     | Added Virtex-II Pro support.                                                                                      |
| 4/21/08    | 1.5     | Added Automotive Spartan-3E, Automotive Spartan-3A, and Automotive Spartan-3A DSP support.                        |
| 7/21/08    | 1.6     | Added QPro Virtex-4 Hi-Rel and QPro Virtex-4 Rad Tolerant support.                                                |
| 10/16/08   | 1.7     | Updated for xps_sysace_v1_01_a version.                                                                           |
| 4/24/09    | 1.8     | Replaced references to supported device families and tool name(s) with hyperlink to PDF file.                     |
| 7/20/09    | 1.9     | Added Resource Utilization Tables for S6 / V6 Devices.                                                            |



## **Notice of Disclaimer**

Xilinx is providing this product documentation, hereinafter "Information," to you "AS IS" with no warranty of any kind, express or implied. Xilinx makes no representation that the Information, or any particular implementation thereof, is free from any claims of infringement. You are responsible for obtaining any rights you may require for any implementation based on the Information. All specifications are subject to change without notice. XILINX EXPRESSLY DISCLAIMS ANY WARRANTY WHATSOEVER WITH RESPECT TO THE ADEQUACY OF THE INFORMATION OR ANY IMPLEMENTATION BASED THEREON, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OR REPRESENTATIONS THAT THIS IMPLEMENTATION IS FREE FROM CLAIMS OF INFRINGEMENT AND ANY IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Except as stated herein, none of the Information may be copied, reproduced, distributed, republished, downloaded, displayed, posted, or transmitted in any form or by any means including, but not limited to, electronic, mechanical, photocopying, recording, or otherwise, without the prior written consent of Xilinx.