Source-Changes-HG archive

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

[src/trunk]: src/sys Use percpu_foreach_xcall() to gather volatile per-cpu co...



details:   https://anonhg.NetBSD.org/src/rev/1c1c75addfa7
branches:  trunk
changeset: 969083:1c1c75addfa7
user:      thorpej <thorpej%NetBSD.org@localhost>
date:      Fri Feb 07 12:35:33 2020 +0000

description:
Use percpu_foreach_xcall() to gather volatile per-cpu counters.  These
must be serialized against the interrupts / soft-interrupts in which
they're manipulated, as well as protected from non-atomic 64-bit memory
loads on 32-bit platforms.

diffstat:

 sys/net/bpf.c         |  12 +++++++++---
 sys/net/if_stats.c    |   8 +++++---
 sys/net/net_stats.c   |   8 +++++---
 sys/net/npf/npf.c     |   9 ++++++---
 sys/net/pktqueue.c    |  12 +++++++++---
 sys/netinet/wqinput.c |   6 ++++--
 sys/netipsec/key.c    |  18 +++++++++++-------
 7 files changed, 49 insertions(+), 24 deletions(-)

diffs (297 lines):

diff -r 9fd7e798ae3f -r 1c1c75addfa7 sys/net/bpf.c
--- a/sys/net/bpf.c     Fri Feb 07 11:55:22 2020 +0000
+++ b/sys/net/bpf.c     Fri Feb 07 12:35:33 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: bpf.c,v 1.234 2020/02/01 02:54:02 riastradh Exp $      */
+/*     $NetBSD: bpf.c,v 1.235 2020/02/07 12:35:33 thorpej Exp $        */
 
 /*
  * Copyright (c) 1990, 1991, 1993
@@ -39,7 +39,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: bpf.c,v 1.234 2020/02/01 02:54:02 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: bpf.c,v 1.235 2020/02/07 12:35:33 thorpej Exp $");
 
 #if defined(_KERNEL_OPT)
 #include "opt_bpf.h"
@@ -78,6 +78,7 @@
 #include <sys/percpu.h>
 #include <sys/pserialize.h>
 #include <sys/lwp.h>
+#include <sys/xcall.h>
 
 #include <net/if.h>
 #include <net/slip.h>
@@ -2395,9 +2396,13 @@
        struct bpf_stat *const stats = p;
        struct bpf_stat *sum = arg;
 
+       int s = splnet();
+
        sum->bs_recv += stats->bs_recv;
        sum->bs_drop += stats->bs_drop;
        sum->bs_capt += stats->bs_capt;
+
+       splx(s);
 }
 
 static int
@@ -2410,7 +2415,8 @@
        memset(&sum, 0, sizeof(sum));
        node = *rnode;
 
-       percpu_foreach(bpf_gstats_percpu, bpf_stats, &sum);
+       percpu_foreach_xcall(bpf_gstats_percpu, XC_HIGHPRI_IPL(IPL_SOFTNET),
+           bpf_stats, &sum);
 
        node.sysctl_data = &sum;
        node.sysctl_size = sizeof(sum);
diff -r 9fd7e798ae3f -r 1c1c75addfa7 sys/net/if_stats.c
--- a/sys/net/if_stats.c        Fri Feb 07 11:55:22 2020 +0000
+++ b/sys/net/if_stats.c        Fri Feb 07 12:35:33 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_stats.c,v 1.1 2020/01/29 03:16:28 thorpej Exp $     */
+/*     $NetBSD: if_stats.c,v 1.2 2020/02/07 12:35:33 thorpej Exp $     */
 
 /*-
  * Copyright (c) 2020 The NetBSD Foundation, Inc.
@@ -30,11 +30,12 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_stats.c,v 1.1 2020/01/29 03:16:28 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_stats.c,v 1.2 2020/02/07 12:35:33 thorpej Exp $");
 
 #include <sys/param.h>
 #include <sys/mbuf.h>
 #include <sys/systm.h>
+#include <sys/xcall.h>
 
 #include <net/if.h>
 
@@ -123,7 +124,8 @@
        };
 
        memset(ifi, 0, sizeof(*ifi));
-       percpu_foreach(ifp->if_stats, if_stats_to_if_data_cb, &ctx);
+       percpu_foreach_xcall(ifp->if_stats, XC_HIGHPRI_IPL(IPL_SOFTNET),
+           if_stats_to_if_data_cb, &ctx);
 }
 
 #else /* ! __IF_STATS_PERCPU */
