

## Chapter 20 GPIO

### 20.1 Overview

GPIO is a programmable General Purpose Programming I/O peripheral. This component is an APB slave device. GPIO controls the output data and direction of external I/O pads. It can also read back the data on external pads using memory-mapped registers.

GPIO supports the following features:

- 32 bits APB data bus width
- Up to 32 independently configurable signals
- Software control registers with write mask for each bit of each signal
- Configurable debounce logic with a slow clock to debounce interrupts
- Configurable interrupt mode
- Two virtual OS with independent control registers can be supported
- In two virtual OS model, each OS has independent interrupt
- Not in two virtual OS model, two interrupts with priority can be set

### 20.2 Block Diagram



Fig. 20-1 GPIO Block Diagram

GPIO is comprised of:

- APB Interface
- The APB Interface implements the APB slave operation. Its data bus width is 32 bits.
- I/O Port Interface
- External data interface to or from I/O pads.
- Interrupt Detection
- Interrupt interface to or from interrupt controller.

### 20.3 Function Description

#### 20.3.1 Data Control

Under software control, the data and direction control for the signal are sourced from the port data registers (GPIO\_SWPORT\_DR\_L/GPIO\_SWPORT\_DR\_H) and direction control registers (GPIO\_SWPORT\_DRR\_L/GPIO\_SWPORT\_DRR\_H).

The direction of the external I/O pad is controlled by the value of the port data direction registers. The data written to these memory-mapped registers gets mapped onto an output signal (gpio\_port\_ddr) of the GPIO peripheral. This output signal controls the direction of an external I/O pad. The default data direction is Input.

The data written to the port data registers drives the output buffer (gpio\_port\_dr) of the I/O pad.

External data are input on the external data signal (gpio\_ext\_port). Reading the external signal register (GPIO\_EXT\_PORT) shows the value of this signal, regardless of the direction. This register is read-only, meaning that it cannot be written from the APB software interface.

### 20.3.2 Interrupts

I/O port can be programmed to accept external signals as interrupt sources on any of the bits of the signal. The type of interrupt is programmable with one of the following settings:

- Active-high and level
- Active-low and level
- Rising edge
- Falling edge
- Both the rising edge and the falling edge

The interrupts can be masked by programming the GPIO\_INT\_MASK\_L/GPIO\_INT\_MASK\_H registers. The interrupt status can be read before masking (GPIO\_INT\_RAWSTATUS) and after masking (GPIO\_INT\_STATUS).

For edge-sensitive interrupts, the Interrupt Service Routine (ISR) can clear the interrupt by writing a 1 to the corresponding bit of the GPIO\_PORT\_EOI\_L/GPIO\_PORT\_EOI\_H registers. This write operation also clears the interrupt status and raw status registers. Writing to the interrupt clear registers has no effect on level-sensitive interrupts. If level-sensitive interrupts cause the processor to interrupt, then the ISR can poll the interrupt raw status register until the interrupt source disappears, or it can write to the interrupt mask register to mask the interrupt before exiting the ISR. If the ISR exits without masking or disabling the interrupt prior to exiting, then the level-sensitive interrupt repeatedly requests an interrupt until the interrupt is cleared at the source.

The interrupts are combined into an active-high interrupt output signal. In order to mask the combined interrupt, all individual interrupts have to be masked. The single combined interrupt does not have its own mask bit.

Whenever I/O port is configured for interrupts, the data direction must be set to Input. If the data direction is reprogrammed to Output, then any pending edge-sensitive interrupts are not lost. However, no new interrupts are generated, and level-sensitive interrupts are lost.

Interrupt signals are internally synchronized to a system clock pclk\_intr, which is connected to the APB bus clock pclk. Therefore, the pclk needs to be running for interrupt detection.

### 20.3.3 Debounce Operation

The external signal can be debounced to remove any spurious glitches that are less than one period of the external debouncing clock.

When an input interrupt signal is debounced using a slow debounce clock (external input clock dbclk or internal divided clock dbclk\_div), the signal must be active for a minimum of two cycles of the debounce clock to guarantee that it is registered. Any input pulse widths less than a debounce clock period are bounced. A pulse width between one and two debounce clock widths may or may not propagate, 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 debounce function can be controlled by programming the debounce enable registers (GPIO\_DEBOUNCE\_L/GPIO\_DEBOUNCE\_H), debounce clock divide enable registers (GPIO\_DBCLK\_DIV\_EN\_L/GPIO\_DBCLK\_DIV\_EN\_H) and debounce clock divide control register (GPIO\_DBCLK\_DIV\_CON).

### 20.3.4 Two OS Operation and Tow Interrupts

To select this model, virtual enable register should be set(GPIO\_VIRTUAL\_EN). Then all the configure can be allotted to two OS (for example OS\_A and OS\_B). OS\_A will use the original address offset, OS\_B will use the offset + 0x1000. The 32 bit I/O port should also be allotted to the OS by setting reg group registers(GPIO\_REG\_GROUP\_L and GPIO\_REG\_GROUP\_H). Once reg group is set, the I/O operation can only be used by the setting address offset. Each OS has its own interrupt for I/O port, this is depended on reg group.

If virtual enable register is disable, reg group can also be used to allotted I/O interrupt. These two independent interrupts may be used for priority interrupt setting.

## 20.4 Register Description

This section describes the control/status registers of the design. Software should read and

write these registers using 32-bits accesses. There are five GPIOs (GPIO0 in PD\_PMU, GPIO1/GPIO2/GPIO3/GPIO4 in PD\_BUS), and each of them has same register group. Therefore, five GPIOs' register groups have five different base addresses.

#### 20.4.1 Registers Summary

| Name                  | Offset | Size | Reset Value | Description                              |
|-----------------------|--------|------|-------------|------------------------------------------|
| GPIO_SWPORT_DR_L      | 0x0000 | W    | 0x00000000  | Port Data Register (Low)                 |
| GPIO_SWPORT_DR_H      | 0x0004 | W    | 0x00000000  | Port Data Register (High)                |
| GPIO_SWPORT_DDR_L     | 0x0008 | W    | 0x00000000  | Port Data Direction Register (Low)       |
| GPIO_SWPORT_DDR_H     | 0x000C | W    | 0x00000000  | Port Data Direction Register (High)      |
| GPIO_INT_EN_L         | 0x0010 | W    | 0x00000000  | Interrupt Enable Register (Low)          |
| GPIO_INT_EN_H         | 0x0014 | W    | 0x00000000  | Interrupt Enable Register (High)         |
| GPIO_INT_MASK_L       | 0x0018 | W    | 0x00000000  | Interrupt Mask Register (Low)            |
| GPIO_INT_MASK_H       | 0x001C | W    | 0x00000000  | Interrupt Mask Register (High)           |
| GPIO_INT_TYPE_L       | 0x0020 | W    | 0x00000000  | Interrupt Level Register (Low)           |
| GPIO_INT_TYPE_H       | 0x0024 | W    | 0x00000000  | Interrupt Level Register (High)          |
| GPIO_INT_POLARITY_L   | 0x0028 | W    | 0x00000000  | Interrupt Polarity Register (Low)        |
| GPIO_INT_POLARITY_H   | 0x002C | W    | 0x00000000  | Interrupt Polarity Register (High)       |
| GPIO_INT_BOTHEDGE_L   | 0x0030 | W    | 0x00000000  | Interrupt Both Edge Type Register (Low)  |
| GPIO_INT_BOTHEDGE_H   | 0x0034 | W    | 0x00000000  | Interrupt Both Edge Type Register (High) |
| GPIO_DEBOUNCE_L       | 0x0038 | W    | 0x00000000  | Debounce Enable Register (Low)           |
| GPIO_DEBOUNCE_H       | 0x003C | W    | 0x00000000  | Debounce Enable Register (High)          |
| GPIO_DBCLK_DIV_EN_L   | 0x0040 | W    | 0x00000000  | DBCLK Divide Enable Register (Low)       |
| GPIO_DBCLK_DIV_EN_H   | 0x0044 | W    | 0x00000000  | DBCLK Divide Enable Register (High)      |
| GPIO_DBCLK_DIV_CON    | 0x0048 | W    | 0x00000001  | DBCLK Divide Control Register            |
| GPIO_INT_STATUS       | 0x0050 | W    | 0x00000000  | Interrupt Status Register                |
| GPIO_INT_RAWSTATUS    | 0x0058 | W    | 0x00000000  | Interrupt Raw Status Register            |
| GPIO_PORT_EOI_L       | 0x0060 | W    | 0x00000000  | Interrupt Clear Register (Low)           |
| GPIO_PORT_EOI_H       | 0x0064 | W    | 0x00000000  | Interrupt Clear Register (High)          |
| GPIO_EXT_PORT         | 0x0070 | W    | 0x00000000  | External Port Data Register              |
| GPIO_VER_ID           | 0x0078 | W    | 0x0101157C  | Version ID Register                      |
| GPIO_GPIO_REG_GROUP_L | 0x0100 | W    | 0x00000000  | GPIO Group Control                       |
| GPIO_GPIO_REG_GROUP_H | 0x0104 | W    | 0x0000FFFF  | GPIO Group Control                       |
| GPIO_GPIO_VIRTUAL_EN  | 0x0108 | W    | 0x00000000  | GPIO Virtual Enable                      |

