



# **XPS General Purpose** Input/Output (GPIO) (v2.00.a)

DS569 Apr 19, 2010 **Product Specification** 

## Introduction

This document describes the specifications for the General Purpose Input/Output (GPIO) core for the Processor Local Bus (PLB). The XPS GPIO is a 32-bit peripheral that attaches to the PLBv4.6.

## **Features**

- Connects as a 32-bit slave on PLB v4.6 bus of 32, 64 or 128 bits
- Configurable as single or dual GPIO channel(s)
- Number of GPIO bits configurable from 1 to 32 bits
- Each GPIO bit can be dynamically programmed as input or output
- Width of each of the channels can be individually configured
- Independent reset values for each bit of all registers
- Optional interrupt request generation

| LogiCORE™ Facts                       |                                             |                                     |  |  |  |
|---------------------------------------|---------------------------------------------|-------------------------------------|--|--|--|
| С                                     | ore Specifics                               |                                     |  |  |  |
| Supported Device Family               | See <u>EDK Support</u><br><u>Families</u> . | ted Device                          |  |  |  |
| Version of Core                       | xps_gpio v2.00.a                            |                                     |  |  |  |
| Re                                    | Resources Used                              |                                     |  |  |  |
|                                       | Min                                         | Max                                 |  |  |  |
| Slices                                |                                             |                                     |  |  |  |
| LUTs                                  |                                             | able 12, Table<br>e 15 and Table 16 |  |  |  |
| FFs                                   |                                             |                                     |  |  |  |
| Block RAMs                            | N/A                                         |                                     |  |  |  |
| Provided with Core                    |                                             |                                     |  |  |  |
| Documentation                         | Product Specification                       |                                     |  |  |  |
| Design File Formats                   | VHDL                                        |                                     |  |  |  |
| Constraints File                      | N/A                                         |                                     |  |  |  |
| Verification                          | N/A                                         |                                     |  |  |  |
| Instantiation Template                | N/A                                         |                                     |  |  |  |
| Reference Designs & Application Notes | N/A                                         |                                     |  |  |  |
| Design                                | Tool Requiremen                             | nts                                 |  |  |  |
| Xilinx Implementation<br>Tools        |                                             |                                     |  |  |  |
| Verification                          | See <u>Tools</u> for requ                   | uirements.                          |  |  |  |
| Simulation                            |                                             |                                     |  |  |  |
| Synthesis                             |                                             |                                     |  |  |  |
|                                       | Support                                     |                                     |  |  |  |
| Prov                                  | ided by Xilinx, Inc.                        |                                     |  |  |  |

© 2006-2010 Xilinx, Inc. All rights reserved. All Xilinx trademarks, registered trademarks, and further disclaimers are as listed at <a href="http://www.xilinx.com/legal.htm">http://www.xilinx.com/legal.htm</a>. All other trademarks and registered trademarks are the property of their respective owners. All specifications are subject to change without notice.

NOTICE OF DISCLAIMER: Xilinx is providing this design, code, or information "as is." By providing the design, code, or information as one possible implementation of this feature, application, or standard, Xilinx makes no representation that this implementation is free from any claims of infringement. You are responsible for obtaining any rights you may require for your implementation. Xilinx expressly disclaims any warranty whatsoever with respect to the adequacy of the implementation, 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.



## **Functional Description**

The XPS GPIO design provides a general purpose input/output interface to a Processor Local Bus (PLB). The XPS GPIO can be configured as either a single or a dual channel device. The channel width is configurable and when both channels are enabled, the channel width of each of the channels can be configured individually.

The ports can be configured dynamically for input or output by enabling or disabling the 3-state buffer. The channels may be configured to generate an interrupt when a transition on any of their inputs occurs.

The major interfaces and modules of the design are shown in Figure 1 and described in the subsequent sections. The XPS GPIO core is comprised of modules:

- PLB Interface Module
- Interrupt Control
- GPIO core



Figure 1: XPS GPIO Block Diagram

## **PLB Interface Module**

PLB Interface module provides an interface between the GPIO core and the PLBV4.6 bus standard. The PLB Interface module implements the basic functionality of PLB slave operation and does the necessary protocol and timing translation between the PLB and the IPIC interfaces. The PLB Interface module allows only single beat transactions.

# Interrupt Control

2

Interrupt Controller provides interrupt capture support for the GPIO core. The Interrupt Controller is used to collect interrupts from the GPIO core, by which the GPIO core requests the attention of the microprocessor through the assertion of interrupt signals. The Interrupt Control module comes into the picture only when the C\_INTERRUPT\_PRESENT generic is set to 1.(For mor e information on the generics, refer Table 2)



## **GPIO Core**

GPIO core provides an interface between the IPIC interface and the XPS GPIO channels. The GPIO core consists of registers and multiplexers for reading and writing the XPS GPIO channel registers. It also includes the necessary logic to identify an interrupt event when the channel input changes.

