Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/dev/pci ixl(4) supports in-chip statistic counters per port



details:   https://anonhg.NetBSD.org/src/rev/c7ed18b778a4
branches:  trunk
changeset: 1006298:c7ed18b778a4
user:      yamaguchi <yamaguchi%NetBSD.org@localhost>
date:      Thu Jan 09 02:43:45 2020 +0000

description:
ixl(4) supports in-chip statistic counters per port

diffstat:

 sys/dev/pci/if_ixl.c |  465 ++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 463 insertions(+), 2 deletions(-)

diffs (truncated from 564 to 300 lines):

diff -r 8aba8d876a09 -r c7ed18b778a4 sys/dev/pci/if_ixl.c
--- a/sys/dev/pci/if_ixl.c      Thu Jan 09 01:38:34 2020 +0000
+++ b/sys/dev/pci/if_ixl.c      Thu Jan 09 02:43:45 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_ixl.c,v 1.16 2020/01/08 09:12:11 yamaguchi Exp $    */
+/*     $NetBSD: if_ixl.c,v 1.17 2020/01/09 02:43:45 yamaguchi Exp $    */
 
 /*
  * Copyright (c) 2013-2015, Intel Corporation
@@ -485,6 +485,82 @@
        unsigned int     product_id;
 };
 
+struct ixl_stats_counters {
+       bool             isc_has_offset;
+       struct evcnt     isc_crc_errors;
+       uint64_t         isc_crc_errors_offset;
+       struct evcnt     isc_illegal_bytes;
+       uint64_t         isc_illegal_bytes_offset;
+       struct evcnt     isc_rx_bytes;
+       uint64_t         isc_rx_bytes_offset;
+       struct evcnt     isc_rx_discards;
+       uint64_t         isc_rx_discards_offset;
+       struct evcnt     isc_rx_unicast;
+       uint64_t         isc_rx_unicast_offset;
+       struct evcnt     isc_rx_multicast;
+       uint64_t         isc_rx_multicast_offset;
+       struct evcnt     isc_rx_broadcast;
+       uint64_t         isc_rx_broadcast_offset;
+       struct evcnt     isc_rx_size_64;
+       uint64_t         isc_rx_size_64_offset;
+       struct evcnt     isc_rx_size_127;
+       uint64_t         isc_rx_size_127_offset;
+       struct evcnt     isc_rx_size_255;
+       uint64_t         isc_rx_size_255_offset;
+       struct evcnt     isc_rx_size_511;
+       uint64_t         isc_rx_size_511_offset;
+       struct evcnt     isc_rx_size_1023;
+       uint64_t         isc_rx_size_1023_offset;
+       struct evcnt     isc_rx_size_1522;
+       uint64_t         isc_rx_size_1522_offset;
+       struct evcnt     isc_rx_size_big;
+       uint64_t         isc_rx_size_big_offset;
+       struct evcnt     isc_rx_undersize;
+       uint64_t         isc_rx_undersize_offset;
+       struct evcnt     isc_rx_oversize;
+       uint64_t         isc_rx_oversize_offset;
+       struct evcnt     isc_rx_fragments;
+       uint64_t         isc_rx_fragments_offset;
+       struct evcnt     isc_rx_jabber;
+       uint64_t         isc_rx_jabber_offset;
+       struct evcnt     isc_tx_bytes;
+       uint64_t         isc_tx_bytes_offset;
+       struct evcnt     isc_tx_dropped_link_down;
+       uint64_t         isc_tx_dropped_link_down_offset;
+       struct evcnt     isc_tx_unicast;
+       uint64_t         isc_tx_unicast_offset;
+       struct evcnt     isc_tx_multicast;
+       uint64_t         isc_tx_multicast_offset;
+       struct evcnt     isc_tx_broadcast;
+       uint64_t         isc_tx_broadcast_offset;
+       struct evcnt     isc_tx_size_64;
+       uint64_t         isc_tx_size_64_offset;
+       struct evcnt     isc_tx_size_127;
+       uint64_t         isc_tx_size_127_offset;
+       struct evcnt     isc_tx_size_255;
+       uint64_t         isc_tx_size_255_offset;
+       struct evcnt     isc_tx_size_511;
+       uint64_t         isc_tx_size_511_offset;
+       struct evcnt     isc_tx_size_1023;
+       uint64_t         isc_tx_size_1023_offset;
+       struct evcnt     isc_tx_size_1522;
+       uint64_t         isc_tx_size_1522_offset;
+       struct evcnt     isc_tx_size_big;
+       uint64_t         isc_tx_size_big_offset;
+       struct evcnt     isc_mac_local_faults;
+       uint64_t         isc_mac_local_faults_offset;
+       struct evcnt     isc_mac_remote_faults;
+       uint64_t         isc_mac_remote_faults_offset;
+       struct evcnt     isc_link_xon_rx;
+       uint64_t         isc_link_xon_rx_offset;
+       struct evcnt     isc_link_xon_tx;
+       uint64_t         isc_link_xon_tx_offset;
+       struct evcnt     isc_link_xoff_rx;
+       uint64_t         isc_link_xoff_rx_offset;
+       struct evcnt     isc_link_xoff_tx;
+       uint64_t         isc_link_xoff_tx_offset;
+};
+
 /*
  * Locking notes:
  * + a field in ixl_tx_ring is protected by txr_lock (a spin mutex), and
@@ -508,9 +584,15 @@
        bool                     sc_attached;
        bool                     sc_dead;
        bool                     sc_rxctl_atq;
+       uint32_t                 sc_port;
        struct sysctllog        *sc_sysctllog;
        struct workqueue        *sc_workq;
        struct workqueue        *sc_workq_txrx;
+       int                      sc_stats_intval;
+       callout_t                sc_stats_callout;
+       struct ixl_work          sc_stats_task;
+       struct ixl_stats_counters
+                                sc_stats_counters;
        uint8_t                  sc_enaddr[ETHER_ADDR_LEN];
        struct ifmedia           sc_media;
        uint64_t                 sc_media_status;
@@ -613,6 +695,9 @@
 #define DDPRINTF(sc, fmt, args...)     __nothing
 #endif
 #define IXL_NOMSIX     false
+#ifndef IXL_STATS_INTERVAL_MSEC
+#define IXL_STATS_INTERVAL_MSEC        10000
+#endif
 
 static enum i40e_mac_type
     ixl_mactype(pci_product_id_t);
@@ -742,6 +827,8 @@
 static void    ixl_teardown_interrupts(struct ixl_softc *);
 static int     ixl_setup_stats(struct ixl_softc *);
 static void    ixl_teardown_stats(struct ixl_softc *);
+static void    ixl_stats_callout(void *);
+static void    ixl_stats_update(void *);
 static int     ixl_setup_sysctls(struct ixl_softc *);
 static void    ixl_teardown_sysctls(struct ixl_softc *);
 static int     ixl_queue_pairs_alloc(struct ixl_softc *);
@@ -973,7 +1060,8 @@
        port = ixl_rd(sc, I40E_PFGEN_PORTNUM);
        port &= I40E_PFGEN_PORTNUM_PORT_NUM_MASK;
        port >>= I40E_PFGEN_PORTNUM_PORT_NUM_SHIFT;
-       aprint_normal(": port %u", port);
+       sc->sc_port = port;
+       aprint_normal(": port %u", sc->sc_port);
 
        ari = ixl_rd(sc, I40E_GLPCI_CAPSUP);
        ari &= I40E_GLPCI_CAPSUP_ARI_EN_MASK;
@@ -1261,6 +1349,10 @@
        sc->sc_tx_intr_process_limit = IXL_TX_INTR_PROCESS_LIMIT;
        sc->sc_rx_intr_process_limit = IXL_RX_INTR_PROCESS_LIMIT;
 
+       ixl_stats_update(sc);
+       sc->sc_stats_counters.isc_has_offset = true;
+       callout_schedule(&sc->sc_stats_callout, mstohz(sc->sc_stats_intval));
+
        if (pmf_device_register(self, NULL, NULL) != true)
                aprint_debug_dev(self, "couldn't establish power handler\n");
        sc->sc_attached = true;
@@ -1328,6 +1420,9 @@
 
        ixl_disable_other_intr(sc);
 
+       callout_stop(&sc->sc_stats_callout);
+       ixl_work_wait(sc->sc_workq, &sc->sc_stats_task);
+
        /* wait for ATQ handler */
        mutex_enter(&sc->sc_atq_lock);
        mutex_exit(&sc->sc_atq_lock);