Notes: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**-Double WORD (64 bits) access **WORD** (64 bits) access

#### 20.4.2 Detail Registers Description

##### GPIO\_SWPORT\_DR\_L

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                      |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0       | RW          | 0x0000             | <p>swport_dr_low<br/>Output data for the lower 16 bits of I/O Port, each bit is individual.<br/>1'b0: Low<br/>1'b1: High</p> <p>Values written to this register are output on the I/O signals for the lower 16 bits of I/O Port if the corresponding data direction bits for I/O Port are set to Output mode. The value read back is equal to the last value written to this register.</p> |

**GPIO SWPORT DR H**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                                  |
| 15:0       | RW          | 0x0000             | <p>swport_dr_high<br/>Output data for the upper 16 bits of I/O Port, each bit is individual.<br/>1'b0: Low<br/>1'b1: High</p> <p>Values written to this register are output on the I/O signals for the upper 16 bits of I/O Port if the corresponding data direction bits for I/O Port are set to Output mode. The value read back is equal to the last value written to this register.</p> |

**GPIO SWPORT DDR L**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                      |
| 15:0       | RW          | 0x0000             | <p>swport_ddr_low<br/>Data direction for the lower 16 bits of I/O Port, each bit is individual.<br/>1'b0: Input<br/>1'b1: Output</p> <p>Values written to this register independently control the direction of the corresponding data bit in the lower 16 bits of I/O Port.</p> |

**GPIO SWPORT DDR H**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0       | RW          | 0x0000             | <p>swport_ddr_high<br/>Data direction for the upper 16 bits of I/O Port, each bit is individual.<br/>1'b0: Input<br/>1'b1: Output<br/>Values written to this register independently control the direction of the corresponding data bit in the upper 16 bits of I/O Port.</p> |

**GPIO INT EN L**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                                                                                                                                      |
| 15:0       | RW          | 0x0000             | <p>int_en_low<br/>Allows each bit of the lower 16 bits of I/O Port to be configured for interrupts.<br/>1'b0: Interrupt is disabled<br/>1'b1: Interrupt is enabled<br/>Whenever a 1 is written to a bit of this register, it configures the corresponding bit on I/O Port to become an interrupt source; otherwise, I/O Port operates as a normal GPIO signal. Interrupts are disabled on the corresponding bits of I/O Port if the corresponding data direction register is set to Output.</p> |

**GPIO INT EN H**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                                                                                                                                       |
| 15:0       | RW          | 0x0000             | <p>int_en_high<br/>Allows each bit of the upper 16 bits of I/O Port to be configured for interrupts.<br/>1'b0: Interrupt is disabled<br/>1'b1: Interrupt is enabled<br/>Whenever a 1 is written to a bit of this register, it configures the corresponding bit on I/O Port to become an interrupt source; otherwise, I/O Port operates as a normal GPIO signal. Interrupts are disabled on the corresponding bits of I/O Port if the corresponding data direction register is set to Output.</p> |

**GPIO INT MASK L**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0       | RW          | 0x0000             | <p>int_mask_low<br/>Controls whether an interrupt on the lower 16 bits of I/O Port can create an interrupt for the interrupt controller by not masking it.<br/>1'b0: Interrupt is unmasked<br/>1'b1: Interrupt is masked<br/>Whenever a 1 is written to a bit in this register, it masks the interrupt generation capability for this signal; otherwise interrupts are allowed through.</p> |

**GPIO INT MASK H**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                                   |
| 15:0       | RW          | 0x0000             | <p>int_mask_high<br/>Controls whether an interrupt on the upper 16 bits of I/O Port can create an interrupt for the interrupt controller by not masking it.<br/>1'b0: Interrupt is unmasked<br/>1'b1: Interrupt is masked<br/>Whenever a 1 is written to a bit in this register, it masks the interrupt generation capability for this signal; otherwise interrupts are allowed through.</p> |

**GPIO INT TYPE L**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                 |
| 15:0       | RW          | 0x0000             | <p>int_type_low<br/>Controls the type of interrupt that can occur on the lower 16 bits of I/O Port.<br/>1'b0: Level-sensitive<br/>1'b1: Edge-sensitive<br/>Whenever a 1 is written to a bit of this register, it configures the interrupt type to be edge-sensitive; otherwise, it is level-sensitive.</p> |

**GPIO INT TYPE H**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0       | RW          | 0x0000             | <p>int_type_high<br/>Controls the type of interrupt that can occur on the upper 16 bits of I/O Port.<br/>1'b0: Level-sensitive<br/>1'b1: Edge-sensitive<br/>Whenever a 1 is written to a bit of this register, it configures the interrupt type to be edge-sensitive; otherwise, it is level-sensitive.</p> |

**GPIO INT POLARITY L**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                         |
| 15:0       | RW          | 0x0000             | <p>int_polarity_low<br/>Controls the polarity of edge or level sensitivity that can occur on the lower 16 bits of I/O Port.<br/>1'b0: Active-low<br/>1'b1: Active-high<br/>Whenever a 1 is written to a bit of this register, it configures the interrupt type to rising-edge or active-high sensitive; otherwise, it is falling-edge or active-low sensitive.</p> |

**GPIO INT POLARITY H**

Address: Operational Base + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                          |
| 15:0       | RW          | 0x0000             | <p>int_polarity_high<br/>Controls the polarity of edge or level sensitivity that can occur on the upper 16 bits of I/O Port.<br/>1'b0: Active-low<br/>1'b1: Active-high<br/>Whenever a 1 is written to a bit of this register, it configures the interrupt type to rising-edge or active-high sensitive; otherwise, it is falling-edge or active-low sensitive.</p> |

**GPIO INT BOTEDGE L**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0       | RW          | 0x0000             | <p>int_bothedge_low<br/>Controls the edge type of interrupt that can occur on the lower 16 bits of I/O Port.<br/>1'b0: Disable both-edge detection<br/>1'b1: Enable both-edge detection</p> <p>Whenever a particular bit is programmed to 1, it enables the generation of interrupts on both the rising edge and the falling edge of an external input signal corresponding to that bit on I/O Port. The values programmed in the registers int_type_low and int_polarity_low for this particular bit are not considered when the corresponding bit of this register is set to 1. Whenever a particular bit is programmed to 0, the interrupt type depends on the value of the corresponding bits in the int_type_low and int_polarity_low registers.</p> |

**GPIO INT BOTEDGE H**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 15:0       | RW          | 0x0000             | <p>int_bothedge_high<br/>Controls the edge type of interrupt that can occur on the upper 16 bits of I/O Port.<br/>1'b0: Disable both-edge detection<br/>1'b1: Enable both-edge detection</p> <p>Whenever a particular bit is programmed to 1, it enables the generation of interrupts on both the rising edge and the falling edge of an external input signal corresponding to that bit on I/O Port. The values programmed in the registers int_type_high and int_polarity_high for this particular bit are not considered when the corresponding bit of this register is set to 1. Whenever a particular bit is programmed to 0, the interrupt type depends on the value of the corresponding bits in the int_type_high and int_polarity_high registers.</p> |

**GPIO DEBOUNCE L**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                                                                |
| 15:0       | RW          | 0x0000             | <p>debounce_low<br/>Controls whether an external signal of the lower 16 bits of I/O Port that is the source of an interrupt needs to be debounced to remove any spurious glitches.<br/>1'b0: Disable debounce<br/>1'b1: Enable debounce</p> <p>Writing a 1 to a bit in this register enables the debouncing circuitry. A signal must be valid for two periods of an external clock before it is internally processed.</p> |

**GPIO DEBOUNCE H**

Address: Operational Base + offset (0x003C)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                                             |
| 15:0  | RW   | 0x0000      | debounce_high<br>Controls whether an external signal of the lower 16 bits of I/O Port that is the source of an interrupt needs to be debounced to remove any spurious glitches.<br>1'b0: Disable debounce<br>1'b1: Enable debounce<br>Writing a 1 to a bit in this register enables the debouncing circuitry. A signal must be valid for two periods of an external clock before it is internally processed. |

**GPIO\_DBCLK\_DIV\_EN\_L**