Figure 2 shows a detailed diagram of the dual channel implementation of the GPIO core. The 3-state buffers in the figure are not actually part of the core. The 3-state buffers are added in the synthesis process, usually automatically, with an Add I/Os option. The control signals of the IPIC interface are not shown in Figure 2

.



Figure 2: GPIO\_CORE Dual Channel Implementation



# **XPS GPIO I/O Signals**

The I/O signals for this reference design are listed in Table 1.

Table 1: XPS GPIO I/O Signals

| Port           | Signal Name                        | Interface      | I/O  | Initial<br>State | Description                                      |  |  |  |  |
|----------------|------------------------------------|----------------|------|------------------|--------------------------------------------------|--|--|--|--|
| System Signals |                                    |                |      |                  |                                                  |  |  |  |  |
| P1             | SPLB_Clk                           | PLB            | I    | -                | PLB clock                                        |  |  |  |  |
| P2             | SPLB_Rst                           | PLB            | I    | -                | PLB reset, active high                           |  |  |  |  |
|                | PLB Interface Signals              |                |      |                  |                                                  |  |  |  |  |
| 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            | I    | -                | 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                         | Interface Sign | nals |                  |                                                  |  |  |  |  |
| 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                          |  |  |  |  |
| P22            | PLB_wrPendReq                      | PLB            | I    | -                | PLB pending bus write request                    |  |  |  |  |
| P23            | PLB_rdPendReq                      | PLB            | I    | -                | PLB pending bus read request                     |  |  |  |  |



Table 1: XPS GPIO I/O Signals (Contd)

| Port | Signal Name                       | Interface         | I/O     | Initial<br>State | Description                              |
|------|-----------------------------------|-------------------|---------|------------------|------------------------------------------|
| 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               | I       | -                | PLB current request priority             |
|      | PLB Slave I                       | nterface Signa    | als     | l .              | 1                                        |
| 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               | 0       | 0                | Slave wait                               |
| P30  | SI_rearbitrate                    | PLB               | 0       | 0                | Slave bus rearbitrate                    |
| P31  | SI_wrDaclk                        | PLB               | 0       | 0                | Slave write data acknowledge             |
| P32  | SI_wrComp                         | PLB               | 0       | 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 Sla                    | ve Interface S    | Signals | 3                |                                          |
| 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                 |
|      | GPIO Inte                         | rface Signals     |         |                  |                                          |
| P43  | IP2INTC_Irpt                      | IPIF<br>Interrupt | 0       | 0                | XPS GPIO Interrupt<br>Active high signal |
| P44  | GPIO_IO[0 to C_GPIO_WIDTH-1]      | GPIO              | I/O     | Z <sup>[1]</sup> | Channel 1 General purpose I/O            |



Table 1: XPS GPIO I/O Signals (Contd)

| Port | Signal Name                    | Interface | I/O | Initial<br>State | Description                   |
|------|--------------------------------|-----------|-----|------------------|-------------------------------|
| P45  | GPIO2_IO[0 to C_GPIO2_WIDTH-1] | GPIO      | I/O | Z <sup>[2]</sup> | Channel 2 General purpose I/O |

- 1. GPIO remains at high impedance only if the default value of C\_TRI\_DEFAULT is used
- 2. GPIO2 remains at high impedance only if the default value of C\_TRI\_DEFAULT\_2 is used

# **XPS GPIO Design Parameters**

To allow the designer to obtain a XPS GPIO 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 GPIO are shown in Table 2

Table 2: XPS GPIO Design Parameters

| Generic    | Feature /<br>Description                            | Parameter Name       | Allowable<br>Values                                                                                                                                                             | Default<br>Value    | VHDL<br>Type         |  |  |  |
|------------|-----------------------------------------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|----------------------|--|--|--|
|            | System Parameter                                    |                      |                                                                                                                                                                                 |                     |                      |  |  |  |
| G1         | Target FPGA family                                  | C_FAMILY             | spartan®3,<br>aspartan®3,<br>spartan®3adsp,<br>spartan®3e,<br>aspartan®3e,<br>spartan®3a,<br>spartan®3a,<br>aspartan®3an,<br>virtex®4,<br>qvirtex®4,<br>qrvirtex®4,<br>virtex®5 | virtex5             | string               |  |  |  |
|            |                                                     | PLB Parameter        | <b>S</b>                                                                                                                                                                        |                     |                      |  |  |  |
| G2         | PLB GPIO Base<br>Address                            | C_BASEADDR           | Valid Address                                                                                                                                                                   | None [1]            | std_logic_<br>vector |  |  |  |
| G3         | PLB GPIO High<br>Address                            | C_HIGHADDR           | Valid Address <sup>[1]</sup>                                                                                                                                                    | None <sup>[1]</sup> | std_logic_<br>vector |  |  |  |
| 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<br>or shared PLB<br>topology | C_SPLB_P2P           | 0 = Shared Bus<br>Topology<br>1 = Point-to-<br>Point Bus Topology                                                                                                               | 0                   | integer              |  |  |  |
| <b>G</b> 7 | PLB Master ID Bus<br>Width                          | C_SPLB_MID<br>_WIDTH | log <sub>2</sub> (C_SPLB_<br>NUM_MASTERS)<br>with a minimum<br>value of 1                                                                                                       | 1                   | integer              |  |  |  |



