Re: [PATCH] drivers/net/pch_gbe: Cleanup stats use
From: Joe Perches
Date: Tue Aug 31 2010 - 14:38:42 EST
Use c90 initializers
Use memset
Use FIELD_SIZEOF
Remove stat_ from struct pch_gbe_stats members
Save offset from start of struct pch_gbe_hw_stats
All stat members are u64, so maybe the size field can be removed
Signed-off-by: Joe Perches <joe@xxxxxxxxxxx>
---
drivers/net/pch_gbe/pch_gbe_ethtool.c | 32 +++++++++++++++++---------------
drivers/net/pch_gbe/pch_gbe_main.c | 28 +---------------------------
2 files changed, 18 insertions(+), 42 deletions(-)
diff --git a/drivers/net/pch_gbe/pch_gbe_ethtool.c b/drivers/net/pch_gbe/pch_gbe_ethtool.c
index 25b9357..f61b314 100644
--- a/drivers/net/pch_gbe/pch_gbe_ethtool.c
+++ b/drivers/net/pch_gbe/pch_gbe_ethtool.c
@@ -31,13 +31,18 @@
* pch_gbe_stats - Stats item infomation
*/
struct pch_gbe_stats {
- signed char stat_string[ETH_GSTRING_LEN];
- int sizeof_stat;
- int stat_offset;
+ signed char string[ETH_GSTRING_LEN];
+ size_t size;
+ size_t offset;
};
-#define PCH_GBE_STAT(m) {#m,\
- sizeof(((struct pch_gbe_adapter *)0)->stats.m),\
- offsetof(struct pch_gbe_adapter, stats.m)}
+
+#define PCH_GBE_STAT(m) \
+{ \
+ .string = #m, \
+ .size = FIELD_SIZEOF(struct pch_gbe_hw_stats, m), \
+ .offset = offsetof(struct pch_gbe_hw_stats, m), \
+}
+
/**
* pch_gbe_gstrings_stats - ethtool information status name list
*/
@@ -545,7 +550,7 @@ static void pch_gbe_get_strings(struct net_device *netdev, u32 stringset,
switch (stringset) {
case (u32) ETH_SS_STATS:
for (i = 0; i < PCH_GBE_GLOBAL_STATS_LEN; i++) {
- memcpy(p, pch_gbe_gstrings_stats[i].stat_string,
+ memcpy(p, pch_gbe_gstrings_stats[i].string,
ETH_GSTRING_LEN);
p += ETH_GSTRING_LEN;
}
@@ -564,16 +569,15 @@ static void pch_gbe_get_ethtool_stats(struct net_device *netdev,
{
struct pch_gbe_adapter *adapter = netdev_priv(netdev);
int i;
+ const struct pch_gbe_stats *gstats = pch_gbe_gstrings_stats;
+ char *hw_stats = (char *)&adapter->stats;
FUNC_ENTER();
pch_gbe_update_stats(adapter);
for (i = 0; i < PCH_GBE_GLOBAL_STATS_LEN; i++) {
- signed char *p =
- (signed char *)adapter +
- pch_gbe_gstrings_stats[i].stat_offset;
- data[i] =
- (pch_gbe_gstrings_stats[i].sizeof_stat ==
- (int)sizeof(u64)) ? *(u64 *) p:(*(u32 *) p);
+ char *p = hw_stats + gstats->offset;
+ data[i] = gstats->size == sizeof(u64) ? *(u64 *)p : *(u32 *)p;
+ gstats++;
}
}
@@ -614,5 +618,3 @@ void pch_gbe_set_ethtool_ops(struct net_device *netdev)
{
SET_ETHTOOL_OPS(netdev, &pch_gbe_ethtool_ops);
}
-
-
diff --git a/drivers/net/pch_gbe/pch_gbe_main.c b/drivers/net/pch_gbe/pch_gbe_main.c
index 8195702..c35ad57 100644
--- a/drivers/net/pch_gbe/pch_gbe_main.c
+++ b/drivers/net/pch_gbe/pch_gbe_main.c
@@ -438,34 +438,8 @@ static int pch_gbe_alloc_queues(struct pch_gbe_adapter *adapter)
*/
static void pch_gbe_init_stats(struct pch_gbe_adapter *adapter)
{
- struct pch_gbe_hw_stats *stats = &adapter->stats;
-
FUNC_ENTER();
- stats->rx_packets = 0;
- stats->tx_packets = 0;
- stats->rx_bytes = 0;
- stats->tx_bytes = 0;
- stats->rx_errors = 0;
- stats->tx_errors = 0;
- stats->rx_dropped = 0;
- stats->tx_dropped = 0;
- stats->multicast = 0;
- stats->collisions = 0;
- stats->rx_crc_errors = 0;
- stats->rx_frame_errors = 0;
- stats->rx_alloc_buff_failed = 0;
- stats->tx_length_errors = 0;
- stats->tx_aborted_errors = 0;
- stats->tx_carrier_errors = 0;
- stats->tx_timeout_count = 0;
- stats->tx_restart_count = 0;
- stats->intr_rx_dsc_empty_count = 0;
- stats->intr_rx_frame_err_count = 0;
- stats->intr_rx_fifo_err_count = 0;
- stats->intr_rx_dma_err_count = 0;
- stats->intr_tx_fifo_err_count = 0;
- stats->intr_tx_dma_err_count = 0;
- stats->intr_tcpip_err_count = 0;
+ memset(&adapter->stats, 0, sizeof(adapter->stats));
return;
}
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/