Address: Operational Base + offset (0x0040)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15:0  | RW   | 0x0000      | dbclk_div_en_low<br>Controls whether to use the internal divided clock when debounce function is enabled for an external signal of the lower 16 bits of I/O Port.<br>1'b0: Disable divider for debounce clock<br>1'b1: Enable divider for debounce clock<br>Whenever a 1 is written to a bit of this register, the clock divided from dbclk is used as debounce clock; otherwise, the original dbclk is used. The clock divide factor depends on the register dbclk_div_con. The values programmed in this register for this particular bit are not considered when the corresponding bit of the register debounce_low is set to 0. |

**GPIO\_DBCLK\_DIV\_EN\_H**

Address: Operational Base + offset (0x0044)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15:0  | RW   | 0x0000      | dbclk_div_en_high<br>Controls whether to use the internal divided clock when debounce function is enabled for an external signal of the upper 16 bits of I/O Port.<br>1'b0: Disable divider for debounce clock<br>1'b1: Enable divider for debounce clock<br>Whenever a 1 is written to a bit of this register, the clock divided from dbclk is used as debounce clock; otherwise, the original dbclk is used. The clock divide factor depends on the register dbclk_div_con. The values programmed in this register for this particular bit are not considered when the corresponding bit of the register debounce_high is set to 0. |

**GPIO DBCLK DIV CON**

Address: Operational Base + offset (0x0048)

| Bit   | Attr | Reset Value | Description                                              |
|-------|------|-------------|----------------------------------------------------------|
| 31:24 | RO   | 0x00        | reserved                                                 |
| 23:0  | RW   | 0x000001    | dbclk_div_con<br>dbclk_div = dbclk / (dbclk_div_con + 1) |

**GPIO INT STATUS**

Address: Operational Base + offset (0x0050)

| Bit  | Attr | Reset Value | Description                                 |
|------|------|-------------|---------------------------------------------|
| 31:0 | RO   | 0x00000000  | int_status<br>Interrupt status of I/O Port. |

**GPIO INT RAWSTATUS**

Address: Operational Base + offset (0x0058)

| Bit  | Attr | Reset Value | Description                                                          |
|------|------|-------------|----------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | int_rawstatus<br>Interrupt raw status of I/O Port (premasking bits). |

**GPIO PORT EOI L**

Address: Operational Base + offset (0x0060)

| Bit   | Attr   | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO     | 0x0000      | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                                                                            |
| 15:0  | R/W SC | 0x0000      | port_eoi_low<br>Controls the clearing of edge type interrupts from the lower 16 bits of I/O Port.<br>1'b0: Nothing<br>1'b1: Clear edge-sensitive interrupt<br>When a 1 is written into a corresponding bit of this register, the interrupt is cleared and the bit is self cleared at once. Writing to this register has no effect on level-sensitive interrupts. All interrupts are cleared when I/O Port is not configured for interrupts. |

**GPIO PORT EOI H**

Address: Operational Base + offset (0x0064)

| Bit   | Attr   | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO     | 0x0000      | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                                                                             |
| 15:0  | R/W SC | 0x0000      | port_eoi_high<br>Controls the clearing of edge type interrupts from the upper 16 bits of I/O Port.<br>1'b0: Nothing<br>1'b1: Clear edge-sensitive interrupt<br>When a 1 is written into a corresponding bit of this register, the interrupt is cleared and the bit is self cleared at once. Writing to this register has no effect on level-sensitive interrupts. All interrupts are cleared when I/O Port is not configured for interrupts. |

**GPIO EXT PORT**

Address: Operational Base + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | ext_port<br>This register always reflects the value of the signals on the external I/O Port. |

**GPIO VER ID**

Address: Operational Base + offset (0x0078)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:0       | RO          | 0x0101157c         | ver_id<br>Version ID. |

**GPIO GPIO REG GROUP L**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                 |
| 15:0       | RW          | 0x0000             | gpio_reg_group_low<br>This register control the low 16 bit of GPIO and each bit corresponds each GPIO.<br>When virtual_en=1'b1:<br>1'b1: GPIO control by OS_A with offset 0x0000<br>1'b0: GPIO control by OS_B with offset 0x1000<br>When virtual_en=1'b0:<br>1'b1: GPIO interrupt connect to gpio_int_flag<br>1'b0: GPIO interrupt connect to gpio_int_flag_exp |

**GPIO GPIO REG GROUP H**

Address: Operational Base + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                   |
| 15:0       | RW          | 0xfffff            | gpio_reg_group_high<br>This register control the high 16 bit of GPIO and each bit corresponds each GPIO.<br>When virtual_en=1'b1:<br>1'b1: GPIO control by OS_A with offset 0x0000<br>1'b0: GPIO control by OS_B with offset 0x1000<br>When virtual_en=1'b0:<br>1'b1: GPIO interrupt connect to gpio_int_flag<br>1'b0: GPIO interrupt connect to gpio_int_flag_exp |

**GPIO GPIO VIRTUAL EN**

Address: Operational Base + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:1       | RO          | 0x0000             | reserved                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | gpio_virtual_en<br>1'b1: Enable virtual, two OS supported<br>1'b0: Disable virtual. |

## 20.5 Interface Description

Table 20-1 GPIO Interface Description

| <b>Module Pin</b>      | <b>Pad Name</b>                                                                   | <b>IOMUX Setting</b>                    |
|------------------------|-----------------------------------------------------------------------------------|-----------------------------------------|
| <b>GPIO0 Interface</b> |                                                                                   |                                         |
| gpio0_port[0]          | REFCLK_OUT/GPIO0_A0_d                                                             | PMU1_IOC_GPIO0A_IOMUX_SEL_L[3:0]=4'b0   |
| gpio0_port[1]          | TSADC_SHUT_ORG/TSADC_SHUT/GPIO0_A1_z                                              | PMU1_IOC_GPIO0A_IOMUX_SEL_L[7:4]=4'b0   |
| gpio0_port[2]          | PMIC_SLEEP1/GPIO0_A2_d                                                            | PMU1_IOC_GPIO0A_IOMUX_SEL_L[11:8]=4'b0  |
| gpio0_port[3]          | PMIC_SLEEP2/GPIO0_A3_d                                                            | PMU1_IOC_GPIO0A_IOMUX_SEL_L[15:12]=4'b0 |
| gpio0_port[4]          | SDMMC_DET/GPIO0_A4_u                                                              | PMU1_IOC_GPIO0A_IOMUX_SEL_H[3:0]=4'b0   |
| gpio0_port[5]          | SPI2_CLK_M2/SDMMC_PWREN/PMU_DEBUG/GPIO0_A5_d                                      | PMU1_IOC_GPIO0A_IOMUX_SEL_H[7:4]=4'b0   |
| gpio0_port[6]          | SPI2_MOSI_M2/I2C0_SDA_M0/GPIO0_A6_z                                               | PMU1_IOC_GPIO0A_IOMUX_SEL_H[11:8]=4'b0  |
| gpio0_port[7]          | PMIC_INT_L/GPIO0_A7_u                                                             | PMU1_IOC_GPIO0A_IOMUX_SEL_H[15:12]=4'b0 |
| gpio0_port[8]          | SPI2_CS1_M2/I2C1_SCL_M1/UART0_RX_M1/GPIO0_B0_z                                    | PMU1_IOC_GPIO0B_IOMUX_SEL_L[3:0]=4'b0   |
| gpio0_port[9]          | SPI2_CS0_M2/I2C1_SDA_M1/PWM5_M0/UART0_TX_M1/GPIO0_B1_z                            | PMU1_IOC_GPIO0B_IOMUX_SEL_L[7:4]=4'b0   |
| gpio0_port[10]         | CLK32K_IN/CLK32K_OUT0/GPIO0_B2_u                                                  | PMU1_IOC_GPIO0B_IOMUX_SEL_L[11:8]=4'b0  |
| gpio0_port[11]         | SPI2_MISO_M2/I2C0_SCL_M0/GPIO0_B3_z                                               | PMU1_IOC_GPIO0B_IOMUX_SEL_L[15:12]=4'b0 |
| gpio0_port[13]         | I2S1_MCLK_M1/JTAG_TCK_M2/I2C1_SCL_M0/UART2_TX_M0/PCIE30X1_1_CLKREQN_M0/GPIO0_B5_d | PMU2_IOC_GPIO0B_IOMUX_SEL_H[7:4]=4'b0   |

