Differences
This shows you the differences between two versions of the page.
Both sides previous revision Previous revision Next revision | Previous revision | ||
led_control [2021/02/22 07:58] – biot | led_control [2025/01/06 19:30] (current) – Add LED modes from Realtek docs svanheule | ||
---|---|---|---|
Line 13: | Line 13: | ||
Both the RTL838x and the RTL839x have a LED control register, named '' | Both the RTL838x and the RTL839x have a LED control register, named '' | ||
- | Manual control seems necessary in case where serially connected LEDs are not used as port-leds (such as additional status LEDs for PoE, "cloud connection" | + | Manual control seems necessary in case where serially connected LEDs are not used as port-leds (such as additional status LEDs for PoE, "cloud connection" |
* 0x0: SoC controls LED | * 0x0: SoC controls LED | ||
* 0x1: One Single Color LED connected here | * 0x1: One Single Color LED connected here | ||
* 0x3: Bi-color LED | * 0x3: Bi-color LED | ||
* 0x7: Tri-color LED | * 0x7: Tri-color LED | ||
- | It is unclear why not 2 bits would be sufficient for this. | + | It is unclear why 2 bits would not be sufficient for this. |
==== LEDs and GPIO expanders on the RTL838x ==== | ==== LEDs and GPIO expanders on the RTL838x ==== | ||
- | The power LED can be set to different blinking modes with register RTL8380_LED_MODE_SEL (0xBB001004), | + | The power LED can be set to different blinking modes with register |
=== RTL8380 external LED and GPIO registers === | === RTL8380 external LED and GPIO registers === | ||
- | These registers are at a base address of 0xBB00A000. | + | These registers are at a base address of '' |
^ Offset ^ Name ^ Description ^ | ^ Offset ^ Name ^ Description ^ | ||
| 0x00 | [[#Global LED control|LED_GLB_CTRL]] | | | | 0x00 | [[#Global LED control|LED_GLB_CTRL]] | | | ||
| 0x04 | [[#Port LED mode control|LED_MODE_CTRL]] | | | | 0x04 | [[#Port LED mode control|LED_MODE_CTRL]] | | | ||
- | | 0x08 | LED_P_EN_CTRL | Bit mask indicating which LEDs are ASIC controlled. Bit position corresponds to the MAC/phy number. Set to 1 to enable the LED output for this phy. | | + | | 0x08 | '' |
- | | 0x0C | LED_SW_CTRL | | | + | | 0x0C | '' |
- | | 0x10+4×n | LED_n_SW_P_EN_CTRL | LED index n = {0, 1, 2}. Bit mask indicating which LEDs are controlled by the user. Bit position corresponds to the MAC/phy number. Set to 0 for automatic control, 1 for manual control. The corresponding bit in LED_P_EN_CTRL must also be set for this setting to be effective. | | + | | 0x10+4×n | '' |
| 0x1C+4×p | [[#Port LED user control|LED_SW_P_p_CTRL]] | Port index p = {0, .., 27} | | | 0x1C+4×p | [[#Port LED user control|LED_SW_P_p_CTRL]] | Port index p = {0, .., 27} | | ||
- | | 0x8C + 4×i | EXT_GPIO_DIR_i_CTRL | i = floor(index/ | + | | 0x8C + 4×i | '' |
- | | 0x94 + 4×i | EXT_GPIO_DATA_i_CTRL | i = floor(index/ | + | | 0x94 + 4×i | '' |
| 0x9C | [[#Extra GPIO command register|EXT_GPIO_INDIRECT_ACCESS]] | | | | 0x9C | [[#Extra GPIO command register|EXT_GPIO_INDIRECT_ACCESS]] | | | ||
- | | 0xA0 | LED_LOAD_LV1 | | | + | | 0xA0 | '' |
- | | 0xA4 | LED_LOAD_LV2 | | | + | | 0xA4 | '' |
- | | 0xA8 | LED_LOAD_LV3 | | | + | | 0xA8 | '' |
| 0xAC+4×k | [[#Port LED status registers|LED0_LO_STSk_CTRL]] | Low ports LED0 status control | | | 0xAC+4×k | [[#Port LED status registers|LED0_LO_STSk_CTRL]] | Low ports LED0 status control | | ||
| 0xB8+4×k | [[#Port LED status registers|LED1_LO_STSk_CTRL]] | Low ports LED1 status control | | | 0xB8+4×k | [[#Port LED status registers|LED1_LO_STSk_CTRL]] | Low ports LED1 status control | | ||
Line 46: | Line 46: | ||
| 0xD4 | [[#Port LED status registers|LED1_HI_STS_CTRL]] | High ports LED1 status control | | | 0xD4 | [[#Port LED status registers|LED1_HI_STS_CTRL]] | High ports LED1 status control | | ||
| 0xD8 | [[#Port LED status registers|LED2_HI_STS_CTRL]] | High ports LED2 status control | | | 0xD8 | [[#Port LED status registers|LED2_HI_STS_CTRL]] | High ports LED2 status control | | ||
- | | 0xDC | LED_RTCT_CTRL | (To confirm) Realtek Cable Test control register | | + | | 0xDC | '' |
- | | 0xE0 | EXTRA_GPIO_CTRL | | | + | | 0xE0 | '' |
- | | 0xE4 | EXTRA_GPIO_DIR0 | | | + | | 0xE4 | '' |
- | | 0xE8 | EXTRA_GPIO_DIR1 | | | + | | 0xE8 | '' |
- | | 0xEC | EXTRA_GPIO_DATA0 | | | + | | 0xEC | '' |
- | | 0xF0 | EXTRA_GPIO_DATA1 | | | + | | 0xF0 | '' |
=== Global LED control === | === Global LED control === | ||
- | Main control register for hardware accelerated LEDs and RTL8231 access. | + | The SoCs have been designed with the RTL8231 LED 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 RTL93xx) RTL8231 chip(s). The SoC's have dedicated pins and controllers for this task. For rtl930x C1 `LED_MDC` and C2 `LED_MDIO` For rtl931x, AL18 `LED_MDC` and AK18 `LED_MDIO`. This does require the RTL8231 connected to only function as a LED expander. This should not be confused with the dedicated `EXT_GPIO_MDxx` pins! |
+ | |||
+ | Main control register for hardware accelerated LEDs and [[RTL8231]] access. | ||
^ Bits ^ Field description ^ | ^ Bits ^ Field description ^ | ||
Line 60: | Line 62: | ||
| 3-5 | High port LED mask. Activate an LED output for ports 24-27 by setting the respective bit. 0: no LEDs, 0x1: one LED, 0x3: two active LEDs, 0x7: three active LEDs. Should have the same value as the low-port configuration, | | 3-5 | High port LED mask. Activate an LED output for ports 24-27 by setting the respective bit. 0: no LEDs, 0x1: one LED, 0x3: two active LEDs, 0x7: three active LEDs. Should have the same value as the low-port configuration, | ||
| 6 | MDIO-clock duty cycle for LED interface | | | 6 | MDIO-clock duty cycle for LED interface | | ||
- | | 7-8 | Combo Port mode. For board RTL8382M_8218B_INTPHY_8218B_2FIB_1G_DEMO cleared to 0, for all others set to 0x2 | | + | | 7-8 | Combo Port mode. For board '' |
| 9-11 | STEP1 Power on LED 2..0 | | | 9-11 | STEP1 Power on LED 2..0 | | ||
| 12-14 | STEP2 Power on LED 2..0 | | | 12-14 | STEP2 Power on LED 2..0 | | ||
Line 82: | Line 84: | ||
* 3: Act Rx | * 3: Act Rx | ||
* 4: Act Tx | * 4: Act Tx | ||
+ | * 5: Col/Full duplex | ||
+ | * 6: Full duplex | ||
* 7: Link 1G | * 7: Link 1G | ||
* 8: Link 100M | * 8: Link 100M | ||
Line 91: | Line 95: | ||
* 14: Link/Act 1G/10M | * 14: Link/Act 1G/10M | ||
* 15: Link/Act 100M/10M | * 15: Link/Act 100M/10M | ||
+ | * 16: Link 10M flashing | ||
+ | * 17: Link 100M flashing | ||
+ | * 18: Link 1G flashing | ||
+ | * 19: Link 10G flashing (RTL839x) | ||
+ | * 20: Link 10G (RTL839x) | ||
+ | * 21: Link/Act 10G (RTL839x) | ||
* 31: Off | * 31: Off | ||
Line 138: | Line 148: | ||
==== LEDs on the RTL839x ==== | ==== LEDs on the RTL839x ==== | ||
On the RTL839x '' | On the RTL839x '' | ||
- | * Bits 0-1: Interface selection: Defined by board config variable '' | + | * Bits 0-1: Interface selection: Defined by board config variable '' |
+ | * '' | ||
+ | * '' | ||
+ | * '' | ||
* Bits 2-3: LED number selection: Number of LEDs per port, configured from '' | * Bits 2-3: LED number selection: Number of LEDs per port, configured from '' | ||
* Bit 4: LED MDIO-Clock duty (cycle?) | * Bit 4: LED MDIO-Clock duty (cycle?) | ||
Line 152: | Line 165: | ||
* Bit 25: LED active (Low or high), Set by '' | * Bit 25: LED active (Low or high), Set by '' | ||
- | Configuration of the automatic control of the LEDs is done on this SoC through defining the function of a port LED. 3 Sets of registers define whether a Port has a Led indicating Copper functionality, | + | Configuration of the automatic control of the LEDs is done on this SoC through defining the function of a port LED. 3 Sets of registers define whether a Port has a Led indicating Copper functionality, |
< | < | ||
.led.led_if_sel = LED_IF_SEL_SERIAL, | .led.led_if_sel = LED_IF_SEL_SERIAL, | ||
Line 180: | Line 193: | ||
^ Offset ^ Name ^ Description ^ | ^ Offset ^ Name ^ Description ^ | ||
- | | 0x0E4 | LEB_GLB_CTRL | | | + | | 0x0E4 | '' |
- | | 0x0E8 | LED_SET_2_3_CTRL | | | + | | 0x0E8 | '' |
- | | 0x0EC | LED_SET_0_1_CTRL | | | + | | 0x0EC | '' |
- | | 0x0F0 + 4×k | LED_COPR_SET_k_SEL_CTRL | k = floor(port/ | + | | 0x0F0 + 4×k | '' |
- | | 0x100 + 4×k | LED_FIB_SET_k_SEL_CTRL | k = floor(port/ | + | | 0x100 + 4×k | '' |
- | | 0x110 + 4×k | LED_COPR_PMASK_k_CTRL | k = floor(port/ | + | | 0x110 + 4×k | '' |
- | | 0x118 + 4×k | LED_FIB_PMASK_k_CTRL | k = floor(port/ | + | | 0x118 + 4×k | '' |
- | | 0x120 + 4×k | LED_COMBO_k_CTRL | k = floor(port/ | + | | 0x120 + 4×k | '' |
- | | 0x128 | LED_SW_CTRL | | | + | | 0x128 | '' |
- | | 0x12C + 4×n | LED_SW_P_EN_n_CTRL | n = floor(port/ | + | | 0x12C + 4×n | '' |
- | | 0x144 + 4×p | LED_SW_P_p_CTRL | p = 0-51 | | + | | 0x144 + 4×p | '' |
- | | 0x214 + 4×i | EXT_GPIO_DIR_i_CTRL | i = floor(index/ | + | | 0x214 + 4×i | '' |
- | | 0x21C + 4×i | EXT_GPIO_DATA_i_CTRL | i = floor(index/ | + | | 0x21C + 4×i | '' |
- | | 0x224 | EXT_GPIO_INDIRECT_ACCESS | | | + | | 0x224 | '' |
- | | 0x228 | LED_LOAD_LV1_10G | | | + | | 0x228 | '' |
- | | 0x22C | LED_LOAD_LV2_10G | | | + | | 0x22C | '' |
- | | 0x230 | LED_LOAD_LV3_10G | | | + | | 0x230 | '' |
- | | 0x234 | LED_LOAD_LV1_1G | | | + | | 0x234 | '' |
- | | 0x238 | LED_LOAD_LV2_1G | | | + | | 0x238 | '' |
- | | 0x23C | LED_LOAD_LV3_1G | | | + | | 0x23C | '' |
- | | 0x240 | LED_LOAD_LV1_100M | | | + | | 0x240 | '' |
- | | 0x244 | LED_LOAD_LV2_100M | | | + | | 0x244 | '' |
- | | 0x248 | LED_LOAD_LV3_100M | | | + | | 0x248 | '' |
- | | 0x24C | LED_LOAD_LV1_10M | | | + | | 0x24C | '' |
- | | 0x250 | LED_LOAD_LV2_10M | | | + | | 0x250 | '' |
- | | 0x254 | LED_LOAD_LV3_10M | | | + | | 0x254 | '' |
- | | 0x258 | LED_P_LOAD_CTRL | | | + | | 0x258 | '' |
- | | 0x25C | BUZZER_CTRL | RTL8231 buzzer settings shadow register | | + | | 0x25C | '' |
+ | === Port LED user control === | ||
+ | 52 registers, at offsets (0x144 + 4×port). After making modifications to the registers, the new configuration need to be committed by writing 0x1 to LED_SW_CTRL. | ||
+ | This sets the SW_LED_LOAD bit, updates the output, and self-clears afterwards. | ||
+ | ^ Bits ^ Field description ^ Field values ^ | ||
+ | | 0-2 | LED0 (cop0) control | 0: off \\ 1: toggle every 32ms \\ 2: toggle every 64ms \\ 3: toggle every 128ms \\ 4: toggle every 256ms \\ 5: toggle every 512ms \\ 6: toggle every 1024ms \\ 7: on | | ||
+ | | 3-5 | LED1 (cop1) control | ::: | | ||
+ | | 6-8 | LED2 (cop2) control | ::: | | ||
+ | | 9-11 | LED3 (fib0) control | ::: | | ||
+ | | 12-14 | LED4 (fib1) control | ::: | | ||
+ | | 15-17 | LED5 (fib2) control | ::: | | ||
==== LEDs on the RTL930x ==== | ==== LEDs on the RTL930x ==== | ||
- | These registers are at a base address of 0xBB00C400. | + | These registers are at a base address of '' |
^ Offset ^ Name ^ Description ^ | ^ Offset ^ Name ^ Description ^ | ||
- | | 0x00 | LED_GLB_CTRL | | | + | | 0x00 | '' |
- | | 0x04 | LED_PORT_NUM_CTR(port) | port: 0-27, 2 bits per port| | + | | 0x04 | '' |
- | | 0x0C | LED_SET_3_CTRL | | | + | | 0x0C | '' |
- | | 0x10 | LED_SET_2_CTRL | | | + | | 0x10 | '' |
- | | 0x14 | LED_SET_1_CTRL | | | + | | 0x14 | '' |
- | | 0x18 | LED_SET_0_CTRL | | | + | | 0x18 | '' |
- | | 0x1C | LED_PORT_COPR_SET_SEL_CTRL(port) | port = 0-27, 2 bits per port| | + | | 0x1C | '' |
- | | 0x24 | LED_PORT_FIB_SEL_CTRL(port) | port = 0-27, 2 bits per port| | + | | 0x24 | '' |
- | | 0x2C | LED_PORT_COPR_MASK_CTRL(port) | port = 0-27, 2 bits per port| | + | | 0x2C | '' |
- | | 0x30 | LED_PORT_FIB_MASK_CTRL(port) | port = 0-27, 2 bits per port| | + | | 0x30 | '' |
- | | 0x34 | LED_PORT_COMBO_MASK_CTRL(port) | port = 0-27, 1 bit per port| | + | | 0x34 | '' |
- | | 0x38 | LED_SW_LED_LOAD | | | + | | 0x38 | '' |
- | | 0x3c | LED_PORT_SW_EN_CTRL(port) | port = 0-27, 4 bits per port | | + | | 0x3c | '' |
- | | 0x4c | LED_PORT_SW_CTRL(port) | port = 0-27, 1 register per port | | + | | 0x4c | '' |
- | | 0xbc | LED_INDRT_ACCESS_CTRL | standard SMI access register | | + | | 0xbc | '' |
- | | 0xc0 | LED_LOAD_LV1_10G | | | + | | 0xc0 | '' |
- | | 0xc4 | LED_LOAD_LV2_10G | | | + | | 0xc4 | '' |
- | | 0xc8 | LED_LOAD_LV3_10G | | | + | | 0xc8 | '' |
- | | 0xcc | LED_LOAD_LV1_2P5G | | | + | | 0xcc | '' |
- | | 0xd0 | LED_LOAD_LV2_2P5G | | | + | | 0xd0 | '' |
- | | 0xd4 | LED_LOAD_LV3_2P5G | | | + | | 0xd4 | '' |
- | | 0xd8 | LED_LOAD_LV1_1G | | | + | | 0xd8 | '' |
- | | 0xdc | LED_LOAD_LV2_1G | | | + | | 0xdc | '' |
- | | 0xe0 | LED_LOAD_LV3_1G | | | + | | 0xe0 | '' |
- | | 0xe4 | LED_LOAD_LV1_500M | | | + | | 0xe4 | '' |
- | | 0xe8 | LED_LOAD_LV2_500M | | | + | | 0xe8 | '' |
- | | 0xec | LED_LOAD_LV3_500M | | | + | | 0xec | '' |
- | | 0xf0 | LED_LOAD_LV1_100M | | | + | | 0xf0 | '' |
- | | 0xf4 | LED_LOAD_LV2_100M | | | + | | 0xf4 | '' |
- | | 0xf8 | LED_LOAD_LV3_100M | | | + | | 0xf8 | '' |
- | | 0xfc | LED_LOAD_LV1_10M | | | + | | 0xfc | '' |
- | | 0x100 | LED_LOAD_LV2_10M | | | + | | 0x100 | '' |
- | | 0x104 | LED_LOAD_LV3_10M | | | + | | 0x104 | '' |
- | | 0x108 | LED_P_LOAD_CTRL | | | + | | 0x108 | '' |
- | The extra GPIO block starts at a base address of 0xBB00BE00: | + | The extra GPIO block starts at a base address of '' |
^ Offset ^ Name ^ Description ^ | ^ Offset ^ Name ^ Description ^ | ||
- | | 0x00 | EXT_GPIO_GLB_CTRL | | | + | | 0x00 | '' |
- | | 0x04 | EXT_GPIO_TRIG_CTRL | | | + | | 0x04 | '' |
- | | 0x08 | EXT_GPIO_DIR_CTRL_1 | | | + | | 0x08 | '' |
- | | 0x0c | EXT_GPIO_DIR_CTRL_2 | | | + | | 0x0c | '' |
- | | 0x10 | EXT_GPIO_DIR_CTRL_3 | | | + | | 0x10 | '' |
- | | 0x14 | EXT_GPIO_DATA_CTRL_1 | | | + | | 0x14 | '' |
- | | 0x18 | EXT_GPIO_DATA_CTRL_2 | | | + | | 0x18 | '' |
- | | 0x1c | EXT_GPIO_DATA_CTRL_3 | | | + | | 0x1c | '' |
- | | 0x20 | EXT_GPIO_INDRT_ACCESS_CTRL | standard SMI access register | | + | | 0x20 | '' |