>Number:         182828
>Category:       kern
>Synopsis:       [patch] [igb] Revision 247430 broke outgoing interface stats 
>for stable/8
>Confidential:   no
>Severity:       non-critical
>Priority:       low
>Responsible:    freebsd-bugs
>State:          open
>Quarter:        
>Keywords:       
>Date-Required:
>Class:          sw-bug
>Submitter-Id:   current-users
>Arrival-Date:   Tue Oct 08 12:40:00 UTC 2013
>Closed-Date:
>Last-Modified:
>Originator:     Eugene Grosbein
>Release:        FreeBSD 8.4-STABLE amd64
>Organization:
RDTC JSC
>Environment:
System: FreeBSD eg.sd.rdtc.ru 8.4-STABLE FreeBSD 8.4-STABLE #3 r251830M: Mon 
Sep 30 18:01:03 NOVT 2013 
r...@eg.sd.rdtc.ru:/usr/local/obj/usr/local/src/sys/EG amd64
>Description:
        There was r241037 commit by glebius@ to head fixing
        "inaccurate overrated if_obytes accounting" in the HEAD:
        http://svnweb.freebsd.org/base?view=revision&revision=241037

        And there was _incomplete_ MFC to stable/8 r247430:
        http://svnweb.freebsd.org/base?view=revision&revision=247430

        r247430 contained some parts of r241037 but missed others vital
        parts, so it introduced "inaccurate overrated if_obytes accounting"
        to stable/8. For example, igb(4) now suffers from same problem.

>How-To-Repeat:
        Run recent 8.4-STABLE with igb(4), make lots of outgoing traffic
        and see that interface statistics is overrated.

>Fix:

        Make mentioned MFC more complete. At least, merge
        changes to sys/net/if_var.h to delete extra increase of if_obytes
        and to sys/dev/oce/oce_if.c to fix last consumer
        of drbr_stats_update() in stable/8:

--- sys/net/if_var.h    2012/09/28 17:36:00     241036
+++ sys/net/if_var.h    2012/09/28 18:28:27     241037
@@ -590,22 +590,10 @@
 } while (0)
 
 #ifdef _KERNEL
-static __inline void
-drbr_stats_update(struct ifnet *ifp, int len, int mflags)
-{
-#ifndef NO_SLOW_STATS
-       ifp->if_obytes += len;
-       if (mflags & M_MCAST)
-               ifp->if_omcasts++;
-#endif
-}
-
 static __inline int
 drbr_enqueue(struct ifnet *ifp, struct buf_ring *br, struct mbuf *m)
 {      
        int error = 0;
-       int len = m->m_pkthdr.len;
-       int mflags = m->m_flags;
 
 #ifdef ALTQ
        if (ALTQ_IS_ENABLED(&ifp->if_snd)) {
@@ -613,12 +601,10 @@
                return (error);
        }
 #endif
-       if ((error = buf_ring_enqueue_bytes(br, m, len)) == ENOBUFS) {
-               br->br_drops++;
+       error = buf_ring_enqueue(br, m);
+       if (error)
                m_freem(m);
-       } else
-               drbr_stats_update(ifp, len, mflags);
-       
+
        return (error);
 }
 
--- sys/dev/oce/oce_if.c        2012/09/28 17:36:00     241036
+++ sys/dev/oce/oce_if.c        2012/09/28 18:28:27     241037
@@ -1183,7 +1183,9 @@
                        }  
                        break;
                }
-               drbr_stats_update(ifp, next->m_pkthdr.len, next->m_flags);
+               ifp->if_obytes += next->m_pkthdr.len;
+               if (next->m_flags & M_MCAST)
+                       ifp->if_omcasts++;
                ETHER_BPF_MTAP(ifp, next);
                next = drbr_dequeue(ifp, br);
        }

Eugene Grosbein
>Release-Note:
>Audit-Trail:
>Unformatted:
_______________________________________________
freebsd-bugs@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/freebsd-bugs
To unsubscribe, send any mail to "freebsd-bugs-unsubscr...@freebsd.org"

Reply via email to