Table 2: XPS GPIO Design Parameters

| Generic | Feature /<br>Description                               | Parameter Name            | Allowable<br>Values                                                                            | Default<br>Value | VHDL<br>Type         |
|---------|--------------------------------------------------------|---------------------------|------------------------------------------------------------------------------------------------|------------------|----------------------|
| G8      | Number of PLB<br>Masters                               | C_SPLB_NUM<br>_MASTERS    | 1-16                                                                                           | 1                | integer              |
| G9      | Width of the Slave<br>Data Bus                         | C_SPLB_NATIVE<br>_DWIDTH  | 32                                                                                             | 32               | integer              |
| G10     | Selects the transactions as being single beat or burst | C_SPLB_SUPPORT<br>_BURSTS | 0 = Supports only single beat transactions                                                     | 0                | integer              |
|         |                                                        | GPIO Paramete             | ers                                                                                            |                  |                      |
| G11     | GPIO Channel1 Data<br>Bus Width                        | C_GPIO_WIDTH              | 1-32                                                                                           | 32               | integer              |
| G12     | GPIO Channel2 Data<br>Bus Width                        | C_GPIO2_WIDTH             | 1-32                                                                                           | 32               | integer              |
| G13     | XPS GPIO Interrupt                                     | C_INTERRUPT_<br>PRESENT   | 0 = Interrupt<br>control module is<br>not present<br>1 = Interrpt control<br>module is present | 0                | integer              |
| G14     | GPIO_DATA reset value                                  | C_DOUT_DEFAULT            | Any valid std_logic_vector                                                                     | 00000000         | std_logic_<br>vector |
| G15     | GPIO_TRI reset value                                   | C_TRI_DEFAULT             | Any valid std_logic_vector                                                                     | FFFFFFF          | std_logic_<br>vector |
| G16     | Use dual channel                                       | C_IS_DUAL                 | 0 = Single channel<br>is enabled<br>1 = Both the<br>channels are<br>enabled                    | 0                | integer              |
| G17     | GPIO2_DATA reset value                                 | C_DOUT_DEFAULT_2          | Any valid std_logic_vector                                                                     | 00000000         | std_logic_<br>vector |
| G18     | GPIO2_TRI reset value                                  | C_TRI_DEFAULT_2           | Any valid std_logic_vector                                                                     | FFFFFFF          | std_logic_<br>vector |
| G19     | Future Usage                                           | C_ALL_INPUTS              | 0,1                                                                                            | 0                | Integer              |
| G20     | Future Usage                                           | C_ALL_INPUTS_2            | 0,1                                                                                            | 0                | Integer              |

## **Allowable Parameter Combinations**

The range specified by C\_BASEADDR and C\_HIGHADDR must encompass the memory space required by the XPS GPIO. The minimum range specified by C\_BASEADDR and C\_HIGHADDR should be at least 0xFF. If C\_INTERRUPT\_PRESENT parameter is set then the address range specified by C\_BASEADDR and C\_HIGHADDR should be at least 0x1FF.

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 GPIO registers



No default value will be specified for C\_BASEADDR and C\_HIGHADDR in order to enforce that the user configures these parameters with actual values. If actual values are not set for C\_BASEADDR and C\_HIGHADDR, a elaboration error will be generated.

# **Parameter - Port Dependencies**

The width of the XPS GPIO channel registers depends on some of the parameters. In addition, when certain features are parameterized away, the related logic is removed. The dependencies between the XPS GPIO design parameters and the I/O ports are shown in Table 3.

Table 3: Parameter-Port Dependencies

| Generic or Port | Parameter          | Affects         | Depends    | Relationship Description                                                                        |
|-----------------|--------------------|-----------------|------------|-------------------------------------------------------------------------------------------------|
|                 |                    | Design          | Parameters |                                                                                                 |
| G4              | C_SPLB_AWDITH      | P3              | -          | Width of the PLB address bus                                                                    |
| G5              | C_SPLB_DWIDTH      | P7, P10,<br>P33 | -          | Number of byte enables decoded<br>Width of the PLB data bus<br>Width of the slave read data bus |
| G7              | C_SPLB_MID_DWIDTH  | P5              | -          | Width of Master ID Bus                                                                          |
| G8              | C_SPLB_NUM_MASTERS | P36,P37,<br>P38 | -          | The number of Master Devices connected to PLBv46 bus                                            |
| G11             | C_GPIO_WIDTH       | P44             | -          | The size of the registers GPIO_DATA and GPIO_TRI determines the number of GPIO_IO pins.         |
| G12             | C_GPIO2_WIDTH      | P45             | G17        | The size of the registers GPIO2_DATA and GPIO2_TRI determines the number of GPIO2_IO pins.      |
| G17             | C_IS_DUAL          | P45             | -          | When C_IS_DUAL is 1, channel 2 is created                                                       |
| G19             | C_ALL_INPUTS_2     | -               | G17        | For future usage and is valid only When C_IS_DUAL is 1                                          |
|                 |                    | I/O             | Signals    |                                                                                                 |
| P3              | PLB_ABus           | -               | G11        | 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 PLB Data Bus                                                              |
| P36             | SI_MBusy           | -               | G8         | Width varies with the number of marsters                                                        |
| P37             | SI_MWrErr          | -               | G8         | Width varies with the number of masters                                                         |
| P38             | SI_MRdErr          | -               | G8         | Width varies with the number of masters                                                         |
| P47             | GPIO_IO            | -               | G11        | Width depends on the GPIO width.                                                                |
| P51             | GPIO2_IO           | -               | G12        | Width depends on the GPIO2 width                                                                |



