Source-Changes-HG archive

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

[src/trunk]: src/sys/net Remove the conditional __IF_STATS_PERCPU.



details:   https://anonhg.NetBSD.org/src/rev/3d3d5f7a4c95
branches:  trunk
changeset: 969304:3d3d5f7a4c95
user:      thorpej <thorpej%NetBSD.org@localhost>
date:      Fri Feb 14 22:04:12 2020 +0000

description:
Remove the conditional __IF_STATS_PERCPU.

diffstat:

 sys/net/if.h       |  33 +--------------------------------
 sys/net/if_stats.c |  44 ++------------------------------------------
 sys/net/if_stats.h |  49 ++++---------------------------------------------
 3 files changed, 7 insertions(+), 119 deletions(-)

diffs (225 lines):

diff -r e8122f5cff60 -r 3d3d5f7a4c95 sys/net/if.h
--- a/sys/net/if.h      Fri Feb 14 18:17:23 2020 +0000
+++ b/sys/net/if.h      Fri Feb 14 22:04:12 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if.h,v 1.281 2020/02/06 23:30:19 thorpej Exp $ */
+/*     $NetBSD: if.h,v 1.282 2020/02/14 22:04:12 thorpej Exp $ */
 
 /*-
  * Copyright (c) 1999, 2000, 2001 The NetBSD Foundation, Inc.
@@ -63,12 +63,6 @@
 #ifndef _NET_IF_H_
 #define _NET_IF_H_
 
-/*
- * Temporary, to allow for a quick disable if problems are discovered
- * during a transition period.
- */
-#define        __IF_STATS_PERCPU
-
 #if !defined(_KERNEL) && !defined(_STANDALONE)
 #include <stdbool.h>
 #endif
@@ -282,7 +276,6 @@
        short           if_timer;       /* ?: time 'til if_slowtimo called */
        unsigned short  if_flags;       /* i: up/down, broadcast, etc. */
        short           if_extflags;    /* :: if_output MP-safe, etc. */
-#ifdef __IF_STATS_PERCPU
        u_char          if_type;        /* :: ethernet, tokenring, etc. */
        u_char          if_addrlen;     /* :: media address length */
        u_char          if_hdrlen;      /* :: media header length */
@@ -297,9 +290,6 @@
 #else
        void            *if_stats;      /* opaque to user-space */
 #endif /* _KERNEL */
-#else /* ! __IF_STATS_PERCPU */
-       struct if_data  if_data;        /* ?: statistics and other data */
-#endif /* __IF_STATS_PERCPU */
        /*
         * Procedure handles.  If you add more of these, don't forget the
         * corresponding NULL stub in if.c.
@@ -426,27 +416,6 @@
 
 #include <net/if_stats.h>
  
-#ifndef __IF_STATS_PERCPU
-#define        if_mtu          if_data.ifi_mtu
-#define        if_type         if_data.ifi_type
-#define        if_addrlen      if_data.ifi_addrlen
-#define        if_hdrlen       if_data.ifi_hdrlen
-#define        if_metric       if_data.ifi_metric
-#define        if_link_state   if_data.ifi_link_state
-#define        if_baudrate     if_data.ifi_baudrate
-#define        if_ipackets     if_data.ifi_ipackets
-#define        if_ierrors      if_data.ifi_ierrors
-#define        if_opackets     if_data.ifi_opackets
-#define        if_oerrors      if_data.ifi_oerrors
-#define        if_collisions   if_data.ifi_collisions
-#define        if_ibytes       if_data.ifi_ibytes
-#define        if_obytes       if_data.ifi_obytes
-#define        if_imcasts      if_data.ifi_imcasts
-#define        if_omcasts      if_data.ifi_omcasts
-#define        if_iqdrops      if_data.ifi_iqdrops
-#define        if_noproto      if_data.ifi_noproto
-#define        if_lastchange   if_data.ifi_lastchange
-#endif /* __IF_STATS_PERCPU */
 #define        if_name(ifp)    ((ifp)->if_xname)
 
 #define        IFF_UP          0x0001          /* interface is up */
diff -r e8122f5cff60 -r 3d3d5f7a4c95 sys/net/if_stats.c
--- a/sys/net/if_stats.c        Fri Feb 14 18:17:23 2020 +0000
+++ b/sys/net/if_stats.c        Fri Feb 14 22:04:12 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_stats.c,v 1.2 2020/02/07 12:35:33 thorpej Exp $     */
+/*     $NetBSD: if_stats.c,v 1.3 2020/02/14 22:04:12 thorpej Exp $     */
 
 /*-
  * Copyright (c) 2020 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_stats.c,v 1.2 2020/02/07 12:35:33 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_stats.c,v 1.3 2020/02/14 22:04:12 thorpej Exp $");
 
 #include <sys/param.h>
 #include <sys/mbuf.h>
@@ -48,11 +48,9 @@
 int
 if_stats_init(ifnet_t * const ifp)
 {
-#ifdef __IF_STATS_PERCPU
        ifp->if_stats = percpu_alloc(IF_STATS_SIZE);
        if (ifp->if_stats == NULL)
                return ENOMEM;
-#endif /* __IF_STATS_PERCPU */
        return 0;
 }
 
