diff options
author | Linas Vepstas <linas@austin.ibm.com> | 2007-02-20 17:41:59 -0500 |
---|---|---|
committer | Jeff Garzik <jeff@garzik.org> | 2007-02-27 04:16:03 -0500 |
commit | 5c8e98fe4742734c1c6b81699a86d1f5b03841e0 (patch) | |
tree | 6a93ccce6f545da153bc937548bc6fe1db1e99ab /drivers | |
parent | d9c199ee781fa874e6feb4c56ae3d0e19f7f82a6 (diff) |
spidernet: transmit race
Multiple threads performing a transmit can race into
the spidernet tx ring cleanup code. This puts the
relevant check under a lock.
Signed-off-by: Linas Vepstas <lins@austin.ibm.com>
Cc: Jens Osterkamp <Jens.Osterkamp@de.ibm.com>
Cc: Kou Ishizaki <kou.ishizaki@toshiba.co.jp>
Signed-off-by: Jeff Garzik <jeff@garzik.org>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/spider_net.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/drivers/net/spider_net.c b/drivers/net/spider_net.c index 15b0bcaec467..653a91adacc7 100644 --- a/drivers/net/spider_net.c +++ b/drivers/net/spider_net.c | |||
@@ -803,8 +803,12 @@ spider_net_release_tx_chain(struct spider_net_card *card, int brutal) | |||
803 | unsigned long flags; | 803 | unsigned long flags; |
804 | int status; | 804 | int status; |
805 | 805 | ||
806 | while (chain->tail != chain->head) { | 806 | while (1) { |
807 | spin_lock_irqsave(&chain->lock, flags); | 807 | spin_lock_irqsave(&chain->lock, flags); |
808 | if (chain->tail == chain->head) { | ||
809 | spin_unlock_irqrestore(&chain->lock, flags); | ||
810 | return 0; | ||
811 | } | ||
808 | descr = chain->tail; | 812 | descr = chain->tail; |
809 | hwdescr = descr->hwdescr; | 813 | hwdescr = descr->hwdescr; |
810 | 814 | ||