# **XPS GPIO Registers**

There are four internal registers in the XPS GPIO design as shown in Table 4. The memory map of the XPS GPIO design is determined by setting the C\_BASEADDR parameter. The internal registers of the XPS GPIO are at a fixed offset from the base address and are byte accessible. The XPS GPIO internal registers and their offset are listed in Table 4.

Table 4: XPS GPIO Registers

| Register<br>Name | Description                         | PLB Address       | Access     |
|------------------|-------------------------------------|-------------------|------------|
| GPIO_DATA        | Channel 1 XPS GPIO Data Register    | C_BASEADDR + 0x00 | Read/Write |
| GPIO_TRI         | Channel 1 XPS GPIO 3-state Register | C_BASEADDR + 0x04 | Read/Write |
| GPIO2_DATA       | Channel 2 XPS GPIO Data register    | C_BASEADDR + 0x08 | Read/Write |
| GPIO2_TRI        | Channel 2 XPS GPIO 3-state Register | C_BASEADDR + 0x0C | Read/Write |

Depending on the value of certain configuration parameters, some of these registers are removed. The parameter - register dependency is described in Table 5. A write to an unimplimented register has no effect. An attempt to read the unimplimented register will return "all zero" value.

Table 5: Parameter-Register Dependency

| Parameter<br>Values |                          | Register                | Retainability             |                          |
|---------------------|--------------------------|-------------------------|---------------------------|--------------------------|
| C_IS_DUAL           | GPIO_DATA <sup>[2]</sup> | GPIO_TRI <sup>[2]</sup> | GPIO2_DATA <sup>[2]</sup> | GPIO2_TRI <sup>[2]</sup> |
| 0                   | Yes                      | Yes                     | No                        | No                       |
| 1                   | Yes                      | Yes                     | Yes                       | Yes                      |

#### Notes:

- 1. When C\_IS\_DUAL = 0, the core is configured for single channel
- 2. Depending on the values of C\_GPIO\_WIDTH and C\_GPIO2\_WIDTH, the data registers and the 3-state control registers (GPIO\_DATA, GPIO\_TRI, GPIO2\_DATA and GPIO2\_TRI) when implemented, get trimmed to the size of value specified by C\_GPIO\_WIDTH and C\_GPIO2\_WIDTH

#### XPS GPIO Data Register (GPIOx\_DATA)

XPS GPIO data register is used to read the input ports and write to the output ports. When a port is configured as input, writing to the port has no effect in the XPS GPIO data register.

There are two XPS GPIO data registers (GPIO\_DATA and GPIO2\_DATA), one corresponding to each channel. The channel 1 data register (GPIO\_DATA) is always present while the channel 2 data register (GPIO2\_DATA) is present only if the core is configured for dual channel i.e. C\_IS\_DUAL = 1.

The XPS GPIO Data Register is shown in Figure 3 and Table 6 details its functionality





Figure 3: XPS GPIO Data Register

Table 6: XPS GPIO Data Register Description

| Bits | Name       | Core<br>Access                            | Reset Value                        | Description                                                                                                                                                                                                                               |
|------|------------|-------------------------------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0:31 | GPIOx_DATA | Read <sup>[1]</sup> /Write <sup>[2]</sup> | C_DOUT_DEFAULT<br>C_DOUT_DEFAULT_2 | XPS GPIO Data For each I/O bit Programmed as input: R: Read value on input pin W: No effect For each I/O bit Programmed as output: R: No effect <sup>[2]</sup> W: Writes value to corresponding XPS GPIO data register bit and output pin |

- 1. When a GPIO pin is configured as input, writing to the pin has no effect in the XPS corresponding GPIO data register bit
- 2. When a GPIO pin is configured as an output, the corresponding data register bit is write only, it cannot be read

## XPS GPIO 3-State Register (GPIOx\_TRI)

The XPS GPIO 3-state register is used to configure the ports dynamically as input or output. When a bit within this register is set, the corresponding I/O port is configured as an input port. When a bit is reset, the corresponding I/O port is configured as an output port.