| <b>Module Pin</b> | <b>Pad Name</b>                                                                                                                         | <b>IOMUX Setting</b>                    |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|
| gpio0_port[14]    | I2S1_SCLK_M1/JTAG_TMS_M2/I2C1_SDA_M0/UART2_RX_M0/PCIE30X1_1_WAKEN_M0/GPIO0_B6_d                                                         | PMU2_IOC_GPIO0B_IOMUX_SEL_H[11:8]=4'b0  |
| gpio0_port[15]    | I2S1_LRCK_M1/PWM0_M0/I2C2_SCL_M0/CAN0_TX_M0/SPI0_CS1_M0/PCIE30X1_1_PERSTN_M0/GPIO0_B7_d                                                 | PMU2_IOC_GPIO0B_IOMUX_SEL_H[15:12]=4'b0 |
| gpio0_port[16]    | PDM0_CLK0_M1/PWM1_M0/I2C2_SDA_M0/CAN0_RX_M0/SPI0_MOSI_M0/PCIE30X1_0_CLKREQN_M0/GPIO0_C0_d                                               | PMU2_IOC_GPIO0C_IOMUX_SEL_L[3:0]=4'b0   |
| gpio0_port[17]    | PMIC_SLEEP3(GPIO0_C1_d)                                                                                                                 | PMU2_IOC_GPIO0C_IOMUX_SEL_L[7:4]=4'b0   |
| gpio0_port[18]    | PMIC_SLEEP4(GPIO0_C2_d)                                                                                                                 | PMU2_IOC_GPIO0C_IOMUX_SEL_L[11:8]=4'b0  |
| gpio0_port[19]    | PMIC_SLEEP5(GPIO0_C3_d)                                                                                                                 | PMU2_IOC_GPIO0C_IOMUX_SEL_L[15:12]=4'b0 |
| gpio0_port[20]    | PDM0_CLK1_M1/PWM2_M0/UART0_RX_M0/I2C4_SDA_M2/DP0_HPDIN_M1/PCIE30X1_0_WAKEN_M0/GPIO0_C4_d                                                | PMU2_IOC_GPIO0C_IOMUX_SEL_H[3:0]=4'b0   |
| gpio0_port[21]    | I2S1_SDIO_M1/GPU_AVSD/UART0_TX_M0/I2C4_SCL_M2/DP1_HPDIN_M1/PWM4_M0/PCIE30X1_0_PERSTN_M0/GPIO0_C5_u                                      | PMU2_IOC_GPIO0C_IOMUX_SEL_H[7:4]=4'b0   |
| gpio0_port[22]    | I2S1_SDIO1_M1/NPU_AVSD/UART0_RTSN_PWM5_M1/SPI0_CLK_M0/PCIE30X4_CLKREQN_M0/SATA_CP_POD/GPIO0_C6_u                                        | PMU2_IOC_GPIO0C_IOMUX_SEL_H[11:8]=4'b0  |
| gpio0_port[23]    | I2S1_SDIO2_M1/PDM0_SDIO_M1/I2C6_SDA_M0/UART1_RTSN_M2/PWM6_M0/SPI0_MISO_M0/PCIE30X4_WAKEN_M0/GPIO0_C7_d                                  | PMU2_IOC_GPIO0C_IOMUX_SEL_H[15:12]=4'b0 |
| gpio0_port[24]    | I2S1_SDIO3_M1/PDM0_SDIO1_M1/I2C6_SCL_M0/UART1_CTSN_M2/PWM7_IR_M0/SPI3_MISO_M2/PCIE30X4_PERSTN_M0/GPIO0_D0_d                             | PMU2_IOC_GPIO0D_IOMUX_SEL_L[3:0]=4'b0   |
| gpio0_port[25]    | I2S1_SDO0_M1/CPU_BIG0_AVSD/I2C0_SCL_M2/UART0_CTSN/UART1_TX_M2/HDMI_RX_SDA_M0/SPI0_CS0_M0/PCIE30X2_CLKREQN_M0/HDMI_TX0_CEC_M1/GPIO0_D1_u | PMU2_IOC_GPIO0D_IOMUX_SEL_L[7:4]=4'b0   |
| gpio0_port[26]    | I2S1_SDO1_M1/I2C0_SDA_M2/UART1_RX_M2/HDMI_RX_SCL_M0/SPI3_MOSI_M2/PCIE30X2_WAKEN_M0/HDMI_TX1_CEC_M1/GPIO0_D2_u                           | PMU2_IOC_GPIO0D_IOMUX_SEL_L[11:8]=4'b0  |

| <b>Module Pin</b> | <b>Pad Name</b>                                                                                                                   | <b>IOMUX Setting</b>                      |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|
| gpio0_port[27]    | LITCPU_AVG/SPI3_CLK_M2/GPIO0_D3_u                                                                                                 | PMU2_IOC_GPIO0D_IOMUX_X_SEL_L[15:12]=4'b0 |
| gpio0_port[28]    | I2S1_SDO2_M1/PDM0_SDI2_M1/PWM3_IR_M0/I2C1_SCL_M2/CAN2_RX_M1/HDMI_TX0_SDA_M1/SPI3_CS0_M2/PCIE30X2_PERSTN_M0/SATA_CPDDET/GPIO0_D4_u | PMU2_IOC_GPIO0D_IOMUX_X_SEL_H[3:0]=4'b0   |
| gpio0_port[29]    | I2S1_SDO3_M1/CPU_BIG1_AVG/I2C1_SDA_M2/CAN2_TX_M1/HDMI_TX0_SCL_M1/SPI3_CS1_M2/SATA_MP_SWITCH/GPIO0_D5_u                            | PMU2_IOC_GPIO0D_IOMUX_X_SEL_H[7:4]=4'b0   |
| gpio0_port[30]    | PMIC_SLEEP6/PDM0_SDI3_M1/GPIO0_D6_d                                                                                               | PMU2_IOC_GPIO0D_IOMUX_X_SEL_H[11:8]=4'b0  |

**GPIO1 Interface**

|               |                                                                                                   |                                        |
|---------------|---------------------------------------------------------------------------------------------------|----------------------------------------|
| gpio1_port[0] | PCIE30X1_1_CLKREQN_M2/DP0_HPDIN_M2/I2C2_SDA_M4/UART6_RX_M1/SPI4_MISO_M2/GPIO1_A0_d                | BUS_IOC_GPIO1A_IOMUX_SEL_L[3:0]=4'b0   |
| gpio1_port[1] | PCIE30X1_1_WAKEN_M2/DP1_HPDIN_M2/SATA1_ACT_LED_M1/I2C2_SCL_M4/UART6_TX_M1/SPI4_MOSI_M2/GPIO1_A1_d | BUS_IOC_GPIO1A_IOMUX_SEL_L[7:4]=4'b0   |
| gpio1_port[2] | VOP_POST_EMPTY/I2C4_SDA_M3/UART6_RTSN_M1/PWM0_M2/SPI4_CLK_M2/GPIO1_A2_d                           | BUS_IOC_GPIO1A_IOMUX_SEL_L[11:8]=4'b0  |
| gpio1_port[3] | HDMI_TX1_SDA_M2/I2C4_SCL_M3/UART6_CTSN_M1/PWM1_M2/SPI4_CS0_M2/GPIO1_A3_d                          | BUS_IOC_GPIO1A_IOMUX_SEL_L[15:12]=4'b0 |
| gpio1_port[4] | HDMI_TX1_SCL_M2/SPI2_MISO_M0/GPIO1_A4_d                                                           | BUS_IOC_GPIO1A_IOMUX_SEL_H[3:0]=4'b0   |
| gpio1_port[5] | HDMI_TX0_HPD_M0/SPI2_MOSI_M0/GPIO1_A5_d                                                           | BUS_IOC_GPIO1A_IOMUX_SEL_H[7:4]=4'b0   |
| gpio1_port[6] | HDMI_TX1_HPD_M0/SPI2_CLK_M0/GPIO1_A6_d                                                            | BUS_IOC_GPIO1A_IOMUX_SEL_H[11:8]=4'b0  |
| gpio1_port[7] | PDM1_SDI0_M1/PCIE30X1_1_PERSTN_M2/PWM3_IR_M3/SPI2_CS0_M0/GPIO1_A7_u                               | BUS_IOC_GPIO1A_IOMUX_SEL_H[15:12]=4'b0 |
| gpio1_port[8] | PDM1_SDI1_M1/PCIE30X4_CLKREQN_M3/SPI2_CS1_M0/GPIO1_B0_u                                           | BUS_IOC_GPIO1B_IOMUX_SEL_L[3:0]=4'b0   |
| gpio1_port[9] | PDM1_SDI2_M1/PCIE30X4_WAKEN_M3/SPI0_MISO_M2/GPIO1_B1_d                                            | BUS_IOC_GPIO1B_IOMUX_SEL_L[7:4]=4'b0   |

