2009/8/31 John Baldwin <j...@freebsd.org>:
> It should be total and it sounds like a bug in the device driver.  It looks
> like ixgbe_update_stats_counters() overwrites the accumulated value of
> if_ierrors:
>
>        /* Rx Errors */
>        ifp->if_ierrors = total_missed_rx + adapter->stats.crcerrs +
>                adapter->stats.rlec;
>
> It also increments if_ierrors in ixgbe_rxeof().  The driver should only do one
> or the other, but probably not both.
>
> --
> John Baldwin
>

Thanks for your reply. I had wondered that, but looking at
e1000/if_em.c it does a similar thing. However, a quick look at
non-intel drivers and it seems others don't. So perhaps this is a
problem across the intel drivers?

So anyway I spent my afternoon reading the ixgbe spec sheet and
creating the attached patch, which hopefully fixes this problem. I
will forward this patch to freebsd <at> intel.com unless someone can
point me toward the maintainers email address, or should I just create
a PR?

thanks
Andrew
diff -u ixgbe.old/ixgbe.c ixgbe/ixgbe.c
--- ixgbe.old/ixgbe.c   2009-08-31 18:15:05.000000000 +0100
+++ ixgbe/ixgbe.c       2009-08-31 19:52:14.000000000 +0100
@@ -3978,7 +3978,6 @@
 
                        if (eop) {
                                rxr->fmp->m_pkthdr.rcvif = ifp;
-                               ifp->if_ipackets++;
                                rxr->rx_packets++;
                                /* capture data for AIM */
                                rxr->bytes += rxr->fmp->m_pkthdr.len;
@@ -4000,8 +3999,9 @@
                                rxr->lmp = NULL;
                        }
                } else {
-                       ifp->if_ierrors++;
 discard:
+                       adapter->dropped_pkts++;
+
                        /* Reuse loaded DMA map and just update mbuf chain */
                        if (hlen) {
                                mh = rxr->rx_buffers[i].m_head;
@@ -4459,12 +4459,15 @@
        u32  missed_rx = 0, bprc, lxon, lxoff, total;
 
        adapter->stats.crcerrs += IXGBE_READ_REG(hw, IXGBE_CRCERRS);
+       adapter->stats.illerrc += IXGBE_READ_REG(hw, IXGBE_ILLERRC);
+       adapter->stats.errbc   += IXGBE_READ_REG(hw, IXGBE_ERRBC);
 
        for (int i = 0; i < 8; i++) {
                int mp;
                mp = IXGBE_READ_REG(hw, IXGBE_MPC(i));
                missed_rx += mp;
                adapter->stats.mpc[i] += mp;
+               adapter->stats.mpctotal += mp;
                adapter->stats.rnbc[i] += IXGBE_READ_REG(hw, IXGBE_RNBC(i));
        }
 
@@ -4532,8 +4535,11 @@
        ifp->if_collisions = 0;
 
        /* Rx Errors */
-       ifp->if_ierrors = missed_rx + adapter->stats.crcerrs +
-               adapter->stats.rlec;
+       ifp->if_ierrors = adapter->stats.mpctotal +
+                         adapter->stats.crcerrs +
+                         adapter->stats.illerrc +
+                         adapter->stats.errbc +
+                         adapter->stats.rlec;
 }

_______________________________________________
freebsd-hackers@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/freebsd-hackers
To unsubscribe, send any mail to "freebsd-hackers-unsubscr...@freebsd.org"

Reply via email to