There are two XPS GPIO 3-state control registers (GPIO\_TRI and GPIO2\_TRI), one corresponding to each channel. The channel 2, 3-state control register (GPIO2\_TRI) is present only if the core is configured for dual channel (C\_IS\_DUAL = 1).

The XPS GPIO 3-state Register is shown in Figure 4 and its functionality is described in Table 7.



Figure 4: XPS GPIO 3-State Register



Table 7: XPS GPIO 3-State Register Description

| Bits | Name      | Core<br>Access | Reset Value                      | Description                                                                                                                                                                                            |
|------|-----------|----------------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0:31 | GPIOx_TRI | Read/Write     | C_TRI_DEFAULT<br>C_TRI_DEFAULT_2 | XPS GPIO 3-state control.  Each I/O pin of theXPS GPIO is individually programmable as an input or output. For each of the bits  '0' - I/O pin configured as output  '1' - I/O pin configured as input |



# **XPS GPIO Interrupts**

The XPS GPIO core can be configured under the control of the C\_INTERRUPT\_PRESENT generic to generate an interrupt when a transition occurs in any of the channel inputs. The GPIO interface module includes interrupt detection logic to identify any transition on channel inputs. When a transition is detected, the same is indicated to the Interrupt Control module. The Interrupt Control module implements the necessary registers to enable and maintain the status of the interrupts. To support interrupt capability for channels, the PLB Interface module implements the following registers:

- Global Interrupt Enable register (GIE)
- IP Interrupt Enable Register (IP IER)
- IP Interrupt Status Register (IP ISR)

The IP IER implements independent interrupt enable bit for each channel while the Global Interrupt Enable Register provides the master enable/disable for the interrupt output to the processor. The IP ISR implements independent interrupt status bit for each channel. The IP ISR provides Read and Toggle-On-Write access. The Toggle-On-Write mechanism allows interrupt service routines to clear one or more ISR bits using a single write transaction. (If needed, it also caters for setting one or more ISR bits--for testing interrupt service routines, for example.)

Table 8 details the XPS GPIO interrupt registers and their offset from the base address of XPS GPIO memory map. These registers are meaningful only if the C\_INTERRUPT\_PRESENT generic is set to 1.

| Register<br>Name | Description                      | PLB Address        | Access      |
|------------------|----------------------------------|--------------------|-------------|
| GIER             | Global Interrupt Enable Register | C_BASEADDR + 0x11C | Read/Write  |
| IP IER           | IP Interrupt Enable Register     | C_BASEADDR + 0x128 | Read/Write  |
| IP ISR           | IP Interrupt Status Register     | C_BASEADDR + 0x120 | Read/TOW[1] |

#### Notes:

12

#### Global Interrupt Enable Register (GIE)

The Global Interrupt Enable Register provides the master enable/disable for the interrupt output to the processor. This is a single bit read/write register as shown in Figure 5. This register is meaningful only if the parameter C\_INTERRUPT\_PRESENT is 1.

Note that this bit must be set to generate interrupts, even if the interrupts are enabled in the IP Interrupt Enable Register (IP IER). The bit definition for Global Interrupt Enable Register is given in Table 9.



Figure 5: Global Interrupt Enable Register

Toggle-On-Write (TOW) access toggles the status of the bit when a value of "1" is written to the corresponding bit



| Bit(s) | Name                    | Core Access | Reset Value | Description                                                                                                   |
|--------|-------------------------|-------------|-------------|---------------------------------------------------------------------------------------------------------------|
| 0      | Global Interrupt Enable | Read/Write  | '0'         | Master enable for the device interrupt output to the system interrupt controller '1' = Enabled '0' = Disabled |
| 1 - 31 | Reserved                | N/A         | '0'         | Reserved. Set to zeros on a read                                                                              |

Table 9: Global Interrupt Enable Register Description

## IP Interrupt Enable (IP IER) and IP Status Registers (IP ISR)

The IP Interrupt Enable Register (IP IER) and IP Interrupt Status Register (IP ISR), shown in Figure 6, provide a bit for each of the interrupts. These registers are meaningful only if the parameter C\_INTERRUPT\_PRESENT is 1.

The interrupt enable bits in the IP Interrupt Enable Register have a one-to-one correspondence with the status bits in the IP Interrupt Status Register. The interrupt events are registered in the IP Interrupt Status Register by the PLB clock and therefore the change in the input port must be stable for at least one clock period wide to guarantee interrupt capture. Each IP ISR register bit can be set or cleared via software by the Toggle-On-Write behaviour.



Figure 6: IP Interrupt Enable and IP Interrupt Status Register

The bit definition for IP Interrupt Enable Register and IP Interrupt Status Register are given in Table 10 and Table 11 respectively.

Table 10: IP Interrupt Enable Register Description

