diff options
author | Stefan Buehler <stbuehler@web.de> | 2008-08-15 17:10:54 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-08-15 17:10:54 -0400 |
commit | 816f8b86621000fc82e16ae5f172164de761d5eb (patch) | |
tree | b7a6964f422ebb4815314397ae8ed4c69d3fcc70 | |
parent | 4ba526ced990f4d61ee8d65fe8a6f0745e8e455c (diff) |
tg3: fix 64 bit counter for ethtool stats
Ethtool stats are 64-bits in length. net_device_stats members are
unsigned long types. When gathering information for
a get_ethtool_stats call, the driver will call a driver-private,
inlined get_stat64() function, which returns an unsigned long value.
This call will inadvertently mask off the upper 32-bits of a stat on
32-bit machines.
This patch defines a new get_estat() inline function and modifies the
ESTAT_ADD() macro to use it.
Signed-off-by: Stefan Buehler <stbuehler@web.de>
Signed-off-by: Matt Carlson <mcarlson@broadcom.com>
Signed-off-by: Michael Chan <mchan@broadcom.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | drivers/net/tg3.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/drivers/net/tg3.c b/drivers/net/tg3.c index c26011eaa2be..ada1d0d11045 100644 --- a/drivers/net/tg3.c +++ b/drivers/net/tg3.c | |||
@@ -8466,6 +8466,11 @@ static inline unsigned long get_stat64(tg3_stat64_t *val) | |||
8466 | return ret; | 8466 | return ret; |
8467 | } | 8467 | } |
8468 | 8468 | ||
8469 | static inline u64 get_estat64(tg3_stat64_t *val) | ||
8470 | { | ||
8471 | return ((u64)val->high << 32) | ((u64)val->low); | ||
8472 | } | ||
8473 | |||
8469 | static unsigned long calc_crc_errors(struct tg3 *tp) | 8474 | static unsigned long calc_crc_errors(struct tg3 *tp) |
8470 | { | 8475 | { |
8471 | struct tg3_hw_stats *hw_stats = tp->hw_stats; | 8476 | struct tg3_hw_stats *hw_stats = tp->hw_stats; |
@@ -8494,7 +8499,7 @@ static unsigned long calc_crc_errors(struct tg3 *tp) | |||
8494 | 8499 | ||
8495 | #define ESTAT_ADD(member) \ | 8500 | #define ESTAT_ADD(member) \ |
8496 | estats->member = old_estats->member + \ | 8501 | estats->member = old_estats->member + \ |
8497 | get_stat64(&hw_stats->member) | 8502 | get_estat64(&hw_stats->member) |
8498 | 8503 | ||
8499 | static struct tg3_ethtool_stats *tg3_get_estats(struct tg3 *tp) | 8504 | static struct tg3_ethtool_stats *tg3_get_estats(struct tg3 *tp) |
8500 | { | 8505 | { |