# General-Purpose I/O Interface 22

2016.10.28

cv\_5v4





The hard processor system (HPS) provides three general-purpose I/O (GPIO) interface modules. The GPIO modules are instances of the Synopsys<sup>®</sup> DesignWare<sup>®</sup> APB General Purpose Programming I/O (DW\_apb\_gpio) peripheral.† (65)

#### Features of the GPIO Interface

The GPIO interface offers the following features:

- Supports digital debounce
- Configurable interrupt mode
- Supports up to 67 I/O pins and 14 input-only pins

© 2016 Intel Corporation. All rights reserved. Intel, the Intel logo, Altera, Arria, Cyclone, Enpirion, MAX, Megacore, NIOS, Quartus and Stratix words and logos are trademarks of Intel Corporation in the US and/or other countries. Other marks and brands may be claimed as the property of others. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO 9001:2008 Registered



Portions © 2016 Synopsys, Inc. Used with permission. All rights reserved. Synopsys & DesignWare are registered trademarks of Synopsys, Inc. All documentation is provided "as is" and without any warranty. Synopsys expressly disclaims any and all warranties, express, implied, or otherwise, including the implied warranties of merchantability, fitness for a particular purpose, and non-infringement, and any warranties arising out of a course of dealing or usage of trade.

<sup>†</sup>Paragraphs marked with the dagger (†) symbol are Synopsys Proprietary. Used with permission.

# **GPIO Interface Block Diagram and System Integration**

The figure below shows a block diagram of the GPIO interface. The following table shows a pin table of the **GPIO** interface:

Figure 22-1: Cyclone V SoC GPIO



Table 22-1: GPIO Interface pin table

| Pin Name     | Mapped to GPIO Signal<br>Name | Comments       |  |  |  |
|--------------|-------------------------------|----------------|--|--|--|
| GPIO [28:0]  | GPIO 0 [28:0]                 | Input / Output |  |  |  |
| GPIO [57:29] | GPIO 1 [28:0]                 | Input / Output |  |  |  |
| GPIO [66:58] | GPIO 2 [8:0]                  | Input / Output |  |  |  |
| HLGPI [13:0] | GPIO 2 [26:13]                | Input only     |  |  |  |

Table 22-2: GPIO Interface pin table

| Pin Name                   | Mapped to GPIO Signal Name | Comments       |
|----------------------------|----------------------------|----------------|
| HPS_DEDICATED_Q1<br>[12:1] | GPIO 0 [11:0]              | Input / Output |
| HPS_DEDICATED_Q2<br>[12:1] | GPIO 0 [23:12]             | Input / Output |
| HPS_DEDICATED_Q3<br>[12:1] | GPIO 1 [11:0]              | Input / Output |
| HPS_DEDICATED_Q4<br>[12:1] | GPIO 1 [23:12]             | Input / Output |

**General-Purpose I/O Interface** 



#### **Related Information**

#### http://www.altera.com/literature/hb/cyclone-v/cv\_52005.pdf

For more information on I/O banks locations on device, refer to Cyclone V I/O Features.

# **Functional Description of the GPIO Interface**

#### **Debounce Operation**

The GPIO modules provided in the HPS include optional debounce capabilities. The external signal can be debounced to remove any spurious glitches that are less than one period of the external debouncing clock, <code>gpio\_db\_clk</code>. †

When input signals are debounced using the <code>gpio\_db\_clk</code> debounce clock, the signals must be active for a minimum of two cycles of the debounce clock to guarantee that they are registered. Any input pulse widths less than a debounce clock period are filtered out. If the input signal pulse width is between one and two debounce clock widths, it may or may not be filtered out, depending on its phase relationship to the debounce clock. If the input pulse spans two rising edges of the debounce clock, it is registered. If it spans only one rising edge, it is not registered. †

The figure below shows a timing diagram of the debounce circuitry for both cases: a bounced input signal, and later, a propagated input signal.

Figure 22-2: Debounce Timing With Asychronous Reset Flip-Flops



**Note:** Enabling the debounce circuitry increases interrupt latency by two clock cycles of the debounce clock.

#### Pin Directions

The pins GPIO0 through GPIO66 can be configured to be either input or output signals. The pins HLGPIO through HLGPI13 share pins with the HPS DDR controller and are input-only signals.

# Taking the GPIO Interface Out of Reset

When a cold or warm reset is issued in the HPS, the reset manager resets this module and holds it in reset until software releases it.

General-Purpose I/O Interface

Altera Corporation



After the Cortex-A9 MPCore CPU boots, it can deassert the reset signal by clearing the appropriate bits in the reset manager's corresponding reset register. For details about reset registers, refer to "Module Reset Signals".

# **GPIO Interface Programming Model**

Debounce capability for each of the input signals can be enabled or disabled under software control by setting the corresponding bits in the gpio\_debounce register, accordingly. The debounce clock must be stable and operational before the debounce capability is enabled.

Under software control, the direction of the external I/O pad is controlled by a write to the gpio\_swportx\_ddr register. When configured as input mode, reading gpio\_ext\_porta would read the values on the signal of the external I/O pad. When configured as output mode, the data written to the gpio\_swporta\_dr register drives the output buffer of the I/O pad. The same pins are shared for both input and output modes, so they cannot be configured as input and output modes at the same time. †

