Commit d4dc35f2 authored by Lars Persson's avatar Lars Persson Committed by David S. Miller

dwc_eth_qos: release descriptors outside netif_tx_lock

To prepare for using the CMA, we can not be in atomic context when
de-allocating DMA buffers.

The tx lock was needed only to protect the hw reset against the xmit
handler. Now we briefly grab the tx lock while stopping the queue to
make sure no thread is inside or will enter the xmit handler.
Signed-off-by: default avatarLars Persson <larper@axis.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 8afb6c47
...@@ -1918,15 +1918,17 @@ static int dwceqos_stop(struct net_device *ndev) ...@@ -1918,15 +1918,17 @@ static int dwceqos_stop(struct net_device *ndev)
phy_stop(lp->phy_dev); phy_stop(lp->phy_dev);
tasklet_disable(&lp->tx_bdreclaim_tasklet); tasklet_disable(&lp->tx_bdreclaim_tasklet);
netif_stop_queue(ndev);
napi_disable(&lp->napi); napi_disable(&lp->napi);
dwceqos_drain_dma(lp); /* Stop all tx before we drain the tx dma. */
netif_tx_lock_bh(lp->ndev);
netif_stop_queue(ndev);
netif_tx_unlock_bh(lp->ndev);
netif_tx_lock(lp->ndev); dwceqos_drain_dma(lp);
dwceqos_reset_hw(lp); dwceqos_reset_hw(lp);
dwceqos_descriptor_free(lp); dwceqos_descriptor_free(lp);
netif_tx_unlock(lp->ndev);
return 0; return 0;
} }
......
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