@@ -63,17 +61,13 @@
 void
 if_stats_fini(ifnet_t * const ifp)
 {
-#ifdef __IF_STATS_PERCPU
        percpu_t *pc = ifp->if_stats;
        ifp->if_stats = NULL;
        if (pc) {
                percpu_free(pc, IF_STATS_SIZE);
        }
-#endif /* __IF_STATS_PERCPU */
 }
 
-#ifdef __IF_STATS_PERCPU
-
 struct if_stats_to_if_data_ctx {
        struct if_data * const ifi;
        const bool zero_stats;
@@ -127,37 +121,3 @@
        percpu_foreach_xcall(ifp->if_stats, XC_HIGHPRI_IPL(IPL_SOFTNET),
            if_stats_to_if_data_cb, &ctx);
 }
-
-#else /* ! __IF_STATS_PERCPU */
-
-/*
- * if_stats_to_if_data --
- *     Collect the interface statistics and place them into the
- *     legacy if_data structure for reportig to user space.
- *     Optionally zeros the stats after collection.
- */
-void
-if_stats_to_if_data(ifnet_t * const ifp, struct if_data * const ifi,
-                   const bool zero_stats)
-{
-
-       memset(ifi, 0, sizeof(*ifi));
-
-       int s = splnet();
-
-       if (ifi) {
-               memcpy(&ifi->ifi_ipackets, &ifp->if_data.ifi_ipackets,
-                   offsetof(struct if_data, ifi_lastchange) -
-                   offsetof(struct if_data, ifi_ipackets));
-       }
-
-       if (zero_stats) {
-               memset(&ifp->if_data.ifi_ipackets, 0,
-                   offsetof(struct if_data, ifi_lastchange) -
-                   offsetof(struct if_data, ifi_ipackets));
-       }
-
-       splx(s);
-}
-
-#endif /* __IF_STATS_PERCPU */
diff -r e8122f5cff60 -r 3d3d5f7a4c95 sys/net/if_stats.h
--- a/sys/net/if_stats.h        Fri Feb 14 18:17:23 2020 +0000
+++ b/sys/net/if_stats.h        Fri Feb 14 22:04:12 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_stats.h,v 1.1 2020/01/29 03:16:28 thorpej Exp $     */
+/*     $NetBSD: if_stats.h,v 1.2 2020/02/14 22:04:12 thorpej Exp $     */
 
 /*-
  * Copyright (c) 2020 The NetBSD Foundation, Inc.
@@ -34,7 +34,6 @@
 
 #include <net/net_stats.h>
 
-#ifdef __IF_STATS_PERCPU
 /*
  * Interface statistics.  All values are unsigned 64-bit.
  */
@@ -116,50 +115,10 @@
        _NET_STATSUB_REF(nsr, x, v);
 }
 
-#endif /* _KERNEL */
-
-#else /* ! __IF_STATS_PERCPU */
-
-#ifdef _KERNEL
-
-/*
- * Transitional aid to allow drivers to migrate to the new API.  Once
- * all drivers are transitioned, the implementation will be replaced
- * with per-cpu counters.
- */
-
-static inline net_stat_ref_t
-IF_STAT_GETREF(ifnet_t *ifp)
-{
-       return (net_stat_ref_t)ifp;
-}
-
-#define        IF_STAT_PUTREF(ifp)     __nothing
-
-#define        if_statinc(ifp, x)      do { ++(ifp)->x; } while (/*CONSTCOND*/0)
-#define        if_statdec(ifp, x)      do { --(ifp)->x; } while (/*CONSTCOND*/0)
-#define        if_statadd(ifp, x, v)   do { (ifp)->x += (v); } while (/*CONSTCOND*/0)
-#define        if_statsub(ifp, x, v)   do { (ifp)->x -= (v); } while (/*CONSTCOND*/0)
-
-#define        if_statadd2(ifp, x1, v1, x2, v2)                                \
-do {                                                                   \
-       (ifp)->x1 += (v1);                                              \
-       (ifp)->x2 += (v2);                                              \
-} while (/*CONSTCOND*/0)
-
-#define        if_statinc_ref(r, x)    if_statinc((ifnet_t *)(r), x)
-#define        if_statdec_ref(r, x)    if_statdec((ifnet_t *)(r), x)
-#define        if_statadd_ref(r, x, v) if_statadd((ifnet_t *)(r), x, v)
-#define        if_statsub_ref(r, x, v) if_statsub((ifnet_t *)(r), x, v)
+int    if_stats_init(ifnet_t *);
+void   if_stats_fini(ifnet_t *);
+void   if_stats_to_if_data(ifnet_t *, struct if_data *, bool);
 
 #endif /* _KERNEL */
 
-#endif /* __IF_STATS_PERCPU */
-
-#ifdef _KERNEL
-int    if_stats_init(ifnet_t *);
-void   if_stats_fini(ifnet_t *);
-void   if_stats_to_if_data(ifnet_t *, struct if_data *, bool);
-#endif /* _KERNEL */
-
 #endif /* !_NET_IF_STATS_H_ */



Home | Main Index | Thread Index | Old Index