Module Name: src
Committed By: riastradh
Date: Sat Jun 29 13:01:30 UTC 2024
Modified Files:
src/sys/net: net_stats.h
Log Message:
net_stats(9): Make this API slightly more type-safe.
TBD: Convert the macros to inline functions for better type-safety.
PR kern/58380
To generate a diff of this commit:
cvs rdiff -u -r1.5 -r1.6 src/sys/net/net_stats.h
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/net/net_stats.h
diff -u src/sys/net/net_stats.h:1.5 src/sys/net/net_stats.h:1.6
--- src/sys/net/net_stats.h:1.5 Wed Jan 29 03:04:55 2020
+++ src/sys/net/net_stats.h Sat Jun 29 13:01:30 2024
@@ -1,4 +1,4 @@
-/* $NetBSD: net_stats.h,v 1.5 2020/01/29 03:04:55 thorpej Exp $ */
+/* $NetBSD: net_stats.h,v 1.6 2024/06/29 13:01:30 riastradh Exp $ */
/*-
* Copyright (c) 2008, 2020 The NetBSD Foundation, Inc.
@@ -35,14 +35,21 @@
#ifdef _KERNEL
#include <sys/percpu.h>
-typedef void *net_stat_ref_t;
+typedef struct net_stat_ref {
+ /*
+ * Flexible array member annoyingly requires some other
+ * non-flexible array member.
+ */
+ uint64_t nsr_stat[1];
+ uint64_t nsr_stats[];
+} *net_stat_ref_t;
#define _NET_STAT_GETREF(stat) ((net_stat_ref_t)percpu_getref((stat)))
#define _NET_STAT_PUTREF(stat) percpu_putref((stat))
#define _NET_STATINC_REF(r, x) \
do { \
- uint64_t *_stat_ = (r); \
+ uint64_t *_stat_ = (r)->nsr_stat; \
_stat_[x]++; \
} while (/*CONSTCOND*/0)
@@ -55,7 +62,7 @@ do { \
#define _NET_STATDEC_REF(r, x) \
do { \
- uint64_t *_stat_ = (r); \
+ uint64_t *_stat_ = (r)->nsr_stat; \
_stat_[x]--; \
} while (/*CONSTCOND*/0)
@@ -68,7 +75,7 @@ do { \
#define _NET_STATADD_REF(r, x, v) \
do { \
- uint64_t *_stat_ = (r); \
+ uint64_t *_stat_ = (r)->nsr_stat; \
_stat_[x] += (v); \
} while (/*CONSTCOND*/0)
@@ -81,7 +88,7 @@ do { \
#define _NET_STATSUB_REF(r, x, v) \
do { \
- uint64_t *_stat_ = (r); \
+ uint64_t *_stat_ = (r)->nsr_stat; \
_stat_[x] -= (v); \
} while (/*CONSTCOND*/0)