# General-Purpose I/O Interface Address Map and Register Definitions

The address map and register definitions for the GPIO consist of the following regions:

- GPIO Module 0
- GPIO Module 1
- GPIO Module 2

#### **Related Information**

- Introduction to the Hard Processor System on page 1-1 For more information, refer to *Introduction to the Hard Processor System* chapter.
- http://www.altera.com/literature/hb/cyclone-v/hps.html

# **GPIO Module Address Map**

Registers in the GPIO module

| Module Instance | Base Address |
|-----------------|--------------|
| gpio0           | 0xff708000   |
| gpiol           | 0xFF709000   |
| gpio2           | 0xff70A000   |

#### **GPIO Module**

| Register                                 | Offset | Width | Acces<br>s | Reset Value | Description                    |
|------------------------------------------|--------|-------|------------|-------------|--------------------------------|
| <pre>gpio_swporta_dr on page 22-5</pre>  | 0x0    | 32    | RW         | 0x0         | Port A Data Register           |
| <pre>gpio_swporta_ddr on page 22-6</pre> | 0x4    | 32    | RW         | 0×0         | Port A Data Direction Register |

General-Purpose I/O Interface



| Register                                   | Offset | Width | Acces<br>s | Reset Value | Description                    |
|--------------------------------------------|--------|-------|------------|-------------|--------------------------------|
| <pre>gpio_inten on page 22-7</pre>         | 0x30   | 32    | RW         | 0x0         | Interrupt Enable Register      |
| <pre>gpio_intmask on page 22-8</pre>       | 0x34   | 32    | RW         | 0x0         | Interrupt Mask Register        |
| gpio_inttype_level on page 22-9            | 0x38   | 32    | RW         | 0x0         | Interrupt Level Register       |
| <pre>gpio_int_polarity on page 22-10</pre> | 0x3C   | 32    | RW         | 0x0         | Interrupt Polarity Register    |
| gpio_intstatus on page 22-11               | 0x40   | 32    | RO         | 0x0         | Interrupt Status Register      |
| gpio_raw_intstatus on page 22-12           | 0x44   | 32    | RO         | 0x0         | Raw Interrupt Status Register  |
| gpio_debounce on page 22-13                | 0x48   | 32    | RW         | 0x0         | Debounce Enable Register       |
| gpio_porta_eoi on page 22-14               | 0x4C   | 32    | WO         | 0x0         | Clear Interrupt Register       |
| gpio_ext_porta on page 22-15               | 0x50   | 32    | RO         | 0x0         | External Port A Register       |
| <pre>gpio_ls_sync on page 22-16</pre>      | 0x60   | 32    | RW         | 0x0         | Synchronization Level Register |
| gpio_id_code on page 22-17                 | 0x64   | 32    | RO         | 0x0         | ID Code Register               |
| <pre>gpio_ver_id_code on page 22-17</pre>  | 0x6C   | 32    | RO         | 0x3230382A  | GPIO Version Register          |
| <pre>gpio_config_reg2 on page 22-18</pre>  | 0x70   | 32    | RO         | 0x39CFC     | Configuration Register 2       |
| <pre>gpio_config_reg1 on page 22-20</pre>  | 0x74   | 32    | RO         | 0x1FF0F2    | Configuration Register 1       |

# gpio\_swporta\_dr

This GPIO Data register is used to input or output data Check the GPIO chapter in the handbook for details on how GPIO2 is implemented.

| Module Instance | Base Address | Register Address |
|-----------------|--------------|------------------|
| gpio0           | 0xff708000   | 0xFF708000       |
| gpiol           | 0xff709000   | 0xFF709000       |
| gpio2           | 0xff70A000   | 0xFF70A000       |

Offset: 0x0



**Altera Corporation** 

Access: RW

**Important:** To prevent indeterminate system behavior, reserved areas of memory must not be accessed by software or hardware. Any area of the memory map that is not explicitly defined as a register space or accessible memory is considered reserved.

|     | Bit Fields                |    |    |                           |    |    |    |    |    |    |    |    |    |    |    |
|-----|---------------------------|----|----|---------------------------|----|----|----|----|----|----|----|----|----|----|----|
| 31  | 30                        | 29 | 28 | 27                        | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Res | served                    |    |    | gpio_swporta_dr<br>RW 0x0 |    |    |    |    |    |    |    |    |    |    |    |
| 15  | 14                        | 13 | 12 | 11                        | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|     | gpio_swporta_dr<br>RW 0x0 |    |    |                           |    |    |    |    |    |    |    |    |    |    |    |

#### gpio\_swporta\_dr Fields

| Bit  | Name            | Description                                                                                                                                                                                                                                                                                                           | Access | Reset |
|------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 28:0 | gpio_swporta_dr | Values written to this register are output on the I/O signals of the GPIO Data Register, if the corresponding data direction bits for GPIO Data Direction Field are set to Output mode. The value read back is equal to the last value written to this register. Note that only bits[26:0] are implemented for gpio2. | RW     | 0x0   |

#### gpio\_swporta\_ddr

