Commit 17b44753 authored by Andrew Lunn's avatar Andrew Lunn Committed by David S. Miller

net: phy: c45 scanning: Don't consider -ENODEV fatal

When scanning the MDIO bus for C22 devices, the driver returning
-ENODEV is not considered fatal, it just indicates the MDIO bus master
knows there is no device at that address, maybe because of hardware
limitation.

Make the C45 scan code act on -ENODEV the same way, to make C22 and
C45 more uniform.

It is expected all reads for a given address will return -ENODEV, so
within get_phy_c45_ids() only the first place a read occurs has been
changed.
Reviewed-by: default avatarFlorian Fainelli <florian.fainelli@broadcom.com>
Signed-off-by: default avatarAndrew Lunn <andrew@lunn.ch>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 56b93cd3
...@@ -780,7 +780,7 @@ static int get_phy_c45_devs_in_pkg(struct mii_bus *bus, int addr, int dev_addr, ...@@ -780,7 +780,7 @@ static int get_phy_c45_devs_in_pkg(struct mii_bus *bus, int addr, int dev_addr,
* and identifiers in @c45_ids. * and identifiers in @c45_ids.
* *
* Returns zero on success, %-EIO on bus access error, or %-ENODEV if * Returns zero on success, %-EIO on bus access error, or %-ENODEV if
* the "devices in package" is invalid. * the "devices in package" is invalid or no device responds.
*/ */
static int get_phy_c45_ids(struct mii_bus *bus, int addr, static int get_phy_c45_ids(struct mii_bus *bus, int addr,
struct phy_c45_device_ids *c45_ids) struct phy_c45_device_ids *c45_ids)
...@@ -803,7 +803,11 @@ static int get_phy_c45_ids(struct mii_bus *bus, int addr, ...@@ -803,7 +803,11 @@ static int get_phy_c45_ids(struct mii_bus *bus, int addr,
*/ */
ret = phy_c45_probe_present(bus, addr, i); ret = phy_c45_probe_present(bus, addr, i);
if (ret < 0) if (ret < 0)
return -EIO; /* returning -ENODEV doesn't stop bus
* scanning
*/
return (phy_reg == -EIO ||
phy_reg == -ENODEV) ? -ENODEV : -EIO;
if (!ret) if (!ret)
continue; continue;
......
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