qeth-repair-crash-in-qeth_l3_vlan_rx_kill_vid.patch
tg3-add-device-id-of-apple-thunderbolt-ethernet-device.patch
tg3-fix-read-dma-workaround-for-5719-a0.patch
+tg3-fix-race-condition-in-tg3_get_stats64.patch
--- /dev/null
+From 0f566b208b41918053b2e67399673aaec02dde5d Mon Sep 17 00:00:00 2001
+From: Michael Chan <mchan@broadcom.com>
+Date: Sun, 29 Jul 2012 19:15:44 +0000
+Subject: tg3: Fix race condition in tg3_get_stats64()
+
+From: Michael Chan <mchan@broadcom.com>
+
+commit 0f566b208b41918053b2e67399673aaec02dde5d upstream.
+
+Spinlock should be taken before checking for tp->hw_stats.
+
+Signed-off-by: Michael Chan <mchan@broadcom.com>
+Signed-off-by: David S. Miller <davem@davemloft.net>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+
+---
+ drivers/net/ethernet/broadcom/tg3.c | 6 ++++--
+ 1 file changed, 4 insertions(+), 2 deletions(-)
+
+--- a/drivers/net/ethernet/broadcom/tg3.c
++++ b/drivers/net/ethernet/broadcom/tg3.c
+@@ -12255,10 +12255,12 @@ static struct rtnl_link_stats64 *tg3_get
+ {
+ struct tg3 *tp = netdev_priv(dev);
+
+- if (!tp->hw_stats)
++ spin_lock_bh(&tp->lock);
++ if (!tp->hw_stats) {
++ spin_unlock_bh(&tp->lock);
+ return &tp->net_stats_prev;
++ }
+
+- spin_lock_bh(&tp->lock);
+ tg3_get_nstats(tp, stats);
+ spin_unlock_bh(&tp->lock);
+