This register establishes the direction of each corresponding GPIO Data Field Bit. Check the GPIO chapter in the handbook for details on how GPIO2 is implemented.

| Module Instance | Base Address | Register Address |
|-----------------|--------------|------------------|
| gpio0           | 0xff708000   | 0xFF708004       |
| gpiol           | 0xff709000   | 0xFF709004       |
| gpio2           | 0xFF70A000   | 0xFF70A004       |

Offset: 0x4 Access: RW

**Important:** To prevent indeterminate system behavior, reserved areas of memory must not be accessed by software or hardware. Any area of the memory map that is not explicitly defined as a register space or accessible memory is considered reserved.



|     | Bit Fields                 |    |    |                            |    |    |    |    |    |    |    |    |    |    |    |
|-----|----------------------------|----|----|----------------------------|----|----|----|----|----|----|----|----|----|----|----|
| 31  | 30                         | 29 | 28 | 27                         | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Res | served                     |    |    | gpio_swporta_ddr<br>RW 0x0 |    |    |    |    |    |    |    |    |    |    |    |
| 15  | 14                         | 13 | 12 | 11                         | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|     | gpio_swporta_ddr<br>RW 0x0 |    |    |                            |    |    |    |    |    |    |    |    |    |    |    |

#### gpio\_swporta\_ddr Fields

| Bit  | Name             |               | Access                                                                                                                                                                          | Reset |     |
|------|------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----|
| 28:0 | gpio_swporta_ddr | the direction | n to this register independently control of the corresponding data bit in the Port er. Note that only bits[26:0] are for gpio2.  Description  Input Direction  Output Direction | RW    | 0x0 |

#### gpio\_inten

The Interrupt enable register allows interrupts for each bit of the Port A data register.

| Module Instance | Base Address | Register Address |
|-----------------|--------------|------------------|
| gpio0           | 0xff708000   | 0xFF708030       |
| gpiol           | 0xFF709000   | 0xFF709030       |
| gpio2           | 0xff70A000   | 0xFF70A030       |

Offset: 0x30

Access: RW

**Important:** To prevent indeterminate system behavior, reserved areas of memory must not be accessed by software or hardware. Any area of the memory map that is not explicitly defined as a register space or accessible memory is considered reserved.

| Bit Fields |                     |    |    |                                                                                                                                        |    |   |   |   |   |   |   |   |   |   |   |
|------------|---------------------|----|----|----------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| 31         | 30                  | 29 | 28 | 28         27         26         25         24         23         22         21         20         19         18         17         16 |    |   |   |   |   |   |   |   |   |   |   |
| Res        | Reserved gpio_inten |    |    |                                                                                                                                        |    |   |   |   |   |   |   |   |   |   |   |
|            | RW 0x0              |    |    |                                                                                                                                        |    |   |   |   |   |   |   |   |   |   |   |
| 15         | 14                  | 13 | 12 | 11                                                                                                                                     | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| gpio_inten |                     |    |    |                                                                                                                                        |    |   |   |   |   |   |   |   |   |   |   |
| RW 0x0     |                     |    |    |                                                                                                                                        |    |   |   |   |   |   |   |   |   |   |   |

#### gpio\_inten Fields

| Bit  | Name       | Description                                                                                                                                                                                                                                                                                                                                                          | Access | Reset |
|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 28:0 | gpio_inten | Allows each bit of Port A Data Register to be configured for interrupt capability. Interrupts are disabled on the corresponding bits of Port A Data Register if the corresponding data direction register is set to Output. Note that only bits[26:0] are implemented for gpio2.  Value Description  0x0 Disable Interrupt on Port A  0x1 Enable Interrupt on Port A | RW     | 0x0   |

#### gpio\_intmask

Controls which pins cause interrupts on Port A Data Register inputs.

| Module Instance | Base Address | Register Address |
|-----------------|--------------|------------------|
| gpio0           | 0xff708000   | 0xFF708034       |
| gpiol           | 0xff709000   | 0xFF709034       |
| gpio2           | 0xff70A000   | 0xFF70A034       |

Offset: 0x34 Access: RW

**Important:** To prevent indeterminate system behavior, reserved areas of memory must not be accessed by software or hardware. Any area of the memory map that is not explicitly defined as a register space or accessible memory is considered reserved.



| Bit Fields            |    |    |    |                                                                                                                                        |    |   |   |   |       |    |   |   |   |   |   |
|-----------------------|----|----|----|----------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|-------|----|---|---|---|---|---|
| 31                    | 30 | 29 | 28 | 28         27         26         25         24         23         22         21         20         19         18         17         16 |    |   |   |   |       |    |   |   |   |   |   |
| Reserved gpio_intmask |    |    |    |                                                                                                                                        |    |   |   |   |       |    |   |   |   |   |   |
|                       |    |    |    |                                                                                                                                        |    |   |   |   | RW 0: | x0 |   |   |   |   |   |
| 15                    | 14 | 13 | 12 | 11                                                                                                                                     | 10 | 9 | 8 | 7 | 6     | 5  | 4 | 3 | 2 | 1 | 0 |
| gpio_intmask          |    |    |    |                                                                                                                                        |    |   |   |   |       |    |   |   |   |   |   |
| RW 0x0                |    |    |    |                                                                                                                                        |    |   |   |   |       |    |   |   |   |   |   |

