diff options
author | Hannes Schmelzer <hannes.schmelzer@br-automation.com> | 2019-03-29 09:54:05 +0100 |
---|---|---|
committer | Tom Rini <trini@konsulko.com> | 2019-04-07 20:31:16 -0400 |
commit | afbc31948a007e03d6a1282677aafc2208f45819 (patch) | |
tree | df64dfbfcab1f6be261797aa6b117c7333d921cf /drivers | |
parent | 0e62d5b2abb69ddc9e58215e2d8dfa5d33996b8a (diff) | |
download | u-boot-afbc31948a007e03d6a1282677aafc2208f45819.tar.gz |
net: phy: implement fallback mechanism for negative phy adresses
Negative phy-addresses can occour if the caller function was not able to
determine a valid phy address (from device-tree for example). In this
case we catch this here and search for ANY phy device on the given mdio-
bus.
Signed-off-by: Hannes Schmelzer <hannes.schmelzer@br-automation.com>
Tested-by: Michal Simek <michal.simek@xilinx.com>
Tested-by: Lukasz Majewski <lukma@denx.de>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/phy/phy.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/net/phy/phy.c b/drivers/net/phy/phy.c index 0c8b29dae4..4e8d2943ee 100644 --- a/drivers/net/phy/phy.c +++ b/drivers/net/phy/phy.c @@ -922,13 +922,14 @@ struct phy_device *phy_connect(struct mii_dev *bus, int addr, #endif { struct phy_device *phydev = NULL; + uint mask = (addr > 0) ? (1 << addr) : 0xffffffff; #ifdef CONFIG_PHY_FIXED phydev = phy_connect_fixed(bus, dev, interface); #endif if (!phydev) - phydev = phy_find_by_mask(bus, 1 << addr, interface); + phydev = phy_find_by_mask(bus, mask, interface); if (phydev) phy_connect_dev(phydev, dev); |