| <b>Module Pin</b> | <b>Pad Name</b>                                                                                                                 | <b>IOMUX Setting</b>                   |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|
| gpio1_port[10]    | PDM1_SD13_M1/PCIE30X4_PERSTN_M3/UART4_RX_M2/SPI0_MOSI_M2/GPIO1_B2_d                                                             | BUS_IOC_GPIO1B_IOMUX_SEL_L[11:8]=4'b0  |
| gpio1_port[11]    | PDM1_CLK1_M1/PCIE30X1_0_WAKEN_M2/SATA0_ACT_LED_M1/UART4_TX_M2/SPI0_CLK_M2/GPIO1_B3_d                                            | BUS_IOC_GPIO1B_IOMUX_SEL_L[15:12]=4'b0 |
| gpio1_port[12]    | PDM1_CLK0_M1/PCIE30X1_0_PERSTN_M2/UART7_RX_M2/SPI0_CS0_M2/GPIO1_B4_u                                                            | BUS_IOC_GPIO1B_IOMUX_SEL_H[3:0]=4'b0   |
| gpio1_port[13]    | PCIE30X1_0_CLKREQN_M2/UART7_TX_M2/SPI0_CS1_M2/GPIO1_B5_u                                                                        | BUS_IOC_GPIO1B_IOMUX_SEL_H[7:4]=4'b0   |
| gpio1_port[14]    | MIPI_CAMERA1_CLK_M0/SPDIF0_TX_M0/PCIE30X2_WAKEN_M3/HDMI_RX_HPDOUT_M2/I2C5_SCL_M3/UART1_TX_M1/GPIO1_B6_d                         | BUS_IOC_GPIO1B_IOMUX_SEL_H[11:8]=4'b0  |
| gpio1_port[15]    | MIPI_CAMERA2_CLK_M0/SPDIF1_TX_M0/PCIE30X2_PERSTN_M3/HDMI_RX_CEC_M2/SATA2_ACT_LED_M1/I2C5_SDA_M3/UART1_RX_M1/PWM13_M2/GPIO1_B7_u | BUS_IOC_GPIO1B_IOMUX_SEL_H[15:12]=4'b0 |
| gpio1_port[16]    | I2C3_SDA_M0/UART3_RX_M0/SPI4_MISO_M0/GPIO1_C0_z                                                                                 | BUS_IOC_GPIO1C_IOMUX_SEL_L[3:0]=4'b0   |
| gpio1_port[17]    | I2C3_SCL_M0/UART3_TX_M0/SPI4_MOSI_M0/GPIO1_C1_z                                                                                 | BUS_IOC_GPIO1C_IOMUX_SEL_L[7:4]=4'b0   |
| gpio1_port[18]    | I2S0_MCLK/I2C6_SDA_M1/UART3_RTSN/PWM3_IR_M2/SPI4_CLK_M0/GPIO1_C2_d                                                              | BUS_IOC_GPIO1C_IOMUX_SEL_L[11:8]=4'b0  |
| gpio1_port[19]    | I2S0_SCLK/I2C6_SCL_M1/UART3_CTSN/PWM7_IR_M2/SPI4_CS0_M0/GPIO1_C3_d                                                              | BUS_IOC_GPIO1C_IOMUX_SEL_L[15:12]=4'b0 |
| gpio1_port[20]    | PDM0_CLK1_M0/I2C2_SDA_M3/PWM11_IR_M2/SPI4_CS1_M0/GPIO1_C4_d                                                                     | BUS_IOC_GPIO1C_IOMUX_SEL_H[3:0]=4'b0   |
| gpio1_port[21]    | I2S0_LRCK/I2C2_SCL_M3/UART4_RTSN/GPIO1_C5_d                                                                                     | BUS_IOC_GPIO1C_IOMUX_SEL_H[7:4]=4'b0   |
| gpio1_port[22]    | PDM0_CLK0_M0/I2C4_SDA_M4/PWM15_IR_M2/GPIO1_C6_d                                                                                 | BUS_IOC_GPIO1C_IOMUX_SEL_H[11:8]=4'b0  |
| gpio1_port[23]    | I2S0_SDO0/I2C4_SCL_M4/UART4_CTSN/GPIO1_C7_d                                                                                     | BUS_IOC_GPIO1C_IOMUX_SEL_H[15:12]=4'b0 |
| gpio1_port[24]    | I2S0_SDO1/I2C7_SCL_M0/UART6_TX_M2/SPI1_MISO_M2/GPIO1_D0_d                                                                       | BUS_IOC_GPIO1D_IOMUX_SEL_L[3:0]=4'b0   |

| <b>Module Pin</b> | <b>Pad Name</b>                                                                                          | <b>IOMUX Setting</b>                   |
|-------------------|----------------------------------------------------------------------------------------------------------|----------------------------------------|
| gpio1_port[25]    | I2S0_SDO2/I2S0_SDI3/PDM0_SDI1_M0/I2C7_SDA_M0/UART6_RX_M2/SPI1_MOSI_M2/GPIO1_D1_d                         | BUS_IOC_GPIO1D_IOMUX_SEL_L[7:4]=4'b0   |
| gpio1_port[26]    | I2S0_SDO3/I2S0_SDI2/PDM0_SDI2_M0/I2C1_SCL_M4/UART4_TX_M0/PWM0_M1/SPI1_CLK_M2/GPIO1_D2_d                  | BUS_IOC_GPIO1D_IOMUX_SEL_L[11:8]=4'b0  |
| gpio1_port[27]    | I2S0_SDI1/PDM0_SDI3_M0/I2C1_SDA_M4/UART4_RX_M0/PWM1_M1/SPI1_CS0_M2/GPIO1_D3_d                            | BUS_IOC_GPIO1D_IOMUX_SEL_L[15:12]=4'b0 |
| gpio1_port[28]    | I2S0_SDI0(GPIO1_D4_d)                                                                                    | BUS_IOC_GPIO1D_IOMUX_SEL_H[3:0]=4'b0   |
| gpio1_port[29]    | PDM0_SDI0_M0/SPI1_CS1_M2/GPIO1_D5_d                                                                      | BUS_IOC_GPIO1D_IOMUX_SEL_H[7:4]=4'b0   |
| gpio1_port[30]    | MIPI_CAMERA3_CLK_M0/HDMI_RX_SCL_M2/I2C8_SCL_M2/UART1_RTSN_M1/PWM14_M2/GPIO1_D6_u                         | BUS_IOC_GPIO1D_IOMUX_SEL_H[11:8]=4'b0  |
| gpio1_port[31]    | MIPI_CAMERA4_CLK_M0/PCIE30X2_CLKRE_QN_M3/HDMI_RX_SDA_M2/I2C8_SDA_M2/UART1_CTSN_M1/PWM15_IR_M3/GPIO1_D7_u | BUS_IOC_GPIO1C_IOMUX_SEL_H[15:12]=4'b0 |

**GPIO2 Interface**

|               |                                                                        |                                        |
|---------------|------------------------------------------------------------------------|----------------------------------------|
| gpio2_port[0] | EMMC_CMD/FSPI_CLK_M0/GPIO2_A0_u                                        | BUS_IOC_GPIO2A_IOMUX_SEL_L[3:0]=4'b0   |
| gpio2_port[1] | EMMC_CLKOUT/GPIO2_A1_d                                                 | BUS_IOC_GPIO2A_IOMUX_SEL_L[7:4]=4'b0   |
| gpio2_port[2] | EMMC_DATA_STROBE/I2C2_SDA_M2/UART5_CTSN_M1/GPIO2_A2_d                  | BUS_IOC_GPIO2A_IOMUX_SEL_L[11:8]=4'b0  |
| gpio2_port[3] | EMMC_RSTN/I2C2_SCL_M2/UART5_RTSN_M1/GPIO2_A3_d                         | BUS_IOC_GPIO2A_IOMUX_SEL_L[15:12]=4'b0 |
| gpio2_port[6] | GMAC0_RXD2/SDIO_D0_M0/FSPI_D0_M1/UART6_RX_M0/GPIO2_A6_u                | BUS_IOC_GPIO2A_IOMUX_SEL_H[11:8]=4'b0  |
| gpio2_port[7] | GMAC0_RXD3/SDIO_D1_M0/FSPI_D1_M1/UART6_TX_M0/GPIO2_A7_u                | BUS_IOC_GPIO2A_IOMUX_SEL_H[15:12]=4'b0 |
| gpio2_port[8] | GMAC0_RXCLK/SDIO_D2_M0/FSPI_D2_M1/I2C8_SCL_M1/UART6_RTSN_M0/GPIO2_B0_u | BUS_IOC_GPIO2B_IOMUX_SEL_L[3:0]=4'b0   |

