Commit 77b28983 authored by Jisheng Zhang's avatar Jisheng Zhang Committed by David S. Miller

net: stmmac: Speed down the PHY if WoL to save energy

When WoL is enabled and the machine is powered off, the PHY remains
waiting for wakeup events at max speed, which is a waste of energy.

Slow down the PHY speed before stopping the ethernet if WoL is enabled,
Signed-off-by: default avatarJisheng Zhang <Jisheng.Zhang@synaptics.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 1d8e5b0f
...@@ -2823,6 +2823,8 @@ static int stmmac_open(struct net_device *dev) ...@@ -2823,6 +2823,8 @@ static int stmmac_open(struct net_device *dev)
stmmac_init_coalesce(priv); stmmac_init_coalesce(priv);
phylink_start(priv->phylink); phylink_start(priv->phylink);
/* We may have called phylink_speed_down before */
phylink_speed_up(priv->phylink);
/* Request the IRQ lines */ /* Request the IRQ lines */
ret = request_irq(dev->irq, stmmac_interrupt, ret = request_irq(dev->irq, stmmac_interrupt,
...@@ -2896,6 +2898,8 @@ static int stmmac_release(struct net_device *dev) ...@@ -2896,6 +2898,8 @@ static int stmmac_release(struct net_device *dev)
if (priv->eee_enabled) if (priv->eee_enabled)
del_timer_sync(&priv->eee_ctrl_timer); del_timer_sync(&priv->eee_ctrl_timer);
if (device_may_wakeup(priv->device))
phylink_speed_down(priv->phylink, false);
/* Stop and disconnect the PHY */ /* Stop and disconnect the PHY */
phylink_stop(priv->phylink); phylink_stop(priv->phylink);
phylink_disconnect_phy(priv->phylink); phylink_disconnect_phy(priv->phylink);
...@@ -5095,6 +5099,8 @@ int stmmac_suspend(struct device *dev) ...@@ -5095,6 +5099,8 @@ int stmmac_suspend(struct device *dev)
} else { } else {
mutex_unlock(&priv->lock); mutex_unlock(&priv->lock);
rtnl_lock(); rtnl_lock();
if (device_may_wakeup(priv->device))
phylink_speed_down(priv->phylink, false);
phylink_stop(priv->phylink); phylink_stop(priv->phylink);
rtnl_unlock(); rtnl_unlock();
mutex_lock(&priv->lock); mutex_lock(&priv->lock);
...@@ -5207,6 +5213,8 @@ int stmmac_resume(struct device *dev) ...@@ -5207,6 +5213,8 @@ int stmmac_resume(struct device *dev)
if (!device_may_wakeup(priv->device) || !priv->plat->pmt) { if (!device_may_wakeup(priv->device) || !priv->plat->pmt) {
rtnl_lock(); rtnl_lock();
phylink_start(priv->phylink); phylink_start(priv->phylink);
/* We may have called phylink_speed_down before */
phylink_speed_up(priv->phylink);
rtnl_unlock(); rtnl_unlock();
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment