net: ethernet: cadence-macb: Add disabled usrio caps
authorNeil Armstrong <narmstrong@baylibre.com>
Tue, 5 Jan 2016 13:39:16 +0000 (14:39 +0100)
committerDavid S. Miller <davem@davemloft.net>
Thu, 7 Jan 2016 21:26:36 +0000 (16:26 -0500)
On some platforms, the macb integration does not use the USRIO
register to configure the (R)MII port and clocks.
When the register is not implemented and the MACB error signal
is connected to the bus error, reading or writing to the USRIO
register can trigger some Imprecise External Aborts on ARM platforms.

Signed-off-by: Neil Armstrong <narmstrong@baylibre.com>
Acked-by: Nicolas Ferre <nicolas.ferre@atmel.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/cadence/macb.c
drivers/net/ethernet/cadence/macb.h

index eb1397484eef81d96a90120859cc3fabf322c84a..8e2b9b6e50e72b4159f26a89915b67f6ab099eb8 100644 (file)
@@ -2113,7 +2113,8 @@ static void macb_get_regs(struct net_device *dev, struct ethtool_regs *regs,
        regs_buff[10] = macb_tx_dma(&bp->queues[0], tail);
        regs_buff[11] = macb_tx_dma(&bp->queues[0], head);
 
-       regs_buff[12] = macb_or_gem_readl(bp, USRIO);
+       if (!(bp->caps & MACB_CAPS_USRIO_DISABLED))
+               regs_buff[12] = macb_or_gem_readl(bp, USRIO);
        if (macb_is_gem(bp)) {
                regs_buff[13] = gem_readl(bp, DMACFG);
        }
@@ -2392,19 +2393,21 @@ static int macb_init(struct platform_device *pdev)
                dev->hw_features &= ~NETIF_F_SG;
        dev->features = dev->hw_features;
 
-       val = 0;
-       if (bp->phy_interface == PHY_INTERFACE_MODE_RGMII)
-               val = GEM_BIT(RGMII);
-       else if (bp->phy_interface == PHY_INTERFACE_MODE_RMII &&
-                (bp->caps & MACB_CAPS_USRIO_DEFAULT_IS_MII))
-               val = MACB_BIT(RMII);
-       else if (!(bp->caps & MACB_CAPS_USRIO_DEFAULT_IS_MII))
-               val = MACB_BIT(MII);
+       if (!(bp->caps & MACB_CAPS_USRIO_DISABLED)) {
+               val = 0;
+               if (bp->phy_interface == PHY_INTERFACE_MODE_RGMII)
+                       val = GEM_BIT(RGMII);
+               else if (bp->phy_interface == PHY_INTERFACE_MODE_RMII &&
+                        (bp->caps & MACB_CAPS_USRIO_DEFAULT_IS_MII))
+                       val = MACB_BIT(RMII);
+               else if (!(bp->caps & MACB_CAPS_USRIO_DEFAULT_IS_MII))
+                       val = MACB_BIT(MII);
 
-       if (bp->caps & MACB_CAPS_USRIO_HAS_CLKEN)
-               val |= MACB_BIT(CLKEN);
+               if (bp->caps & MACB_CAPS_USRIO_HAS_CLKEN)
+                       val |= MACB_BIT(CLKEN);
 
-       macb_or_gem_writel(bp, USRIO, val);
+               macb_or_gem_writel(bp, USRIO, val);
+       }
 
        /* Set MII management clock divider */
        val = macb_mdc_clk_div(bp);
index 5c03e811224d37b97938c6f9c25440581163b716..0d4ecfcd60b7cef54754186ddfab8269de48114f 100644 (file)
 #define MACB_CAPS_USRIO_HAS_CLKEN              0x00000002
 #define MACB_CAPS_USRIO_DEFAULT_IS_MII         0x00000004
 #define MACB_CAPS_NO_GIGABIT_HALF              0x00000008
+#define MACB_CAPS_USRIO_DISABLED               0x00000010
 #define MACB_CAPS_FIFO_MODE                    0x10000000
 #define MACB_CAPS_GIGABIT_MODE_AVAILABLE       0x20000000
 #define MACB_CAPS_SG_DISABLED                  0x40000000