--- a/drivers/net/phy/mdio_bus.c +++ b/drivers/net/phy/mdio_bus.c @@ -132,6 +132,9 @@ struct phy_device *phydev = to_phy_device(dev); struct phy_driver *phydrv = to_phy_driver(drv); + if (phydrv->detect) + return (phydrv->detect(phydev->bus, phydev->addr)); + return ((phydrv->phy_id & phydrv->phy_id_mask) == (phydev->phy_id & phydrv->phy_id_mask)); } --- a/include/linux/phy.h +++ b/include/linux/phy.h @@ -325,6 +325,11 @@ u32 features; u32 flags; + /* Called during discovery to test if the + * device can attach to the bus, even if + * phy id and mask do not match */ + bool (*detect)(struct mii_bus *bus, int addr); + /* Called to initialize the PHY, * including after a reset */ int (*config_init)(struct phy_device *phydev);