[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <1e350c73-291a-210a-7d34-92cb3af3850d@gmail.com>
Date: Fri, 16 Mar 2018 22:15:05 +0100
From: Heiner Kallweit <hkallweit1@...il.com>
To: Florian Fainelli <f.fainelli@...il.com>,
Andrew Lunn <andrew@...n.ch>,
Geert Uytterhoeven <geert+renesas@...der.be>
Cc: "netdev@...r.kernel.org" <netdev@...r.kernel.org>
Subject: [PATCH RFC v2 3/7] net: phy: resume PHY only if needed in
mdio_bus_phy_suspend
Currently the PHY is unconditionally resumed in mdio_bus_phy_suspend().
In cases where the PHY was sleepinh before suspending or if somebody else
takes care of resuming later, this is not needed and wastes energy.
Also start the state machine only if it's used by the driver (indicated
by the adjust_link callback being defined).
Signed-off-by: Heiner Kallweit <hkallweit1@...il.com>
---
v2:
- rename variable in mdio_bus_phy_needs_start
---
drivers/net/phy/phy_device.c | 30 ++++++++++++++++++++++--------
1 file changed, 22 insertions(+), 8 deletions(-)
diff --git a/drivers/net/phy/phy_device.c b/drivers/net/phy/phy_device.c
index 85ebb969..c934725b 100644
--- a/drivers/net/phy/phy_device.c
+++ b/drivers/net/phy/phy_device.c
@@ -124,6 +124,18 @@ static bool phy_may_suspend(struct phy_device *phydev)
}
#ifdef CONFIG_PM
+
+static bool mdio_bus_phy_needs_start(struct phy_device *phydev)
+{
+ bool needs_start;
+
+ mutex_lock(&phydev->lock);
+ needs_start = phydev->state == PHY_UP && phydev->adjust_link;
+ mutex_unlock(&phydev->lock);
+
+ return needs_start;
+}
+
static int mdio_bus_phy_suspend(struct device *dev)
{
struct phy_device *phydev = to_phy_device(dev);
@@ -142,16 +154,17 @@ static int mdio_bus_phy_suspend(struct device *dev)
static int mdio_bus_phy_resume(struct device *dev)
{
struct phy_device *phydev = to_phy_device(dev);
- int ret;
+ int ret = 0;
- ret = phy_resume(phydev);
- if (ret < 0)
- return ret;
+ if (!phydev->attached_dev)
+ return 0;
- if (phydev->attached_dev && phydev->adjust_link)
- phy_start_machine(phydev);
+ if (mdio_bus_phy_needs_start(phydev))
+ phy_start(phydev);
+ else if (!phydev->adjust_link)
+ ret = phy_resume(phydev);
- return 0;
+ return ret;
}
static int mdio_bus_phy_restore(struct device *dev)
@@ -171,7 +184,8 @@ static int mdio_bus_phy_restore(struct device *dev)
phydev->link = 0;
phydev->state = PHY_UP;
- phy_start_machine(phydev);
+ if (mdio_bus_phy_needs_start(phydev))
+ phy_start(phydev);
return 0;
}
--
2.16.2
Powered by blists - more mailing lists