aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLinas Vepstas <linas@austin.ibm.com>2007-02-20 17:41:59 -0500
committerJeff Garzik <jeff@garzik.org>2007-02-27 04:16:03 -0500
commit5c8e98fe4742734c1c6b81699a86d1f5b03841e0 (patch)
tree6a93ccce6f545da153bc937548bc6fe1db1e99ab
parentd9c199ee781fa874e6feb4c56ae3d0e19f7f82a6 (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>
-rw-r--r--drivers/net/spider_net.c6
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