Skip to content

Commit

Permalink
net: phy: don't touch suspended flag if there's no suspend/resume cal…
Browse files Browse the repository at this point in the history
…lback

So far we set phydev->suspended to true in phy_suspend() even if the
PHY driver doesn't implement the suspend callback. This applies
accordingly for the resume path. The current behavior doesn't cause
any issue I'd be aware of, but it's not logical and misleading,
especially considering the description of the flag:
"suspended: Set to true if this phy has been suspended successfully"

Signed-off-by: Heiner Kallweit <hkallweit1@gmail.com>
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
Reviewed-by: Florian Fainelli <f.fainelli@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
  • Loading branch information
Heiner Kallweit authored and David S. Miller committed Mar 27, 2020
1 parent 05cc6c5 commit 8a8f828
Showing 1 changed file with 15 additions and 17 deletions.
32 changes: 15 additions & 17 deletions drivers/net/phy/phy_device.c
Original file line number Diff line number Diff line change
Expand Up @@ -1519,42 +1519,40 @@ EXPORT_SYMBOL(phy_detach);

int phy_suspend(struct phy_device *phydev)
{
struct phy_driver *phydrv = to_phy_driver(phydev->mdio.dev.driver);
struct net_device *netdev = phydev->attached_dev;
struct ethtool_wolinfo wol = { .cmd = ETHTOOL_GWOL };
int ret = 0;
struct net_device *netdev = phydev->attached_dev;
struct phy_driver *phydrv = phydev->drv;
int ret;

/* If the device has WOL enabled, we cannot suspend the PHY */
phy_ethtool_get_wol(phydev, &wol);
if (wol.wolopts || (netdev && netdev->wol_enabled))
return -EBUSY;

if (phydev->drv && phydrv->suspend)
ret = phydrv->suspend(phydev);

if (ret)
return ret;
if (!phydrv || !phydrv->suspend)
return 0;

phydev->suspended = true;
ret = phydrv->suspend(phydev);
if (!ret)
phydev->suspended = true;

return ret;
}
EXPORT_SYMBOL(phy_suspend);

int __phy_resume(struct phy_device *phydev)
{
struct phy_driver *phydrv = to_phy_driver(phydev->mdio.dev.driver);
int ret = 0;
struct phy_driver *phydrv = phydev->drv;
int ret;

WARN_ON(!mutex_is_locked(&phydev->lock));

if (phydev->drv && phydrv->resume)
ret = phydrv->resume(phydev);

if (ret)
return ret;
if (!phydrv || !phydrv->resume)
return 0;

phydev->suspended = false;
ret = phydrv->resume(phydev);
if (!ret)
phydev->suspended = false;

return ret;
}
Expand Down

0 comments on commit 8a8f828

Please sign in to comment.