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 Fix a bug that ifconfig -z (SOICZIFDATA) d...



details:   https://anonhg.NetBSD.org/src/rev/77f0b40ccc70
branches:  trunk
changeset: 337416:77f0b40ccc70
user:      msaitoh <msaitoh%NetBSD.org@localhost>
date:      Tue Apr 14 07:41:52 2015 +0000

description:
Fix a bug that ifconfig -z (SOICZIFDATA) doesn't work.

diffstat:

 sys/dev/pci/ixgbe/ixgbe.c |  29 +++++++++++++++--------------
 1 files changed, 15 insertions(+), 14 deletions(-)

diffs (69 lines):

diff -r 3b55982db454 -r 77f0b40ccc70 sys/dev/pci/ixgbe/ixgbe.c
--- a/sys/dev/pci/ixgbe/ixgbe.c Tue Apr 14 07:17:06 2015 +0000
+++ b/sys/dev/pci/ixgbe/ixgbe.c Tue Apr 14 07:41:52 2015 +0000
@@ -59,7 +59,7 @@
  * POSSIBILITY OF SUCH DAMAGE.
  */
 /*$FreeBSD: head/sys/dev/ixgbe/ixgbe.c 243716 2012-11-30 22:33:21Z jfv $*/
-/*$NetBSD: ixgbe.c,v 1.26 2015/04/14 07:17:06 msaitoh Exp $*/
+/*$NetBSD: ixgbe.c,v 1.27 2015/04/14 07:41:52 msaitoh Exp $*/
 
 #include "opt_inet.h"
 #include "opt_inet6.h"
@@ -5313,8 +5313,10 @@
        struct ixgbe_hw *hw = &adapter->hw;
        u32  missed_rx = 0, bprc, lxon, lxoff, total;
        u64  total_missed_rx = 0;
-
-       adapter->stats.crcerrs.ev_count += IXGBE_READ_REG(hw, IXGBE_CRCERRS);
+       uint64_t crcerrs, rlec;
+
+       crcerrs = IXGBE_READ_REG(hw, IXGBE_CRCERRS);
+       adapter->stats.crcerrs.ev_count += crcerrs;
        adapter->stats.illerrc.ev_count += IXGBE_READ_REG(hw, IXGBE_ILLERRC);
        adapter->stats.errbc.ev_count += IXGBE_READ_REG(hw, IXGBE_ERRBC);
        adapter->stats.mspdc.ev_count += IXGBE_READ_REG(hw, IXGBE_MSPDC);
@@ -5328,7 +5330,7 @@
                /* global total per queue */
                adapter->stats.mpc[j].ev_count += mp;
                /* Running comprehensive total for stats display */
-               total_missed_rx += adapter->stats.mpc[j].ev_count;
+               total_missed_rx += mp;
                if (hw->mac.type == ixgbe_mac_82598EB)
                        adapter->stats.rnbc[j] +=
                            IXGBE_READ_REG(hw, IXGBE_RNBC(i));
@@ -5357,7 +5359,8 @@
        }
        adapter->stats.mlfc.ev_count += IXGBE_READ_REG(hw, IXGBE_MLFC);
        adapter->stats.mrfc.ev_count += IXGBE_READ_REG(hw, IXGBE_MRFC);
-       adapter->stats.rlec.ev_count += IXGBE_READ_REG(hw, IXGBE_RLEC);
+       rlec = IXGBE_READ_REG(hw, IXGBE_RLEC);
+       adapter->stats.rlec.ev_count += rlec;
 
        /* Hardware workaround, gprc counts missed packets */
        adapter->stats.gprc.ev_count += IXGBE_READ_REG(hw, IXGBE_GPRC) - missed_rx;
@@ -5439,17 +5442,15 @@
        }
 
        /* Fill out the OS statistics structure */
-       ifp->if_ipackets = adapter->stats.gprc.ev_count;
-       ifp->if_opackets = adapter->stats.gptc.ev_count;
-       ifp->if_ibytes = adapter->stats.gorc.ev_count;
-       ifp->if_obytes = adapter->stats.gotc.ev_count;
-       ifp->if_imcasts = adapter->stats.mprc.ev_count;
-       ifp->if_omcasts = adapter->stats.mptc.ev_count;
+       /*
+        * NetBSD: Don't override if_{i|o}{packets|bytes|mcasts} with
+        * adapter->stats counters. It's required to make ifconfig -z
+        * (SOICZIFDATA) work.
+        */
        ifp->if_collisions = 0;
-
+       
        /* Rx Errors */
-       ifp->if_ierrors = total_missed_rx + adapter->stats.crcerrs.ev_count +
-               adapter->stats.rlec.ev_count;
+       ifp->if_ierrors += total_missed_rx + crcerrs + rlec;
 }
 
 /** ixgbe_sysctl_tdh_handler - Handler function



Home | Main Index | Thread Index | Old Index