#### gpio\_intmask Fields

| Bit  | Name         | Description                                                                                                                                                                                                                                                                                                                                   | Access | Reset |
|------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 28:0 | gpio_intmask | Controls whether an interrupt on Port A Data Register can generate an interrupt to the interrupt controller by not masking it. The unmasked status can be read as well as the resultant status after masking. Note that only bits[26:0] are implemented for gpio2.  Value  Description  0x0  Interrupt bits are unmasked  0x1  Mask Interrupt | RW     | 0x0   |

#### gpio\_inttype\_level

The interrupt level register defines the type of interrupt (edge or level).

| Module Instance | Base Address | Register Address |
|-----------------|--------------|------------------|
| gpio0           | 0xFF708000   | 0xFF708038       |
| gpiol           | 0xFF709000   | 0xFF709038       |
| gpio2           | 0xFF70A000   | 0xFF70A038       |

Offset: 0x38

Access: RW

**Important:** To prevent indeterminate system behavior, reserved areas of memory must not be accessed by software or hardware. Any area of the memory map that is not explicitly defined as a register space or accessible memory is considered reserved.

| Bit Fields         |        |    |                              |                                                                                                                                        |  |  |  |  |  |  |  |
|--------------------|--------|----|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 31                 | 30     | 29 | 28                           | 28         27         26         25         24         23         22         21         20         19         18         17         16 |  |  |  |  |  |  |  |
| Res                | served |    | gpio_inttype_level<br>RW 0x0 |                                                                                                                                        |  |  |  |  |  |  |  |
| 15                 | 14     | 13 | 12                           | 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                           |  |  |  |  |  |  |  |
| gpio_inttype_level |        |    |                              |                                                                                                                                        |  |  |  |  |  |  |  |
| RW 0x0             |        |    |                              |                                                                                                                                        |  |  |  |  |  |  |  |

#### gpio\_inttype\_level Fields

| Bit  | Name               |                                                                                                                                                               | Description                    | Access | Reset |
|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|--------|-------|
| 28:0 | gpio_inttype_level | This field controls the type of interrupt that can occur on the Port A Data Register. Note that only bits[26:0] are implemented for gpio2.  Value Description |                                |        | 0x0   |
|      |                    | 0x0<br>0x1                                                                                                                                                    | Level-sensitive Edge-sensitive |        |       |

#### gpio\_int\_polarity

Controls the Polarity of Interrupts that can occur on inputs of Port A Data Register

| Module Instance | Base Address | Register Address |
|-----------------|--------------|------------------|
| gpio0           | 0xff708000   | 0xFF70803C       |
| gpiol           | 0xFF709000   | 0xFF70903C       |
| gpio2           | 0xFF70A000   | 0xFF70A03C       |

Offset: 0x3C Access: RW

**Important:** To prevent indeterminate system behavior, reserved areas of memory must not be accessed by software or hardware. Any area of the memory map that is not explicitly defined as a register space or accessible memory is considered reserved.

**General-Purpose I/O Interface Altera Corporation** 



|     | Bit Fields                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----|----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31  | 30                         | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Res | Reserved gpio_int_polarity |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|     | RW 0x0                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15  | 14                         | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|     | gpio_int_polarity          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|     | RW 0x0                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

#### gpio\_int\_polarity Fields

| Bit  | Name              |                  | Description                                                                                                                                 | Access | Reset |
|------|-------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 28:0 | gpio_int_polarity | can occur on inp | rity of edge or level sensitivity that at of Port A Data Register. Note that e implemented for gpio2.  Description  Active low  Active high | RW     | 0x0   |

#### gpio\_intstatus

The Interrupt status is reported for all Port A Data Register Bits.

| Module Instance | Base Address | Register Address |
|-----------------|--------------|------------------|
| gpio0           | 0xff708000   | 0xFF708040       |
| gpiol           | 0xff709000   | 0xFF709040       |
| gpio2           | 0xFF70A000   | 0xFF70A040       |

Offset: 0x40
Access: RO

**Important:** To prevent indeterminate system behavior, reserved areas of memory must not be accessed by software or hardware. Any area of the memory map that is not explicitly defined as a register

space or accessible memory is considered reserved.



|                          | Bit Fields |    |    |                          |    |    |    |    |    |    |    |    |    |    |    |
|--------------------------|------------|----|----|--------------------------|----|----|----|----|----|----|----|----|----|----|----|
| 31                       | 30         | 29 | 28 | 27                       | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Res                      | served     |    |    | gpio_intstatus<br>RO 0x0 |    |    |    |    |    |    |    |    |    |    |    |
| 15                       | 14         | 13 | 12 | 11                       | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| gpio_intstatus<br>RO 0x0 |            |    |    |                          |    |    |    |    |    |    |    |    |    |    |    |

#### gpio\_intstatus Fields