| <b>Module Pin</b> | <b>Pad Name</b>                                                                   | <b>IOMUX Setting</b>                   |
|-------------------|-----------------------------------------------------------------------------------|----------------------------------------|
| gpio2_port[9]     | GMAC0_TXD2/SDIO_D3_M0/FSPI_D3_M1/I2C8_SDA_M1/UART6_CTSN_M0(GPIO2_B1_u)            | BUS_IOC_GPIO2B_IOMUX_SEL_L[7:4]=4'b0   |
| gpio2_port[10]    | GMAC0_TXD3/SDIO_CMD_M0/I2C3_SCL_M3(GPIO2_B2_u)                                    | BUS_IOC_GPIO2B_IOMUX_SEL_L[11:8]=4'b0  |
| gpio2_port[11]    | GMAC0_TXCLK/SDIO_CLK_M0/FSPI_CLK_M1/I2C3_SDA_M3(GPIO2_B3_d)                       | BUS_IOC_GPIO2B_IOMUX_SEL_L[15:12]=4'b0 |
| gpio2_port[12]    | GMAC0_PTP_REFCLK/FSPI_CS0N_M1/HDMI_TX1_SDA_M0/I2C4_SDA_M1/UART7_RX_M0(GPIO2_B4_u) | BUS_IOC_GPIO2B_IOMUX_SEL_H[3:0]=4'b0   |
| gpio2_port[13]    | GMAC0_PPSTRING/FSPI_CS1N_M1/HDMI_TX1_SCL_M0/I2C4_SCL_M1/UART7_TX_M0(GPIO2_B5_u)   | BUS_IOC_GPIO2B_IOMUX_SEL_H[7:4]=4'b0   |
| gpio2_port[14]    | GMAC0_TXD0/I2S2_MCLK_M0/I2C5_SCL_M4/UART1_RX_M0(GPIO2_B6_d)                       | BUS_IOC_GPIO2B_IOMUX_SEL_H[11:8]=4'b0  |
| gpio2_port[15]    | GMAC0_TXD1/I2S2_SCLK_M0/I2C5_SDA_M4/UART1_TX_M0(GPIO2_B7_d)                       | BUS_IOC_GPIO2B_IOMUX_SEL_H[15:12]=4'b0 |
| gpio2_port[16]    | GMAC0_RXCLK/SDIO_D2_M0/FSPI_D2_M1/I2C8_SCL_M1/UART6_RTSN_M0(GPIO2_B0_u)           | BUS_IOC_GPIO2C_IOMUX_SEL_L[3:0]=4'b0   |
| gpio2_port[17]    | GMAC0_TXD2/SDIO_D3_M0/FSPI_D3_M1/I2C8_SDA_M1/UART6_CTSN_M0(GPIO2_B1_u)            | BUS_IOC_GPIO2C_IOMUX_SEL_L[7:4]=4'b0   |
| gpio2_port[18]    | GMAC0_TXD3/SDIO_CMD_M0/I2C3_SCL_M3(GPIO2_B2_u)                                    | BUS_IOC_GPIO2C_IOMUX_SEL_L[11:8]=4'b0  |
| gpio2_port[19]    | GMAC0_TXCLK/SDIO_CLK_M0/FSPI_CLK_M1/I2C3_SDA_M3(GPIO2_B3_d)                       | BUS_IOC_GPIO2C_IOMUX_SEL_L[15:12]=4'b0 |
| gpio2_port[20]    | GMAC0_PTP_REFCLK/FSPI_CS0N_M1/HDMI_TX1_SDA_M0/I2C4_SDA_M1/UART7_RX_M0(GPIO2_B4_u) | BUS_IOC_GPIO2C_IOMUX_SEL_H[3:0]=4'b0   |
| gpio2_port[21]    | GMAC0_PPSTRING/FSPI_CS1N_M1/HDMI_TX1_SCL_M0/I2C4_SCL_M1/UART7_TX_M0(GPIO2_B5_u)   | BUS_IOC_GPIO2C_IOMUX_SEL_H[7:4]=4'b0   |
| gpio2_port[22]    | EMMC_D0/FSPI_D0_M0(GPIO2_D0_u)                                                    | BUS_IOC_GPIO2D_IOMUX_SEL_L[3:0]=4'b0   |
| gpio2_port[25]    | EMMC_D1/FSPI_D1_M0(GPIO2_D1_u)                                                    | BUS_IOC_GPIO2D_IOMUX_SEL_L[7:4]=4'b0   |

| <b>Module Pin</b>      | <b>Pad Name</b>                                                                                       | <b>IOMUX Setting</b>                   |
|------------------------|-------------------------------------------------------------------------------------------------------|----------------------------------------|
| gpio2_port[26]         | EMMC_D2/FSPI_D2_M0/GPIO2_D2_u                                                                         | BUS_IOC_GPIO2D_IOMUX_SEL_L[11:8]=4'b0  |
| gpio2_port[27]         | EMMC_D3/FSPI_D3_M0/GPIO2_D3_u                                                                         | BUS_IOC_GPIO2D_IOMUX_SEL_L[15:12]=4'b0 |
| gpio2_port[28]         | EMMC_D4/I2C1_SCL_M3/UART5_RX_M2/GPIO2_D4_u                                                            | BUS_IOC_GPIO2D_IOMUX_SEL_H[3:0]=4'b0   |
| gpio2_port[29]         | EMMC_D5/I2C1_SDA_M3/UART5_TX_M2/GPIO2_D5_u                                                            | BUS_IOC_GPIO2D_IOMUX_SEL_H[7:4]=4'b0   |
| gpio2_port[30]         | EMMC_D6/FSPI_CS0N_M0/GPIO2_D6_u                                                                       | BUS_IOC_GPIO2D_IOMUX_SEL_H[11:8]=4'b0  |
| gpio2_port[31]         | EMMC_D7/FSPI_CS1N_M0/GPIO2_D7_u                                                                       | BUS_IOC_GPIO2D_IOMUX_SEL_H[15:12]=4'b0 |
| <b>GPIO3 Interface</b> |                                                                                                       |                                        |
| gpio3_port[0]          | GMAC1_TXD2/SDIO_D0_M1/I2S3_MCLK/FSP_I_D0_M2/I2C6_SDA_M4/PWM10_M0/SPI4_MISO_M1/GPIO3_A0_u              | BUS_IOC_GPIO3A_IOMUX_SEL_L[3:0]=4'b0   |
| gpio3_port[1]          | GMAC1_TXD3/SDIO_D1_M1/I2S3_SCLK/AUD_DSM_LN/FSPI_D1_M2/I2C6_SCL_M4/PWM11_IR_M0/SPI4_MOSI_M1/GPIO3_A1_u | BUS_IOC_GPIO3A_IOMUX_SEL_L[7:4]=4'b0   |
| gpio3_port[2]          | GMAC1_RXD2/SDIO_D2_M1/I2S3_LRCK/AUDDSM_LP/FSPI_D2_M2/UART8_TX_M1/SPI4_CLK_M1/GPIO3_A2_u               | BUS_IOC_GPIO3A_IOMUX_SEL_L[11:8]=4'b0  |
| gpio3_port[3]          | GMAC1_RXD3/SDIO_D3_M1/I2S3_SDO/AUD_DSM_RN/FSPI_D3_M2/UART8_RX_M1/SPI4_CS0_M1/GPIO3_A3_u               | BUS_IOC_GPIO3A_IOMUX_SEL_L[15:12]=4'b0 |
| gpio3_port[4]          | GMAC1_TXCLK/SDIO_CMD_M1/I2S3_SDI/AUDDSM_RP/UART8_RTSN_M1/SPI4_CS1_M1/GPIO3_A4_d                       | BUS_IOC_GPIO3A_IOMUX_SEL_H[3:0]=4'b0   |
| gpio3_port[5]          | GMAC1_RXCLK/SDIO_CLK_M1/MIPI_CAMERA0_CLK_M1/FSPI_CLK_M2/I2C4_SDA_M0/UART8_CTSN_M1/GPIO3_A5_d          | BUS_IOC_GPIO3A_IOMUX_SEL_H[7:4]=4'b0   |
| gpio3_port[6]          | ETH1_REFCLKO_25M/MIPI_CAMERA1_CLK_M1/I2C4_SCL_M0/GPIO3_A6_d                                           | BUS_IOC_GPIO3A_IOMUX_SEL_H[11:8]=4'b0  |
| gpio3_port[7]          | GMAC1_RXD0/MIPI_CAMERA2_CLK_M1/PWM8_M0/GPIO3_A7_u                                                     | BUS_IOC_GPIO3A_IOMUX_SEL_H[15:12]=4'b0 |

