Differences
This shows you the differences between two versions of the page.
Both sides previous revision Previous revision Next revision | Previous revision | ||
gpio_control [2020/12/09 07:12] – [RTL8380 registers] Correct high pin range svanheule | gpio_control [2025/01/15 10:56] (current) – Update RTL8390 pin muxing table svanheule | ||
---|---|---|---|
Line 1: | Line 1: | ||
====== GPIO control ====== | ====== GPIO control ====== | ||
- | ===== RTL8380 pin muxing ===== | ||
- | |||
- | ^ Peripheral ^ Package pin ^ GPIO index ^ Alternative function ^ Pin configuration ^ | ||
- | | RTL8231 MIIM bus | 111 | 2 | MDC | Setting the enable bit (BIT(0)) in the EXTRA_GPIO_CTRL register (0xBB00A0E0) selects the MIIM peripheral, otherwise the GPIO function is used. | | ||
- | | ::: | 112 | 3 | MDIO | ::: | | ||
- | | UART1 | 116 | ? | RX | Setting BIT(4) in GMII_INTF_SEL (0xBB001000) enables UART1 | | ||
- | | ::: | 117 | ? | TX | ::: | | ||
- | | JTAG | 29 | 12 | TMS | BIT(2) and BIT(3) in GMII_INTF_SEL (0xBB001000) allow selecting the JTAG interface. | | ||
- | | ::: | 28 | 13 | TCK | ::: | | ||
- | | ::: | 32 | 14 | /TRST | ::: | | ||
- | | ::: | 30 | 10 | TDO | ::: | | ||
- | | ::: | 31 | 11 | TDI | ::: | | ||
===== Built-in GPIO ===== | ===== Built-in GPIO ===== | ||
Line 19: | Line 7: | ||
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. | 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. | ||
- | ==== Pin mux registers | + | ==== Registers |
- | On the [[RTL838x]] and [[RTL839x]] SoCs, these registers can be found on the SoC bus (base address | + | On the [[RTL838x]] and [[RTL839x]] SoCs, these registers can be found on the SoC bus (base address |
^ Offset ^ Name ^ Description ^ | ^ Offset ^ Name ^ Description ^ | ||
- | | 0x3500 | + | | 0x00 | CONTROL |
- | | 0x3504 | + | | 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 | ||
- | ==== Pin registers | + | ===== RTL8380 pin muxing ===== |
- | On the [[RTL838x]] and [[RTL839x]] SoCs, these registers can be found on the SoC bus (base address 0xB8000000). | + | |
- | ^ Offset | + | ^ Peripheral |
- | | 0x3508 | + | | System LED | 113 | 0 | sys-led | Use the SYS_LED_EN bit in LED_GLB_CTRL to mux sys-led peripheral | |
- | | 0x350C | + | | GPIO1 | 112 | 1 | N/A | No known alternative functions | |
+ | | RTL8231 MIIM bus | 111 | 2 | MDC | ||
+ | | ::: | 110 | 3 | MDIO | ::: | | ||
+ | | UART1 | 116 | ? | RX | Setting BIT(4) in GMII_INTF_SEL (0xBB001000) enables UART1, Clearing BIT(4) selects SPI_SLAVE mode. | | ||
+ | | ::: | 117 | ? | TX | ::: | | ||
+ | | 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. | | ||
+ | | ::: | ||
+ | | ::: | 32 | 14 | /TRST | ::: | | ||
+ | | ::: | 30 | 10 | TDO | ::: | | ||
+ | | ::: | 31 | 11 | TDI | ::: | | ||
+ | | 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]] and [[GS1900-24EP]], | ||
+ | | GPIO17 | ? | 17 | N/A | Configured by the [[GS310TP]] and [[GS1900-24EP]], | ||
+ | | 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]], | ||
- | ==== Interrupt registers | + | ===== RTL8390 pin muxing ===== |
- | On the [[RTL838x]] and [[RTL839x]] SoCs, these registers can be found on the SoC bus (base address 0xB8000000). | + | |
+ | ^ 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 | | ||
+ | | RTL8231 MIIM bus | | 1 | MDC | | | ||
+ | | ::: | | 2 | MDIO | ::: | | ||
+ | | JTAG | | 3 | TMS | Set JTAG_SEL to 0 (default) for JTAG, 2 for GPIO | | ||
+ | | ::: | | 4 | TCK | ::: | | ||
+ | | ::: | | 5 | /TRST | ::: | | ||
+ | | ::: | | 6 | TDI | ::: | | ||
+ | | ::: | | 7 | TDO | ::: | | ||
+ | | UART1 | | 3 | /RTS | Set JTAG_SEL to 1 for UART1, 2 for GPIO | | ||
+ | | ::: | ||
+ | | ::: | ||
+ | | ::: | ||
+ | | 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 | | ||
- | ^ Offset ^ Name ^ Description ^ | ||
- | | 0x3510 | 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. | | ||
- | | 0x3514 | IMR_LOW | ||
- | | 0x351C | 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 62: | Line 89: | ||
| 0x1188 | ISR_LOW | | 0x1188 | ISR_LOW | ||
| 0x118C | ISR_HIGH | | 0x118C | ISR_HIGH | ||
+ | |||
+ | ==== RTL930x muxing ==== | ||
+ | The RTL930x doesn' |