| Bit  | Name           |                    | Description                                                | Access | Reset |
|------|----------------|--------------------|------------------------------------------------------------|--------|-------|
| 28:0 | gpio_intstatus | only bits[26:0] ar | f Port A Data Register. Note that e implemented for gpio2. | RO     | 0x0   |
|      |                | Value              | Description                                                |        |       |
|      |                | 0x0                | Inactive                                                   |        |       |
|      |                | 0x1                | Active                                                     |        |       |
|      |                |                    |                                                            |        |       |

#### gpio\_raw\_intstatus

This is the Raw Interrupt Status Register for Port A Data Register. It is used with the Interrupt Mask Register to allow interrupts from the Port A Data Register.

| Module Instance | Base Address | Register Address |
|-----------------|--------------|------------------|
| gpio0           | 0xff708000   | 0xFF708044       |
| gpiol           | 0xff709000   | 0xFF709044       |
| gpio2           | 0xff70A000   | 0xFF70A044       |

Offset: 0x44 Access: RO

Important: To prevent indeterminate system behavior, reserved areas of memory must not be accessed by software or hardware. Any area of the memory map that is not explicitly defined as a register space or accessible memory is considered reserved.

**General-Purpose I/O Interface Altera Corporation** 



|     | Bit Fields |    |    |        |    |     |         |         |        |         |    |    |    |    |    |
|-----|------------|----|----|--------|----|-----|---------|---------|--------|---------|----|----|----|----|----|
| 31  | 30         | 29 | 28 | 27     | 26 | 25  | 24      | 23      | 22     | 21      | 20 | 19 | 18 | 17 | 16 |
| Res | served     |    |    |        |    |     |         | gpic    | _raw_i | ntstatu | ıs |    |    |    |    |
|     |            |    |    | RO 0x0 |    |     |         |         |        |         |    |    |    |    |    |
| 15  | 14         | 13 | 12 | 11     | 10 | 9   | 8       | 7       | 6      | 5       | 4  | 3  | 2  | 1  | 0  |
|     |            |    |    |        |    | gpi | io_raw_ | intstat | cus    |         |    |    |    |    |    |
|     | RO 0x0     |    |    |        |    |     |         |         |        |         |    |    |    |    |    |

#### gpio\_raw\_intstatus Fields

| Bit  | Name               |                                      | Description                 | Access | Reset |
|------|--------------------|--------------------------------------|-----------------------------|--------|-------|
| 28:0 | gpio_raw_intstatus | (premasking bits). implemented for g |                             | RO     | 0x0   |
|      |                    | 0x0<br>0x1                           | Description Inactive Active |        |       |

## gpio\_debounce

Debounces each IO Pin

| Module Instance | Base Address | Register Address |
|-----------------|--------------|------------------|
| gpio0           | 0xff708000   | 0xFF708048       |
| gpiol           | 0xFF709000   | 0xFF709048       |
| gpio2           | 0xFF70A000   | 0xFF70A048       |

Offset: 0x48 Access: RW

**Important:** To prevent indeterminate system behavior, reserved areas of memory must not be accessed by software or hardware. Any area of the memory map that is not explicitly defined as a register space or accessible memory is considered reserved.

|     | Bit Fields |    |    |                         |    |    |         |    |    |    |    |    |    |    |    |
|-----|------------|----|----|-------------------------|----|----|---------|----|----|----|----|----|----|----|----|
| 31  | 30         | 29 | 28 | 27                      | 26 | 25 | 24      | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Res | served     |    |    | gpio_debounce<br>RW 0x0 |    |    |         |    |    |    |    |    |    |    |    |
| 15  | 14         | 13 | 12 | 11                      | 10 | 9  | 8       | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|     |            |    |    |                         |    |    | gpio_de |    |    |    |    |    |    |    |    |

#### gpio\_debounce Fields

| Bit  | Name          |                                                    | Description                                                                                                                                                                                                                                                | Access | Reset |
|------|---------------|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 28:0 | gpio_debounce | of an interrup<br>spurious glitch<br>periods of an | her an external signal that is the source to needs to be debounced to remove any nes. A signal must be valid for two external clock (gpio_db_clk) before it is cessed. Note that only bits[26:0] are for gpio2.  Description  No debounce  Enable debounce | RW     | 0x0   |

#### gpio\_porta\_eoi

Port A Data Register interrupt handling.

| Module Instance | Base Address | Register Address |
|-----------------|--------------|------------------|
| gpio0           | 0xff708000   | 0xFF70804C       |
| gpiol           | 0xff709000   | 0xFF70904C       |
| gpio2           | 0xff70A000   | 0xFF70A04C       |

Offset: 0x4C Access: wo

**Important:** To prevent indeterminate system behavior, reserved areas of memory must not be accessed by software or hardware. Any area of the memory map that is not explicitly defined as a register space or accessible memory is considered reserved.



|     | Bit Fields |    |    |                |    |    |    |    |    |    |    |    |    |    |    |
|-----|------------|----|----|----------------|----|----|----|----|----|----|----|----|----|----|----|
| 31  | 30         | 29 | 28 | 27             | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Res | erved      |    |    | gpio_porta_eoi |    |    |    |    |    |    |    |    |    |    |    |
|     |            |    |    | WO 0x0         |    |    |    |    |    |    |    |    |    |    |    |
| 15  | 14         | 13 | 12 | 11             | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|     |            |    |    | gpio_porta_eoi |    |    |    |    |    |    |    |    |    |    |    |
|     | WO 0x0     |    |    |                |    |    |    |    |    |    |    |    |    |    |    |