| <b>Module Pin</b> | <b>Pad Name</b>                                                                                        | <b>IOMUX Setting</b>                   |
|-------------------|--------------------------------------------------------------------------------------------------------|----------------------------------------|
| gpio3_port[8]     | GMAC1_RXD1/MIPI_CAMERA3_CLK_M1/PWM9_M0/GPIO3_B0_u                                                      | BUS_IOC_GPIO3B_IOMUX_SEL_L[3:0]=4'b0   |
| gpio3_port[9]     | GMAC1_RXDV_CRS/MIPI_CAMERA4_CLK_M1/UART2_TX_M2/PWM2_M1/GPIO3_B1_d                                      | BUS_IOC_GPIO3B_IOMUX_SEL_L[7:4]=4'b0   |
| gpio3_port[10]    | GMAC1_TXER/I2S2_SDI_M1/UART2_RX_M2/PWM3_IR_M1/GPIO3_B2_d                                               | BUS_IOC_GPIO3B_IOMUX_SEL_L[11:8]=4'b0  |
| gpio3_port[11]    | GMAC1_TXD0/I2S2_SDO_M1/UART2_RTSN/GPIO3_B3_u                                                           | BUS_IOC_GPIO3B_IOMUX_SEL_L[15:12]=4'b0 |
| gpio3_port[12]    | GMAC1_TXD1/I2S2_MCLK_M1/UART2_CTSN/GPIO3_B4_u                                                          | BUS_IOC_GPIO3B_IOMUX_SEL_H[3:0]=4'b0   |
| gpio3_port[13]    | GMAC1_TXEN/I2S2_SCLK_M1/CAN1_RX_M0/UART3_TX_M1/PWM12_M0/GPIO3_B5_u                                     | BUS_IOC_GPIO3B_IOMUX_SEL_H[7:4]=4'b0   |
| gpio3_port[14]    | GMAC1_MCLKINOUT/I2S2_LRCK_M1/CAN1_TX_M0/UART3_RX_M1/PWM13_M0/GPIO3_B6_d                                | BUS_IOC_GPIO3B_IOMUX_SEL_H[11:8]=4'b0  |
| gpio3_port[15]    | GMAC1_PTP_REF_CLK/HDMI_TX1_HPD_M1/I2C3_SCL_M1/SPI1_MOSI_M1/GPIO3_B7_d                                  | BUS_IOC_GPIO3B_IOMUX_SEL_H[15:12]=4'b0 |
| gpio3_port[16]    | GMAC1_PPSTRIG/I2C3_SDA_M1/UART7_TX_M1/SPI1_MISO_M1/GPIO3_C0_d                                          | BUS_IOC_GPIO3C_IOMUX_SEL_L[3:0]=4'b0   |
| gpio3_port[17]    | GMAC1_PPSCLK/PCIE30X2_BUTTON_RSTN/UART7_RX_M1/SPI1_CLK_M1/GPIO3_C1_d                                   | BUS_IOC_GPIO3C_IOMUX_SEL_L[7:4]=4'b0   |
| gpio3_port[18]    | GMAC1_MDC/MIPI_TE0/I2C8_SCL_M4/UART7_RTSN_M1/PWM14_M0/SPI1_CS0_M1/GPIO3_C2_d                           | BUS_IOC_GPIO3C_IOMUX_SEL_L[11:8]=4'b0  |
| gpio3_port[19]    | GMAC1_MDIO/MIPI_TE1/I2C8_SDA_M4/UART7_CTSN_M1/PWM15_IR_M0/SPI1_CS1_M1/GPIO3_C3_d                       | BUS_IOC_GPIO3C_IOMUX_SEL_L[15:12]=4'b0 |
| gpio3_port[20]    | CIF_D8/FSPI_CS0N_M2/PCIE30X4_CLKREQ_N_M2/HDMI_TX1_CEC_M2/CAN2_RX_M0/UART5_RX_M1/SPI3_CS0_M3/GPIO3_C4_u | BUS_IOC_GPIO3C_IOMUX_SEL_H[3:0]=4'b0   |
| gpio3_port[21]    | CIF_D9/FSPI_CS1N_M2/PCIE30X4_WAKEN_M2/HDMI_TX1_SDA_M1/CAN2_TX_M0/UART5_RX_M1/SPI3_CS1_M3/GPIO3_C5_u    | BUS_IOC_GPIO3C_IOMUX_SEL_H[7:4]=4'b0   |
| gpio3_port[22]    | CIF_D10/PCIE30X4_PERSTN_M2/HDMI_TX1_SCL_M1/SPI3_MISO_M3/GPIO3_C6_u                                     | BUS_IOC_GPIO3C_IOMUX_SEL_H[11:8]=4'b0  |

| <b>Module Pin</b> | <b>Pad Name</b>                                                                                         | <b>IOMUX Setting</b>                   |
|-------------------|---------------------------------------------------------------------------------------------------------|----------------------------------------|
| gpio3_port[23]    | CIF_D11/PCIE20X1_2_CLKREQN_M0/HDMI_TX0_SCL_M2/I2C5_SCL_M0/SPI3_MOSI_M3/GPIO3_C7_u                       | BUS_IOC_GPIO3C_IOMUX_SEL_H[15:12]=4'b0 |
| gpio3_port[24]    | CIF_D12/PCIE20X1_2_WAKEN_M0/HDMI_TX0_SDA_M2/I2C5_SDA_M0/UART4_RX_M1/PWM8_M2/SPI3_CLK_M3/GPIO3_D0_u      | BUS_IOC_GPIO3D_IOMUX_SEL_L[3:0]=4'b0   |
| gpio3_port[25]    | CIF_D13/PCIE20X1_2_PERSTN_M0/HDMI_RX_X_CEC_M1/UART4_TX_M1/PWM9_M2/SPI0_MISO_M3/GPIO3_D1_d               | BUS_IOC_GPIO3D_IOMUX_SEL_L[7:4]=4'b0   |
| gpio3_port[26]    | CIF_D14/PCIE30X2_CLKREQN_M2/HDMI_RX_SCL_M1/I2C7_SCL_M2/UART9_RTSN_M2/SPI0_MOSI_M3/GPIO3_D2_d            | BUS_IOC_GPIO3D_IOMUX_SEL_L[11:8]=4'b0  |
| gpio3_port[27]    | CIF_D15/PCIE30X2_WAKEN_M2/HDMI_RX_SDA_M1/I2C7_SDA_M2/UART9_CTSN_M2/PWM10_M2/SPI0_CLK_M3/GPIO3_D3_d      | BUS_IOC_GPIO3D_IOMUX_SEL_L[15:12]=4'b0 |
| gpio3_port[28]    | HDMI_TX0_HPD_M1/PCIE30X2_PERSTN_M2/HDMI_RX_HPDOUT_M1/MCU_JTAG_TCK_M1/UART9_RX_M2/SPI0_CS0_M3/GPIO3_D4_d | BUS_IOC_GPIO3D_IOMUX_SEL_H[3:0]=4'b0   |
| gpio3_port[29]    | PCIE30X4_BUTTON_RSTN/DP1_HPPIN_M0/MCU_JTAG_TMS_M1/UART9_TX_M2/PWM11_IR_M3/SPI0_CS1_M3/GPIO3_D5_d        | BUS_IOC_GPIO3D_IOMUX_SEL_H[7:4]=4'b0   |

**GPIO4 Interface**

|               |                                                                                           |                                        |
|---------------|-------------------------------------------------------------------------------------------|----------------------------------------|
| gpio4_port[0] | CIF_D0/BT1120_D0/I2S1_MCLK_M0/PCIE30X1_1_CLKREQN_M1/UART9_RTSN_M1/SPI0_MISO_M1/GPIO4_A0_d | BUS_IOC_GPIO4A_IOMUX_SEL_L[3:0]=4'b0   |
| gpio4_port[1] | CIF_D1/BT1120_D1/I2S1_SCLK_M0/PCIE30X1_1_WAKEN_M1/UART9_CTSN_M1/SPI0_MOSI_M1/GPIO4_A1_d   | BUS_IOC_GPIO4A_IOMUX_SEL_L[7:4]=4'b0   |
| gpio4_port[2] | CIF_D2/BT1120_D2/I2S1_LRCK_M0/PCIE30X1_1_PERSTN_M1/SPI0_CLK_M1/GPIO4_A2_d                 | BUS_IOC_GPIO4A_IOMUX_SEL_L[11:8]=4'b0  |
| gpio4_port[3] | CIF_D3/BT1120_D3/PCIE30X1_0_CLKREQN_M1/UART0_TX_M2/GPIO4_A3_d                             | BUS_IOC_GPIO4A_IOMUX_SEL_L[15:12]=4'b0 |
| gpio4_port[4] | CIF_D4/BT1120_D4/PCIE30X1_0_WAKEN_M1/I2C3_SCL_M2/UART0_RX_M2/SPI2_MISO_M1/GPIO4_A4_d      | BUS_IOC_GPIO4A_IOMUX_SEL_H[3:0]=4'b0   |

