staging: octeon-ethernet: Fix of_get_mac_address ERR_PTR check
authorPetr Štetiar <ynezz@true.cz>
Mon, 6 May 2019 21:24:46 +0000 (23:24 +0200)
committerDavid S. Miller <davem@davemloft.net>
Tue, 7 May 2019 19:22:47 +0000 (12:22 -0700)
Commit 284eb160681c ("staging: octeon-ethernet: support
of_get_mac_address new ERR_PTR error") has introduced checking for
ERR_PTR encoded error value from of_get_mac_address with IS_ERR macro,
which is not sufficient in this case, as the mac variable is set to NULL
initialy and if the kernel is compiled without DT support this NULL
would get passed to IS_ERR, which would lead to the wrong decision and
would pass that NULL pointer and invalid MAC address further.

Fixes: 284eb160681c ("staging: octeon-ethernet: support of_get_mac_address new ERR_PTR error")
Signed-off-by: Petr Štetiar <ynezz@true.cz>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/staging/octeon/ethernet.c

index 2b0301821d7b81b9fb0c33ab3e85ab677524ae7a..8847a11c212fe450950e1ea398558a27bcfe9e4b 100644 (file)
@@ -421,7 +421,7 @@ int cvm_oct_common_init(struct net_device *dev)
        if (priv->of_node)
                mac = of_get_mac_address(priv->of_node);
 
-       if (!IS_ERR(mac))
+       if (!IS_ERR_OR_NULL(mac))
                ether_addr_copy(dev->dev_addr, mac);
        else
                eth_hw_addr_random(dev);