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/07/31 19:13] – Add GPIOs from GS1900-24EP svanheule | gpio_control [2025/01/15 10:56] (current) – Update RTL8390 pin muxing table svanheule | ||
---|---|---|---|
Line 51: | 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 | ::: | |
- | | ::: | | 7 | TDO | ::: | | + | |
| ::: | | 6 | TDI | ::: | | | ::: | | 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 | | ||
===== 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 84: | Line 89: | ||
| 0x1188 | ISR_LOW | | 0x1188 | ISR_LOW | ||
| 0x118C | ISR_HIGH | | 0x118C | ISR_HIGH | ||
+ | |||
+ | ==== RTL930x muxing ==== | ||
+ | The RTL930x doesn' |