phy: bcm54213pe: configure the LED outputs to be more user-friendly
authorJonathan Bell <jonathan@raspberrypi.org>
Fri, 17 May 2019 12:31:21 +0000 (13:31 +0100)
committerpopcornmix <popcornmix@gmail.com>
Wed, 1 Jul 2020 15:32:56 +0000 (16:32 +0100)
The default state was both LEDs indicating link speed.

Change the default configuration to
- Amber: 1000/100 link speed indication
- Green: link present + activity indication

Signed-off-by: Jonathan Bell <jonathan@raspberrypi.org>
drivers/net/phy/broadcom.c
include/linux/brcmphy.h

index e7a4cbb..f5881fb 100644 (file)
@@ -43,6 +43,21 @@ static int bcm54210e_config_init(struct phy_device *phydev)
        return 0;
 }
 
+static void bcm54213pe_config_init(struct phy_device *phydev)
+{
+       u16 val;
+
+       /* Enable ACT+LINK indication on ACTIVITY trigger */
+       val = bcm_phy_read_shadow(phydev, BCM54XX_SHD_LEDCTL);
+       val |= BCM54XX_SHD_LEDCTL_ACTLINK_EN;
+       bcm_phy_write_shadow(phydev, BCM54XX_SHD_LEDCTL, val);
+
+       /* Set ACTIVITY on LED "1" output, LINKSPD[1] on LED "3" output */
+       val = BCM5482_SHD_LEDS1_LED1(BCM_LED_SRC_ACTIVITYLED) |
+               BCM5482_SHD_LEDS1_LED3(BCM_LED_SRC_LINKSPD1);
+       bcm_phy_write_shadow(phydev, BCM5482_SHD_LEDS1, val);
+}
+
 static int bcm54612e_config_init(struct phy_device *phydev)
 {
        int reg;
@@ -301,6 +316,8 @@ static int bcm54xx_config_init(struct phy_device *phydev)
                err = bcm54210e_config_init(phydev);
                if (err)
                        return err;
+       } else if (BRCM_PHY_MODEL(phydev) == PHY_ID_BCM54213PE) {
+               bcm54213pe_config_init(phydev);
        } else if (BRCM_PHY_MODEL(phydev) == PHY_ID_BCM54612E) {
                err = bcm54612e_config_init(phydev);
                if (err)
index bfb3721..d7ebafb 100644 (file)
 #define  BCM54XX_SHD_SCR3_DLLAPD_DIS   0x0002
 #define  BCM54XX_SHD_SCR3_TRDDAPD      0x0004
 
+/* 01001: Additional LED trigger options */
+#define BCM54XX_SHD_LEDCTL             0x09
+#define  BCM54XX_SHD_LEDCTL_ACTLINK_EN 0x0010
+
 /* 01010: Auto Power-Down */
 #define BCM54XX_SHD_APD                        0x0a
 #define  BCM_APD_CLR_MASK              0xFE9F /* clear bits 5, 6 & 8 */