Commit 265ad063 authored by David S. Miller's avatar David S. Miller

Merge branch 'net-timeout-fixes-for-GENET-and-SYSTEMPORT'

Florian Fainelli says:

====================
net: timeout fixes for GENET and SYSTEMPORT

This patch series fixes occasional transmit timeout around the time
the system goes into suspend. GENET and SYSTEMPORT have nearly the same
logic in that regard and were both affected in the same way.

Please queue up for stable, thanks!
====================
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parents c7e86acf 7cb6a2a2
...@@ -1902,9 +1902,6 @@ static void bcm_sysport_netif_start(struct net_device *dev) ...@@ -1902,9 +1902,6 @@ static void bcm_sysport_netif_start(struct net_device *dev)
intrl2_1_mask_clear(priv, 0xffffffff); intrl2_1_mask_clear(priv, 0xffffffff);
else else
intrl2_0_mask_clear(priv, INTRL2_0_TDMA_MBDONE_MASK); intrl2_0_mask_clear(priv, INTRL2_0_TDMA_MBDONE_MASK);
/* Last call before we start the real business */
netif_tx_start_all_queues(dev);
} }
static void rbuf_init(struct bcm_sysport_priv *priv) static void rbuf_init(struct bcm_sysport_priv *priv)
...@@ -2048,6 +2045,8 @@ static int bcm_sysport_open(struct net_device *dev) ...@@ -2048,6 +2045,8 @@ static int bcm_sysport_open(struct net_device *dev)
bcm_sysport_netif_start(dev); bcm_sysport_netif_start(dev);
netif_tx_start_all_queues(dev);
return 0; return 0;
out_clear_rx_int: out_clear_rx_int:
...@@ -2071,7 +2070,7 @@ static void bcm_sysport_netif_stop(struct net_device *dev) ...@@ -2071,7 +2070,7 @@ static void bcm_sysport_netif_stop(struct net_device *dev)
struct bcm_sysport_priv *priv = netdev_priv(dev); struct bcm_sysport_priv *priv = netdev_priv(dev);
/* stop all software from updating hardware */ /* stop all software from updating hardware */
netif_tx_stop_all_queues(dev); netif_tx_disable(dev);
napi_disable(&priv->napi); napi_disable(&priv->napi);
cancel_work_sync(&priv->dim.dim.work); cancel_work_sync(&priv->dim.dim.work);
phy_stop(dev->phydev); phy_stop(dev->phydev);
...@@ -2658,12 +2657,12 @@ static int __maybe_unused bcm_sysport_suspend(struct device *d) ...@@ -2658,12 +2657,12 @@ static int __maybe_unused bcm_sysport_suspend(struct device *d)
if (!netif_running(dev)) if (!netif_running(dev))
return 0; return 0;
netif_device_detach(dev);
bcm_sysport_netif_stop(dev); bcm_sysport_netif_stop(dev);
phy_suspend(dev->phydev); phy_suspend(dev->phydev);
netif_device_detach(dev);
/* Disable UniMAC RX */ /* Disable UniMAC RX */
umac_enable_set(priv, CMD_RX_EN, 0); umac_enable_set(priv, CMD_RX_EN, 0);
...@@ -2746,8 +2745,6 @@ static int __maybe_unused bcm_sysport_resume(struct device *d) ...@@ -2746,8 +2745,6 @@ static int __maybe_unused bcm_sysport_resume(struct device *d)
goto out_free_rx_ring; goto out_free_rx_ring;
} }
netif_device_attach(dev);
/* RX pipe enable */ /* RX pipe enable */
topctrl_writel(priv, 0, RX_FLUSH_CNTL); topctrl_writel(priv, 0, RX_FLUSH_CNTL);
...@@ -2788,6 +2785,8 @@ static int __maybe_unused bcm_sysport_resume(struct device *d) ...@@ -2788,6 +2785,8 @@ static int __maybe_unused bcm_sysport_resume(struct device *d)
bcm_sysport_netif_start(dev); bcm_sysport_netif_start(dev);
netif_device_attach(dev);
return 0; return 0;
out_free_rx_ring: out_free_rx_ring:
......
...@@ -2855,7 +2855,6 @@ static void bcmgenet_netif_start(struct net_device *dev) ...@@ -2855,7 +2855,6 @@ static void bcmgenet_netif_start(struct net_device *dev)
umac_enable_set(priv, CMD_TX_EN | CMD_RX_EN, true); umac_enable_set(priv, CMD_TX_EN | CMD_RX_EN, true);
netif_tx_start_all_queues(dev);
bcmgenet_enable_tx_napi(priv); bcmgenet_enable_tx_napi(priv);
/* Monitor link interrupts now */ /* Monitor link interrupts now */
...@@ -2937,6 +2936,8 @@ static int bcmgenet_open(struct net_device *dev) ...@@ -2937,6 +2936,8 @@ static int bcmgenet_open(struct net_device *dev)
bcmgenet_netif_start(dev); bcmgenet_netif_start(dev);
netif_tx_start_all_queues(dev);
return 0; return 0;
err_irq1: err_irq1:
...@@ -2958,7 +2959,7 @@ static void bcmgenet_netif_stop(struct net_device *dev) ...@@ -2958,7 +2959,7 @@ static void bcmgenet_netif_stop(struct net_device *dev)
struct bcmgenet_priv *priv = netdev_priv(dev); struct bcmgenet_priv *priv = netdev_priv(dev);
bcmgenet_disable_tx_napi(priv); bcmgenet_disable_tx_napi(priv);
netif_tx_stop_all_queues(dev); netif_tx_disable(dev);
/* Disable MAC receive */ /* Disable MAC receive */
umac_enable_set(priv, CMD_RX_EN, false); umac_enable_set(priv, CMD_RX_EN, false);
...@@ -3620,13 +3621,13 @@ static int bcmgenet_suspend(struct device *d) ...@@ -3620,13 +3621,13 @@ static int bcmgenet_suspend(struct device *d)
if (!netif_running(dev)) if (!netif_running(dev))
return 0; return 0;
netif_device_detach(dev);
bcmgenet_netif_stop(dev); bcmgenet_netif_stop(dev);
if (!device_may_wakeup(d)) if (!device_may_wakeup(d))
phy_suspend(dev->phydev); phy_suspend(dev->phydev);
netif_device_detach(dev);
/* Prepare the device for Wake-on-LAN and switch to the slow clock */ /* Prepare the device for Wake-on-LAN and switch to the slow clock */
if (device_may_wakeup(d) && priv->wolopts) { if (device_may_wakeup(d) && priv->wolopts) {
ret = bcmgenet_power_down(priv, GENET_POWER_WOL_MAGIC); ret = bcmgenet_power_down(priv, GENET_POWER_WOL_MAGIC);
...@@ -3700,8 +3701,6 @@ static int bcmgenet_resume(struct device *d) ...@@ -3700,8 +3701,6 @@ static int bcmgenet_resume(struct device *d)
/* Always enable ring 16 - descriptor ring */ /* Always enable ring 16 - descriptor ring */
bcmgenet_enable_dma(priv, dma_ctrl); bcmgenet_enable_dma(priv, dma_ctrl);
netif_device_attach(dev);
if (!device_may_wakeup(d)) if (!device_may_wakeup(d))
phy_resume(dev->phydev); phy_resume(dev->phydev);
...@@ -3710,6 +3709,8 @@ static int bcmgenet_resume(struct device *d) ...@@ -3710,6 +3709,8 @@ static int bcmgenet_resume(struct device *d)
bcmgenet_netif_start(dev); bcmgenet_netif_start(dev);
netif_device_attach(dev);
return 0; return 0;
out_clk_disable: out_clk_disable:
......
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