Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/pci/ixgbe Clear all event counters when SIOCZIFDATA(...
details: https://anonhg.NetBSD.org/src/rev/670fbc1c12b3
branches: trunk
changeset: 353862:670fbc1c12b3
user: msaitoh <msaitoh%NetBSD.org@localhost>
date: Fri May 26 07:42:15 2017 +0000
description:
Clear all event counters when SIOCZIFDATA(ifconfig -z) is called.
diffstat:
sys/dev/pci/ixgbe/ixgbe.c | 122 +++++++++++++++++++++++++++++++++++++++++++++-
1 files changed, 120 insertions(+), 2 deletions(-)
diffs (167 lines):
diff -r d0ee662db7c7 -r 670fbc1c12b3 sys/dev/pci/ixgbe/ixgbe.c
--- a/sys/dev/pci/ixgbe/ixgbe.c Fri May 26 06:41:42 2017 +0000
+++ b/sys/dev/pci/ixgbe/ixgbe.c Fri May 26 07:42:15 2017 +0000
@@ -59,7 +59,7 @@
* POSSIBILITY OF SUCH DAMAGE.
*/
/*$FreeBSD: head/sys/dev/ixgbe/if_ix.c 302384 2016-07-07 03:39:18Z sbruno $*/
-/*$NetBSD: ixgbe.c,v 1.84 2017/05/22 07:35:14 msaitoh Exp $*/
+/*$NetBSD: ixgbe.c,v 1.85 2017/05/26 07:42:15 msaitoh Exp $*/
#ifdef _KERNEL_OPT
#include "opt_inet.h"
@@ -198,6 +198,7 @@
static void ixgbe_add_device_sysctls(struct adapter *);
static void ixgbe_add_hw_stats(struct adapter *);
+static void ixgbe_clear_evcnt(struct adapter *);
static int ixgbe_set_flowcntl(struct adapter *, int);
static int ixgbe_set_advertise(struct adapter *, int);
@@ -1063,6 +1064,7 @@
ixgbe_ioctl(struct ifnet * ifp, u_long command, void *data)
{
struct adapter *adapter = ifp->if_softc;
+ struct ixgbe_hw *hw = &adapter->hw;
struct ifcapreq *ifcr = data;
struct ifreq *ifr = data;
int error = 0;
@@ -1113,6 +1115,11 @@
case SIOCGLIFADDR:
IOCTL_DEBUGOUT("ioctl: SIOCGLIFADDR (Get Interface addr)");
break;
+ case SIOCZIFDATA:
+ IOCTL_DEBUGOUT("ioctl: SIOCZIFDATA (Zero counter)");
+ hw->mac.ops.clear_hw_cntrs(hw);
+ ixgbe_clear_evcnt(adapter);
+ break;
case SIOCAIFADDR:
IOCTL_DEBUGOUT("ioctl: SIOCAIFADDR (add/chg IF alias)");
break;
@@ -1128,7 +1135,6 @@
return ifmedia_ioctl(ifp, ifr, &adapter->media, command);
case SIOCGI2C:
{
- struct ixgbe_hw *hw = &adapter->hw;
struct ixgbe_i2c_req i2c;
IOCTL_DEBUGOUT("ioctl: SIOCGI2C (Get I2C Data)");
error = copyin(ifr->ifr_data, &i2c, sizeof(i2c));
@@ -5077,6 +5083,118 @@
}
static void
+ixgbe_clear_evcnt(struct adapter *adapter)
+{
+ struct tx_ring *txr = adapter->tx_rings;
+ struct rx_ring *rxr = adapter->rx_rings;
+ struct ixgbe_hw *hw = &adapter->hw;
+ struct ixgbe_hw_stats *stats = &adapter->stats.pf;
+
+ adapter->handleq.ev_count = 0;
+ adapter->req.ev_count = 0;
+ adapter->efbig_tx_dma_setup.ev_count = 0;
+ adapter->mbuf_defrag_failed.ev_count = 0;
+ adapter->efbig2_tx_dma_setup.ev_count = 0;
+ adapter->einval_tx_dma_setup.ev_count = 0;
+ adapter->other_tx_dma_setup.ev_count = 0;
+ adapter->eagain_tx_dma_setup.ev_count = 0;
+ adapter->enomem_tx_dma_setup.ev_count = 0;
+ adapter->watchdog_events.ev_count = 0;
+ adapter->tso_err.ev_count = 0;
+ adapter->link_irq.ev_count = 0;
+
+ txr = adapter->tx_rings;
+ for (int i = 0; i < adapter->num_queues; i++, rxr++, txr++) {
+ adapter->queues[i].irqs.ev_count = 0;
+ txr->no_desc_avail.ev_count = 0;
+ txr->total_packets.ev_count = 0;
+ txr->tso_tx.ev_count = 0;
+#ifndef IXGBE_LEGACY_TX
+ txr->pcq_drops.ev_count = 0;
+#endif
+
+ if (i < __arraycount(stats->mpc)) {
+ stats->mpc[i].ev_count = 0;
+ if (hw->mac.type == ixgbe_mac_82598EB)
+ stats->rnbc[i].ev_count = 0;
+ }
+ if (i < __arraycount(stats->pxontxc)) {
+ stats->pxontxc[i].ev_count = 0;
+ stats->pxonrxc[i].ev_count = 0;
+ stats->pxofftxc[i].ev_count = 0;
+ stats->pxoffrxc[i].ev_count = 0;
+ stats->pxon2offc[i].ev_count = 0;
+ }
+ if (i < __arraycount(stats->qprc)) {
+ stats->qprc[i].ev_count = 0;
+ stats->qptc[i].ev_count = 0;
+ stats->qbrc[i].ev_count = 0;
+ stats->qbtc[i].ev_count = 0;
+ stats->qprdc[i].ev_count = 0;
+ }
+
+ rxr->rx_packets.ev_count = 0;
+ rxr->rx_bytes.ev_count = 0;
+ rxr->rx_copies.ev_count = 0;
+ rxr->no_jmbuf.ev_count = 0;
+ rxr->rx_discarded.ev_count = 0;
+ }
+ stats->ipcs.ev_count = 0;
+ stats->l4cs.ev_count = 0;
+ stats->ipcs_bad.ev_count = 0;
+ stats->l4cs_bad.ev_count = 0;
+ stats->intzero.ev_count = 0;
+ stats->legint.ev_count = 0;
+ stats->crcerrs.ev_count = 0;
+ stats->illerrc.ev_count = 0;
+ stats->errbc.ev_count = 0;
+ stats->mspdc.ev_count = 0;
+ stats->mpctotal.ev_count = 0;
+ stats->mlfc.ev_count = 0;
+ stats->mrfc.ev_count = 0;
+ stats->rlec.ev_count = 0;
+ stats->lxontxc.ev_count = 0;
+ stats->lxonrxc.ev_count = 0;
+ stats->lxofftxc.ev_count = 0;
+ stats->lxoffrxc.ev_count = 0;
+
+ /* Packet Reception Stats */
+ stats->tor.ev_count = 0;
+ stats->gorc.ev_count = 0;
+ stats->tpr.ev_count = 0;
+ stats->gprc.ev_count = 0;
+ stats->mprc.ev_count = 0;
+ stats->bprc.ev_count = 0;
+ stats->prc64.ev_count = 0;
+ stats->prc127.ev_count = 0;
+ stats->prc255.ev_count = 0;
+ stats->prc511.ev_count = 0;
+ stats->prc1023.ev_count = 0;
+ stats->prc1522.ev_count = 0;
+ stats->ruc.ev_count = 0;
+ stats->rfc.ev_count = 0;
+ stats->roc.ev_count = 0;
+ stats->rjc.ev_count = 0;
+ stats->mngprc.ev_count = 0;
+ stats->mngpdc.ev_count = 0;
+ stats->xec.ev_count = 0;
+
+ /* Packet Transmission Stats */
+ stats->gotc.ev_count = 0;
+ stats->tpt.ev_count = 0;
+ stats->gptc.ev_count = 0;
+ stats->bptc.ev_count = 0;
+ stats->mptc.ev_count = 0;
+ stats->mngptc.ev_count = 0;
+ stats->ptc64.ev_count = 0;
+ stats->ptc127.ev_count = 0;
+ stats->ptc255.ev_count = 0;
+ stats->ptc511.ev_count = 0;
+ stats->ptc1023.ev_count = 0;
+ stats->ptc1522.ev_count = 0;
+}
+
+static void
ixgbe_set_sysctl_value(struct adapter *adapter, const char *name,
const char *description, int *limit, int value)
{
Home |
Main Index |
Thread Index |
Old Index