aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorYuval Mintz <yuvalmin@broadcom.com>2012-01-23 02:31:52 -0500
committerDavid S. Miller <davem@davemloft.net>2012-01-23 13:58:18 -0500
commitd5e836329bd836d24b168004827532426cad2f39 (patch)
treed839753a9d3d364f27e23b43ab0e7f07cb4de378
parent460a25cdaef1a2b6b8e14e371d868aa91b0e72e8 (diff)
bnx2x: fixed ethtool statistics for MF modes
Previosuly, in MF modes `ethtool -S' lacked some of the statistics which appeared in non-MF modes. This has been fixed. Signed-off-by: Yuval Mintz <yuvalmin@broadcom.com> Signed-off-by: Eilon Greenstein <eilong@broadcom.com> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--drivers/net/ethernet/broadcom/bnx2x/bnx2x_ethtool.c106
1 files changed, 41 insertions, 65 deletions
diff --git a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_ethtool.c b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_ethtool.c
index f99c6e312a5d..7d32e0059966 100644
--- a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_ethtool.c
+++ b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_ethtool.c
@@ -2121,18 +2121,16 @@ static int bnx2x_get_sset_count(struct net_device *dev, int stringset)
2121 case ETH_SS_STATS: 2121 case ETH_SS_STATS:
2122 if (is_multi(bp)) { 2122 if (is_multi(bp)) {
2123 num_stats = bnx2x_num_stat_queues(bp) * 2123 num_stats = bnx2x_num_stat_queues(bp) *
2124 BNX2X_NUM_Q_STATS; 2124 BNX2X_NUM_Q_STATS;
2125 if (!IS_MF_MODE_STAT(bp)) 2125 } else
2126 num_stats += BNX2X_NUM_STATS; 2126 num_stats = 0;
2127 } else { 2127 if (IS_MF_MODE_STAT(bp)) {
2128 if (IS_MF_MODE_STAT(bp)) { 2128 for (i = 0; i < BNX2X_NUM_STATS; i++)
2129 num_stats = 0; 2129 if (IS_FUNC_STAT(i))
2130 for (i = 0; i < BNX2X_NUM_STATS; i++) 2130 num_stats++;
2131 if (IS_FUNC_STAT(i)) 2131 } else
2132 num_stats++; 2132 num_stats += BNX2X_NUM_STATS;
2133 } else 2133
2134 num_stats = BNX2X_NUM_STATS;
2135 }
2136 return num_stats; 2134 return num_stats;
2137 2135
2138 case ETH_SS_TEST: 2136 case ETH_SS_TEST:
@@ -2151,8 +2149,8 @@ static void bnx2x_get_strings(struct net_device *dev, u32 stringset, u8 *buf)
2151 2149
2152 switch (stringset) { 2150 switch (stringset) {
2153 case ETH_SS_STATS: 2151 case ETH_SS_STATS:
2152 k = 0;
2154 if (is_multi(bp)) { 2153 if (is_multi(bp)) {
2155 k = 0;
2156 for_each_eth_queue(bp, i) { 2154 for_each_eth_queue(bp, i) {
2157 memset(queue_name, 0, sizeof(queue_name)); 2155 memset(queue_name, 0, sizeof(queue_name));
2158 sprintf(queue_name, "%d", i); 2156 sprintf(queue_name, "%d", i);
@@ -2163,20 +2161,17 @@ static void bnx2x_get_strings(struct net_device *dev, u32 stringset, u8 *buf)
2163 queue_name); 2161 queue_name);
2164 k += BNX2X_NUM_Q_STATS; 2162 k += BNX2X_NUM_Q_STATS;
2165 } 2163 }
2166 if (IS_MF_MODE_STAT(bp))
2167 break;
2168 for (j = 0; j < BNX2X_NUM_STATS; j++)
2169 strcpy(buf + (k + j)*ETH_GSTRING_LEN,
2170 bnx2x_stats_arr[j].string);
2171 } else {
2172 for (i = 0, j = 0; i < BNX2X_NUM_STATS; i++) {
2173 if (IS_MF_MODE_STAT(bp) && IS_PORT_STAT(i))
2174 continue;
2175 strcpy(buf + j*ETH_GSTRING_LEN,
2176 bnx2x_stats_arr[i].string);
2177 j++;
2178 }
2179 } 2164 }
2165
2166
2167 for (i = 0, j = 0; i < BNX2X_NUM_STATS; i++) {
2168 if (IS_MF_MODE_STAT(bp) && IS_PORT_STAT(i))
2169 continue;
2170 strcpy(buf + (k + j)*ETH_GSTRING_LEN,
2171 bnx2x_stats_arr[i].string);
2172 j++;
2173 }
2174
2180 break; 2175 break;
2181 2176
2182 case ETH_SS_TEST: 2177 case ETH_SS_TEST:
@@ -2190,10 +2185,9 @@ static void bnx2x_get_ethtool_stats(struct net_device *dev,
2190{ 2185{
2191 struct bnx2x *bp = netdev_priv(dev); 2186 struct bnx2x *bp = netdev_priv(dev);
2192 u32 *hw_stats, *offset; 2187 u32 *hw_stats, *offset;
2193 int i, j, k; 2188 int i, j, k = 0;
2194 2189
2195 if (is_multi(bp)) { 2190 if (is_multi(bp)) {
2196 k = 0;
2197 for_each_eth_queue(bp, i) { 2191 for_each_eth_queue(bp, i) {
2198 hw_stats = (u32 *)&bp->fp[i].eth_q_stats; 2192 hw_stats = (u32 *)&bp->fp[i].eth_q_stats;
2199 for (j = 0; j < BNX2X_NUM_Q_STATS; j++) { 2193 for (j = 0; j < BNX2X_NUM_Q_STATS; j++) {
@@ -2214,46 +2208,28 @@ static void bnx2x_get_ethtool_stats(struct net_device *dev,
2214 } 2208 }
2215 k += BNX2X_NUM_Q_STATS; 2209 k += BNX2X_NUM_Q_STATS;
2216 } 2210 }
2217 if (IS_MF_MODE_STAT(bp)) 2211 }
2218 return; 2212
2219 hw_stats = (u32 *)&bp->eth_stats; 2213 hw_stats = (u32 *)&bp->eth_stats;
2220 for (j = 0; j < BNX2X_NUM_STATS; j++) { 2214 for (i = 0, j = 0; i < BNX2X_NUM_STATS; i++) {
2221 if (bnx2x_stats_arr[j].size == 0) { 2215 if (IS_MF_MODE_STAT(bp) && IS_PORT_STAT(i))
2222 /* skip this counter */ 2216 continue;
2223 buf[k + j] = 0; 2217 if (bnx2x_stats_arr[i].size == 0) {
2224 continue; 2218 /* skip this counter */
2225 } 2219 buf[k + j] = 0;
2226 offset = (hw_stats + bnx2x_stats_arr[j].offset); 2220 j++;
2227 if (bnx2x_stats_arr[j].size == 4) { 2221 continue;
2228 /* 4-byte counter */
2229 buf[k + j] = (u64) *offset;
2230 continue;
2231 }
2232 /* 8-byte counter */
2233 buf[k + j] = HILO_U64(*offset, *(offset + 1));
2234 } 2222 }
2235 } else { 2223 offset = (hw_stats + bnx2x_stats_arr[i].offset);
2236 hw_stats = (u32 *)&bp->eth_stats; 2224 if (bnx2x_stats_arr[i].size == 4) {
2237 for (i = 0, j = 0; i < BNX2X_NUM_STATS; i++) { 2225 /* 4-byte counter */
2238 if (IS_MF_MODE_STAT(bp) && IS_PORT_STAT(i)) 2226 buf[k + j] = (u64) *offset;
2239 continue;
2240 if (bnx2x_stats_arr[i].size == 0) {
2241 /* skip this counter */
2242 buf[j] = 0;
2243 j++;
2244 continue;
2245 }
2246 offset = (hw_stats + bnx2x_stats_arr[i].offset);
2247 if (bnx2x_stats_arr[i].size == 4) {
2248 /* 4-byte counter */
2249 buf[j] = (u64) *offset;
2250 j++;
2251 continue;
2252 }
2253 /* 8-byte counter */
2254 buf[j] = HILO_U64(*offset, *(offset + 1));
2255 j++; 2227 j++;
2228 continue;
2256 } 2229 }
2230 /* 8-byte counter */
2231 buf[k + j] = HILO_U64(*offset, *(offset + 1));
2232 j++;
2257 } 2233 }
2258} 2234}
2259 2235