| <b>Module Pin</b> | <b>Pad Name</b>                                                                                                                      | <b>IOMUX Setting</b>                   |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|
| gpio4_port[5]     | CIF_D5/BT1120_D5/I2S1_SDI0_M0/PCIE30X1_0_PERSTN_M1/I2C3_SDA_M2/UART3_TX_M2/SPI2_MOSI_M1/GPIO4_A5_d                                   | BUS_IOC_GPIO4A_IOMUX_SEL_H[7:4]=4'b0   |
| gpio4_port[6]     | CIF_D6/BT1120_D6/I2S1_SDI1_M0/PCIE30X2_CLKREQN_M1/I2C5_SCL_M2/UART3_RX_M2/SPI2_CLK_M1/GPIO4_A6_d                                     | BUS_IOC_GPIO4A_IOMUX_SEL_H[11:8]=4'b0  |
| gpio4_port[7]     | CIF_D7/BT1120_D7/I2S1_SDI2_M0/PCIE30X2_WAKEN_M1/I2C5_SDA_M2/SPI2_CS0_M1/GPIO4_A7_d                                                   | BUS_IOC_GPIO4A_IOMUX_SEL_H[15:12]=4'b0 |
| gpio4_port[8]     | CIF_CLKIN/BT1120_CLKOUT/I2S1_SDI3_M0/PCIE30X2_PERSTN_M1/I2C6_SDA_M3/UART8_TX_M0/SPI2_CS1_M1/GPIO4_B0_d                               | BUS_IOC_GPIO4B_IOMUX_SEL_L[3:0]=4'b0   |
| gpio4_port[9]     | MIPI_CAMERA0_CLK_M0/SPDIF1_TX_M1/I2S1_SDO0_M0/PCIE30X1_0_BUTTON_RSTN/SATA2_ACT_LED_M0/I2C6_SCL_M3/UART8_RX_M0/SPI0_CS1_M1/GPIO4_B1_u | BUS_IOC_GPIO4B_IOMUX_SEL_L[7:4]=4'b0   |
| gpio4_port[10]    | CIF_HREF/BT1120_D8/I2S1_SDO1_M0/PCIE30X1_1_BUTTON_RSTN/I2C7_SCL_M3/UART8_RTSN_M0/PWM14_M1/SPI0_CS0_M1/CAN1_RX_M1/GPIO4_B2_u          | BUS_IOC_GPIO4B_IOMUX_SEL_L[11:8]=4'b0  |
| gpio4_port[11]    | CIF_VSYNC/BT1120_D9/I2S1_SDO2_M0/PCI_E20X1_2_BUTTON_RSTN/I2C7_SDA_M3/UART8_CTSN_M0/PWM15_IR_M1/CAN1_TX_M1/GPIO4_B3_u                 | BUS_IOC_GPIO4B_IOMUX_SEL_L[15:12]=4'b0 |
| gpio4_port[12]    | CIF_CLKOUT/BT1120_D10/I2S1_SDO3_M0/PCIE30X4_CLKREQN_M1/DP0_HPDIN_M0/SPDIFO_TX_M1/UART9_TX_M1/PWM11_IR_M1/GPIO4_B4_u                  | BUS_IOC_GPIO4B_IOMUX_SEL_H[3:0]=4'b0   |
| gpio4_port[13]    | BT1120_D11/PCIE30X4_WAKEN_M1/HDMI_RX_CEC_M0/SATA1_ACT_LED_M0/UART9_RX_M1/PWM12_M1/SPI3_MISO_M1/GPIO4_B5_d                            | BUS_IOC_GPIO4B_IOMUX_SEL_H[7:4]=4'b0   |
| gpio4_port[14]    | BT1120_D12/PCIE30X4_PERSTN_M1/HDMI_RX_HPDOUT_M0/SATA0_ACT_LED_M0/I2C5_SCL_M1/PWM13_M1/SPI3_MOSI_M1/GPIO4_B6_d                        | BUS_IOC_GPIO4B_IOMUX_SEL_H[11:8]=4'b0  |
| gpio4_port[15]    | BT1120_D13/PCIE20X1_2_CLKREQN_M1/HDMI_TX0_SCL_M0/I2C5_SDA_M1/SPI3_CLK_M1/GPIO4_B7_u                                                  | BUS_IOC_GPIO4B_IOMUX_SEL_H[15:12]=4'b0 |

| <b>Module Pin</b> | <b>Pad Name</b>                                                                                         | <b>IOMUX Setting</b>                   |
|-------------------|---------------------------------------------------------------------------------------------------------|----------------------------------------|
| gpio4_port[16]    | BT1120_D14/PCIE20X1_2_WAKEN_M1/HDMI_TX0_SDA_M0/I2C8_SCL_M3/SPI3_CS0_M1/GPIO4_C0_u                       | BUS_IOC_GPIO4C_IOMUX_SEL_L[3:0]=4'b0   |
| gpio4_port[17]    | BT1120_D15/SPDIF1_TX_M2/PCIE20X1_2_PERSTN_M1/HDMI_TX0_CEC_M0/I2C8_SDA_M3/PWM6_M1/SPI3_CS1_M1/GPIO4_C1_d | BUS_IOC_GPIO4C_IOMUX_SEL_L[7:4]=4'b0   |
| gpio4_port[18]    | GMAC0_RXDV CRS/UART7_RTSN_M0/PWM2_M2/SPI3_CS0_M0/GPIO4_C2_d                                             | BUS_IOC_GPIO4C_IOMUX_SEL_L[11:8]=4'b0  |
| gpio4_port[19]    | GMAC0_MCLKINOUT/I2S2_SDO_M0/I2C7_SCL_M1/PWM4_M1/SPI3_CS1_M0/GPIO4_C3_d                                  | BUS_IOC_GPIO4C_IOMUX_SEL_L[15:12]=4'b0 |
| gpio4_port[20]    | GMAC0_MDC/I2C7_SDA_M1/UART9_RTSN_M0/PWM5_M2/SPI3_MISO_M0/GPIO4_C4_d                                     | BUS_IOC_GPIO4C_IOMUX_SEL_H[3:0]=4'b0   |
| gpio4_port[21]    | GMAC0_MDIO/I2C0_SCL_M1/UART9_CTSN_M0/PWM6_M2/SPI3_MOSI_M0/GPIO4_C5_d                                    | BUS_IOC_GPIO4C_IOMUX_SEL_H[7:4]=4'b0   |
| gpio4_port[22]    | GMAC0_TXER/I2C0_SDA_M1/UART7_CTSN_M0/PWM7_IR_M3/SPI3_CLK_M0/GPIO4_C6_d                                  | BUS_IOC_GPIO4C_IOMUX_SEL_H[11:8]=4'b0  |
| gpio4_port[24]    | SDMMC_D0/PDM1_SDI3_M0/JTAG_TCK_M1/I2C3_SCL_M4/UART2_TX_M1/PWM8_M1/GPIO4_D0_u                            | BUS_IOC_GPIO4D_IOMUX_SEL_L[3:0]=4'b0   |
| gpio4_port[25]    | SDMMC_D1/PDM1_SDI2_M0/JTAG_TMS_M1/I2C3_SDA_M4/UART2_RX_M1/PWM9_M1/GPIO4_D1_u                            | BUS_IOC_GPIO4D_IOMUX_SEL_L[7:4]=4'b0   |
| gpio4_port[26]    | SDMMC_D2/PDM1_SDI1_M0/JTAG_TCK_M0/I2C8_SCL_M0/UART5_CTSN_M0/GPIO4_D2_u                                  | BUS_IOC_GPIO4D_IOMUX_SEL_L[11:8]=4'b0  |
| gpio4_port[27]    | SDMMC_D3/PDM1_SDI0_M0/JTAG_TMS_M0/I2C8_SDA_M0/UART5_RTSN_M0/PWM10_M1/GPIO4_D3_u                         | BUS_IOC_GPIO4D_IOMUX_SEL_L[15:12]=4'b0 |
| gpio4_port[28]    | SDMMC_CMD/PDM1_CLK1_M0/MCU_JTAG_TCK_M0/CAN0_TX_M1/UART5_RX_M0/PWM7_IR_M1/GPIO4_D4_u                     | BUS_IOC_GPIO4D_IOMUX_SEL_H[3:0]=4'b0   |
| gpio4_port[29]    | SDMMC_CLK/PDM1_CLK0_M0/TEST_CLK0_UT_M0/MCU_JTAG_TMS_M0/CAN0_RX_M1/UART5_TX_M0/GPIO4_D5_d                | BUS_IOC_GPIO4D_IOMUX_SEL_H[7:4]=4'b0   |

Notes: Unused Module Pin is tied to zero!

## **20.6 Application Notes**

- Reading from an unused location or unused bits in a particular register always returns zeros. There is no error mechanism in the APB.
- Programming the GPIO registers for interrupt detection should be completed prior to enabling the interrupts in order to prevent spurious glitches on the interrupt output signal to the interrupt controller.

Rockchip Confidential