#### gpio\_porta\_eoi Fields

| Bit  | Name           |                           | Description        | Access | Reset |
|------|----------------|---------------------------|--------------------|--------|-------|
| 28:0 | gpio_porta_eoi | Port A Data I implemented |                    | WO     | 0×0   |
|      |                | Value                     | Description        |        |       |
|      |                | 0x0                       | No interrupt clear |        |       |
|      |                | 0x1                       | Clear interrupt    |        |       |
|      |                |                           |                    |        |       |

#### gpio\_ext\_porta

The external port register is used to input data to the metastability flops.

| Module Instance | Base Address | Register Address |
|-----------------|--------------|------------------|
| gpio0           | 0xff708000   | 0xFF708050       |
| gpiol           | 0xff709000   | 0xFF709050       |
| gpio2           | 0xFF70A000   | 0xFF70A050       |

Offset: 0x50 Access: RO

**Important:** To prevent indeterminate system behavior, reserved areas of memory must not be accessed by software or hardware. Any area of the memory map that is not explicitly defined as a register

space or accessible memory is considered reserved.

gpio\_ls\_sync

|     | Bit Fields                     |    |    |                                                                                                                                        |  |  |  |  |  |  |  |  |
|-----|--------------------------------|----|----|----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| 31  | 30                             | 29 | 28 | 28         27         26         25         24         23         22         21         20         19         18         17         16 |  |  |  |  |  |  |  |  |
| Res | Reserved gpio_ext_porta RO 0x0 |    |    |                                                                                                                                        |  |  |  |  |  |  |  |  |
| 15  | 14                             | 13 | 12 | 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                           |  |  |  |  |  |  |  |  |
|     | gpio_ext_porta<br>RO 0x0       |    |    |                                                                                                                                        |  |  |  |  |  |  |  |  |

#### gpio\_ext\_porta Fields

| Bit  | Name           | Description                                                                                                                                                                                                                                                                            | Access | Reset |
|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 28:0 | gpio_ext_porta | When Port A Data Register is configured as Input, then reading this location reads the values on the signals. When the data direction of Port A Data Register is set as Output, reading this location reads Port A Data Register. Note that only bits[26:0] are implemented for gpio2. | RO     | 0x0   |

#### gpio\_ls\_sync

The Synchronization level register is used to synchronize input with l4\_mp\_clk

| Module Instance | Base Address | Register Address |
|-----------------|--------------|------------------|
| gpio0           | 0xFF708000   | 0xff708060       |
| gpiol           | 0xFF709000   | 0xFF709060       |
| gpio2           | 0xFF70A000   | 0xFF70A060       |

Offset: 0x60 Access: RW

**Important:** To prevent indeterminate system behavior, reserved areas of memory must not be accessed by software or hardware. Any area of the memory map that is not explicitly defined as a register space or accessible memory is considered reserved.

|    | Bit Fields |    |    |    |    |    |    |    |    |    |                            |    |    |    |    |
|----|------------|----|----|----|----|----|----|----|----|----|----------------------------|----|----|----|----|
| 31 | 30         | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20                         | 19 | 18 | 17 | 16 |
|    | Reserved   |    |    |    |    |    |    |    |    |    |                            |    |    |    |    |
| 15 | 14         | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4                          | 3  | 2  | 1  | 0  |
|    | Reserved   |    |    |    |    |    |    |    |    |    | gpio_ls_<br>sync<br>RW 0x0 |    |    |    |    |



#### gpio\_ls\_sync Fields

| Bit | Name         |                              | Description                                    | Access | Reset |
|-----|--------------|------------------------------|------------------------------------------------|--------|-------|
| 0   | gpio_ls_sync | The leve mp_clk.             | el-sensitive interrupts is synchronized to l4_ | RW     | 0x0   |
|     |              | Value                        | Description                                    |        |       |
|     |              | 0x0                          | No synchronization to l4_mp_clk                |        |       |
|     |              | 0x1 Synchronize to l4_mp_clk |                                                |        |       |
|     |              |                              |                                                |        |       |

# **gpio\_id\_code**GPIO ID code.

| Module Instance | Base Address | Register Address |
|-----------------|--------------|------------------|
| gpio0           | 0xFF708000   | 0xff708064       |
| gpiol           | 0xFF709000   | 0xff709064       |
| gpio2           | 0xFF70A000   | 0xff70A064       |

Offset: 0x64

Access: RO

|    | Bit Fields                                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|---------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30                                                                  | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|    | gpio_id_code                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|    | RO 0x0                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 15   14   13   12   11   10   9   8   7   6   5   4   3   2   1   0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|    | gpio_id_code                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|    | RO 0x0                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

#### gpio\_id\_code Fields

| Bit  | Name         | Description         | Access | Reset |
|------|--------------|---------------------|--------|-------|
| 31:0 | gpio_id_code | Chip identification | RO     | 0x0   |

## gpio\_ver\_id\_code

GPIO Component Version





