net: dsa: qca8k: make sure PAD0 MAC06 exchange is disabled
authorAnsuel Smith <ansuelsmth@gmail.com>
Tue, 2 Nov 2021 18:30:41 +0000 (19:30 +0100)
committerDavid S. Miller <davem@davemloft.net>
Wed, 3 Nov 2021 14:21:06 +0000 (14:21 +0000)
Some device set MAC06 exchange in the bootloader. This cause some
problem as we don't support this strange mode and we just set the port6
as the primary CPU port. With MAC06 exchange, PAD0 reg configure port6
instead of port0. Add an extra check and explicitly disable MAC06 exchange
to correctly configure the port PAD config.

Signed-off-by: Ansuel Smith <ansuelsmth@gmail.com>
Fixes: 3fcf734aa482 ("net: dsa: qca8k: add support for cpu port 6")
Reviewed-by: Vladimir Oltean <olteanv@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/dsa/qca8k.c
drivers/net/dsa/qca8k.h

index ea7f127..a429c97 100644 (file)
@@ -1109,6 +1109,14 @@ qca8k_setup(struct dsa_switch *ds)
        if (ret)
                return ret;
 
+       /* Make sure MAC06 is disabled */
+       ret = qca8k_reg_clear(priv, QCA8K_REG_PORT0_PAD_CTRL,
+                             QCA8K_PORT0_PAD_MAC06_EXCHANGE_EN);
+       if (ret) {
+               dev_err(priv->dev, "failed disabling MAC06 exchange");
+               return ret;
+       }
+
        /* Enable CPU Port */
        ret = qca8k_reg_set(priv, QCA8K_REG_GLOBAL_FW_CTRL0,
                            QCA8K_GLOBAL_FW_CTRL0_CPU_PORT_EN);
index e10571a..128b8cf 100644 (file)
@@ -34,6 +34,7 @@
 #define   QCA8K_MASK_CTRL_DEVICE_ID_MASK               GENMASK(15, 8)
 #define   QCA8K_MASK_CTRL_DEVICE_ID(x)                 ((x) >> 8)
 #define QCA8K_REG_PORT0_PAD_CTRL                       0x004
+#define   QCA8K_PORT0_PAD_MAC06_EXCHANGE_EN            BIT(31)
 #define   QCA8K_PORT0_PAD_SGMII_RXCLK_FALLING_EDGE     BIT(19)
 #define   QCA8K_PORT0_PAD_SGMII_TXCLK_FALLING_EDGE     BIT(18)
 #define QCA8K_REG_PORT5_PAD_CTRL                       0x008