Skip to content

Commit 20c1d28

Browse files
Vasundhara Volamdavem330
authored andcommitted
bnxt_en: Display function level rx/tx_discard_pkts via ethtool
Add counters to display sum of rx/tx_discard_pkts of all rings as function level statistics via ethtool. Signed-off-by: Vasundhara Volam <vasundhara-v.volam@broadcom.com> Signed-off-by: Michael Chan <michael.chan@broadcom.com> Signed-off-by: David S. Miller <davem@davemloft.net>
1 parent 2727c88 commit 20c1d28

File tree

1 file changed

+33
-0
lines changed

1 file changed

+33
-0
lines changed

drivers/net/ethernet/broadcom/bnxt/bnxt_ethtool.c

Lines changed: 33 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -140,6 +140,19 @@ static int bnxt_set_coalesce(struct net_device *dev,
140140
#define BNXT_RX_STATS_EXT_ENTRY(counter) \
141141
{ BNXT_RX_STATS_EXT_OFFSET(counter), __stringify(counter) }
142142

143+
enum {
144+
RX_TOTAL_DISCARDS,
145+
TX_TOTAL_DISCARDS,
146+
};
147+
148+
static struct {
149+
u64 counter;
150+
char string[ETH_GSTRING_LEN];
151+
} bnxt_sw_func_stats[] = {
152+
{0, "rx_total_discard_pkts"},
153+
{0, "tx_total_discard_pkts"},
154+
};
155+
143156
static const struct {
144157
long offset;
145158
char string[ETH_GSTRING_LEN];
@@ -237,13 +250,16 @@ static const struct {
237250
BNXT_RX_STATS_EXT_ENTRY(resume_roce_pause_events),
238251
};
239252

253+
#define BNXT_NUM_SW_FUNC_STATS ARRAY_SIZE(bnxt_sw_func_stats)
240254
#define BNXT_NUM_PORT_STATS ARRAY_SIZE(bnxt_port_stats_arr)
241255
#define BNXT_NUM_PORT_STATS_EXT ARRAY_SIZE(bnxt_port_stats_ext_arr)
242256

243257
static int bnxt_get_num_stats(struct bnxt *bp)
244258
{
245259
int num_stats = BNXT_NUM_STATS * bp->cp_nr_rings;
246260

261+
num_stats += BNXT_NUM_SW_FUNC_STATS;
262+
247263
if (bp->flags & BNXT_FLAG_PORT_STATS)
248264
num_stats += BNXT_NUM_PORT_STATS;
249265

@@ -279,6 +295,9 @@ static void bnxt_get_ethtool_stats(struct net_device *dev,
279295
if (!bp->bnapi)
280296
return;
281297

298+
for (i = 0; i < BNXT_NUM_SW_FUNC_STATS; i++)
299+
bnxt_sw_func_stats[i].counter = 0;
300+
282301
for (i = 0; i < bp->cp_nr_rings; i++) {
283302
struct bnxt_napi *bnapi = bp->bnapi[i];
284303
struct bnxt_cp_ring_info *cpr = &bnapi->cp_ring;
@@ -288,7 +307,16 @@ static void bnxt_get_ethtool_stats(struct net_device *dev,
288307
for (k = 0; k < stat_fields; j++, k++)
289308
buf[j] = le64_to_cpu(hw_stats[k]);
290309
buf[j++] = cpr->rx_l4_csum_errors;
310+
311+
bnxt_sw_func_stats[RX_TOTAL_DISCARDS].counter +=
312+
le64_to_cpu(cpr->hw_stats->rx_discard_pkts);
313+
bnxt_sw_func_stats[TX_TOTAL_DISCARDS].counter +=
314+
le64_to_cpu(cpr->hw_stats->tx_discard_pkts);
291315
}
316+
317+
for (i = 0; i < BNXT_NUM_SW_FUNC_STATS; i++, j++)
318+
buf[j] = bnxt_sw_func_stats[i].counter;
319+
292320
if (bp->flags & BNXT_FLAG_PORT_STATS) {
293321
__le64 *port_stats = (__le64 *)bp->hw_rx_port_stats;
294322

@@ -359,6 +387,11 @@ static void bnxt_get_strings(struct net_device *dev, u32 stringset, u8 *buf)
359387
sprintf(buf, "[%d]: rx_l4_csum_errors", i);
360388
buf += ETH_GSTRING_LEN;
361389
}
390+
for (i = 0; i < BNXT_NUM_SW_FUNC_STATS; i++) {
391+
strcpy(buf, bnxt_sw_func_stats[i].string);
392+
buf += ETH_GSTRING_LEN;
393+
}
394+
362395
if (bp->flags & BNXT_FLAG_PORT_STATS) {
363396
for (i = 0; i < BNXT_NUM_PORT_STATS; i++) {
364397
strcpy(buf, bnxt_port_stats_arr[i].string);

0 commit comments

Comments
 (0)