| Module Instance | Base Address | Register Address |
|-----------------|--------------|------------------|
| gpio0           | 0xFF708000   | 0xff70806C       |
| gpio1           | 0xFF709000   | 0xFF70906C       |
| gpio2           | 0xFF70A000   | 0xFF70A06C       |

Offset: 0x6C Access: RO

|    | Bit Fields                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|-----------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30                                | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|    | gpio_ver_id_code<br>RO 0x3230382A |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 |                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|    | gpio_ver_id_code                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|    | RO 0x3230382A                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

#### gpio\_ver\_id\_code Fields

| Bit  | Name             | Description                                                                                                     | Access | Reset          |
|------|------------------|-----------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31:0 | gpio_ver_id_code | ASCII value for each number in the version, followed by *. For example. 32_30_31_2A represents the version 2.01 | RO     | 0x32303<br>82A |

#### gpio\_config\_reg2

Specifies the bit width of port A.

| Module Instance | Base Address | Register Address |
|-----------------|--------------|------------------|
| gpio0           | 0xFF708000   | 0xff708070       |
| gpiol           | 0xFF709000   | 0xFF709070       |
| gpio2           | 0xFF70A000   | 0xFF70A070       |

Offset: 0x70 Access: RO

**Important:** To prevent indeterminate system behavior, reserved areas of memory must not be accessed by software or hardware. Any area of the memory map that is not explicitly defined as a register space or accessible memory is considered reserved.

**General-Purpose I/O Interface Altera Corporation** 



#### gpio\_config\_reg2 Fields

| Bit   | Name                | Description                                                                            | Access | Reset |
|-------|---------------------|----------------------------------------------------------------------------------------|--------|-------|
| 19:15 | encoded_id_pwidth_d | Specifies the width of GPIO Port D. Ignored because there is no Port D in the GPIO.    | RO     | 0x7   |
|       |                     | Value Description                                                                      |        |       |
|       |                     | 0x7 Width (less 1) of 8 bits                                                           |        |       |
|       |                     | 0x1c Width (less 1) of 29 bits                                                         |        |       |
| 14:10 | encoded_id_pwidth_c | Specifies the width of GPIO Port C. Ignored because there is no Port C in the GPIO.    | RO     | 0x7   |
|       |                     | Value Description                                                                      |        |       |
|       |                     | 0x7 Width (less 1) of 8 bits                                                           |        |       |
|       |                     | 0x1c Width (less 1) of 29 bits                                                         |        |       |
| 9:5   | encoded_id_pwidth_b | Specifies the width of GPIO Port B. Ignored because there is no Port B in the GPIO.    | RO     | 0x7   |
|       |                     | Value Description                                                                      |        |       |
|       |                     | 0x7 Width (less 1) of 8 bits                                                           |        |       |
|       |                     | 0x1c Width (less 1) of 29 bits                                                         |        |       |
| 4:0   | encoded_id_pwidth_a | Specifies the width of GPIO Port A. The value 28 represents the 29-bit width less one. | RO     | 0x1C  |
|       |                     | Value Description                                                                      |        |       |
|       |                     | 0x7 Width (less 1) of 8 bits                                                           |        |       |
|       |                     | 0x1c Width (less 1) of 29 bits                                                         |        |       |
|       |                     |                                                                                        |        |       |



#### gpio\_config\_reg1

Reports settings of various GPIO configuration parameters

| Module Instance | Base Address | Register Address |
|-----------------|--------------|------------------|
| gpio0           | 0xff708000   | 0xFF708074       |
| gpiol           | 0xff709000   | 0xFF709074       |
| gpio2           | 0xFF70A000   | 0xFF70A074       |

Offset: 0x74
Access: RO

**Important:** To prevent indeterminate system behavior, reserved areas of memory must not be accessed by software or hardware. Any area of the memory map that is not explicitly defined as a register space or accessible memory is considered reserved.

|         | Bit Fields                                      |                           |                             |    |         |    |                           |                            |                                           |                            |                            |             |              |    |                 |
|---------|-------------------------------------------------|---------------------------|-----------------------------|----|---------|----|---------------------------|----------------------------|-------------------------------------------|----------------------------|----------------------------|-------------|--------------|----|-----------------|
| 31      | 30                                              | 29                        | 28                          | 27 | 26      | 25 | 24                        | 23                         | 22                                        | 21                         | 20                         | 19          | 18           | 17 | 16              |
|         | Reserved                                        |                           |                             |    |         |    |                           |                            |                                           |                            | enc                        | coded_i     | _            | 1  |                 |
| 15      | 14                                              | 13                        | 12                          | 11 | 10      | 9  | 8                         | 7                          | 6                                         | 5                          | 4                          | 3           | 2            | 1  | 0               |
| gpio_id | add_<br>encod<br>ed_<br>param<br>s<br>RO<br>0x1 | debou<br>nce<br>RO<br>0x1 | porta<br>_intr<br>RO<br>0x1 | Ā  | Reserve | d  | hw_<br>porta<br>RO<br>0x0 | portd - singl e_ctl RO 0x1 | portc<br>-<br>singl<br>e_ctl<br>RO<br>0x1 | portb - singl e_ctl RO 0x1 | porta _ singl e_ctl RO 0x1 | num_j<br>RO | ports<br>0x0 |    | ata_width O 0x2 |

