Commit 225c6579 authored by Florian Fainelli's avatar Florian Fainelli Committed by Paolo Abeni

net: bcmgenet: Restore phy_stop() depending upon suspend/close

Removing the phy_stop() from bcmgenet_netif_stop() ended up causing
warnings from the PHY library that phy_start() is called from the
RUNNING state since we are no longer stopping the PHY state machine
during bcmgenet_suspend().

Restore the call to phy_stop() but make it conditional on being called
from the close or suspend path.

Fixes: c96e731c ("net: bcmgenet: connect and disconnect from the PHY state machine")
Fixes: 93e0401e ("net: bcmgenet: Remove phy_stop() from bcmgenet_netif_stop()")
Signed-off-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
Reviewed-by: default avatarPavan Chebbi <pavan.chebbi@broadcom.com>
Link: https://lore.kernel.org/r/20230515025608.2587012-1-f.fainelli@gmail.comSigned-off-by: default avatarPaolo Abeni <pabeni@redhat.com>
parent df0acdc5
...@@ -3450,7 +3450,7 @@ static int bcmgenet_open(struct net_device *dev) ...@@ -3450,7 +3450,7 @@ static int bcmgenet_open(struct net_device *dev)
return ret; return ret;
} }
static void bcmgenet_netif_stop(struct net_device *dev) static void bcmgenet_netif_stop(struct net_device *dev, bool stop_phy)
{ {
struct bcmgenet_priv *priv = netdev_priv(dev); struct bcmgenet_priv *priv = netdev_priv(dev);
...@@ -3465,6 +3465,8 @@ static void bcmgenet_netif_stop(struct net_device *dev) ...@@ -3465,6 +3465,8 @@ static void bcmgenet_netif_stop(struct net_device *dev)
/* Disable MAC transmit. TX DMA disabled must be done before this */ /* Disable MAC transmit. TX DMA disabled must be done before this */
umac_enable_set(priv, CMD_TX_EN, false); umac_enable_set(priv, CMD_TX_EN, false);
if (stop_phy)
phy_stop(dev->phydev);
bcmgenet_disable_rx_napi(priv); bcmgenet_disable_rx_napi(priv);
bcmgenet_intr_disable(priv); bcmgenet_intr_disable(priv);
...@@ -3485,7 +3487,7 @@ static int bcmgenet_close(struct net_device *dev) ...@@ -3485,7 +3487,7 @@ static int bcmgenet_close(struct net_device *dev)
netif_dbg(priv, ifdown, dev, "bcmgenet_close\n"); netif_dbg(priv, ifdown, dev, "bcmgenet_close\n");
bcmgenet_netif_stop(dev); bcmgenet_netif_stop(dev, false);
/* Really kill the PHY state machine and disconnect from it */ /* Really kill the PHY state machine and disconnect from it */
phy_disconnect(dev->phydev); phy_disconnect(dev->phydev);
...@@ -4303,7 +4305,7 @@ static int bcmgenet_suspend(struct device *d) ...@@ -4303,7 +4305,7 @@ static int bcmgenet_suspend(struct device *d)
netif_device_detach(dev); netif_device_detach(dev);
bcmgenet_netif_stop(dev); bcmgenet_netif_stop(dev, true);
if (!device_may_wakeup(d)) if (!device_may_wakeup(d))
phy_suspend(dev->phydev); phy_suspend(dev->phydev);
......
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