| Bit(s) | Name                          | Core<br>Access | Reset<br>Value | Description                                                      |
|--------|-------------------------------|----------------|----------------|------------------------------------------------------------------|
| 0 - 29 | Reserved                      | N/A            | '0'            | Reserved. Set to zeros on a read                                 |
| 30     | Channel 2<br>Interrupt Enable | Read/Write     | '0'            | Enable Channel 2 Interrupt '1' = Enabled '0' = Disabled (masked) |
| 31     | Channel 1<br>Interrupt Enable | Read/Write     | '0'            | Enable Channel 1 Interrupt '1' = Enabled '0' = Disabled (masked) |



| Table | 11: | IP II | nterrupt | <b>Status</b> | Register | Description |
|-------|-----|-------|----------|---------------|----------|-------------|
|-------|-----|-------|----------|---------------|----------|-------------|

| Bit(s) | Name                             | Core<br>Access | Reset<br>Value | Description                                                                                   |
|--------|----------------------------------|----------------|----------------|-----------------------------------------------------------------------------------------------|
| 0 - 29 | Reserved                         | N/A            | '0'            | Reserved. Set to zeros on a read                                                              |
| 30     | Channel 2<br>Interrupt<br>Status | Read/TOW [1]   | '0'            | Channel 2 Interrupt Status '1' = Channel 2 input interrupt '0' = No Channel 2 input interrupt |
| 31     | Channel 1<br>Interrupt<br>Status | Read/TOW [1]   | '0'            | Channel 1 Interrupt Status '1' = Channel 1 input interrupt '0' = No Channel 1 input interrupt |

# **XPS GPIO Operation**

The XPS GPIO can be configured as either a single or a dual channel device using the C\_IS\_DUAL generic. When both channels are enabled (C\_IS\_DUAL = 1), the width of each channel can be different, as defined by the C\_GPIO\_WIDTH and C\_GPIO2\_WIDTH generics.

The XPS GPIO has a 3-state I/O capability. The GPIOx\_TRI register is used to enable the 3-state buffers which enable 3-state outputs on the GPIOx\_IO pins. The GPIOx\_TRI register is also driven out of the dedicated GPIOx\_t\_out output pins. Each of the GPIOx\_IO pins has a corresponding bit in the GPIOx\_TRI register.

To configure a port as output, the corresponding bit in the GPIOx\_TRI register is written as 0. A subsequent write to the GPIOx\_DATA register causes the data written to appear on the GPIOx\_IO pins for I/Os that are configured as outputs.

To configure a port as input, the corresponding bit in the GPIOx\_TRI register is written as 1, thereby disabling the 3-state buffers. An input port takes input from the bi-directional (GPIOx\_IO) pins.

The GPIOx\_DATA and the GPIOx\_TRI registers are reset to the values set on the generics C\_DOUT\_DEFAULTx and C\_TRI\_DEFAULTx at configuration time.

If the C\_INTERRUPT\_PRESENT generic is 1, a transition on any input will cause an interrupt. There are independent interrupt enable and interrupt status bits for each channel if dual channel operation is used.

# **User Application Hints**

14

The user may find the following steps helpful in accessing the XPS GPIO core:

For input ports when the channel is configured for interrupt

- 1. Configure the port as input by writing the corresponding bit in GPIOx\_TRI register with the value of 1.
- 2. Enable the channel interrupt by setting the corresponding bit in the IP Interrupt Enable Register; Also enable the Global Interrupt, by setting the bit 0 of the Global Interrupt Register to 1.
- 3. When an interrupt is received, read the corresponding bit in the GPIOx\_DATA register. Clear the status in the IP Interrupt Status Register by writing the corresponding bit with the value of 1.

For input ports when the channel is not configured for interrupt

Toggle-On-Write (TOW) access toggles the status of the bit when a value of 1 is written to the corresponding bit



- 1. Configure the port as input by writing the corresponding bit in GPIOx\_TRI register with the value of 1.
- 2. Read the corresponding bit in GPIOx\_DATA register.

#### For output ports

- 1. Configure the port as output by writing the corresponding bit in GPIOx\_TRI register with a value of 0.
- 2. Write the corresponding bit in GPIOx\_DATA register.

# **Design Implementation**

# **Target Technology**

The intended target technology is Virtex and Spartan family FPGAs.

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

Since the GPIO 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 GPIO 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 GPIO benchmarks and the resource utilization for various parameter combinations are detailed in Table 12, Table 13, Table 14, Table 15 and Table 16 for Virtex-4, Virtex-5, Virtex-6, Spartan-3 and Spartan-6 respectively.

Table 12: Performance and Resource Utilization Benchmarks For Virtex-4 (Device: xc4vlx25-ff668-10)