diff -r 9fd7e798ae3f -r 1c1c75addfa7 sys/net/net_stats.c
--- a/sys/net/net_stats.c       Fri Feb 07 11:55:22 2020 +0000
+++ b/sys/net/net_stats.c       Fri Feb 07 12:35:33 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: net_stats.c,v 1.5 2017/06/01 02:45:14 chs Exp $        */
+/*     $NetBSD: net_stats.c,v 1.6 2020/02/07 12:35:33 thorpej Exp $    */
 
 /*-
  * Copyright (c) 2008 The NetBSD Foundation, Inc.
@@ -30,12 +30,13 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: net_stats.c,v 1.5 2017/06/01 02:45:14 chs Exp $");
+__KERNEL_RCSID(0, "$NetBSD: net_stats.c,v 1.6 2020/02/07 12:35:33 thorpej Exp $");
 
 #include <sys/types.h>
 #include <sys/systm.h>
 #include <sys/sysctl.h>
 #include <sys/kmem.h>
+#include <sys/xcall.h>
 
 #include <net/net_stats.h>
 
@@ -80,7 +81,8 @@
        ctx.ctx_counters = counters;
        ctx.ctx_ncounters = ncounters;
 
-       percpu_foreach(stat, netstat_convert_to_user_cb, &ctx);
+       percpu_foreach_xcall(stat, XC_HIGHPRI_IPL(IPL_SOFTNET),
+           netstat_convert_to_user_cb, &ctx);
 
        node = *rnode;
        node.sysctl_data = counters;
diff -r 9fd7e798ae3f -r 1c1c75addfa7 sys/net/npf/npf.c
--- a/sys/net/npf/npf.c Fri Feb 07 11:55:22 2020 +0000
+++ b/sys/net/npf/npf.c Fri Feb 07 12:35:33 2020 +0000
@@ -33,7 +33,7 @@
 
 #ifdef _KERNEL
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: npf.c,v 1.41 2019/08/25 13:21:03 rmind Exp $");
+__KERNEL_RCSID(0, "$NetBSD: npf.c,v 1.42 2020/02/07 12:35:33 thorpej Exp $");
 
 #include <sys/param.h>
 #include <sys/types.h>
@@ -41,6 +41,7 @@
 #include <sys/conf.h>
 #include <sys/kmem.h>
 #include <sys/percpu.h>
+#include <sys/xcall.h>
 #endif
 
 #include "npf_impl.h"
@@ -201,11 +202,13 @@
 npfk_stats(npf_t *npf, uint64_t *buf)
 {
        memset(buf, 0, NPF_STATS_SIZE);
-       percpu_foreach(npf->stats_percpu, npf_stats_collect, buf);
+       percpu_foreach_xcall(npf->stats_percpu, XC_HIGHPRI_IPL(IPL_SOFTNET),
+           npf_stats_collect, buf);
 }
 
 __dso_public void
 npfk_stats_clear(npf_t *npf)
 {
-       percpu_foreach(npf->stats_percpu, npf_stats_clear_cb, NULL);
+       percpu_foreach_xcall(npf->stats_percpu, XC_HIGHPRI_IPL(IPL_SOFTNET),
+           npf_stats_clear_cb, NULL);
 }
diff -r 9fd7e798ae3f -r 1c1c75addfa7 sys/net/pktqueue.c
--- a/sys/net/pktqueue.c        Fri Feb 07 11:55:22 2020 +0000
+++ b/sys/net/pktqueue.c        Fri Feb 07 12:35:33 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: pktqueue.c,v 1.10 2018/08/10 07:24:09 msaitoh Exp $    */
+/*     $NetBSD: pktqueue.c,v 1.11 2020/02/07 12:35:33 thorpej Exp $    */
 
 /*-
  * Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -36,7 +36,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: pktqueue.c,v 1.10 2018/08/10 07:24:09 msaitoh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: pktqueue.c,v 1.11 2020/02/07 12:35:33 thorpej Exp $");
 
 #include <sys/param.h>
 #include <sys/types.h>
@@ -48,6 +48,7 @@
 #include <sys/mbuf.h>
 #include <sys/proc.h>
 #include <sys/percpu.h>
+#include <sys/xcall.h>
 
 #include <net/pktqueue.h>
 
@@ -161,9 +162,13 @@
        const pktq_counters_t *c = mem;
        pktq_counters_t *sum = arg;
 
+       int s = splnet();
+
        for (u_int i = 0; i < PQCNT_NCOUNTERS; i++) {
                sum->count[i] += c->count[i];
        }
+
+       splx(s);
 }
 
 uint64_t
@@ -173,7 +178,8 @@
 
        if (c != PKTQ_MAXLEN) {
                memset(&sum, 0, sizeof(sum));
-               percpu_foreach(pq->pq_counters, pktq_collect_counts, &sum);
+               percpu_foreach_xcall(pq->pq_counters,
+                   XC_HIGHPRI_IPL(IPL_SOFTNET), pktq_collect_counts, &sum);
        }
        switch (c) {
        case PKTQ_NITEMS:
diff -r 9fd7e798ae3f -r 1c1c75addfa7 sys/netinet/wqinput.c
--- a/sys/netinet/wqinput.c     Fri Feb 07 11:55:22 2020 +0000
+++ b/sys/netinet/wqinput.c     Fri Feb 07 12:35:33 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: wqinput.c,v 1.7 2020/02/01 12:54:51 riastradh Exp $    */
+/*     $NetBSD: wqinput.c,v 1.8 2020/02/07 12:35:33 thorpej Exp $      */
 
 /*-
  * Copyright (c) 2017 Internet Initiative Japan Inc.
@@ -41,6 +41,7 @@
 #include <sys/queue.h>
 #include <sys/percpu.h>
 #include <sys/sysctl.h>
+#include <sys/xcall.h>
 
 #include <net/if.h>
 #include <netinet/wqinput.h>
@@ -98,7 +99,8 @@
        node = *rnode;
        wqi = node.sysctl_data;
 
-       percpu_foreach(wqi->wqi_worklists, wqinput_drops, &sum);
+       percpu_foreach_xcall(wqi->wqi_worklists, XC_HIGHPRI_IPL(IPL_SOFTNET),
+           wqinput_drops, &sum);
 
        node.sysctl_data = &sum;
        error = sysctl_lookup(SYSCTLFN_CALL(&node));
diff -r 9fd7e798ae3f -r 1c1c75addfa7 sys/netipsec/key.c
--- a/sys/netipsec/key.c        Fri Feb 07 11:55:22 2020 +0000
+++ b/sys/netipsec/key.c        Fri Feb 07 12:35:33 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: key.c,v 1.269 2019/11/14 03:17:08 knakahara Exp $      */
+/*     $NetBSD: key.c,v 1.270 2020/02/07 12:35:33 thorpej Exp $        */
 /*     $FreeBSD: key.c,v 1.3.2.3 2004/02/14 22:23:23 bms Exp $ */
 /*     $KAME: key.c,v 1.191 2001/06/27 10:46:49 sakane Exp $   */
 