@@ -5447,6 +5542,7 @@
        struct ixl_queue_pair *qp;
        struct ixl_tx_ring *txr;
        struct ixl_rx_ring *rxr;
+       struct ixl_stats_counters *isc;
        unsigned int i;
 
        for (i = 0; i < sc->sc_nqueue_pairs_max; i++) {
@@ -5491,6 +5587,90 @@
        evcnt_attach_dynamic(&sc->sc_event_crit_err, EVCNT_TYPE_MISC,
            NULL, device_xname(sc->sc_dev), "Critical error");
 
+       isc = &sc->sc_stats_counters;
+       evcnt_attach_dynamic(&isc->isc_crc_errors, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "CRC errors");
+       evcnt_attach_dynamic(&isc->isc_illegal_bytes, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Illegal bytes");
+       evcnt_attach_dynamic(&isc->isc_mac_local_faults, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Mac local faults");
+       evcnt_attach_dynamic(&isc->isc_mac_remote_faults, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Mac remote faults");
+       evcnt_attach_dynamic(&isc->isc_link_xon_rx, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Rx xon");
+       evcnt_attach_dynamic(&isc->isc_link_xon_tx, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Tx xon");
+       evcnt_attach_dynamic(&isc->isc_link_xoff_rx, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Rx xoff");
+       evcnt_attach_dynamic(&isc->isc_link_xoff_tx, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Tx xoff");
+       evcnt_attach_dynamic(&isc->isc_rx_fragments, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Rx fragments");
+       evcnt_attach_dynamic(&isc->isc_rx_jabber, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Rx jabber");
+
+       evcnt_attach_dynamic(&isc->isc_rx_size_64, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Rx size 64");
+       evcnt_attach_dynamic(&isc->isc_rx_size_127, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Rx size 127");
+       evcnt_attach_dynamic(&isc->isc_rx_size_255, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Rx size 255");
+       evcnt_attach_dynamic(&isc->isc_rx_size_511, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Rx size 511");
+       evcnt_attach_dynamic(&isc->isc_rx_size_1023, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Rx size 1023");
+       evcnt_attach_dynamic(&isc->isc_rx_size_1522, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Rx size 1522");
+       evcnt_attach_dynamic(&isc->isc_rx_size_big, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Rx jumbo packets");
+       evcnt_attach_dynamic(&isc->isc_rx_undersize, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Rx under size");
+       evcnt_attach_dynamic(&isc->isc_rx_oversize, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Rx over size");
+
+       evcnt_attach_dynamic(&isc->isc_rx_bytes, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Rx bytes / port");
+       evcnt_attach_dynamic(&isc->isc_rx_discards, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Rx discards / port");
+       evcnt_attach_dynamic(&isc->isc_rx_unicast, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Rx unicast / port");
+       evcnt_attach_dynamic(&isc->isc_rx_multicast, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Rx multicast / port");
+       evcnt_attach_dynamic(&isc->isc_rx_broadcast, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Rx broadcast / port");
+
+       evcnt_attach_dynamic(&isc->isc_tx_size_64, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Tx size 64");
+       evcnt_attach_dynamic(&isc->isc_tx_size_127, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Tx size 127");
+       evcnt_attach_dynamic(&isc->isc_tx_size_255, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Tx size 255");
+       evcnt_attach_dynamic(&isc->isc_tx_size_511, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Tx size 511");
+       evcnt_attach_dynamic(&isc->isc_tx_size_1023, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Tx size 1023");
+       evcnt_attach_dynamic(&isc->isc_tx_size_1522, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Tx size 1522");
+       evcnt_attach_dynamic(&isc->isc_tx_size_big, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Tx jumbo packets");
+
+       evcnt_attach_dynamic(&isc->isc_tx_bytes, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Tx bytes / port");
+       evcnt_attach_dynamic(&isc->isc_tx_dropped_link_down, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev),
+           "Tx dropped due to link down / port");
+       evcnt_attach_dynamic(&isc->isc_tx_unicast, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Tx unicast / port");
+       evcnt_attach_dynamic(&isc->isc_tx_multicast, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Tx multicast / port");
+       evcnt_attach_dynamic(&isc->isc_tx_broadcast, EVCNT_TYPE_MISC,
+           NULL, device_xname(sc->sc_dev), "Tx broadcast / port");
+
+       sc->sc_stats_intval = IXL_STATS_INTERVAL_MSEC;
+       callout_init(&sc->sc_stats_callout, CALLOUT_MPSAFE);
+       callout_setfunc(&sc->sc_stats_callout, ixl_stats_callout, sc);
+       ixl_work_set(&sc->sc_stats_task, ixl_stats_update, sc);
+
        return 0;
 }
 
@@ -5499,6 +5679,7 @@
 {
        struct ixl_tx_ring *txr;
        struct ixl_rx_ring *rxr;
+       struct ixl_stats_counters *isc;
        unsigned int i;
 
        for (i = 0; i < sc->sc_nqueue_pairs_max; i++) {
@@ -5519,11 +5700,286 @@
                evcnt_detach(&rxr->rxr_defer);
        }
 
+       isc = &sc->sc_stats_counters;
+       evcnt_detach(&isc->isc_crc_errors);
+       evcnt_detach(&isc->isc_illegal_bytes);
+       evcnt_detach(&isc->isc_mac_local_faults);
+       evcnt_detach(&isc->isc_mac_remote_faults);
+       evcnt_detach(&isc->isc_link_xon_rx);
+       evcnt_detach(&isc->isc_link_xon_tx);
+       evcnt_detach(&isc->isc_link_xoff_rx);
+       evcnt_detach(&isc->isc_link_xoff_tx);
+       evcnt_detach(&isc->isc_rx_fragments);
+       evcnt_detach(&isc->isc_rx_jabber);
+       evcnt_detach(&isc->isc_rx_bytes);
+       evcnt_detach(&isc->isc_rx_discards);
+       evcnt_detach(&isc->isc_rx_unicast);
+       evcnt_detach(&isc->isc_rx_multicast);
+       evcnt_detach(&isc->isc_rx_broadcast);
+       evcnt_detach(&isc->isc_rx_size_64);
+       evcnt_detach(&isc->isc_rx_size_127);
+       evcnt_detach(&isc->isc_rx_size_255);
+       evcnt_detach(&isc->isc_rx_size_511);
+       evcnt_detach(&isc->isc_rx_size_1023);
+       evcnt_detach(&isc->isc_rx_size_1522);
+       evcnt_detach(&isc->isc_rx_size_big);
+       evcnt_detach(&isc->isc_rx_undersize);
+       evcnt_detach(&isc->isc_rx_oversize);
+       evcnt_detach(&isc->isc_tx_bytes);
+       evcnt_detach(&isc->isc_tx_dropped_link_down);
+       evcnt_detach(&isc->isc_tx_unicast);
+       evcnt_detach(&isc->isc_tx_multicast);
+       evcnt_detach(&isc->isc_tx_broadcast);
+       evcnt_detach(&isc->isc_tx_size_64);



Home | Main Index | Thread Index | Old Index