|           |                         |                  |                   |        | •                   |      | -                         |
|-----------|-------------------------|------------------|-------------------|--------|---------------------|------|---------------------------|
|           | Parameter Va            | De               | E                 |        |                     |      |                           |
| C_IS_DUAL | C_INTERRUPT_<br>PRESENT | C_GPIO_<br>WIDTH | C_GPIO2<br>_WIDTH | Slices | Slice<br>Flip-Flops | LUTs | F <sub>MAX</sub><br>(MHz) |
| 0         | 0                       | 32               | 32                | 173    | 264                 | 110  | 254                       |
| 0         | 0                       | 16               | 32                | 100    | 182                 | 90   | 275                       |
| 0         | 1                       | 32               | 16                | 213    | 351                 | 206  | 234                       |
| 0         | 1                       | 1                | 1                 | 61     | 100                 | 66   | 252                       |
| 1         | 0                       | 32               | 32                | 222    | 394                 | 220  | 232                       |
| 1         | 0                       | 5                | 28                | 153    | 262                 | 175  | 227                       |
| 1         | 0                       | 28               | 5                 | 145    | 262                 | 175  | 224                       |
| 1         | 1                       | 32               | 32                | 294    | 548                 | 331  | 197                       |
| 1         | 1                       | 15               | 28                | 233    | 416                 | 279  | 205                       |

#### Note:

 These benchmark designs contain only the XPS GPIO module without any additional logic. Benchmark numbers approach the performance ceiling rather than representing performance under typical user condition



Table 13: Performance and Resource Utilization Benchmarks For Virtex-5 (Device: xc5vlx50-ff1153-1)

|           | Parameter Va            | lues             | De                |       |                     |      |                           |
|-----------|-------------------------|------------------|-------------------|-------|---------------------|------|---------------------------|
| C_IS_DUAL | C_INTERRUPT<br>_PRESENT | C_GPIO_<br>WIDTH | C_GPIO2<br>_WIDTH | Slice | Slice<br>Flip-Flops | LUTs | F <sub>MAX</sub><br>(MHz) |
| 0         | 0                       | 32               | 32                | 77    | 264                 | 109  | 285                       |
| 0         | 0                       | 16               | 32                | 55    | 182                 | 89   | 317                       |
| 0         | 1                       | 32               | 16                | 99    | 351                 | 200  | 246                       |
| 0         | 1                       | 1                | 1                 | 40    | 100                 | 60   | 293                       |
| 1         | 0                       | 32               | 32                | 110   | 394                 | 219  | 267                       |
| 1         | 0                       | 5                | 28                | 80    | 262                 | 174  | 289                       |
| 1         | 0                       | 28               | 5                 | 80    | 262                 | 174  | 277                       |
| 1         | 1                       | 32               | 32                | 152   | 548                 | 323  | 239                       |
| 1         | 1                       | 15               | 28                | 121   | 416                 | 270  | 256                       |

Table 14: Performance and Resource Utilization Benchmarks for Virtex-6 (XC6VLX130-1-TFF1156)

| Parameter Values |                         |                  |                   | Ι      | E                   |      |                           |
|------------------|-------------------------|------------------|-------------------|--------|---------------------|------|---------------------------|
| C_IS_DUAL        | C_INTERRUPT<br>_PRESENT | C_GPIO_<br>WIDTH | C_GPIO2<br>_WIDTH | Slices | Slice<br>Flip-Flops | LUTs | F <sub>MAX</sub><br>(MHz) |
| 0                | 0                       | 32               | 32                | 59     | 264                 | 186  | 329                       |
| 0                | 0                       | 16               | 32                | 44     | 182                 | 134  | 415                       |
| 0                | 1                       | 32               | 16                | 86     | 351                 | 271  | 317                       |
| 0                | 1                       | 1                | 1                 | 42     | 100                 | 79   | 303                       |
| 1                | 0                       | 32               | 32                | 89     | 394                 | 301  | 347                       |
| 1                | 0                       | 5                | 28                | 72     | 262                 | 215  | 287                       |
| 1                | 0                       | 28               | 5                 | 72     | 262                 | 217  | 311                       |
| 1                | 1                       | 32               | 32                | 124    | 548                 | 437  | 282                       |
| 1                | 1                       | 15               | 28                | 110    | 416                 | 340  | 309                       |

### Notes:

1. These benchmark designs contain only the XPS GPIO module without any additional logic. Benchmark numbers approach the performance ceiling rather than representing performance under typical user condition

<sup>1.</sup> These benchmark designs contain only the XPS GPIO module without any additional logic. Benchmark numbers approach the performance ceiling rather than representing performance under typical user condition



Table 15: Performance and Resource Utilization Benchmarks For Spartan-3(Device: xc3s1600e-fg484-4)

|           | Parameter V             | I                | Е                 |        |                     |      |       |
|-----------|-------------------------|------------------|-------------------|--------|---------------------|------|-------|
| C_IS_DUAL | C_INTERRUPT<br>_PRESENT | C_GPIO_<br>WIDTH | C_GPIO2<br>_WIDTH | Slices | Slice<br>Flip-Flops | LUTs | (MHz) |
| 0         | 0                       | 32               | 32                | 141    | 264                 | 110  | 160   |
| 0         | 0                       | 16               | 32                | 99     | 182                 | 90   | 166   |
| 0         | 1                       | 32               | 16                | 324    | 351                 | 206  | 135   |
| 0         | 1                       | 1                | 1                 | 71     | 100                 | 66   | 166   |
| 1         | 0                       | 32               | 32                | 321    | 394                 | 220  | 146   |
| 1         | 0                       | 5                | 28                | 142    | 262                 | 175  | 176   |
| 1         | 0                       | 28               | 5                 | 201    | 262                 | 175  | 147   |
| 1         | 1                       | 32               | 32                | 400    | 548                 | 331  | 156   |
| 1         | 1                       | 15               | 28                | 281    | 416                 | 280  | 137   |

