diff options
author | Michael Chan <mchan@broadcom.com> | 2006-06-18 00:55:55 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2006-06-18 00:55:55 -0400 |
commit | c71302d61f844f766a44e1b04258086cc41f624e (patch) | |
tree | 678780353e025222ce87667466bba599c4c21d97 /drivers/net/tg3.c | |
parent | 35089bb203f44e33b6bbb6c4de0b0708f9a48921 (diff) |
[TG3]: Remove unnecessary tx_lock
Remove tx_lock where it is unnecessary. tg3 runs lockless and so it
requires interrupts to be disabled and sync'ed, netif_queue and NAPI
poll to be stopped before the device can be reconfigured. After
stopping everything, it is no longer necessary to get the tx_lock.
Signed-off-by: Michael Chan <mchan@broadcom.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/tg3.c')
-rw-r--r-- | drivers/net/tg3.c | 4 |
1 files changed, 0 insertions, 4 deletions
diff --git a/drivers/net/tg3.c b/drivers/net/tg3.c index 3c9b13b3cf9b..542d4c3a10e5 100644 --- a/drivers/net/tg3.c +++ b/drivers/net/tg3.c | |||
@@ -2984,9 +2984,7 @@ static void tg3_tx_recover(struct tg3 *tp) | |||
2984 | "and include system chipset information.\n", tp->dev->name); | 2984 | "and include system chipset information.\n", tp->dev->name); |
2985 | 2985 | ||
2986 | spin_lock(&tp->lock); | 2986 | spin_lock(&tp->lock); |
2987 | spin_lock(&tp->tx_lock); | ||
2988 | tp->tg3_flags |= TG3_FLAG_TX_RECOVERY_PENDING; | 2987 | tp->tg3_flags |= TG3_FLAG_TX_RECOVERY_PENDING; |
2989 | spin_unlock(&tp->tx_lock); | ||
2990 | spin_unlock(&tp->lock); | 2988 | spin_unlock(&tp->lock); |
2991 | } | 2989 | } |
2992 | 2990 | ||
@@ -3429,12 +3427,10 @@ static inline void tg3_full_lock(struct tg3 *tp, int irq_sync) | |||
3429 | if (irq_sync) | 3427 | if (irq_sync) |
3430 | tg3_irq_quiesce(tp); | 3428 | tg3_irq_quiesce(tp); |
3431 | spin_lock_bh(&tp->lock); | 3429 | spin_lock_bh(&tp->lock); |
3432 | spin_lock(&tp->tx_lock); | ||
3433 | } | 3430 | } |
3434 | 3431 | ||
3435 | static inline void tg3_full_unlock(struct tg3 *tp) | 3432 | static inline void tg3_full_unlock(struct tg3 *tp) |
3436 | { | 3433 | { |
3437 | spin_unlock(&tp->tx_lock); | ||
3438 | spin_unlock_bh(&tp->lock); | 3434 | spin_unlock_bh(&tp->lock); |
3439 | } | 3435 | } |
3440 | 3436 | ||