diff options
author | Mike McCormack <mikem@ring3k.org> | 2010-05-13 02:12:49 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-05-14 06:06:20 -0400 |
commit | df01093bb08916f434ebedde4610805d4105d05f (patch) | |
tree | 85f19aa28e7b525ac22c5a981d2f4f83de97858a /drivers/net | |
parent | 37652522faa0877dc6d0dbb6b999bdccc07f0e89 (diff) |
sky2: Avoid race in sky2_change_mtu
netif_stop_queue does not ensure all in-progress transmits are complete,
so use netif_tx_disable() instead.
Secondly, make sure NAPI polls are disabled before stopping the tx queue,
otherwise sky2_status_intr might trigger a TX queue wakeup between when
we stop the queue and NAPI is disabled.
Signed-off-by: Mike McCormack <mikem@ring3k.org>
Acked-by: Stephen Hemminger <shemminger@vyatta.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net')
-rw-r--r-- | drivers/net/sky2.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/net/sky2.c b/drivers/net/sky2.c index 15da5e419eb1..efc31e93eb78 100644 --- a/drivers/net/sky2.c +++ b/drivers/net/sky2.c | |||
@@ -2275,8 +2275,8 @@ static int sky2_change_mtu(struct net_device *dev, int new_mtu) | |||
2275 | sky2_write32(hw, B0_IMSK, 0); | 2275 | sky2_write32(hw, B0_IMSK, 0); |
2276 | 2276 | ||
2277 | dev->trans_start = jiffies; /* prevent tx timeout */ | 2277 | dev->trans_start = jiffies; /* prevent tx timeout */ |
2278 | netif_stop_queue(dev); | ||
2279 | napi_disable(&hw->napi); | 2278 | napi_disable(&hw->napi); |
2279 | netif_tx_disable(dev); | ||
2280 | 2280 | ||
2281 | synchronize_irq(hw->pdev->irq); | 2281 | synchronize_irq(hw->pdev->irq); |
2282 | 2282 | ||