Commit 3955b22b authored by Giuseppe CAVALLARO's avatar Giuseppe CAVALLARO Committed by David S. Miller

stmmac: mdio register has to fail if the phy is not found

With this patch the stmmac fails in case of the phy device
is not found; w/o this fix the mdio can be register twice when
do down/up the iface and this is not correct.
Reported-by: default avatarStas <stsp@list.ru>
Signed-off-by: default avatarGiuseppe Cavallaro <peppe.cavallaro@st.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent de53d557
...@@ -188,8 +188,6 @@ int stmmac_mdio_register(struct net_device *ndev) ...@@ -188,8 +188,6 @@ int stmmac_mdio_register(struct net_device *ndev)
goto bus_register_fail; goto bus_register_fail;
} }
priv->mii = new_bus;
found = 0; found = 0;
for (addr = 0; addr < PHY_MAX_ADDR; addr++) { for (addr = 0; addr < PHY_MAX_ADDR; addr++) {
struct phy_device *phydev = new_bus->phy_map[addr]; struct phy_device *phydev = new_bus->phy_map[addr];
...@@ -237,8 +235,14 @@ int stmmac_mdio_register(struct net_device *ndev) ...@@ -237,8 +235,14 @@ int stmmac_mdio_register(struct net_device *ndev)
} }
} }
if (!found) if (!found) {
pr_warning("%s: No PHY found\n", ndev->name); pr_warning("%s: No PHY found\n", ndev->name);
mdiobus_unregister(new_bus);
mdiobus_free(new_bus);
return -ENODEV;
}
priv->mii = new_bus;
return 0; return 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment