aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorVladislav Zolotarov <vladz@broadcom.com>2010-04-18 21:14:07 -0400
committerDavid S. Miller <davem@davemloft.net>2010-04-19 16:17:09 -0400
commitdea7aab1923a9ee81c5cafaa4bd47266abf30186 (patch)
treef708fc0530d507aa78fde5c9ae23cb2805aa53a1 /drivers
parentcdaa7cb84b63e0491582ef62fd0c7bf22a57e519 (diff)
bnx2x: Added new statistics
Added total_mcast/bcast_pkts_transmitted statistics. Author: Dmitry Kravkov <dmitry@broadcom.com> Signed-off-by: Dmitry Kravkov <dmitry@broadcom.com> Signed-off-by: Vladislav Zolotarov <vladz@broadcom.com> Signed-off-by: Eilon Greenstein <eilong@broadcom.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/net/bnx2x.h4
-rw-r--r--drivers/net/bnx2x_main.c118
2 files changed, 76 insertions, 46 deletions
diff --git a/drivers/net/bnx2x.h b/drivers/net/bnx2x.h
index bdfe084b8abe..ceb8a42b945c 100644
--- a/drivers/net/bnx2x.h
+++ b/drivers/net/bnx2x.h
@@ -272,7 +272,7 @@ struct bnx2x_eth_q_stats {
272 u32 hw_csum_err; 272 u32 hw_csum_err;
273}; 273};
274 274
275#define BNX2X_NUM_Q_STATS 11 275#define BNX2X_NUM_Q_STATS 13
276#define Q_STATS_OFFSET32(stat_name) \ 276#define Q_STATS_OFFSET32(stat_name) \
277 (offsetof(struct bnx2x_eth_q_stats, stat_name) / 4) 277 (offsetof(struct bnx2x_eth_q_stats, stat_name) / 4)
278 278
@@ -778,7 +778,7 @@ struct bnx2x_eth_stats {
778 u32 nig_timer_max; 778 u32 nig_timer_max;
779}; 779};
780 780
781#define BNX2X_NUM_STATS 41 781#define BNX2X_NUM_STATS 43
782#define STATS_OFFSET32(stat_name) \ 782#define STATS_OFFSET32(stat_name) \
783 (offsetof(struct bnx2x_eth_stats, stat_name) / 4) 783 (offsetof(struct bnx2x_eth_stats, stat_name) / 4)
784 784
diff --git a/drivers/net/bnx2x_main.c b/drivers/net/bnx2x_main.c
index d91a269161d6..ad440c8616a5 100644
--- a/drivers/net/bnx2x_main.c
+++ b/drivers/net/bnx2x_main.c
@@ -3568,7 +3568,6 @@ static void bnx2x_sp_task(struct work_struct *work)
3568 struct bnx2x *bp = container_of(work, struct bnx2x, sp_task.work); 3568 struct bnx2x *bp = container_of(work, struct bnx2x, sp_task.work);
3569 u16 status; 3569 u16 status;
3570 3570
3571
3572 /* Return here if interrupt is disabled */ 3571 /* Return here if interrupt is disabled */
3573 if (unlikely(atomic_read(&bp->intr_sem) != 0)) { 3572 if (unlikely(atomic_read(&bp->intr_sem) != 0)) {
3574 DP(NETIF_MSG_INTR, "called but intr_sem not 0, returning\n"); 3573 DP(NETIF_MSG_INTR, "called but intr_sem not 0, returning\n");
@@ -4425,6 +4424,21 @@ static int bnx2x_storm_stats_update(struct bnx2x *bp)
4425 qstats->total_bytes_received_lo, 4424 qstats->total_bytes_received_lo,
4426 le32_to_cpu(tclient->rcv_unicast_bytes.lo)); 4425 le32_to_cpu(tclient->rcv_unicast_bytes.lo));
4427 4426
4427 SUB_64(qstats->total_bytes_received_hi,
4428 le32_to_cpu(uclient->bcast_no_buff_bytes.hi),
4429 qstats->total_bytes_received_lo,
4430 le32_to_cpu(uclient->bcast_no_buff_bytes.lo));
4431
4432 SUB_64(qstats->total_bytes_received_hi,
4433 le32_to_cpu(uclient->mcast_no_buff_bytes.hi),
4434 qstats->total_bytes_received_lo,
4435 le32_to_cpu(uclient->mcast_no_buff_bytes.lo));
4436
4437 SUB_64(qstats->total_bytes_received_hi,
4438 le32_to_cpu(uclient->ucast_no_buff_bytes.hi),
4439 qstats->total_bytes_received_lo,
4440 le32_to_cpu(uclient->ucast_no_buff_bytes.lo));
4441
4428 qstats->valid_bytes_received_hi = 4442 qstats->valid_bytes_received_hi =
4429 qstats->total_bytes_received_hi; 4443 qstats->total_bytes_received_hi;
4430 qstats->valid_bytes_received_lo = 4444 qstats->valid_bytes_received_lo =
@@ -4673,47 +4687,43 @@ static void bnx2x_stats_update(struct bnx2x *bp)
4673 bnx2x_drv_stats_update(bp); 4687 bnx2x_drv_stats_update(bp);
4674 4688
4675 if (netif_msg_timer(bp)) { 4689 if (netif_msg_timer(bp)) {
4676 struct bnx2x_fastpath *fp0_rx = bp->fp;
4677 struct bnx2x_fastpath *fp0_tx = bp->fp;
4678 struct tstorm_per_client_stats *old_tclient =
4679 &bp->fp->old_tclient;
4680 struct bnx2x_eth_q_stats *qstats = &bp->fp->eth_q_stats;
4681 struct bnx2x_eth_stats *estats = &bp->eth_stats; 4690 struct bnx2x_eth_stats *estats = &bp->eth_stats;
4682 struct net_device_stats *nstats = &bp->dev->stats;
4683 int i; 4691 int i;
4684 4692
4685 netdev_printk(KERN_DEBUG, bp->dev, "\n"); 4693 printk(KERN_DEBUG "%s: brb drops %u brb truncate %u\n",
4686 printk(KERN_DEBUG " tx avail (%4x) tx hc idx (%x)" 4694 bp->dev->name,
4687 " tx pkt (%lx)\n",
4688 bnx2x_tx_avail(fp0_tx),
4689 le16_to_cpu(*fp0_tx->tx_cons_sb), nstats->tx_packets);
4690 printk(KERN_DEBUG " rx usage (%4x) rx hc idx (%x)"
4691 " rx pkt (%lx)\n",
4692 (u16)(le16_to_cpu(*fp0_rx->rx_cons_sb) -
4693 fp0_rx->rx_comp_cons),
4694 le16_to_cpu(*fp0_rx->rx_cons_sb), nstats->rx_packets);
4695 printk(KERN_DEBUG " %s (Xoff events %u) brb drops %u "
4696 "brb truncate %u\n",
4697 (netif_queue_stopped(bp->dev) ? "Xoff" : "Xon"),
4698 qstats->driver_xoff,
4699 estats->brb_drop_lo, estats->brb_truncate_lo); 4695 estats->brb_drop_lo, estats->brb_truncate_lo);
4700 printk(KERN_DEBUG "tstats: checksum_discard %u "
4701 "packets_too_big_discard %lu no_buff_discard %lu "
4702 "mac_discard %u mac_filter_discard %u "
4703 "xxovrflow_discard %u brb_truncate_discard %u "
4704 "ttl0_discard %u\n",
4705 le32_to_cpu(old_tclient->checksum_discard),
4706 bnx2x_hilo(&qstats->etherstatsoverrsizepkts_hi),
4707 bnx2x_hilo(&qstats->no_buff_discard_hi),
4708 estats->mac_discard, estats->mac_filter_discard,
4709 estats->xxoverflow_discard, estats->brb_truncate_discard,
4710 le32_to_cpu(old_tclient->ttl0_discard));
4711 4696
4712 for_each_queue(bp, i) { 4697 for_each_queue(bp, i) {
4713 printk(KERN_DEBUG "[%d]: %lu\t%lu\t%lu\n", i, 4698 struct bnx2x_fastpath *fp = &bp->fp[i];
4714 bnx2x_fp(bp, i, tx_pkt), 4699 struct bnx2x_eth_q_stats *qstats = &fp->eth_q_stats;
4715 bnx2x_fp(bp, i, rx_pkt), 4700
4716 bnx2x_fp(bp, i, rx_calls)); 4701 printk(KERN_DEBUG "%s: rx usage(%4u) *rx_cons_sb(%u)"
4702 " rx pkt(%lu) rx calls(%lu %lu)\n",
4703 fp->name, (le16_to_cpu(*fp->rx_cons_sb) -
4704 fp->rx_comp_cons),
4705 le16_to_cpu(*fp->rx_cons_sb),
4706 bnx2x_hilo(&qstats->
4707 total_unicast_packets_received_hi),
4708 fp->rx_calls, fp->rx_pkt);
4709 }
4710
4711 for_each_queue(bp, i) {
4712 struct bnx2x_fastpath *fp = &bp->fp[i];
4713 struct bnx2x_eth_q_stats *qstats = &fp->eth_q_stats;
4714 struct netdev_queue *txq =
4715 netdev_get_tx_queue(bp->dev, i);
4716
4717 printk(KERN_DEBUG "%s: tx avail(%4u) *tx_cons_sb(%u)"
4718 " tx pkt(%lu) tx calls (%lu)"
4719 " %s (Xoff events %u)\n",
4720 fp->name, bnx2x_tx_avail(fp),
4721 le16_to_cpu(*fp->tx_cons_sb),
4722 bnx2x_hilo(&qstats->
4723 total_unicast_packets_transmitted_hi),
4724 fp->tx_pkt,
4725 (netif_tx_queue_stopped(txq) ? "Xoff" : "Xon"),
4726 qstats->driver_xoff);
4717 } 4727 }
4718 } 4728 }
4719 4729
@@ -11558,7 +11568,11 @@ static const struct {
11558 11568
11559/* 10 */{ Q_STATS_OFFSET32(total_bytes_transmitted_hi), 8, "[%d]: tx_bytes" }, 11569/* 10 */{ Q_STATS_OFFSET32(total_bytes_transmitted_hi), 8, "[%d]: tx_bytes" },
11560 { Q_STATS_OFFSET32(total_unicast_packets_transmitted_hi), 11570 { Q_STATS_OFFSET32(total_unicast_packets_transmitted_hi),
11561 8, "[%d]: tx_packets" } 11571 8, "[%d]: tx_ucast_packets" },
11572 { Q_STATS_OFFSET32(total_multicast_packets_transmitted_hi),
11573 8, "[%d]: tx_mcast_packets" },
11574 { Q_STATS_OFFSET32(total_broadcast_packets_transmitted_hi),
11575 8, "[%d]: tx_bcast_packets" }
11562}; 11576};
11563 11577
11564static const struct { 11578static const struct {
@@ -11620,16 +11634,20 @@ static const struct {
11620 { STATS_OFFSET32(tx_stat_ifhcoutbadoctets_hi), 11634 { STATS_OFFSET32(tx_stat_ifhcoutbadoctets_hi),
11621 8, STATS_FLAGS_PORT, "tx_error_bytes" }, 11635 8, STATS_FLAGS_PORT, "tx_error_bytes" },
11622 { STATS_OFFSET32(total_unicast_packets_transmitted_hi), 11636 { STATS_OFFSET32(total_unicast_packets_transmitted_hi),
11623 8, STATS_FLAGS_BOTH, "tx_packets" }, 11637 8, STATS_FLAGS_BOTH, "tx_ucast_packets" },
11638 { STATS_OFFSET32(total_multicast_packets_transmitted_hi),
11639 8, STATS_FLAGS_BOTH, "tx_mcast_packets" },
11640 { STATS_OFFSET32(total_broadcast_packets_transmitted_hi),
11641 8, STATS_FLAGS_BOTH, "tx_bcast_packets" },
11624 { STATS_OFFSET32(tx_stat_dot3statsinternalmactransmiterrors_hi), 11642 { STATS_OFFSET32(tx_stat_dot3statsinternalmactransmiterrors_hi),
11625 8, STATS_FLAGS_PORT, "tx_mac_errors" }, 11643 8, STATS_FLAGS_PORT, "tx_mac_errors" },
11626 { STATS_OFFSET32(rx_stat_dot3statscarriersenseerrors_hi), 11644 { STATS_OFFSET32(rx_stat_dot3statscarriersenseerrors_hi),
11627 8, STATS_FLAGS_PORT, "tx_carrier_errors" }, 11645 8, STATS_FLAGS_PORT, "tx_carrier_errors" },
11628 { STATS_OFFSET32(tx_stat_dot3statssinglecollisionframes_hi), 11646/* 30 */{ STATS_OFFSET32(tx_stat_dot3statssinglecollisionframes_hi),
11629 8, STATS_FLAGS_PORT, "tx_single_collisions" }, 11647 8, STATS_FLAGS_PORT, "tx_single_collisions" },
11630 { STATS_OFFSET32(tx_stat_dot3statsmultiplecollisionframes_hi), 11648 { STATS_OFFSET32(tx_stat_dot3statsmultiplecollisionframes_hi),
11631 8, STATS_FLAGS_PORT, "tx_multi_collisions" }, 11649 8, STATS_FLAGS_PORT, "tx_multi_collisions" },
11632/* 30 */{ STATS_OFFSET32(tx_stat_dot3statsdeferredtransmissions_hi), 11650 { STATS_OFFSET32(tx_stat_dot3statsdeferredtransmissions_hi),
11633 8, STATS_FLAGS_PORT, "tx_deferred" }, 11651 8, STATS_FLAGS_PORT, "tx_deferred" },
11634 { STATS_OFFSET32(tx_stat_dot3statsexcessivecollisions_hi), 11652 { STATS_OFFSET32(tx_stat_dot3statsexcessivecollisions_hi),
11635 8, STATS_FLAGS_PORT, "tx_excess_collisions" }, 11653 8, STATS_FLAGS_PORT, "tx_excess_collisions" },
@@ -11645,11 +11663,11 @@ static const struct {
11645 8, STATS_FLAGS_PORT, "tx_128_to_255_byte_packets" }, 11663 8, STATS_FLAGS_PORT, "tx_128_to_255_byte_packets" },
11646 { STATS_OFFSET32(tx_stat_etherstatspkts256octetsto511octets_hi), 11664 { STATS_OFFSET32(tx_stat_etherstatspkts256octetsto511octets_hi),
11647 8, STATS_FLAGS_PORT, "tx_256_to_511_byte_packets" }, 11665 8, STATS_FLAGS_PORT, "tx_256_to_511_byte_packets" },
11648 { STATS_OFFSET32(tx_stat_etherstatspkts512octetsto1023octets_hi), 11666/* 40 */{ STATS_OFFSET32(tx_stat_etherstatspkts512octetsto1023octets_hi),
11649 8, STATS_FLAGS_PORT, "tx_512_to_1023_byte_packets" }, 11667 8, STATS_FLAGS_PORT, "tx_512_to_1023_byte_packets" },
11650 { STATS_OFFSET32(etherstatspkts1024octetsto1522octets_hi), 11668 { STATS_OFFSET32(etherstatspkts1024octetsto1522octets_hi),
11651 8, STATS_FLAGS_PORT, "tx_1024_to_1522_byte_packets" }, 11669 8, STATS_FLAGS_PORT, "tx_1024_to_1522_byte_packets" },
11652/* 40 */{ STATS_OFFSET32(etherstatspktsover1522octets_hi), 11670 { STATS_OFFSET32(etherstatspktsover1522octets_hi),
11653 8, STATS_FLAGS_PORT, "tx_1523_to_9022_byte_packets" }, 11671 8, STATS_FLAGS_PORT, "tx_1523_to_9022_byte_packets" },
11654 { STATS_OFFSET32(pause_frames_sent_hi), 11672 { STATS_OFFSET32(pause_frames_sent_hi),
11655 8, STATS_FLAGS_PORT, "tx_pause_frames" } 11673 8, STATS_FLAGS_PORT, "tx_pause_frames" }
@@ -12184,6 +12202,8 @@ static netdev_tx_t bnx2x_start_xmit(struct sk_buff *skb, struct net_device *dev)
12184 int i; 12202 int i;
12185 u8 hlen = 0; 12203 u8 hlen = 0;
12186 __le16 pkt_size = 0; 12204 __le16 pkt_size = 0;
12205 struct ethhdr *eth;
12206 u8 mac_type = UNICAST_ADDRESS;
12187 12207
12188#ifdef BNX2X_STOP_ON_ERROR 12208#ifdef BNX2X_STOP_ON_ERROR
12189 if (unlikely(bp->panic)) 12209 if (unlikely(bp->panic))
@@ -12207,6 +12227,16 @@ static netdev_tx_t bnx2x_start_xmit(struct sk_buff *skb, struct net_device *dev)
12207 skb->ip_summed, skb->protocol, ipv6_hdr(skb)->nexthdr, 12227 skb->ip_summed, skb->protocol, ipv6_hdr(skb)->nexthdr,
12208 ip_hdr(skb)->protocol, skb_shinfo(skb)->gso_type, xmit_type); 12228 ip_hdr(skb)->protocol, skb_shinfo(skb)->gso_type, xmit_type);
12209 12229
12230 eth = (struct ethhdr *)skb->data;
12231
12232 /* set flag according to packet type (UNICAST_ADDRESS is default)*/
12233 if (unlikely(is_multicast_ether_addr(eth->h_dest))) {
12234 if (is_broadcast_ether_addr(eth->h_dest))
12235 mac_type = BROADCAST_ADDRESS;
12236 else
12237 mac_type = MULTICAST_ADDRESS;
12238 }
12239
12210#if (MAX_SKB_FRAGS >= MAX_FETCH_BD - 3) 12240#if (MAX_SKB_FRAGS >= MAX_FETCH_BD - 3)
12211 /* First, check if we need to linearize the skb (due to FW 12241 /* First, check if we need to linearize the skb (due to FW
12212 restrictions). No need to check fragmentation if page size > 8K 12242 restrictions). No need to check fragmentation if page size > 8K
@@ -12240,8 +12270,8 @@ static netdev_tx_t bnx2x_start_xmit(struct sk_buff *skb, struct net_device *dev)
12240 tx_start_bd = &fp->tx_desc_ring[bd_prod].start_bd; 12270 tx_start_bd = &fp->tx_desc_ring[bd_prod].start_bd;
12241 12271
12242 tx_start_bd->bd_flags.as_bitfield = ETH_TX_BD_FLAGS_START_BD; 12272 tx_start_bd->bd_flags.as_bitfield = ETH_TX_BD_FLAGS_START_BD;
12243 tx_start_bd->general_data = (UNICAST_ADDRESS << 12273 tx_start_bd->general_data = (mac_type <<
12244 ETH_TX_START_BD_ETH_ADDR_TYPE_SHIFT); 12274 ETH_TX_START_BD_ETH_ADDR_TYPE_SHIFT);
12245 /* header nbd */ 12275 /* header nbd */
12246 tx_start_bd->general_data |= (1 << ETH_TX_START_BD_HDR_NBDS_SHIFT); 12276 tx_start_bd->general_data |= (1 << ETH_TX_START_BD_HDR_NBDS_SHIFT);
12247 12277