net: bcmgenet: Indicate MAC is in charge of PHY PM
authorFlorian Fainelli <f.fainelli@gmail.com>
Thu, 4 Aug 2022 17:36:04 +0000 (10:36 -0700)
committerJakub Kicinski <kuba@kernel.org>
Sat, 6 Aug 2022 02:02:18 +0000 (19:02 -0700)
Avoid the PHY library call unnecessarily into the suspend/resume functions by
setting phydev->mac_managed_pm to true. The GENET driver essentially does
exactly what mdio_bus_phy_resume() does by calling phy_init_hw() plus
phy_resume().

Fixes: fba863b81604 ("net: phy: make PHY PM ops a no-op if MAC driver manages PHY PM")
Signed-off-by: Florian Fainelli <f.fainelli@gmail.com>
Link: https://lore.kernel.org/r/20220804173605.1266574-1-f.fainelli@gmail.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/ethernet/broadcom/genet/bcmmii.c

index c888dde..7ded559 100644 (file)
@@ -393,6 +393,9 @@ int bcmgenet_mii_probe(struct net_device *dev)
        if (priv->internal_phy && !GENET_IS_V5(priv))
                dev->phydev->irq = PHY_MAC_INTERRUPT;
 
+       /* Indicate that the MAC is responsible for PHY PM */
+       dev->phydev->mac_managed_pm = true;
+
        return 0;
 }