gpio_control

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
gpio_control [2022/07/31 19:13] – Add GPIOs from GS1900-24EP svanheulegpio_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 |  | | MDC  |  | 
-| RTL8231 MIIM bus |  | | MDC  |  | +| :::              |  | | MDIO | ::: | 
-| :::              |  | | MDIO | ::: | +| JTAG |  | | 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 | +
-| :::    | 7 | TX | ::: | +
-| JTAG |  |  | TMS   | Set JTAG_SEL to 0 (default) for JTAG, 2 for GPIO |+
 | :::  |  | 4 | TCK   | ::: | | :::  |  | 4 | TCK   | ::: |
-| :::  |  |  | /TRST | ::: | +| :::  |  | | /TRST | ::: |
-| :::  |  | 7 | TDO   | ::: |+
 | :::  |  | 6 | TDI   | ::: | | :::  |  | 6 | TDI   | ::: |
 +| :::  |  | 7 | TDO   | ::: |
 +| UART1 |  | 3 | /RTS | Set JTAG_SEL to 1 for UART1, 2 for GPIO |
 +| :::    | 4 | /CTS | ::: |
 +| :::    | 6 | RXD   | ::: |
 +| :::    | 7 | TXD   | ::: |
 +| 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    | Interrupt status register | | 0x1188 | ISR_LOW    | Interrupt status register |
 | 0x118C | ISR_HIGH   | Interrupt status register | | 0x118C | ISR_HIGH   | Interrupt status register |
 +
 +==== RTL930x muxing ====
 +The RTL930x doesn't have a dedicated muxing section in the address space. Instead, the GPIO pin muxing is all over the SoC's addressing space, so this will be a challange. A dedicated page exists to inventory the [[rtl93xx:gpio_space|GPIO mux registers]].
  • gpio_control.1659294806.txt.gz
  • Last modified: 2022/07/31 19:13
  • by svanheule