diff options
author | Stephen Hemminger <shemminger@osdl.org> | 2005-12-09 11:35:08 -0800 |
---|---|---|
committer | Jeff Garzik <jgarzik@pobox.com> | 2005-12-12 15:27:21 -0500 |
commit | 8c463ef7928d7a42bb9ca410df9b294dc01c1850 (patch) | |
tree | 37615a7fc948094d2780aab66a354af0d4609d03 /drivers/net/sky2.c | |
parent | 8cc048e338ad4034255f3ff72ef1f631963e1263 (diff) | |
download | op-kernel-dev-8c463ef7928d7a42bb9ca410df9b294dc01c1850.zip op-kernel-dev-8c463ef7928d7a42bb9ca410df9b294dc01c1850.tar.gz |
[PATCH] sky2: quiet ring full message in case of race
Don't print ring full message if we lose race.
Signed-off-by: Stephen Hemminger <shemminger@osdl.org>
Signed-off-by: Jeff Garzik <jgarzik@pobox.com>
Diffstat (limited to 'drivers/net/sky2.c')
-rw-r--r-- | drivers/net/sky2.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/drivers/net/sky2.c b/drivers/net/sky2.c index e1733aa..54947ae 100644 --- a/drivers/net/sky2.c +++ b/drivers/net/sky2.c @@ -1081,11 +1081,16 @@ static int sky2_xmit_frame(struct sk_buff *skb, struct net_device *dev) return NETDEV_TX_LOCKED; if (unlikely(tx_avail(sky2) < tx_le_req(skb))) { - netif_stop_queue(dev); + /* There is a known but harmless race with lockless tx + * and netif_stop_queue. + */ + if (!netif_queue_stopped(dev)) { + netif_stop_queue(dev); + printk(KERN_WARNING PFX "%s: ring full when queue awake!\n", + dev->name); + } spin_unlock(&sky2->tx_lock); - printk(KERN_WARNING PFX "%s: ring full when queue awake!\n", - dev->name); return NETDEV_TX_BUSY; } |