diff options
author | Jeremy Fitzhardinge <jeremy@goop.org> | 2006-06-26 03:03:40 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2006-06-26 03:03:40 -0400 |
commit | 8834807b43200b1658b49d3b779e74a4f77e4ffb (patch) | |
tree | e9f8f2312b9ee3d4f6ea388f3b33c65e1495868c /net | |
parent | d83561a4d67863b4aa297e8f598823dd4dfe855e (diff) |
[NET] netpoll: don't spin forever sending to stopped queues
When transmitting a skb in netpoll_send_skb(), only retry a limited number
of times if the device queue is stopped.
Signed-off-by: Jeremy Fitzhardinge <jeremy@goop.org>
Acked-by: Matt Mackall <mpm@selenic.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net')
-rw-r--r-- | net/core/netpoll.c | 10 |
1 files changed, 3 insertions, 7 deletions
diff --git a/net/core/netpoll.c b/net/core/netpoll.c index 9cb781830380..377d1e7257b5 100644 --- a/net/core/netpoll.c +++ b/net/core/netpoll.c | |||
@@ -279,14 +279,10 @@ static void netpoll_send_skb(struct netpoll *np, struct sk_buff *skb) | |||
279 | * network drivers do not expect to be called if the queue is | 279 | * network drivers do not expect to be called if the queue is |
280 | * stopped. | 280 | * stopped. |
281 | */ | 281 | */ |
282 | if (netif_queue_stopped(np->dev)) { | 282 | status = NETDEV_TX_BUSY; |
283 | netif_tx_unlock(np->dev); | 283 | if (!netif_queue_stopped(np->dev)) |
284 | netpoll_poll(np); | 284 | status = np->dev->hard_start_xmit(skb, np->dev); |
285 | udelay(50); | ||
286 | continue; | ||
287 | } | ||
288 | 285 | ||
289 | status = np->dev->hard_start_xmit(skb, np->dev); | ||
290 | netif_tx_unlock(np->dev); | 286 | netif_tx_unlock(np->dev); |
291 | 287 | ||
292 | /* success */ | 288 | /* success */ |