Re: [PATCH net] net: stmmac: Hold rtnl lock in suspend/resume callbacks

2019-09-16 Thread David Miller
From: Jose Abreu 
Date: Fri, 13 Sep 2019 11:50:32 +0200

> We need to hold rnl lock in suspend and resume callbacks because phylink
> requires it. Otherwise we will get a WARN() in suspend and resume.
> 
> Also, move phylink start and stop callbacks to inside device's internal
> lock so that we prevent concurrent HW accesses.
> 
> Fixes: 74371272f97f ("net: stmmac: Convert to phylink and remove phylib 
> logic")
> Reported-by: Christophe ROULLIER 
> Tested-by: Christophe ROULLIER 
> Signed-off-by: Jose Abreu 

Applied and queued up for v5.3 -stable.

Thanks.


[PATCH net] net: stmmac: Hold rtnl lock in suspend/resume callbacks

2019-09-13 Thread Jose Abreu
We need to hold rnl lock in suspend and resume callbacks because phylink
requires it. Otherwise we will get a WARN() in suspend and resume.

Also, move phylink start and stop callbacks to inside device's internal
lock so that we prevent concurrent HW accesses.

Fixes: 74371272f97f ("net: stmmac: Convert to phylink and remove phylib logic")
Reported-by: Christophe ROULLIER 
Tested-by: Christophe ROULLIER 
Signed-off-by: Jose Abreu 

---
Cc: Giuseppe Cavallaro 
Cc: Alexandre Torgue 
Cc: Jose Abreu 
Cc: "David S. Miller" 
Cc: Maxime Coquelin 
Cc: net...@vger.kernel.org
Cc: linux-st...@st-md-mailman.stormreply.com
Cc: linux-arm-ker...@lists.infradead.org
Cc: linux-kernel@vger.kernel.org
Cc: Christophe ROULLIER 
---
 drivers/net/ethernet/stmicro/stmmac/stmmac_main.c | 12 
 1 file changed, 8 insertions(+), 4 deletions(-)

diff --git a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c 
b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
index fd54c7c87485..b19ab09cb18f 100644
--- a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
+++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
@@ -4451,10 +4451,12 @@ int stmmac_suspend(struct device *dev)
if (!ndev || !netif_running(ndev))
return 0;
 
-   phylink_stop(priv->phylink);
-
mutex_lock(>lock);
 
+   rtnl_lock();
+   phylink_stop(priv->phylink);
+   rtnl_unlock();
+
netif_device_detach(ndev);
stmmac_stop_all_queues(priv);
 
@@ -4558,9 +4560,11 @@ int stmmac_resume(struct device *dev)
 
stmmac_start_all_queues(priv);
 
-   mutex_unlock(>lock);
-
+   rtnl_lock();
phylink_start(priv->phylink);
+   rtnl_unlock();
+
+   mutex_unlock(>lock);
 
return 0;
 }
-- 
2.7.4