Table 16: Performance and Resource Utilization Benchmarks for Spartan-6 (XC6SLX16-2-CSG324)

|           | Parameter V             | Γ                | E                 |        |                     |      |                        |
|-----------|-------------------------|------------------|-------------------|--------|---------------------|------|------------------------|
| C_IS_DUAL | C_INTERRUPT<br>_PRESENT | C_GPIO_<br>WIDTH | C_GPIO2<br>_WIDTH | Slices | Slice<br>Flip-Flops | LUTs | F <sub>MAX</sub> (MHz) |
| 0         | 0                       | 32               | 32                | 52     | 264                 | 168  | 197                    |
| 0         | 0                       | 16               | 32                | 44     | 182                 | 129  | 178                    |
| 0         | 1                       | 32               | 16                | 82     | 351                 | 257  | 175                    |
| 0         | 1                       | 1                | 1                 | 74     | 350                 | 248  | 172                    |
| 1         | 0                       | 32               | 32                | 79     | 394                 | 269  | 172                    |
| 1         | 0                       | 5                | 28                | 65     | 262                 | 199  | 155                    |
| 1         | 0                       | 28               | 5                 | 63     | 262                 | 198  | 153                    |
| 1         | 1                       | 32               | 32                | 113    | 548                 | 409  | 155                    |
| 1         | 1                       | 15               | 28                | 96     | 416                 | 326  | 164                    |

#### Notes:

1. These benchmark designs contain only the XPS GPIO module without any additional logic. Benchmark numbers approach the performance ceiling rather than representing performance under typical user condition

## **System Performance**

To measure the system performance (Fmax) of this core, this core was added to a Virtex-4 system, a Virtex-5 system, a Spartan-3A system, a Spartan-6 system and a Virtex-6 systemas the Device Under Test (DUT) as shown in Figure 7, Figure 8, Figure 9, Figure 10 and Figure 11.

DS569 Apr 19, 2010 <u>www.xilinx.com</u> 17

<sup>1.</sup> These benchmark designs contain only the XPS GPIO module without any additional logic. Benchmark numbers approach the performance ceiling rather than representing performance under typical user condition



Because the XPS GPIO 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 7: Virtex-4 FX System



Figure 8: Virtex-5 FXT System



Figure 9: Spartan-3A DSP System



Figure 10: Spartan 6 System



Figure 11: Virtex 6 System

DS569 Apr 19, 2010 <u>www.xilinx.com</u> 19



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 FMax numbers are shown in Table 17.

Table 17: XPS GPIO Core System Performance

| Target FPGA | Target<br>f <sub>MAX</sub><br>(MHz) |
|-------------|-------------------------------------|
| S3AD3400 -4 | 90                                  |
| V4FX60 -10  | 100                                 |
| V5FXT70 -1  | 120                                 |
| S6LX16 -2   | 100                                 |
| V6LX130t -1 | 150                                 |

The target fMAX is influenced by the exact system and is provided for guidance. It is not a guaranteed value across all systems.



# **Reference Documents**

IBM 128-Bit Processor Local Bus, Architecture Specifications, v4.6.

## **Notice of Disclaimer**

Xilinx is providing this design, code, or information (collectively, the "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.

# **Revision History**

| Date       | Version | Revision                                                                                   |
|------------|---------|--------------------------------------------------------------------------------------------|
| 11/10/06   | 1.0     | Initial Xilinx release                                                                     |
| 9/26/2007  | 1.1     | Added FMax Margin System Performance section.                                              |
| 11/27/2007 | 1.2     | Added Spartan-3A DSP to supported devices.                                                 |
| 1/14/08    | 1.3     | Added Virtex-II Pro support.                                                               |
| 4/16/08    | 1.4     | Added Automotive Spartan-3E, Automotive Spartan-3A, and Automotive Spartan-3A DSP support. |
| 7/22/08    | 1.5     | Added QPro Virtex-4 Hi-Rel and QPro Virtex-4 Rad Tolerant FPGA support.                    |
| 10/13/08   | 1.6     | Removed Virtex-II Pro and added Spartan-3 devices, added GPIO2_IO parameter description    |
| 12/08/08   | 1.7     | Added C_ALL_INPUTS and C_ALL_INPUTS_2 parameters                                           |
| 01/05/09   | 1.8     | Updated resource utlization table                                                          |
| 4/28/09    | 1.9     | Updated the margin system diagrams                                                         |
| 7/17/09    | 1.10    | Updated resource utilization table and added v6 & S6 resource utilization tables           |
| 4/19/10    | 1.11    | Updated resource utlization table for s6 & V6                                              |