net: mvpp2: fix use of the random mac address for PPv2.2
authorAntoine Tenart <antoine.tenart@free-electrons.com>
Sat, 2 Sep 2017 09:06:48 +0000 (11:06 +0200)
committerDavid S. Miller <davem@davemloft.net>
Mon, 4 Sep 2017 03:16:55 +0000 (20:16 -0700)
The MAC retrieval logic is using a variable to store an h/w stored mac
address and checks this mac against invalid ones before using it. But
the mac address is only read from h/w when using PPv2.1. So when using
PPv2.2 it defaults to its init state.

This patches fixes the logic to only check if the h/w mac is valid when
actually retrieving a mac from h/w.

Signed-off-by: Antoine Tenart <antoine.tenart@free-electrons.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/marvell/mvpp2.c

index a702e60ba70d15a922fbf7702d785d617c5f30e4..c6003508f1666328c196f60c2edf9d6a7a8bb0a7 100644 (file)
@@ -7478,15 +7478,17 @@ static void mvpp2_port_copy_mac_addr(struct net_device *dev, struct mvpp2 *priv,
                *mac_from = "device tree";
                ether_addr_copy(dev->dev_addr, dt_mac_addr);
        } else {
-               if (priv->hw_version == MVPP21)
+               if (priv->hw_version == MVPP21) {
                        mvpp21_get_mac_address(port, hw_mac_addr);
-               if (is_valid_ether_addr(hw_mac_addr)) {
-                       *mac_from = "hardware";
-                       ether_addr_copy(dev->dev_addr, hw_mac_addr);
-               } else {
-                       *mac_from = "random";
-                       eth_hw_addr_random(dev);
+                       if (is_valid_ether_addr(hw_mac_addr)) {
+                               *mac_from = "hardware";
+                               ether_addr_copy(dev->dev_addr, hw_mac_addr);
+                               return;
+                       }
                }
+
+               *mac_from = "random";
+               eth_hw_addr_random(dev);
        }
 }