stmmac: Don't exit mdio registration when mdio subnode is not found in the DTS
authorRomain Perier <romain.perier@gmail.com>
Thu, 7 Jan 2016 20:13:28 +0000 (21:13 +0100)
committerDavid S. Miller <davem@davemloft.net>
Sun, 10 Jan 2016 23:02:33 +0000 (18:02 -0500)
Originally, most of the platforms using this driver did not define an mdio subnode
in the devicetree. Commit e34d65 ("stmmac: create of compatible mdio bus for stmmac driver")
introduced a backward compatibily issue by using of_mdiobus_register explicitly
with an mdio subnode. This patch fixes the issue by calling the function
mdiobus_register, when mdio subnode is not found. The driver is now compatible
with both modes.

Fixes: e34d65696d2e ("stmmac: create of compatible mdio bus for stmmac driver")
Signed-off-by: Romain Perier <romain.perier@gmail.com>
Tested-by: Phil Reid <preid@electromag.com.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/stmicro/stmmac/stmmac_mdio.c

index bff28595b427927700c27fe48c7eb75b78cfecde..0faf1633603531a709358388b116d596d746e3e9 100644 (file)
@@ -217,8 +217,7 @@ int stmmac_mdio_register(struct net_device *ndev)
                if (mdio_node) {
                        netdev_dbg(ndev, "FOUND MDIO subnode\n");
                } else {
-                       netdev_err(ndev, "NO MDIO subnode\n");
-                       return 0;
+                       netdev_warn(ndev, "No MDIO subnode found\n");
                }
        }
 
@@ -244,7 +243,10 @@ int stmmac_mdio_register(struct net_device *ndev)
        new_bus->phy_mask = mdio_bus_data->phy_mask;
        new_bus->parent = priv->device;
 
-       err = of_mdiobus_register(new_bus, mdio_node);
+       if (mdio_node)
+               err = of_mdiobus_register(new_bus, mdio_node);
+       else
+               err = mdiobus_register(new_bus);
        if (err != 0) {
                pr_err("%s: Cannot register as MDIO bus\n", new_bus->name);
                goto bus_register_fail;