#### gpio\_config\_reg1 Fields

| Bit   | Name             | Description                                                    | Access | Reset |
|-------|------------------|----------------------------------------------------------------|--------|-------|
| 20:16 | encoded_id_width | This value is fixed at 32 bits.                                | RO     | 0x1F  |
|       |                  | Value Description  0x1f Width of ID Field                      |        |       |
| 15    | gpio_id          | Provides an ID code value  Value Description  0x1 GPIO ID Code | RO     | 0x1   |



| Bit | Name               | Description                                                                                                               | Access | Reset |
|-----|--------------------|---------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 14  | add_encoded_params | Fixed to allow the indentification of the Designware IP component.                                                        | RO     | 0x1   |
|     |                    | Value Description                                                                                                         |        |       |
|     |                    | 0x1 Enable IP indentification                                                                                             |        |       |
| 13  | debounce           | The value of this field is fixed to allow debouncing of the Port A signals.                                               | RO     | 0x1   |
|     |                    | Value Description                                                                                                         |        |       |
|     |                    | 0x1 Debounce is Enabled                                                                                                   |        |       |
| 12  | porta_intr         | The value of this field is fixed to allow interrupts on Port A.                                                           | RO     | 0x1   |
|     |                    | Value Description                                                                                                         |        |       |
|     |                    | 0x1 Port A Interrupts Enabled                                                                                             |        |       |
| 8   | hw_porta           | The value is fixed to enable Port A configuration to be controlled by software only.                                      | RO     | 0x0   |
|     |                    | Value Description                                                                                                         |        |       |
|     |                    | 0x0 Software Configuration Control Enabled                                                                                |        |       |
| 7   | portd_single_ctl   | Indicates the mode of operation of Port D to be software controlled only. Ignored because there is no Port D in the GPIO. | RO     | 0x1   |
|     |                    | Value Description                                                                                                         |        |       |
|     |                    | 0x1 Software Enabled Individual Port Control                                                                              |        |       |
| 6   | portc_single_ctl   | Indicates the mode of operation of Port C to be software controlled only. Ignored because there is no Port C in the GPIO. | RO     | 0x1   |
|     |                    | Value Description                                                                                                         |        |       |
|     |                    | 0x1 Software Enabled Individual Port Control                                                                              |        |       |

| Bit | Name             | Description                                                                                                               | Access | Reset |
|-----|------------------|---------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 5   | portb_single_ctl | Indicates the mode of operation of Port B to be software controlled only. Ignored because there is no Port B in the GPIO. | RO     | 0x1   |
|     |                  | Value Description                                                                                                         |        |       |
|     |                  | 0x1 Software Enabled Individual Port Control                                                                              |        |       |
| 4   | porta_single_ctl | Indicates the mode of operation of Port A to be software controlled only.                                                 | RO     | 0x1   |
|     |                  | Value Description                                                                                                         |        |       |
|     |                  | 0x1 Software Enabled Individual Port Control                                                                              |        |       |
| 3:2 | num_ports        | The value of this register is fixed at one port (Port A).                                                                 | RO     | 0x0   |
|     |                  | Value Description                                                                                                         |        |       |
|     |                  | 0x0 Number of GPIO Ports = 1                                                                                              |        |       |
| 1:0 | apb_data_width   | Fixed to support an ABP data bus width of 32-bits.                                                                        | RO     | 0x2   |
|     |                  | Value Description                                                                                                         |        |       |
|     |                  | 0x2 APB Data Width = 32-bits                                                                                              |        |       |

# **Document Revision History**

**Table 22-3: Document Revision History** 

| Date                 | Version    | Changes                                                                                           |
|----------------------|------------|---------------------------------------------------------------------------------------------------|
| October 2016         | 2016.10.28 | Maintenance release.                                                                              |
| May 2016             | 2016.05.27 | Maintenance release.                                                                              |
| May 2016             | 2016.05.03 | Maintenance release.                                                                              |
| November 2015        | 2015.11.02 | Maintenance release.                                                                              |
| May 2015             | 2015.05.04 | Maintenance release.                                                                              |
| December 2014        | 2014.12.15 | <ul><li>Maintenance release.</li><li>Added <i>Taking the GPIO Out of Reset</i> section.</li></ul> |
| June 2014 2014.06.30 |            | Added Address Map and Register Descriptions                                                       |



| Date          | Version    | Changes                                                                                                                                     |
|---------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| February 2014 | 2014.02.28 | Updated content in sections:                                                                                                                |
|               |            | <ul> <li>Features of the GPIO Interface</li> <li>GPIO Interface Block Diagram and System Integration</li> <li>Debounce Operation</li> </ul> |
| December 2013 | 2013.12.30 | Minor formatting updates  Updated GPIO interface block diagram and GPIO interface pin table                                                 |
| November 2012 | 1.2        | Minor updates.                                                                                                                              |
| May 2012      | 1.1        | Added programming model section.                                                                                                            |
| January 2012  | 1.0        | Initial release.                                                                                                                            |