@@ -32,7 +32,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: key.c,v 1.269 2019/11/14 03:17:08 knakahara Exp $");
+__KERNEL_RCSID(0, "$NetBSD: key.c,v 1.270 2020/02/07 12:35:33 thorpej Exp $");
 
 /*
  * This code is referred to RFC 2367
@@ -73,6 +73,7 @@
 #include <sys/localcount.h>
 #include <sys/pserialize.h>
 #include <sys/hash.h>
+#include <sys/xcall.h>
 
 #include <net/if.h>
 #include <net/route.h>
@@ -3961,7 +3962,8 @@
                            time_mono_to_wall(lt.sadb_lifetime_addtime);
                        lt.sadb_lifetime_usetime =
                            time_mono_to_wall(lt.sadb_lifetime_usetime);
-                       percpu_foreach(sav->lft_c_counters_percpu,
+                       percpu_foreach_xcall(sav->lft_c_counters_percpu,
+                           XC_HIGHPRI_IPL(IPL_SOFTNET),
                            key_sum_lifetime_counters, sum);
                        lt.sadb_lifetime_allocations =
                            sum[LIFETIME_COUNTER_ALLOCATIONS];
@@ -5027,7 +5029,8 @@
                                uint64_t lft_c_bytes = 0;
                                lifetime_counters_t sum = {0};
 
-                               percpu_foreach(sav->lft_c_counters_percpu,
+                               percpu_foreach_xcall(sav->lft_c_counters_percpu,
+                                   XC_HIGHPRI_IPL(IPL_SOFTNET),
                                    key_sum_lifetime_counters, sum);
                                lft_c_bytes = sum[LIFETIME_COUNTER_BYTES];
 
@@ -5089,7 +5092,8 @@
                                uint64_t lft_c_bytes = 0;
                                lifetime_counters_t sum = {0};
 
-                               percpu_foreach(sav->lft_c_counters_percpu,
+                               percpu_foreach_xcall(sav->lft_c_counters_percpu,
+                                   XC_HIGHPRI_IPL(IPL_SOFTNET),
                                    key_sum_lifetime_counters, sum);
                                lft_c_bytes = sum[LIFETIME_COUNTER_BYTES];
 
@@ -7425,8 +7429,8 @@
        lt = mtod(m, struct sadb_lifetime *);
        lt->sadb_lifetime_len = PFKEY_UNIT64(sizeof(struct sadb_lifetime));
        lt->sadb_lifetime_exttype = SADB_EXT_LIFETIME_CURRENT;
-       percpu_foreach(sav->lft_c_counters_percpu,
-           key_sum_lifetime_counters, sum);
+       percpu_foreach_xcall(sav->lft_c_counters_percpu,
+           XC_HIGHPRI_IPL(IPL_SOFTNET), key_sum_lifetime_counters, sum);
        lt->sadb_lifetime_allocations = sum[LIFETIME_COUNTER_ALLOCATIONS];
        lt->sadb_lifetime_bytes = sum[LIFETIME_COUNTER_BYTES];
        lt->sadb_lifetime_addtime =



Home | Main Index | Thread Index | Old Index