return rc;
 }
 
-#define BNXT_NUM_STATS 22
+static const char * const bnxt_ring_stats_str[] = {
+       "rx_ucast_packets",
+       "rx_mcast_packets",
+       "rx_bcast_packets",
+       "rx_discards",
+       "rx_drops",
+       "rx_ucast_bytes",
+       "rx_mcast_bytes",
+       "rx_bcast_bytes",
+       "tx_ucast_packets",
+       "tx_mcast_packets",
+       "tx_bcast_packets",
+       "tx_discards",
+       "tx_drops",
+       "tx_ucast_bytes",
+       "tx_mcast_bytes",
+       "tx_bcast_bytes",
+};
+
+static const char * const bnxt_ring_tpa_stats_str[] = {
+       "tpa_packets",
+       "tpa_bytes",
+       "tpa_events",
+       "tpa_aborts",
+};
+
+static const char * const bnxt_ring_sw_stats_str[] = {
+       "rx_l4_csum_errors",
+       "missed_irqs",
+};
 
 #define BNXT_RX_STATS_ENTRY(counter)   \
        { BNXT_RX_STATS_OFFSET(counter), __stringify(counter) }
         ARRAY_SIZE(bnxt_tx_pkts_pri_arr))
 #define BNXT_NUM_PCIE_STATS ARRAY_SIZE(bnxt_pcie_stats_arr)
 
+static int bnxt_get_num_ring_stats(struct bnxt *bp)
+{
+       int num_stats;
+
+       num_stats = ARRAY_SIZE(bnxt_ring_stats_str) +
+                   ARRAY_SIZE(bnxt_ring_sw_stats_str);
+       if (BNXT_SUPPORTS_TPA(bp))
+               num_stats += ARRAY_SIZE(bnxt_ring_tpa_stats_str);
+       return num_stats * bp->cp_nr_rings;
+}
+
 static int bnxt_get_num_stats(struct bnxt *bp)
 {
-       int num_stats = BNXT_NUM_STATS * bp->cp_nr_rings;
+       int num_stats = bnxt_get_num_ring_stats(bp);
 
        num_stats += BNXT_NUM_SW_FUNC_STATS;
 
 {
        u32 i, j = 0;
        struct bnxt *bp = netdev_priv(dev);
-       u32 stat_fields = sizeof(struct ctx_hw_stats) / 8;
+       u32 stat_fields = ARRAY_SIZE(bnxt_ring_stats_str);
+
+       if (BNXT_SUPPORTS_TPA(bp))
+               stat_fields += ARRAY_SIZE(bnxt_ring_tpa_stats_str);
 
        if (!bp->bnapi) {
-               j += BNXT_NUM_STATS * bp->cp_nr_rings + BNXT_NUM_SW_FUNC_STATS;
+               j += bnxt_get_num_ring_stats(bp) + BNXT_NUM_SW_FUNC_STATS;
                goto skip_ring_stats;
        }
 
 static void bnxt_get_strings(struct net_device *dev, u32 stringset, u8 *buf)
 {
        struct bnxt *bp = netdev_priv(dev);
-       u32 i;
+       u32 i, j, num_str;
 
        switch (stringset) {
-       /* The number of strings must match BNXT_NUM_STATS defined above. */
        case ETH_SS_STATS:
                for (i = 0; i < bp->cp_nr_rings; i++) {
-                       sprintf(buf, "[%d]: rx_ucast_packets", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: rx_mcast_packets", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: rx_bcast_packets", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: rx_discards", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: rx_drops", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: rx_ucast_bytes", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: rx_mcast_bytes", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: rx_bcast_bytes", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: tx_ucast_packets", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: tx_mcast_packets", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: tx_bcast_packets", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: tx_discards", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: tx_drops", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: tx_ucast_bytes", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: tx_mcast_bytes", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: tx_bcast_bytes", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: tpa_packets", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: tpa_bytes", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: tpa_events", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: tpa_aborts", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: rx_l4_csum_errors", i);
-                       buf += ETH_GSTRING_LEN;
-                       sprintf(buf, "[%d]: missed_irqs", i);
-                       buf += ETH_GSTRING_LEN;
+                       num_str = ARRAY_SIZE(bnxt_ring_stats_str);
+                       for (j = 0; j < num_str; j++) {
+                               sprintf(buf, "[%d]: %s", i,
+                                       bnxt_ring_stats_str[j]);
+                               buf += ETH_GSTRING_LEN;
+                       }
+                       if (!BNXT_SUPPORTS_TPA(bp))
+                               goto skip_tpa_stats;
+
+                       num_str = ARRAY_SIZE(bnxt_ring_tpa_stats_str);
+                       for (j = 0; j < num_str; j++) {
+                               sprintf(buf, "[%d]: %s", i,
+                                       bnxt_ring_tpa_stats_str[j]);
+                               buf += ETH_GSTRING_LEN;
+                       }
+skip_tpa_stats:
+                       num_str = ARRAY_SIZE(bnxt_ring_sw_stats_str);
+                       for (j = 0; j < num_str; j++) {
+                               sprintf(buf, "[%d]: %s", i,
+                                       bnxt_ring_sw_stats_str[j]);
+                               buf += ETH_GSTRING_LEN;
+                       }
                }
                for (i = 0; i < BNXT_NUM_SW_FUNC_STATS; i++) {
                        strcpy(buf, bnxt_sw_func_stats[i].string);