Differences
This shows you the differences between two versions of the page.
Both sides previous revision Previous revision Next revision | Previous revision | ||
gpio_control [2022/04/07 18:56] – Add RTL8390 pinmux table svanheule | gpio_control [2025/01/15 10:56] (current) – Update RTL8390 pin muxing table svanheule | ||
---|---|---|---|
Line 1: | Line 1: | ||
====== GPIO control ====== | ====== GPIO control ====== | ||
+ | |||
+ | ===== Built-in GPIO ===== | ||
+ | |||
+ | A number of GPIO pins are available on the SoC's package. For the RTL8380 series with LQF216 only has a limited number of GPIOs broken out, but the RTL8390 and later use BGA packages with more pins available. | ||
+ | The GPIO port registers provide controls for four GPIO ports. The bits per port are MSB first, but per 32-bit registers the ports are in least-significant order. | ||
+ | The rtl8380-gpio driver fixes this mixed layout, and provides A0 as gpio 0, B0 as gpio 8, and so on. This is done so the GPIO numbers used in the SDK and datasheets are consistent with rtl8380-gpio. | ||
+ | |||
+ | ==== Registers ==== | ||
+ | On the [[RTL838x]] and [[RTL839x]] SoCs, these registers can be found on the SoC bus (base address 0xB8003500). The FUNCTION register doesn' | ||
+ | |||
+ | ^ Offset ^ Name ^ Description ^ | ||
+ | | 0x00 | CONTROL | ||
+ | | 0x04 | FUNCTION | ||
+ | | 0x08 | DIRECTION | ||
+ | | 0x0C | DATA | Pin data register. Write to set a GPIO output value, read to get the input value. | | ||
+ | | 0x10 | ISR | Interrupt status register. If a pin interrupt was triggered, read this register to find out which pin caused the interrupt. \\ To clear a pin interrupt, write 1 to the respective bit. | | ||
+ | | 0x14 | IMR_LOW | ||
+ | | 0x18 | IMR_HIGH | ||
+ | | 0x38 | C0_IER | ||
+ | | 0x3C | C1_IER | ||
===== RTL8380 pin muxing ===== | ===== RTL8380 pin muxing ===== | ||
Line 10: | Line 30: | ||
| UART1 | 116 | ? | RX | Setting BIT(4) in GMII_INTF_SEL (0xBB001000) enables UART1, Clearing BIT(4) selects SPI_SLAVE mode. | | | UART1 | 116 | ? | RX | Setting BIT(4) in GMII_INTF_SEL (0xBB001000) enables UART1, Clearing BIT(4) selects SPI_SLAVE mode. | | ||
| ::: | 117 | ? | TX | ::: | | | ::: | 117 | ? | TX | ::: | | ||
- | | JTAG | 29 | 12 | TMS | BIT(2) and BIT(3) in GMII_INTF_SEL (0xBB001000) allow selecting the JTAG interface. | | + | | GPIO8 | ? | 8 | N/A | Configured by the [[GS1900-24EP]], |
+ | | GPIO9 | ? | 9 | N/A | Configured by the [[GS1900-24EP]], | ||
+ | | JTAG | 29 | 12 | TMS | BIT(2) and BIT(3) in GMII_INTF_SEL (0xBB001000) allow selecting the JTAG interface. \\ Set to 0 for JTAG (default), 2 for GPIO. | | ||
| ::: | 28 | 13 | TCK | ::: | | | ::: | 28 | 13 | TCK | ::: | | ||
| ::: | 32 | 14 | /TRST | ::: | | | ::: | 32 | 14 | /TRST | ::: | | ||
| ::: | 30 | 10 | TDO | ::: | | | ::: | 30 | 10 | TDO | ::: | | ||
| ::: | 31 | 11 | TDI | ::: | | | ::: | 31 | 11 | TDI | ::: | | ||
- | | GPIO15 | ? | 15 | N/A | Configured by the [[GS310TP]], | + | | GPIO15 | ? | 15 | N/A | Configured by the [[GS310TP]] and [[GS1900-24EP]], no known mux or pin location | |
- | | GPIO16 | ? | 16 | N/A | Configured by the [[GS310TP]], | + | | GPIO16 | ? | 16 | N/A | Configured by the [[GS310TP]] and [[GS1900-24EP]], no known mux or pin location | |
- | | GPIO17 | ? | 17 | N/A | Configured by the [[GS310TP]], | + | | GPIO17 | ? | 17 | N/A | Configured by the [[GS310TP]] and [[GS1900-24EP]], no known mux or pin location | |
- | | GPIO18 | ? | 18 | N/A | Configured by the [[GS310TP]], | + | | GPIO18 | ? | 18 | N/A | Configured by the [[GS310TP]] and [[GS1900-24EP]], |
+ | | GPIO19 | ? | 19 | N/A | Configured by the [[GS1900-24EP]], | ||
+ | | GPIO20 | ? | 20 | N/A | Configured by the [[GS1900-24EP]], | ||
+ | | GPIO21 | ? | 21 | N/A | Configured by the [[GS1900-24EP]], | ||
+ | | GPIO22 | ? | 22 | N/A | Configured by the [[GS1900-24EP]], | ||
+ | | GPIO23 | ? | 23 | N/A | Configured by the [[GS1900-24EP]], no known mux or pin location | | ||
===== RTL8390 pin muxing ===== | ===== RTL8390 pin muxing ===== | ||
Line 24: | Line 51: | ||
^ Peripheral ^ Package pin ^ GPIO index ^ Alternative function ^ Pin configuration ^ | ^ Peripheral ^ Package pin ^ GPIO index ^ Alternative function ^ Pin configuration ^ | ||
| System LED | | 0 | sys-led | Use the SYS_LED_EN bit in LED_GLB_CTRL to mux sys-led peripheral | | | System LED | | 0 | sys-led | Use the SYS_LED_EN bit in LED_GLB_CTRL to mux sys-led peripheral | | ||
- | | GPIO1 | | 1 | N/A | No known alternative functions | | + | | RTL8231 MIIM bus | | 1 | MDC | | |
- | | RTL8231 MIIM bus | | 2 | MDC | | | + | | ::: | | 2 | MDIO | ::: | |
- | | ::: | | 3 | MDIO | ::: | | + | | JTAG | | 3 | TMS | Set JTAG_SEL to 0 (default) for JTAG, 2 for GPIO | |
- | | UART1 | | 6 | RX | Set JTAG_SEL to 1 for UART1, 2 for GPIO | | + | |
- | | ::: | + | |
- | | JTAG | | | TMS | Set JTAG_SEL to 0 (default) for JTAG, 2 for GPIO | | + | |
| ::: | | 4 | TCK | ::: | | | ::: | | 4 | TCK | ::: | | ||
- | | ::: | | | /TRST | ::: | | + | | ::: | | 5 | /TRST | ::: | |
+ | | ::: | | 6 | TDI | ::: | | ||
| ::: | | 7 | TDO | ::: | | | ::: | | 7 | TDO | ::: | | ||
- | | ::: | | 6 | TDI | ::: | | + | | UART1 | | 3 | /RTS | Set JTAG_SEL to 1 for UART1, 2 for GPIO | |
+ | | ::: | | 4 | /CTS | ::: | | ||
+ | | ::: | | 6 | RXD | ::: | | ||
+ | | ::: | ||
+ | | SPI CS | | 8 | /CS2 | Set SPI_CS_IF_SEL to 1 for extra chip selects, 0 for GPIO | | ||
+ | | ::: | | 9 | /CS3 | ::: | | ||
+ | | IEEE 1588 | | 12 | | OUTPUT_1588_SEL | ||
- | ===== Built-in GPIO ===== | ||
- | |||
- | A number of GPIO pins are available on the SoC's package. For the RTL8380 series with LQF216 only has a limited number of GPIOs broken out, but the RTL8390 and later use BGA packages with more pins available. | ||
- | The GPIO port registers provide controls for four GPIO ports. The bits per port are MSB first, but per 32-bit registers the ports are in least-significant order. | ||
- | The rtl8380-gpio driver fixes this mixed layout, and provides A0 as gpio 0, B0 as gpio 8, and so on. This is done so the GPIO numbers used in the SDK and datasheets are consistent with rtl8380-gpio. | ||
- | |||
- | ==== Registers ==== | ||
- | On the [[RTL838x]] and [[RTL839x]] SoCs, these registers can be found on the SoC bus (base address 0xB8003500). The FUNCTION register doesn' | ||
- | |||
- | ^ Offset ^ Name ^ Description ^ | ||
- | | 0x00 | CONTROL | ||
- | | 0x04 | FUNCTION | ||
- | | 0x08 | DIRECTION | ||
- | | 0x0C | DATA | Pin data register. Write to set a GPIO output value, read to get the input value. | | ||
- | | 0x10 | ISR | Interrupt status register. If a pin interrupt was triggered, read this register to find out which pin caused the interrupt. \\ To clear a pin interrupt, write 1 to the respective bit. | | ||
- | | 0x14 | IMR_LOW | ||
- | | 0x18 | IMR_HIGH | ||
===== External GPIO ===== | ===== External GPIO ===== | ||
The SoCs have been designed with the [[RTL8231]] GPIO expanders in mind as a first-class citizen. | The SoCs have been designed with the [[RTL8231]] GPIO expanders in mind as a first-class citizen. | ||
- | A hardware peripheral is present that can keep track of the state of one (or two on RTL9310) RTL8231 chip(s). | + | A hardware peripheral is present that can keep track of the state of one (or two on RTL93xx) RTL8231 chip(s). |
+ | The SoC's have dedicated pins and controllers for this task. For rtl930x B6 `EXT_GPIO_MDIO` and A5 `EXT_GPIO_MDC` For rtl931x, AM25: `GPIO_MDC` and AL25: `GPIO_MDIO`. This does require the RTL8231 connected to only function as GPIO expander. This should not be confused with the dedicated `LED_MDxx` pins! | ||
To allow direct access to the devices, a raw command can be sent. For RTL8380 and RTL8390, there is no indication of request failure. RTL9300 and RTL9310 do have a flag to indicate failed read commands. | To allow direct access to the devices, a raw command can be sent. For RTL8380 and RTL8390, there is no indication of request failure. RTL9300 and RTL9310 do have a flag to indicate failed read commands. | ||
Line 74: | Line 89: | ||
| 0x1188 | ISR_LOW | | 0x1188 | ISR_LOW | ||
| 0x118C | ISR_HIGH | | 0x118C | ISR_HIGH | ||
+ | |||
+ | ==== RTL930x muxing ==== | ||
+ | The RTL930x doesn' |