160727d8bSWarner Losh /*-
251369649SPedro F. Giffuni * SPDX-License-Identifier: BSD-3-Clause
351369649SPedro F. Giffuni *
4df8bae1dSRodney W. Grimes * Copyright (c) 1989, 1993
5df8bae1dSRodney W. Grimes * The Regents of the University of California. All rights reserved.
6df8bae1dSRodney W. Grimes *
7df8bae1dSRodney W. Grimes * This code is derived from software contributed to Berkeley by
8df8bae1dSRodney W. Grimes * Mike Karels at Berkeley Software Design, Inc.
9df8bae1dSRodney W. Grimes *
10df8bae1dSRodney W. Grimes * Redistribution and use in source and binary forms, with or without
11df8bae1dSRodney W. Grimes * modification, are permitted provided that the following conditions
12df8bae1dSRodney W. Grimes * are met:
13df8bae1dSRodney W. Grimes * 1. Redistributions of source code must retain the above copyright
14df8bae1dSRodney W. Grimes * notice, this list of conditions and the following disclaimer.
15df8bae1dSRodney W. Grimes * 2. Redistributions in binary form must reproduce the above copyright
16df8bae1dSRodney W. Grimes * notice, this list of conditions and the following disclaimer in the
17df8bae1dSRodney W. Grimes * documentation and/or other materials provided with the distribution.
18fbbd9655SWarner Losh * 3. Neither the name of the University nor the names of its contributors
19df8bae1dSRodney W. Grimes * may be used to endorse or promote products derived from this software
20df8bae1dSRodney W. Grimes * without specific prior written permission.
21df8bae1dSRodney W. Grimes *
22df8bae1dSRodney W. Grimes * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
23df8bae1dSRodney W. Grimes * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24df8bae1dSRodney W. Grimes * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
25df8bae1dSRodney W. Grimes * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
26df8bae1dSRodney W. Grimes * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27df8bae1dSRodney W. Grimes * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
28df8bae1dSRodney W. Grimes * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
29df8bae1dSRodney W. Grimes * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30df8bae1dSRodney W. Grimes * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
31df8bae1dSRodney W. Grimes * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
32df8bae1dSRodney W. Grimes * SUCH DAMAGE.
33df8bae1dSRodney W. Grimes */
34df8bae1dSRodney W. Grimes
35df8bae1dSRodney W. Grimes #ifndef _SYS_SYSCTL_H_
36df8bae1dSRodney W. Grimes #define _SYS_SYSCTL_H_
37df8bae1dSRodney W. Grimes
386bff85ffSDag-Erling Smørgrav #ifdef _KERNEL
39fc1901abSJohn Baldwin #include <sys/queue.h>
40d3f96f66SAlan Somers #include <sys/tree.h>
416bff85ffSDag-Erling Smørgrav #endif
428a6472b7SPeter Dufault
43df8bae1dSRodney W. Grimes /*
44df8bae1dSRodney W. Grimes * Definitions for sysctl call. The sysctl call uses a hierarchical name
45df8bae1dSRodney W. Grimes * for objects that can be examined or modified. The name is expressed as
46df8bae1dSRodney W. Grimes * a sequence of integers. Like a file path name, the meaning of each
47df8bae1dSRodney W. Grimes * component depends on its place in the hierarchy. The top-level and kern
48df8bae1dSRodney W. Grimes * identifiers are defined here, and other identifiers are defined in the
49df8bae1dSRodney W. Grimes * respective subsystem header files.
5099eefc72SWarner Losh *
5199eefc72SWarner Losh * Each subsystem defined by sysctl defines a list of variables for that
5299eefc72SWarner Losh * subsystem. Each name is either a node with further levels defined below it,
5399eefc72SWarner Losh * or it is a leaf of some particular type given below. Each sysctl level
5499eefc72SWarner Losh * defines a set of name/type pairs to be used by sysctl(8) in manipulating the
5599eefc72SWarner Losh * subsystem.
56df8bae1dSRodney W. Grimes */
57df8bae1dSRodney W. Grimes
5876364053SDag-Erling Smørgrav #define CTL_MAXNAME 24 /* largest number of components supported */
59df8bae1dSRodney W. Grimes
6043688a78SPawel Jakub Dawidek #define CTLTYPE 0xf /* mask for the type */
61df8bae1dSRodney W. Grimes #define CTLTYPE_NODE 1 /* name is a node */
62df8bae1dSRodney W. Grimes #define CTLTYPE_INT 2 /* name describes an integer */
63df8bae1dSRodney W. Grimes #define CTLTYPE_STRING 3 /* name describes a string */
64cbc134adSMatthew D Fleming #define CTLTYPE_S64 4 /* name describes a signed 64-bit number */
65b396cd83SPoul-Henning Kamp #define CTLTYPE_OPAQUE 5 /* name describes a structure */
66b396cd83SPoul-Henning Kamp #define CTLTYPE_STRUCT CTLTYPE_OPAQUE /* name describes a structure */
677b32dc4eSJim Pirzyk #define CTLTYPE_UINT 6 /* name describes an unsigned integer */
687b32dc4eSJim Pirzyk #define CTLTYPE_LONG 7 /* name describes a long */
697b32dc4eSJim Pirzyk #define CTLTYPE_ULONG 8 /* name describes an unsigned long */
70cbc134adSMatthew D Fleming #define CTLTYPE_U64 9 /* name describes an unsigned 64-bit number */
71c3220d0bSConrad Meyer #define CTLTYPE_U8 0xa /* name describes an unsigned 8-bit number */
72c3220d0bSConrad Meyer #define CTLTYPE_U16 0xb /* name describes an unsigned 16-bit number */
73be87839eSConrad Meyer #define CTLTYPE_S8 0xc /* name describes a signed 8-bit number */
74be87839eSConrad Meyer #define CTLTYPE_S16 0xd /* name describes a signed 16-bit number */
75be87839eSConrad Meyer #define CTLTYPE_S32 0xe /* name describes a signed 32-bit number */
76be87839eSConrad Meyer #define CTLTYPE_U32 0xf /* name describes an unsigned 32-bit number */
77b396cd83SPoul-Henning Kamp
78b396cd83SPoul-Henning Kamp #define CTLFLAG_RD 0x80000000 /* Allow reads of variable */
79b396cd83SPoul-Henning Kamp #define CTLFLAG_WR 0x40000000 /* Allow writes to the variable */
80b396cd83SPoul-Henning Kamp #define CTLFLAG_RW (CTLFLAG_RD|CTLFLAG_WR)
81693593b6SAndriy Gapon #define CTLFLAG_DORMANT 0x20000000 /* This sysctl is not active yet */
823ac9f819SPoul-Henning Kamp #define CTLFLAG_ANYBODY 0x10000000 /* All users can set this var */
832b648ac0SDon Lewis #define CTLFLAG_SECURE 0x08000000 /* Permit set only if securelevel<=0 */
8475c13541SPoul-Henning Kamp #define CTLFLAG_PRISON 0x04000000 /* Prisoned roots can fiddle */
85bd3cdc31SAndrzej Bialecki #define CTLFLAG_DYN 0x02000000 /* Dynamic oid - can be freed */
86306e6b83SMaxime Henrion #define CTLFLAG_SKIP 0x01000000 /* Skip this sysctl when listing */
87fe41ca53SMatthew Dillon #define CTLMASK_SECURE 0x00F00000 /* Secure level */
88af3b2549SHans Petter Selasky #define CTLFLAG_TUN 0x00080000 /* Default value is loaded from getenv() */
898c024896SPawel Jakub Dawidek #define CTLFLAG_RDTUN (CTLFLAG_RD|CTLFLAG_TUN)
908c024896SPawel Jakub Dawidek #define CTLFLAG_RWTUN (CTLFLAG_RW|CTLFLAG_TUN)
911e99191dSJohn Baldwin #define CTLFLAG_MPSAFE 0x00040000 /* Handler is MP safe */
92eb79e1c7SBjoern A. Zeeb #define CTLFLAG_VNET 0x00020000 /* Prisons with vnet can fiddle */
9343688a78SPawel Jakub Dawidek #define CTLFLAG_DYING 0x00010000 /* Oid is being removed */
94ff66f6a4SRobert Watson #define CTLFLAG_CAPRD 0x00008000 /* Can be read in capability mode */
95ff66f6a4SRobert Watson #define CTLFLAG_CAPWR 0x00004000 /* Can be written in capability mode */
9665d2eae1SAlfred Perlstein #define CTLFLAG_STATS 0x00002000 /* Statistics, not a tuneable */
97af3b2549SHans Petter Selasky #define CTLFLAG_NOFETCH 0x00001000 /* Don't fetch tunable from getenv() */
98ff66f6a4SRobert Watson #define CTLFLAG_CAPRW (CTLFLAG_CAPRD|CTLFLAG_CAPWR)
99210176adSPawel Biernacki /*
100210176adSPawel Biernacki * This is transient flag to be used until all sysctl handlers are converted
101210176adSPawel Biernacki * to not lock Giant.
102210176adSPawel Biernacki * One, and only one of CTLFLAG_MPSAFE or CTLFLAG_NEEDGIANT is required
103210176adSPawel Biernacki * for SYSCTL_PROC and SYSCTL_NODE.
104210176adSPawel Biernacki */
105210176adSPawel Biernacki #define CTLFLAG_NEEDGIANT 0x00000800 /* Handler require Giant */
106fe41ca53SMatthew Dillon
107fe41ca53SMatthew Dillon /*
108fe41ca53SMatthew Dillon * Secure level. Note that CTLFLAG_SECURE == CTLFLAG_SECURE1.
109fe41ca53SMatthew Dillon *
110fe41ca53SMatthew Dillon * Secure when the securelevel is raised to at least N.
111fe41ca53SMatthew Dillon */
112fe41ca53SMatthew Dillon #define CTLSHIFT_SECURE 20
113fe41ca53SMatthew Dillon #define CTLFLAG_SECURE1 (CTLFLAG_SECURE | (0 << CTLSHIFT_SECURE))
114fe41ca53SMatthew Dillon #define CTLFLAG_SECURE2 (CTLFLAG_SECURE | (1 << CTLSHIFT_SECURE))
115fe41ca53SMatthew Dillon #define CTLFLAG_SECURE3 (CTLFLAG_SECURE | (2 << CTLSHIFT_SECURE))
116b396cd83SPoul-Henning Kamp
11775680b05SJulian Elischer /*
11875680b05SJulian Elischer * USE THIS instead of a hardwired number from the categories below
11975680b05SJulian Elischer * to get dynamically assigned sysctl entries using the linker-set
12075680b05SJulian Elischer * technology. This is the way nearly all new sysctl variables should
1218a6472b7SPeter Dufault * be implemented.
12275680b05SJulian Elischer * e.g. SYSCTL_INT(_parent, OID_AUTO, name, CTLFLAG_RW, &variable, 0, "");
12375680b05SJulian Elischer */
124cfe25876SPoul-Henning Kamp #define OID_AUTO (-1)
125cfe25876SPoul-Henning Kamp
1267ca4d05fSPeter Pentchev /*
1277ca4d05fSPeter Pentchev * The starting number for dynamically-assigned entries. WARNING!
1287ca4d05fSPeter Pentchev * ALL static sysctl entries should have numbers LESS than this!
1297ca4d05fSPeter Pentchev */
1307ca4d05fSPeter Pentchev #define CTL_AUTO_START 0x100
1317ca4d05fSPeter Pentchev
132664a31e4SPeter Wemm #ifdef _KERNEL
1336dfb79efSJohn Baldwin #include <sys/linker_set.h>
1346dfb79efSJohn Baldwin
1356007751fSHans Petter Selasky #ifdef KLD_MODULE
1366007751fSHans Petter Selasky /* XXX allow overspecification of type in external kernel modules */
1376007751fSHans Petter Selasky #define SYSCTL_CT_ASSERT_MASK CTLTYPE
1386007751fSHans Petter Selasky #else
1396007751fSHans Petter Selasky #define SYSCTL_CT_ASSERT_MASK 0
1406007751fSHans Petter Selasky #endif
1416007751fSHans Petter Selasky
142e4cd31ddSJeff Roberson #define SYSCTL_HANDLER_ARGS struct sysctl_oid *oidp, void *arg1, \
143e072f955SConrad Meyer intmax_t arg2, struct sysctl_req *req
144b396cd83SPoul-Henning Kamp
1455be99846SBruce M Simpson /* definitions for sysctl_req 'lock' member */
14673d6f851SMatthew D Fleming #define REQ_UNWIRED 1
14773d6f851SMatthew D Fleming #define REQ_WIRED 2
1485be99846SBruce M Simpson
149a7bc3102SPeter Wemm /* definitions for sysctl_req 'flags' member */
1504ec9d137SBrooks Davis #ifdef COMPAT_FREEBSD32
151a7bc3102SPeter Wemm #define SCTL_MASK32 1 /* 32 bit emulation */
152a7bc3102SPeter Wemm #endif
153a7bc3102SPeter Wemm
154ae0eb976SPoul-Henning Kamp /*
155ae0eb976SPoul-Henning Kamp * This describes the access space for a sysctl request. This is needed
156ae0eb976SPoul-Henning Kamp * so that we can use the interface from the kernel or from user-space.
157ae0eb976SPoul-Henning Kamp */
15899eefc72SWarner Losh struct thread;
159ae0eb976SPoul-Henning Kamp struct sysctl_req {
160ce178806SRobert Watson struct thread *td; /* used for access checking */
16173d6f851SMatthew D Fleming int lock; /* wiring state */
162ae0eb976SPoul-Henning Kamp void *oldptr;
163069e9bc1SDoug Rabson size_t oldlen;
164069e9bc1SDoug Rabson size_t oldidx;
165069e9bc1SDoug Rabson int (*oldfunc)(struct sysctl_req *, const void *, size_t);
16610f7b12cSBrooks Davis const void *newptr;
167069e9bc1SDoug Rabson size_t newlen;
168069e9bc1SDoug Rabson size_t newidx;
169069e9bc1SDoug Rabson int (*newfunc)(struct sysctl_req *, void *, size_t);
170a961520cSDon Lewis size_t validlen;
171a7bc3102SPeter Wemm int flags;
172ae0eb976SPoul-Henning Kamp };
173ae0eb976SPoul-Henning Kamp
174d3f96f66SAlan Somers struct sysctl_oid;
175d3f96f66SAlan Somers
176d3f96f66SAlan Somers /* RB Tree handling */
177d3f96f66SAlan Somers RB_HEAD(sysctl_oid_list, sysctl_oid);
178ce02431fSDoug Rabson
179ae0eb976SPoul-Henning Kamp /*
180ae0eb976SPoul-Henning Kamp * This describes one "oid" in the MIB tree. Potentially more nodes can
181ae0eb976SPoul-Henning Kamp * be hidden behind it, expanded by the handler.
182ae0eb976SPoul-Henning Kamp */
183b396cd83SPoul-Henning Kamp struct sysctl_oid {
184af3b2549SHans Petter Selasky struct sysctl_oid_list oid_children;
185ce02431fSDoug Rabson struct sysctl_oid_list* oid_parent;
186d3f96f66SAlan Somers RB_ENTRY(sysctl_oid) oid_link;
187d3f96f66SAlan Somers /* Sort key for all siblings, and lookup key for userland */
188b396cd83SPoul-Henning Kamp int oid_number;
189f0d2d038SMark Murray u_int oid_kind;
190b396cd83SPoul-Henning Kamp void *oid_arg1;
191e072f955SConrad Meyer intmax_t oid_arg2;
192d3f96f66SAlan Somers /* Must be unique amongst all siblings. */
193946bb7a2SPoul-Henning Kamp const char *oid_name;
19482d9ae4eSPoul-Henning Kamp int (*oid_handler)(SYSCTL_HANDLER_ARGS);
195946bb7a2SPoul-Henning Kamp const char *oid_fmt;
196bd3cdc31SAndrzej Bialecki int oid_refcnt;
197ccecef29SMatthew D Fleming u_int oid_running;
1985937226dSPoul-Henning Kamp const char *oid_descr;
1991e1f3941SEd Schouten const char *oid_label;
200b396cd83SPoul-Henning Kamp };
2013a34a5c3SPoul-Henning Kamp
202d3f96f66SAlan Somers static inline int
cmp_sysctl_oid(struct sysctl_oid * a,struct sysctl_oid * b)203d3f96f66SAlan Somers cmp_sysctl_oid(struct sysctl_oid *a, struct sysctl_oid *b)
204d3f96f66SAlan Somers {
205d3f96f66SAlan Somers if (a->oid_number > b->oid_number)
206d3f96f66SAlan Somers return (1);
207d3f96f66SAlan Somers else if (a->oid_number < b->oid_number)
208d3f96f66SAlan Somers return (-1);
209d3f96f66SAlan Somers else
210d3f96f66SAlan Somers return (0);
211d3f96f66SAlan Somers }
212d3f96f66SAlan Somers
213d3f96f66SAlan Somers RB_PROTOTYPE(sysctl_oid_list, sysctl_oid, oid_link, cmp_sysctl_oid);
214d3f96f66SAlan Somers
215ae0eb976SPoul-Henning Kamp #define SYSCTL_IN(r, p, l) (r->newfunc)(r, p, l)
216ae0eb976SPoul-Henning Kamp #define SYSCTL_OUT(r, p, l) (r->oldfunc)(r, p, l)
2178a0d2c61SIan Lepore #define SYSCTL_OUT_STR(r, p) (r->oldfunc)(r, p, strlen(p) + 1)
218ae0eb976SPoul-Henning Kamp
21984e717c4SHans Petter Selasky int sysctl_handle_bool(SYSCTL_HANDLER_ARGS);
220c3220d0bSConrad Meyer int sysctl_handle_8(SYSCTL_HANDLER_ARGS);
221c3220d0bSConrad Meyer int sysctl_handle_16(SYSCTL_HANDLER_ARGS);
222be87839eSConrad Meyer int sysctl_handle_32(SYSCTL_HANDLER_ARGS);
223be87839eSConrad Meyer int sysctl_handle_64(SYSCTL_HANDLER_ARGS);
22482d9ae4eSPoul-Henning Kamp int sysctl_handle_int(SYSCTL_HANDLER_ARGS);
225a4684d74SAndre Oppermann int sysctl_msec_to_ticks(SYSCTL_HANDLER_ARGS);
22682d9ae4eSPoul-Henning Kamp int sysctl_handle_long(SYSCTL_HANDLER_ARGS);
22782d9ae4eSPoul-Henning Kamp int sysctl_handle_string(SYSCTL_HANDLER_ARGS);
22882d9ae4eSPoul-Henning Kamp int sysctl_handle_opaque(SYSCTL_HANDLER_ARGS);
2294e76af6aSGleb Smirnoff int sysctl_handle_counter_u64(SYSCTL_HANDLER_ARGS);
230b5b7b142SGleb Smirnoff int sysctl_handle_counter_u64_array(SYSCTL_HANDLER_ARGS);
231b396cd83SPoul-Henning Kamp
2320a5a3ccbSGleb Smirnoff int sysctl_handle_uma_zone_max(SYSCTL_HANDLER_ARGS);
2330a5a3ccbSGleb Smirnoff int sysctl_handle_uma_zone_cur(SYSCTL_HANDLER_ARGS);
2340a5a3ccbSGleb Smirnoff
235003ffd57SWarner Losh int sysctl_msec_to_sbintime(SYSCTL_HANDLER_ARGS);
236003ffd57SWarner Losh int sysctl_usec_to_sbintime(SYSCTL_HANDLER_ARGS);
2370f702183SJohn Baldwin int sysctl_sec_to_timeval(SYSCTL_HANDLER_ARGS);
238003ffd57SWarner Losh
23950c202c5SJeff Roberson int sysctl_dpcpu_int(SYSCTL_HANDLER_ARGS);
240e6e06a8bSJeff Roberson int sysctl_dpcpu_long(SYSCTL_HANDLER_ARGS);
24150c202c5SJeff Roberson int sysctl_dpcpu_quad(SYSCTL_HANDLER_ARGS);
24250c202c5SJeff Roberson
243ce02431fSDoug Rabson /*
244ce02431fSDoug Rabson * These functions are used to add/remove an oid from the mib.
245ce02431fSDoug Rabson */
246ce02431fSDoug Rabson void sysctl_register_oid(struct sysctl_oid *oidp);
247693593b6SAndriy Gapon void sysctl_register_disabled_oid(struct sysctl_oid *oidp);
248693593b6SAndriy Gapon void sysctl_enable_oid(struct sysctl_oid *oidp);
249ce02431fSDoug Rabson void sysctl_unregister_oid(struct sysctl_oid *oidp);
250ce02431fSDoug Rabson
251bd3cdc31SAndrzej Bialecki /* Declare a static oid to allow child oids to be added to it. */
252ce02431fSDoug Rabson #define SYSCTL_DECL(name) \
253af3b2549SHans Petter Selasky extern struct sysctl_oid sysctl__##name
254ce02431fSDoug Rabson
25543688a78SPawel Jakub Dawidek /* Hide these in macros. */
256af3b2549SHans Petter Selasky #define SYSCTL_CHILDREN(oid_ptr) (&(oid_ptr)->oid_children)
257af3b2549SHans Petter Selasky #define SYSCTL_PARENT(oid_ptr) \
258af3b2549SHans Petter Selasky (((oid_ptr)->oid_parent != &sysctl__children) ? \
259af3b2549SHans Petter Selasky __containerof((oid_ptr)->oid_parent, struct sysctl_oid, \
260af3b2549SHans Petter Selasky oid_children) : (struct sysctl_oid *)NULL)
261af3b2549SHans Petter Selasky #define SYSCTL_STATIC_CHILDREN(oid_name) (&sysctl__##oid_name.oid_children)
262bd3cdc31SAndrzej Bialecki
26343688a78SPawel Jakub Dawidek /* === Structs and macros related to context handling. === */
264bd3cdc31SAndrzej Bialecki
265bd3cdc31SAndrzej Bialecki /* All dynamically created sysctls can be tracked in a context list. */
266bd3cdc31SAndrzej Bialecki struct sysctl_ctx_entry {
267bd3cdc31SAndrzej Bialecki struct sysctl_oid *entry;
268bd3cdc31SAndrzej Bialecki TAILQ_ENTRY(sysctl_ctx_entry) link;
269bd3cdc31SAndrzej Bialecki };
270bd3cdc31SAndrzej Bialecki
271bd3cdc31SAndrzej Bialecki TAILQ_HEAD(sysctl_ctx_list, sysctl_ctx_entry);
272bd3cdc31SAndrzej Bialecki
2734bf2855cSJake Burkholder #define SYSCTL_NODE_CHILDREN(parent, name) \
274af3b2549SHans Petter Selasky sysctl__##parent##_##name.oid_children
2754bf2855cSJake Burkholder
27616c84e5eSWarner Losh #ifndef NO_SYSCTL_DESCR
27716c84e5eSWarner Losh #define __DESCR(d) d
27816c84e5eSWarner Losh #else
27916c84e5eSWarner Losh #define __DESCR(d) ""
28016c84e5eSWarner Losh #endif
28116c84e5eSWarner Losh
282210176adSPawel Biernacki #ifdef notyet
283210176adSPawel Biernacki #define SYSCTL_ENFORCE_FLAGS(x) \
28496592b7aSPawel Biernacki _Static_assert((((x) & CTLFLAG_MPSAFE) != 0) ^ (((x) & CTLFLAG_NEEDGIANT) != 0), \
285210176adSPawel Biernacki "Has to be either CTLFLAG_MPSAFE or CTLFLAG_NEEDGIANT")
286210176adSPawel Biernacki #else
287210176adSPawel Biernacki #define SYSCTL_ENFORCE_FLAGS(x)
288210176adSPawel Biernacki #endif
289210176adSPawel Biernacki
290af3b2549SHans Petter Selasky /* This macro is only for internal use */
2911e1f3941SEd Schouten #define SYSCTL_OID_RAW(id, parent_child_head, nbr, name, kind, a1, a2, handler, fmt, descr, label) \
292af3b2549SHans Petter Selasky struct sysctl_oid id = { \
293af3b2549SHans Petter Selasky .oid_parent = (parent_child_head), \
294d3f96f66SAlan Somers .oid_children = RB_INITIALIZER(&id.oid_children), \
295f5e153b0SHans Petter Selasky .oid_number = (nbr), \
296f5e153b0SHans Petter Selasky .oid_kind = (kind), \
297f5e153b0SHans Petter Selasky .oid_arg1 = (a1), \
298f5e153b0SHans Petter Selasky .oid_arg2 = (a2), \
299af3b2549SHans Petter Selasky .oid_name = (name), \
300f5e153b0SHans Petter Selasky .oid_handler = (handler), \
301f5e153b0SHans Petter Selasky .oid_fmt = (fmt), \
3021e1f3941SEd Schouten .oid_descr = __DESCR(descr), \
3031e1f3941SEd Schouten .oid_label = (label), \
30443688a78SPawel Jakub Dawidek }; \
305210176adSPawel Biernacki DATA_SET(sysctl_set, id); \
306210176adSPawel Biernacki SYSCTL_ENFORCE_FLAGS(kind)
307af3b2549SHans Petter Selasky
308af3b2549SHans Petter Selasky /* This constructs a static "raw" MIB oid. */
309af3b2549SHans Petter Selasky #define SYSCTL_OID(parent, nbr, name, kind, a1, a2, handler, fmt, descr) \
3101e1f3941SEd Schouten SYSCTL_OID_WITH_LABEL(parent, nbr, name, kind, a1, a2, \
3111e1f3941SEd Schouten handler, fmt, descr, NULL)
3121e1f3941SEd Schouten
3131e1f3941SEd Schouten #define SYSCTL_OID_WITH_LABEL(parent, nbr, name, kind, a1, a2, handler, fmt, descr, label) \
314af3b2549SHans Petter Selasky static SYSCTL_OID_RAW(sysctl__##parent##_##name, \
315af3b2549SHans Petter Selasky SYSCTL_CHILDREN(&sysctl__##parent), \
3161e1f3941SEd Schouten nbr, #name, kind, a1, a2, handler, fmt, descr, label)
317af3b2549SHans Petter Selasky
318af3b2549SHans Petter Selasky /* This constructs a global "raw" MIB oid. */
3191e1f3941SEd Schouten #define SYSCTL_OID_GLOBAL(parent, nbr, name, kind, a1, a2, handler, fmt, descr, label) \
320af3b2549SHans Petter Selasky SYSCTL_OID_RAW(sysctl__##parent##_##name, \
321af3b2549SHans Petter Selasky SYSCTL_CHILDREN(&sysctl__##parent), \
3221e1f3941SEd Schouten nbr, #name, kind, a1, a2, handler, fmt, descr, label)
323b396cd83SPoul-Henning Kamp
324bd3cdc31SAndrzej Bialecki #define SYSCTL_ADD_OID(ctx, parent, nbr, name, kind, a1, a2, handler, fmt, descr) \
325210176adSPawel Biernacki ({ \
326210176adSPawel Biernacki SYSCTL_ENFORCE_FLAGS(kind); \
327210176adSPawel Biernacki sysctl_add_oid(ctx, parent, nbr, name, kind, a1, a2,handler, \
328210176adSPawel Biernacki fmt, __DESCR(descr), NULL); \
329210176adSPawel Biernacki })
330bd3cdc31SAndrzej Bialecki
331af3b2549SHans Petter Selasky /* This constructs a root node from which other nodes can hang. */
332af3b2549SHans Petter Selasky #define SYSCTL_ROOT_NODE(nbr, name, access, handler, descr) \
333af3b2549SHans Petter Selasky SYSCTL_OID_RAW(sysctl___##name, &sysctl__children, \
334af3b2549SHans Petter Selasky nbr, #name, CTLTYPE_NODE|(access), NULL, 0, \
3351e1f3941SEd Schouten handler, "N", descr, NULL); \
3366007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
3376007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_NODE)
338af3b2549SHans Petter Selasky
3396ade4cf7SBruce Evans /* This constructs a node from which other oids can hang. */
340946bb7a2SPoul-Henning Kamp #define SYSCTL_NODE(parent, nbr, name, access, handler, descr) \
3411e1f3941SEd Schouten SYSCTL_NODE_WITH_LABEL(parent, nbr, name, access, handler, descr, NULL)
3421e1f3941SEd Schouten
3431e1f3941SEd Schouten #define SYSCTL_NODE_WITH_LABEL(parent, nbr, name, access, handler, descr, label) \
344af3b2549SHans Petter Selasky SYSCTL_OID_GLOBAL(parent, nbr, name, CTLTYPE_NODE|(access), \
3451e1f3941SEd Schouten NULL, 0, handler, "N", descr, label); \
346d0c58a23SPawel Biernacki SYSCTL_ENFORCE_FLAGS(access); \
3476007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
3486007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_NODE)
349b396cd83SPoul-Henning Kamp
350bd3cdc31SAndrzej Bialecki #define SYSCTL_ADD_NODE(ctx, parent, nbr, name, access, handler, descr) \
3511e1f3941SEd Schouten SYSCTL_ADD_NODE_WITH_LABEL(ctx, parent, nbr, name, access, \
3521e1f3941SEd Schouten handler, descr, NULL)
3531e1f3941SEd Schouten
3541e1f3941SEd Schouten #define SYSCTL_ADD_NODE_WITH_LABEL(ctx, parent, nbr, name, access, handler, descr, label) \
355f0188618SHans Petter Selasky ({ \
3566007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
3576007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_NODE); \
358210176adSPawel Biernacki SYSCTL_ENFORCE_FLAGS(access); \
359d8be0570SPoul-Henning Kamp sysctl_add_oid(ctx, parent, nbr, name, CTLTYPE_NODE|(access), \
3601e1f3941SEd Schouten NULL, 0, handler, "N", __DESCR(descr), label); \
361f0188618SHans Petter Selasky })
362bd3cdc31SAndrzej Bialecki
3634813ad54SHans Petter Selasky #define SYSCTL_ADD_ROOT_NODE(ctx, nbr, name, access, handler, descr) \
364f0188618SHans Petter Selasky ({ \
3656007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
3666007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_NODE); \
367210176adSPawel Biernacki SYSCTL_ENFORCE_FLAGS(access); \
3684813ad54SHans Petter Selasky sysctl_add_oid(ctx, &sysctl__children, nbr, name, \
369f0188618SHans Petter Selasky CTLTYPE_NODE|(access), \
3701e1f3941SEd Schouten NULL, 0, handler, "N", __DESCR(descr), NULL); \
371f0188618SHans Petter Selasky })
3724813ad54SHans Petter Selasky
3736ade4cf7SBruce Evans /* Oid for a string. len can be 0 to indicate '\0' termination. */
374946bb7a2SPoul-Henning Kamp #define SYSCTL_STRING(parent, nbr, name, access, arg, len, descr) \
375210176adSPawel Biernacki SYSCTL_OID(parent, nbr, name, \
376210176adSPawel Biernacki CTLTYPE_STRING | CTLFLAG_MPSAFE | (access), \
377f0188618SHans Petter Selasky arg, len, sysctl_handle_string, "A", descr); \
3786007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
3796007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_STRING)
380b396cd83SPoul-Henning Kamp
381bd3cdc31SAndrzej Bialecki #define SYSCTL_ADD_STRING(ctx, parent, nbr, name, access, arg, len, descr) \
382f0188618SHans Petter Selasky ({ \
383f0188618SHans Petter Selasky char *__arg = (arg); \
3846007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
3856007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_STRING); \
386210176adSPawel Biernacki sysctl_add_oid(ctx, parent, nbr, name, \
387210176adSPawel Biernacki CTLTYPE_STRING | CTLFLAG_MPSAFE | (access), \
3881e1f3941SEd Schouten __arg, len, sysctl_handle_string, "A", __DESCR(descr), \
3891e1f3941SEd Schouten NULL); \
390f0188618SHans Petter Selasky })
391bd3cdc31SAndrzej Bialecki
39210a1e981SEric Joyner /* Oid for a constant '\0' terminated string. */
39310a1e981SEric Joyner #define SYSCTL_CONST_STRING(parent, nbr, name, access, arg, descr) \
39476a49ebaSMateusz Guzik SYSCTL_OID(parent, nbr, name, CTLTYPE_STRING | CTLFLAG_MPSAFE | (access),\
39510a1e981SEric Joyner __DECONST(char *, arg), 0, sysctl_handle_string, "A", descr); \
39623f4131aSZhenlei Huang CTASSERT(!((access) & CTLFLAG_WR)); \
39710a1e981SEric Joyner CTASSERT(((access) & CTLTYPE) == 0 || \
39810a1e981SEric Joyner ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_STRING)
39910a1e981SEric Joyner
40010a1e981SEric Joyner #define SYSCTL_ADD_CONST_STRING(ctx, parent, nbr, name, access, arg, descr) \
40110a1e981SEric Joyner ({ \
40210a1e981SEric Joyner char *__arg = __DECONST(char *, arg); \
40323f4131aSZhenlei Huang CTASSERT(!((access) & CTLFLAG_WR)); \
40410a1e981SEric Joyner CTASSERT(((access) & CTLTYPE) == 0 || \
40510a1e981SEric Joyner ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_STRING); \
40676a49ebaSMateusz Guzik sysctl_add_oid(ctx, parent, nbr, name, CTLTYPE_STRING | \
40776a49ebaSMateusz Guzik CTLFLAG_MPSAFE | (access), __arg, 0, sysctl_handle_string, "A",\
40876a49ebaSMateusz Guzik __DESCR(descr), NULL); \
40910a1e981SEric Joyner })
41010a1e981SEric Joyner
41184e717c4SHans Petter Selasky /* Oid for a bool. If ptr is NULL, val is returned. */
41284e717c4SHans Petter Selasky #define SYSCTL_NULL_BOOL_PTR ((bool *)NULL)
41384e717c4SHans Petter Selasky #define SYSCTL_BOOL(parent, nbr, name, access, ptr, val, descr) \
41484e717c4SHans Petter Selasky SYSCTL_OID(parent, nbr, name, \
41584e717c4SHans Petter Selasky CTLTYPE_U8 | CTLFLAG_MPSAFE | (access), \
41684e717c4SHans Petter Selasky ptr, val, sysctl_handle_bool, "CU", descr); \
41784e717c4SHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 && \
41884e717c4SHans Petter Selasky sizeof(bool) == sizeof(*(ptr)))
41984e717c4SHans Petter Selasky
42084e717c4SHans Petter Selasky #define SYSCTL_ADD_BOOL(ctx, parent, nbr, name, access, ptr, val, descr) \
42184e717c4SHans Petter Selasky ({ \
42284e717c4SHans Petter Selasky bool *__ptr = (ptr); \
42384e717c4SHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0); \
42484e717c4SHans Petter Selasky sysctl_add_oid(ctx, parent, nbr, name, \
42584e717c4SHans Petter Selasky CTLTYPE_U8 | CTLFLAG_MPSAFE | (access), \
4261e1f3941SEd Schouten __ptr, val, sysctl_handle_bool, "CU", __DESCR(descr), \
4271e1f3941SEd Schouten NULL); \
42884e717c4SHans Petter Selasky })
42984e717c4SHans Petter Selasky
430be87839eSConrad Meyer /* Oid for a signed 8-bit int. If ptr is NULL, val is returned. */
431e072f955SConrad Meyer #define SYSCTL_NULL_S8_PTR ((int8_t *)NULL)
432be87839eSConrad Meyer #define SYSCTL_S8(parent, nbr, name, access, ptr, val, descr) \
433be87839eSConrad Meyer SYSCTL_OID(parent, nbr, name, \
434be87839eSConrad Meyer CTLTYPE_S8 | CTLFLAG_MPSAFE | (access), \
435be87839eSConrad Meyer ptr, val, sysctl_handle_8, "C", descr); \
436be87839eSConrad Meyer CTASSERT((((access) & CTLTYPE) == 0 || \
437be87839eSConrad Meyer ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S8) && \
438be87839eSConrad Meyer sizeof(int8_t) == sizeof(*(ptr)))
439be87839eSConrad Meyer
440be87839eSConrad Meyer #define SYSCTL_ADD_S8(ctx, parent, nbr, name, access, ptr, val, descr) \
441be87839eSConrad Meyer ({ \
442be87839eSConrad Meyer int8_t *__ptr = (ptr); \
443be87839eSConrad Meyer CTASSERT(((access) & CTLTYPE) == 0 || \
444be87839eSConrad Meyer ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S8); \
445be87839eSConrad Meyer sysctl_add_oid(ctx, parent, nbr, name, \
446be87839eSConrad Meyer CTLTYPE_S8 | CTLFLAG_MPSAFE | (access), \
4471e1f3941SEd Schouten __ptr, val, sysctl_handle_8, "C", __DESCR(descr), NULL); \
448be87839eSConrad Meyer })
449be87839eSConrad Meyer
450c3220d0bSConrad Meyer /* Oid for an unsigned 8-bit int. If ptr is NULL, val is returned. */
451e072f955SConrad Meyer #define SYSCTL_NULL_U8_PTR ((uint8_t *)NULL)
452c3220d0bSConrad Meyer #define SYSCTL_U8(parent, nbr, name, access, ptr, val, descr) \
453c3220d0bSConrad Meyer SYSCTL_OID(parent, nbr, name, \
454c3220d0bSConrad Meyer CTLTYPE_U8 | CTLFLAG_MPSAFE | (access), \
455c3220d0bSConrad Meyer ptr, val, sysctl_handle_8, "CU", descr); \
456c3220d0bSConrad Meyer CTASSERT((((access) & CTLTYPE) == 0 || \
457c3220d0bSConrad Meyer ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U8) && \
458c3220d0bSConrad Meyer sizeof(uint8_t) == sizeof(*(ptr)))
459c3220d0bSConrad Meyer
460c3220d0bSConrad Meyer #define SYSCTL_ADD_U8(ctx, parent, nbr, name, access, ptr, val, descr) \
461c3220d0bSConrad Meyer ({ \
462c3220d0bSConrad Meyer uint8_t *__ptr = (ptr); \
463c3220d0bSConrad Meyer CTASSERT(((access) & CTLTYPE) == 0 || \
464c3220d0bSConrad Meyer ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U8); \
465c3220d0bSConrad Meyer sysctl_add_oid(ctx, parent, nbr, name, \
466c3220d0bSConrad Meyer CTLTYPE_U8 | CTLFLAG_MPSAFE | (access), \
4671e1f3941SEd Schouten __ptr, val, sysctl_handle_8, "CU", __DESCR(descr), NULL); \
468c3220d0bSConrad Meyer })
469c3220d0bSConrad Meyer
470be87839eSConrad Meyer /* Oid for a signed 16-bit int. If ptr is NULL, val is returned. */
471e072f955SConrad Meyer #define SYSCTL_NULL_S16_PTR ((int16_t *)NULL)
472be87839eSConrad Meyer #define SYSCTL_S16(parent, nbr, name, access, ptr, val, descr) \
473be87839eSConrad Meyer SYSCTL_OID(parent, nbr, name, \
474be87839eSConrad Meyer CTLTYPE_S16 | CTLFLAG_MPSAFE | (access), \
475be87839eSConrad Meyer ptr, val, sysctl_handle_16, "S", descr); \
476be87839eSConrad Meyer CTASSERT((((access) & CTLTYPE) == 0 || \
477be87839eSConrad Meyer ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S16) && \
478be87839eSConrad Meyer sizeof(int16_t) == sizeof(*(ptr)))
479be87839eSConrad Meyer
480be87839eSConrad Meyer #define SYSCTL_ADD_S16(ctx, parent, nbr, name, access, ptr, val, descr) \
481be87839eSConrad Meyer ({ \
482be87839eSConrad Meyer int16_t *__ptr = (ptr); \
483be87839eSConrad Meyer CTASSERT(((access) & CTLTYPE) == 0 || \
484be87839eSConrad Meyer ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S16); \
485be87839eSConrad Meyer sysctl_add_oid(ctx, parent, nbr, name, \
486be87839eSConrad Meyer CTLTYPE_S16 | CTLFLAG_MPSAFE | (access), \
4871e1f3941SEd Schouten __ptr, val, sysctl_handle_16, "S", __DESCR(descr), NULL); \
488be87839eSConrad Meyer })
489be87839eSConrad Meyer
490c3220d0bSConrad Meyer /* Oid for an unsigned 16-bit int. If ptr is NULL, val is returned. */
491e072f955SConrad Meyer #define SYSCTL_NULL_U16_PTR ((uint16_t *)NULL)
492c3220d0bSConrad Meyer #define SYSCTL_U16(parent, nbr, name, access, ptr, val, descr) \
493c3220d0bSConrad Meyer SYSCTL_OID(parent, nbr, name, \
494c3220d0bSConrad Meyer CTLTYPE_U16 | CTLFLAG_MPSAFE | (access), \
495c3220d0bSConrad Meyer ptr, val, sysctl_handle_16, "SU", descr); \
496c3220d0bSConrad Meyer CTASSERT((((access) & CTLTYPE) == 0 || \
497c3220d0bSConrad Meyer ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U16) && \
498c3220d0bSConrad Meyer sizeof(uint16_t) == sizeof(*(ptr)))
499c3220d0bSConrad Meyer
500c3220d0bSConrad Meyer #define SYSCTL_ADD_U16(ctx, parent, nbr, name, access, ptr, val, descr) \
501c3220d0bSConrad Meyer ({ \
502c3220d0bSConrad Meyer uint16_t *__ptr = (ptr); \
503c3220d0bSConrad Meyer CTASSERT(((access) & CTLTYPE) == 0 || \
504c3220d0bSConrad Meyer ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U16); \
505c3220d0bSConrad Meyer sysctl_add_oid(ctx, parent, nbr, name, \
506c3220d0bSConrad Meyer CTLTYPE_U16 | CTLFLAG_MPSAFE | (access), \
5071e1f3941SEd Schouten __ptr, val, sysctl_handle_16, "SU", __DESCR(descr), NULL); \
508c3220d0bSConrad Meyer })
509c3220d0bSConrad Meyer
510be87839eSConrad Meyer /* Oid for a signed 32-bit int. If ptr is NULL, val is returned. */
511e072f955SConrad Meyer #define SYSCTL_NULL_S32_PTR ((int32_t *)NULL)
512be87839eSConrad Meyer #define SYSCTL_S32(parent, nbr, name, access, ptr, val, descr) \
513be87839eSConrad Meyer SYSCTL_OID(parent, nbr, name, \
514be87839eSConrad Meyer CTLTYPE_S32 | CTLFLAG_MPSAFE | (access), \
515be87839eSConrad Meyer ptr, val, sysctl_handle_32, "I", descr); \
516be87839eSConrad Meyer CTASSERT((((access) & CTLTYPE) == 0 || \
517be87839eSConrad Meyer ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S32) && \
518be87839eSConrad Meyer sizeof(int32_t) == sizeof(*(ptr)))
519be87839eSConrad Meyer
520be87839eSConrad Meyer #define SYSCTL_ADD_S32(ctx, parent, nbr, name, access, ptr, val, descr) \
521be87839eSConrad Meyer ({ \
522be87839eSConrad Meyer int32_t *__ptr = (ptr); \
523be87839eSConrad Meyer CTASSERT(((access) & CTLTYPE) == 0 || \
524be87839eSConrad Meyer ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S32); \
525be87839eSConrad Meyer sysctl_add_oid(ctx, parent, nbr, name, \
526be87839eSConrad Meyer CTLTYPE_S32 | CTLFLAG_MPSAFE | (access), \
5271e1f3941SEd Schouten __ptr, val, sysctl_handle_32, "I", __DESCR(descr), NULL); \
528be87839eSConrad Meyer })
529be87839eSConrad Meyer
530be87839eSConrad Meyer /* Oid for an unsigned 32-bit int. If ptr is NULL, val is returned. */
531e072f955SConrad Meyer #define SYSCTL_NULL_U32_PTR ((uint32_t *)NULL)
532be87839eSConrad Meyer #define SYSCTL_U32(parent, nbr, name, access, ptr, val, descr) \
533be87839eSConrad Meyer SYSCTL_OID(parent, nbr, name, \
534be87839eSConrad Meyer CTLTYPE_U32 | CTLFLAG_MPSAFE | (access), \
535be87839eSConrad Meyer ptr, val, sysctl_handle_32, "IU", descr); \
536be87839eSConrad Meyer CTASSERT((((access) & CTLTYPE) == 0 || \
537be87839eSConrad Meyer ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U32) && \
538be87839eSConrad Meyer sizeof(uint32_t) == sizeof(*(ptr)))
539be87839eSConrad Meyer
540be87839eSConrad Meyer #define SYSCTL_ADD_U32(ctx, parent, nbr, name, access, ptr, val, descr) \
541be87839eSConrad Meyer ({ \
542be87839eSConrad Meyer uint32_t *__ptr = (ptr); \
543be87839eSConrad Meyer CTASSERT(((access) & CTLTYPE) == 0 || \
544be87839eSConrad Meyer ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U32); \
545be87839eSConrad Meyer sysctl_add_oid(ctx, parent, nbr, name, \
546be87839eSConrad Meyer CTLTYPE_U32 | CTLFLAG_MPSAFE | (access), \
5471e1f3941SEd Schouten __ptr, val, sysctl_handle_32, "IU", __DESCR(descr), NULL); \
548be87839eSConrad Meyer })
549be87839eSConrad Meyer
550be87839eSConrad Meyer /* Oid for a signed 64-bit int. If ptr is NULL, val is returned. */
551e072f955SConrad Meyer #define SYSCTL_NULL_S64_PTR ((int64_t *)NULL)
552be87839eSConrad Meyer #define SYSCTL_S64(parent, nbr, name, access, ptr, val, descr) \
553be87839eSConrad Meyer SYSCTL_OID(parent, nbr, name, \
554be87839eSConrad Meyer CTLTYPE_S64 | CTLFLAG_MPSAFE | (access), \
555be87839eSConrad Meyer ptr, val, sysctl_handle_64, "Q", descr); \
556be87839eSConrad Meyer CTASSERT((((access) & CTLTYPE) == 0 || \
557be87839eSConrad Meyer ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S64) && \
558be87839eSConrad Meyer sizeof(int64_t) == sizeof(*(ptr)))
559be87839eSConrad Meyer
560be87839eSConrad Meyer #define SYSCTL_ADD_S64(ctx, parent, nbr, name, access, ptr, val, descr) \
561be87839eSConrad Meyer ({ \
562be87839eSConrad Meyer int64_t *__ptr = (ptr); \
563be87839eSConrad Meyer CTASSERT(((access) & CTLTYPE) == 0 || \
564be87839eSConrad Meyer ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S64); \
565be87839eSConrad Meyer sysctl_add_oid(ctx, parent, nbr, name, \
566be87839eSConrad Meyer CTLTYPE_S64 | CTLFLAG_MPSAFE | (access), \
5671e1f3941SEd Schouten __ptr, val, sysctl_handle_64, "Q", __DESCR(descr), NULL); \
568be87839eSConrad Meyer })
569be87839eSConrad Meyer
570be87839eSConrad Meyer /* Oid for an unsigned 64-bit int. If ptr is NULL, val is returned. */
571e072f955SConrad Meyer #define SYSCTL_NULL_U64_PTR ((uint64_t *)NULL)
572be87839eSConrad Meyer #define SYSCTL_U64(parent, nbr, name, access, ptr, val, descr) \
573be87839eSConrad Meyer SYSCTL_OID(parent, nbr, name, \
574be87839eSConrad Meyer CTLTYPE_U64 | CTLFLAG_MPSAFE | (access), \
575be87839eSConrad Meyer ptr, val, sysctl_handle_64, "QU", descr); \
576be87839eSConrad Meyer CTASSERT((((access) & CTLTYPE) == 0 || \
577be87839eSConrad Meyer ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U64) && \
578be87839eSConrad Meyer sizeof(uint64_t) == sizeof(*(ptr)))
579be87839eSConrad Meyer
580be87839eSConrad Meyer #define SYSCTL_ADD_U64(ctx, parent, nbr, name, access, ptr, val, descr) \
581be87839eSConrad Meyer ({ \
582be87839eSConrad Meyer uint64_t *__ptr = (ptr); \
583be87839eSConrad Meyer CTASSERT(((access) & CTLTYPE) == 0 || \
584be87839eSConrad Meyer ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U64); \
585be87839eSConrad Meyer sysctl_add_oid(ctx, parent, nbr, name, \
586be87839eSConrad Meyer CTLTYPE_U64 | CTLFLAG_MPSAFE | (access), \
5871e1f3941SEd Schouten __ptr, val, sysctl_handle_64, "QU", __DESCR(descr), NULL); \
588be87839eSConrad Meyer })
589be87839eSConrad Meyer
590f0188618SHans Petter Selasky /* Oid for an int. If ptr is SYSCTL_NULL_INT_PTR, val is returned. */
591f0188618SHans Petter Selasky #define SYSCTL_NULL_INT_PTR ((int *)NULL)
592946bb7a2SPoul-Henning Kamp #define SYSCTL_INT(parent, nbr, name, access, ptr, val, descr) \
5931e1f3941SEd Schouten SYSCTL_INT_WITH_LABEL(parent, nbr, name, access, ptr, val, descr, NULL)
5941e1f3941SEd Schouten
5951e1f3941SEd Schouten #define SYSCTL_INT_WITH_LABEL(parent, nbr, name, access, ptr, val, descr, label) \
5961e1f3941SEd Schouten SYSCTL_OID_WITH_LABEL(parent, nbr, name, \
5971eae8811SMatthew D Fleming CTLTYPE_INT | CTLFLAG_MPSAFE | (access), \
5981e1f3941SEd Schouten ptr, val, sysctl_handle_int, "I", descr, label); \
599f0efae77SHans Petter Selasky CTASSERT((((access) & CTLTYPE) == 0 || \
600f0efae77SHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_INT) && \
601f0efae77SHans Petter Selasky sizeof(int) == sizeof(*(ptr)))
602b396cd83SPoul-Henning Kamp
603bd3cdc31SAndrzej Bialecki #define SYSCTL_ADD_INT(ctx, parent, nbr, name, access, ptr, val, descr) \
604f0188618SHans Petter Selasky ({ \
605f0188618SHans Petter Selasky int *__ptr = (ptr); \
6066007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
6076007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_INT); \
6081eae8811SMatthew D Fleming sysctl_add_oid(ctx, parent, nbr, name, \
6091eae8811SMatthew D Fleming CTLTYPE_INT | CTLFLAG_MPSAFE | (access), \
6101e1f3941SEd Schouten __ptr, val, sysctl_handle_int, "I", __DESCR(descr), NULL); \
611f0188618SHans Petter Selasky })
612bd3cdc31SAndrzej Bialecki
6139701cd40SJohn Baldwin /* Oid for an unsigned int. If ptr is NULL, val is returned. */
614f0188618SHans Petter Selasky #define SYSCTL_NULL_UINT_PTR ((unsigned *)NULL)
6159701cd40SJohn Baldwin #define SYSCTL_UINT(parent, nbr, name, access, ptr, val, descr) \
6161eae8811SMatthew D Fleming SYSCTL_OID(parent, nbr, name, \
6171eae8811SMatthew D Fleming CTLTYPE_UINT | CTLFLAG_MPSAFE | (access), \
618f0188618SHans Petter Selasky ptr, val, sysctl_handle_int, "IU", descr); \
619f0efae77SHans Petter Selasky CTASSERT((((access) & CTLTYPE) == 0 || \
620f0efae77SHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_UINT) && \
621f0efae77SHans Petter Selasky sizeof(unsigned) == sizeof(*(ptr)))
6229701cd40SJohn Baldwin
623bd3cdc31SAndrzej Bialecki #define SYSCTL_ADD_UINT(ctx, parent, nbr, name, access, ptr, val, descr) \
624f0188618SHans Petter Selasky ({ \
625f0188618SHans Petter Selasky unsigned *__ptr = (ptr); \
6266007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
6276007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_UINT); \
6281eae8811SMatthew D Fleming sysctl_add_oid(ctx, parent, nbr, name, \
6291eae8811SMatthew D Fleming CTLTYPE_UINT | CTLFLAG_MPSAFE | (access), \
6301e1f3941SEd Schouten __ptr, val, sysctl_handle_int, "IU", __DESCR(descr), NULL); \
631f0188618SHans Petter Selasky })
632bd3cdc31SAndrzej Bialecki
6339701cd40SJohn Baldwin /* Oid for a long. The pointer must be non NULL. */
634f0188618SHans Petter Selasky #define SYSCTL_NULL_LONG_PTR ((long *)NULL)
6359701cd40SJohn Baldwin #define SYSCTL_LONG(parent, nbr, name, access, ptr, val, descr) \
6361eae8811SMatthew D Fleming SYSCTL_OID(parent, nbr, name, \
6371eae8811SMatthew D Fleming CTLTYPE_LONG | CTLFLAG_MPSAFE | (access), \
638f0188618SHans Petter Selasky ptr, val, sysctl_handle_long, "L", descr); \
639f0efae77SHans Petter Selasky CTASSERT((((access) & CTLTYPE) == 0 || \
640f0efae77SHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_LONG) && \
641f0efae77SHans Petter Selasky sizeof(long) == sizeof(*(ptr)))
6429701cd40SJohn Baldwin
643bd3cdc31SAndrzej Bialecki #define SYSCTL_ADD_LONG(ctx, parent, nbr, name, access, ptr, descr) \
644f0188618SHans Petter Selasky ({ \
645f0188618SHans Petter Selasky long *__ptr = (ptr); \
6466007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
6476007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_LONG); \
6481eae8811SMatthew D Fleming sysctl_add_oid(ctx, parent, nbr, name, \
6491eae8811SMatthew D Fleming CTLTYPE_LONG | CTLFLAG_MPSAFE | (access), \
6501e1f3941SEd Schouten __ptr, 0, sysctl_handle_long, "L", __DESCR(descr), NULL); \
651f0188618SHans Petter Selasky })
652bd3cdc31SAndrzej Bialecki
653be231030SRobert Drehmel /* Oid for an unsigned long. The pointer must be non NULL. */
654f0188618SHans Petter Selasky #define SYSCTL_NULL_ULONG_PTR ((unsigned long *)NULL)
6559701cd40SJohn Baldwin #define SYSCTL_ULONG(parent, nbr, name, access, ptr, val, descr) \
6561eae8811SMatthew D Fleming SYSCTL_OID(parent, nbr, name, \
6571eae8811SMatthew D Fleming CTLTYPE_ULONG | CTLFLAG_MPSAFE | (access), \
658f0188618SHans Petter Selasky ptr, val, sysctl_handle_long, "LU", descr); \
659f0efae77SHans Petter Selasky CTASSERT((((access) & CTLTYPE) == 0 || \
660f0efae77SHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_ULONG) && \
661f0efae77SHans Petter Selasky sizeof(unsigned long) == sizeof(*(ptr)))
662069e9bc1SDoug Rabson
663bd3cdc31SAndrzej Bialecki #define SYSCTL_ADD_ULONG(ctx, parent, nbr, name, access, ptr, descr) \
664f0188618SHans Petter Selasky ({ \
665f0188618SHans Petter Selasky unsigned long *__ptr = (ptr); \
6666007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
6676007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_ULONG); \
6681eae8811SMatthew D Fleming sysctl_add_oid(ctx, parent, nbr, name, \
6691eae8811SMatthew D Fleming CTLTYPE_ULONG | CTLFLAG_MPSAFE | (access), \
6701e1f3941SEd Schouten __ptr, 0, sysctl_handle_long, "LU", __DESCR(descr), NULL); \
671f0188618SHans Petter Selasky })
672bd3cdc31SAndrzej Bialecki
6737f41115eSPawel Jakub Dawidek /* Oid for a quad. The pointer must be non NULL. */
6744db0aba3SHans Petter Selasky #define SYSCTL_NULL_QUAD_PTR ((int64_t *)NULL)
6757f41115eSPawel Jakub Dawidek #define SYSCTL_QUAD(parent, nbr, name, access, ptr, val, descr) \
6761eae8811SMatthew D Fleming SYSCTL_OID(parent, nbr, name, \
677cbc134adSMatthew D Fleming CTLTYPE_S64 | CTLFLAG_MPSAFE | (access), \
678f0188618SHans Petter Selasky ptr, val, sysctl_handle_64, "Q", descr); \
679f0efae77SHans Petter Selasky CTASSERT((((access) & CTLTYPE) == 0 || \
680f0efae77SHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S64) && \
681f0efae77SHans Petter Selasky sizeof(int64_t) == sizeof(*(ptr)))
6827f41115eSPawel Jakub Dawidek
6837f41115eSPawel Jakub Dawidek #define SYSCTL_ADD_QUAD(ctx, parent, nbr, name, access, ptr, descr) \
684f0188618SHans Petter Selasky ({ \
685f0188618SHans Petter Selasky int64_t *__ptr = (ptr); \
6866007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
6876007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S64); \
6881eae8811SMatthew D Fleming sysctl_add_oid(ctx, parent, nbr, name, \
689cbc134adSMatthew D Fleming CTLTYPE_S64 | CTLFLAG_MPSAFE | (access), \
6901e1f3941SEd Schouten __ptr, 0, sysctl_handle_64, "Q", __DESCR(descr), NULL); \
691f0188618SHans Petter Selasky })
6921eae8811SMatthew D Fleming
693f0188618SHans Petter Selasky #define SYSCTL_NULL_UQUAD_PTR ((uint64_t *)NULL)
6941eae8811SMatthew D Fleming #define SYSCTL_UQUAD(parent, nbr, name, access, ptr, val, descr) \
6951eae8811SMatthew D Fleming SYSCTL_OID(parent, nbr, name, \
696cbc134adSMatthew D Fleming CTLTYPE_U64 | CTLFLAG_MPSAFE | (access), \
697f0188618SHans Petter Selasky ptr, val, sysctl_handle_64, "QU", descr); \
698f0efae77SHans Petter Selasky CTASSERT((((access) & CTLTYPE) == 0 || \
699f0efae77SHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U64) && \
700f0efae77SHans Petter Selasky sizeof(uint64_t) == sizeof(*(ptr)))
7011eae8811SMatthew D Fleming
7021eae8811SMatthew D Fleming #define SYSCTL_ADD_UQUAD(ctx, parent, nbr, name, access, ptr, descr) \
703f0188618SHans Petter Selasky ({ \
704f0188618SHans Petter Selasky uint64_t *__ptr = (ptr); \
7056007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
7066007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U64); \
7071eae8811SMatthew D Fleming sysctl_add_oid(ctx, parent, nbr, name, \
708cbc134adSMatthew D Fleming CTLTYPE_U64 | CTLFLAG_MPSAFE | (access), \
7091e1f3941SEd Schouten __ptr, 0, sysctl_handle_64, "QU", __DESCR(descr), NULL); \
710f0188618SHans Petter Selasky })
711f0188618SHans Petter Selasky
7127f417bfaSPedro F. Giffuni /* Oid for a CPU dependent variable */
713f0188618SHans Petter Selasky #define SYSCTL_ADD_UAUTO(ctx, parent, nbr, name, access, ptr, descr) \
714f0188618SHans Petter Selasky ({ \
715f0188618SHans Petter Selasky struct sysctl_oid *__ret; \
716f0efae77SHans Petter Selasky CTASSERT((sizeof(uint64_t) == sizeof(*(ptr)) || \
717f0efae77SHans Petter Selasky sizeof(unsigned) == sizeof(*(ptr))) && \
718f0efae77SHans Petter Selasky ((access) & CTLTYPE) == 0); \
719f0188618SHans Petter Selasky if (sizeof(uint64_t) == sizeof(*(ptr))) { \
720f0188618SHans Petter Selasky __ret = sysctl_add_oid(ctx, parent, nbr, name, \
721f0188618SHans Petter Selasky CTLTYPE_U64 | CTLFLAG_MPSAFE | (access), \
722f0188618SHans Petter Selasky (ptr), 0, sysctl_handle_64, "QU", \
7231e1f3941SEd Schouten __DESCR(descr), NULL); \
724f0188618SHans Petter Selasky } else { \
725f0188618SHans Petter Selasky __ret = sysctl_add_oid(ctx, parent, nbr, name, \
726f0188618SHans Petter Selasky CTLTYPE_UINT | CTLFLAG_MPSAFE | (access), \
727f0188618SHans Petter Selasky (ptr), 0, sysctl_handle_int, "IU", \
7281e1f3941SEd Schouten __DESCR(descr), NULL); \
729f0188618SHans Petter Selasky } \
730f0188618SHans Petter Selasky __ret; \
731f0188618SHans Petter Selasky })
7327f41115eSPawel Jakub Dawidek
733514a6e61SJohn Baldwin /* Oid for a 64-bit unsigned counter(9). The pointer must be non NULL. */
734369f5bceSGleb Smirnoff #define SYSCTL_COUNTER_U64(parent, nbr, name, access, ptr, descr) \
7354e76af6aSGleb Smirnoff SYSCTL_OID(parent, nbr, name, \
73688661492SEric van Gyzen CTLTYPE_U64 | CTLFLAG_MPSAFE | CTLFLAG_STATS | (access), \
737f0188618SHans Petter Selasky (ptr), 0, sysctl_handle_counter_u64, "QU", descr); \
738f0efae77SHans Petter Selasky CTASSERT((((access) & CTLTYPE) == 0 || \
739f0efae77SHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U64) && \
740f0efae77SHans Petter Selasky sizeof(counter_u64_t) == sizeof(*(ptr)) && \
741f0efae77SHans Petter Selasky sizeof(uint64_t) == sizeof(**(ptr)))
7424e76af6aSGleb Smirnoff
7434e76af6aSGleb Smirnoff #define SYSCTL_ADD_COUNTER_U64(ctx, parent, nbr, name, access, ptr, descr) \
744f0188618SHans Petter Selasky ({ \
745d6231037SGleb Smirnoff counter_u64_t *__ptr = (ptr); \
7466007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
7476007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U64); \
7484e76af6aSGleb Smirnoff sysctl_add_oid(ctx, parent, nbr, name, \
74988661492SEric van Gyzen CTLTYPE_U64 | CTLFLAG_MPSAFE | CTLFLAG_STATS | (access), \
7501e1f3941SEd Schouten __ptr, 0, sysctl_handle_counter_u64, "QU", __DESCR(descr), \
7511e1f3941SEd Schouten NULL); \
752f0188618SHans Petter Selasky })
7534e76af6aSGleb Smirnoff
754b5b7b142SGleb Smirnoff /* Oid for an array of counter(9)s. The pointer and length must be non zero. */
755b5b7b142SGleb Smirnoff #define SYSCTL_COUNTER_U64_ARRAY(parent, nbr, name, access, ptr, len, descr) \
756b5b7b142SGleb Smirnoff SYSCTL_OID(parent, nbr, name, \
757bc5708c0SGleb Smirnoff CTLTYPE_U64 | CTLFLAG_MPSAFE | CTLFLAG_STATS | (access), \
758bc5708c0SGleb Smirnoff (ptr), (len), sysctl_handle_counter_u64_array, "QU", descr);\
759a435d46fSHans Petter Selasky CTASSERT((((access) & CTLTYPE) == 0 || \
760a435d46fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_OPAQUE) && \
761a435d46fSHans Petter Selasky sizeof(counter_u64_t) == sizeof(*(ptr)) && \
762a435d46fSHans Petter Selasky sizeof(uint64_t) == sizeof(**(ptr)))
763b5b7b142SGleb Smirnoff
764b5b7b142SGleb Smirnoff #define SYSCTL_ADD_COUNTER_U64_ARRAY(ctx, parent, nbr, name, access, \
765b5b7b142SGleb Smirnoff ptr, len, descr) \
766b5b7b142SGleb Smirnoff ({ \
767b5b7b142SGleb Smirnoff counter_u64_t *__ptr = (ptr); \
768b5b7b142SGleb Smirnoff CTASSERT(((access) & CTLTYPE) == 0 || \
769b5b7b142SGleb Smirnoff ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_OPAQUE); \
770b5b7b142SGleb Smirnoff sysctl_add_oid(ctx, parent, nbr, name, \
77188661492SEric van Gyzen CTLTYPE_OPAQUE | CTLFLAG_MPSAFE | CTLFLAG_STATS | (access), \
772b5b7b142SGleb Smirnoff __ptr, len, sysctl_handle_counter_u64_array, "S", \
7731e1f3941SEd Schouten __DESCR(descr), NULL); \
774b5b7b142SGleb Smirnoff })
775b5b7b142SGleb Smirnoff
7766ade4cf7SBruce Evans /* Oid for an opaque object. Specified by a pointer and a length. */
77703ddfca8SPoul-Henning Kamp #define SYSCTL_OPAQUE(parent, nbr, name, access, ptr, len, fmt, descr) \
778210176adSPawel Biernacki SYSCTL_OID(parent, nbr, name, \
779210176adSPawel Biernacki CTLTYPE_OPAQUE | CTLFLAG_MPSAFE | (access), \
780f0188618SHans Petter Selasky ptr, len, sysctl_handle_opaque, fmt, descr); \
7816007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
7826007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_OPAQUE)
783b396cd83SPoul-Henning Kamp
784bd3cdc31SAndrzej Bialecki #define SYSCTL_ADD_OPAQUE(ctx, parent, nbr, name, access, ptr, len, fmt, descr) \
785f0188618SHans Petter Selasky ({ \
7866007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
7876007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_OPAQUE); \
788210176adSPawel Biernacki sysctl_add_oid(ctx, parent, nbr, name, \
789210176adSPawel Biernacki CTLTYPE_OPAQUE | CTLFLAG_MPSAFE | (access), \
7901e1f3941SEd Schouten ptr, len, sysctl_handle_opaque, fmt, __DESCR(descr), NULL); \
791f0188618SHans Petter Selasky })
792bd3cdc31SAndrzej Bialecki
7936ade4cf7SBruce Evans /* Oid for a struct. Specified by a pointer and a type. */
794946bb7a2SPoul-Henning Kamp #define SYSCTL_STRUCT(parent, nbr, name, access, ptr, type, descr) \
795210176adSPawel Biernacki SYSCTL_OID(parent, nbr, name, \
796210176adSPawel Biernacki CTLTYPE_OPAQUE | CTLFLAG_MPSAFE | (access), \
797946bb7a2SPoul-Henning Kamp ptr, sizeof(struct type), sysctl_handle_opaque, \
798f0188618SHans Petter Selasky "S," #type, descr); \
7996007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
8006007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_OPAQUE)
801b396cd83SPoul-Henning Kamp
802bd3cdc31SAndrzej Bialecki #define SYSCTL_ADD_STRUCT(ctx, parent, nbr, name, access, ptr, type, descr) \
803f0188618SHans Petter Selasky ({ \
8046007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
8056007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_OPAQUE); \
806210176adSPawel Biernacki sysctl_add_oid(ctx, parent, nbr, name, \
807210176adSPawel Biernacki CTLTYPE_OPAQUE | CTLFLAG_MPSAFE | (access), \
808f0188618SHans Petter Selasky (ptr), sizeof(struct type), \
8091e1f3941SEd Schouten sysctl_handle_opaque, "S," #type, __DESCR(descr), NULL); \
810f0188618SHans Petter Selasky })
811bd3cdc31SAndrzej Bialecki
8126ade4cf7SBruce Evans /* Oid for a procedure. Specified by a pointer and an arg. */
813946bb7a2SPoul-Henning Kamp #define SYSCTL_PROC(parent, nbr, name, access, ptr, arg, handler, fmt, descr) \
814d8be0570SPoul-Henning Kamp SYSCTL_OID(parent, nbr, name, (access), \
815f0188618SHans Petter Selasky ptr, arg, handler, fmt, descr); \
816f0188618SHans Petter Selasky CTASSERT(((access) & CTLTYPE) != 0)
817bd3cdc31SAndrzej Bialecki
818bd3cdc31SAndrzej Bialecki #define SYSCTL_ADD_PROC(ctx, parent, nbr, name, access, ptr, arg, handler, fmt, descr) \
819f0188618SHans Petter Selasky ({ \
820f0188618SHans Petter Selasky CTASSERT(((access) & CTLTYPE) != 0); \
821210176adSPawel Biernacki SYSCTL_ENFORCE_FLAGS(access); \
822d8be0570SPoul-Henning Kamp sysctl_add_oid(ctx, parent, nbr, name, (access), \
8231e1f3941SEd Schouten (ptr), (arg), (handler), (fmt), __DESCR(descr), NULL); \
824f0188618SHans Petter Selasky })
825bd3cdc31SAndrzej Bialecki
8260a5a3ccbSGleb Smirnoff /* Oid to handle limits on uma(9) zone specified by pointer. */
8270a5a3ccbSGleb Smirnoff #define SYSCTL_UMA_MAX(parent, nbr, name, access, ptr, descr) \
8280a5a3ccbSGleb Smirnoff SYSCTL_OID(parent, nbr, name, \
8290a5a3ccbSGleb Smirnoff CTLTYPE_INT | CTLFLAG_MPSAFE | (access), \
830f0188618SHans Petter Selasky (ptr), 0, sysctl_handle_uma_zone_max, "I", descr); \
8316007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
8326007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_INT)
833f0188618SHans Petter Selasky
8340a5a3ccbSGleb Smirnoff #define SYSCTL_ADD_UMA_MAX(ctx, parent, nbr, name, access, ptr, descr) \
835f0188618SHans Petter Selasky ({ \
836f0188618SHans Petter Selasky uma_zone_t __ptr = (ptr); \
8376007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
8386007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_INT); \
8390a5a3ccbSGleb Smirnoff sysctl_add_oid(ctx, parent, nbr, name, \
8400a5a3ccbSGleb Smirnoff CTLTYPE_INT | CTLFLAG_MPSAFE | (access), \
8411e1f3941SEd Schouten __ptr, 0, sysctl_handle_uma_zone_max, "I", __DESCR(descr), \
8421e1f3941SEd Schouten NULL); \
843f0188618SHans Petter Selasky })
8440a5a3ccbSGleb Smirnoff
8450a5a3ccbSGleb Smirnoff /* Oid to obtain current use of uma(9) zone specified by pointer. */
8460a5a3ccbSGleb Smirnoff #define SYSCTL_UMA_CUR(parent, nbr, name, access, ptr, descr) \
8470a5a3ccbSGleb Smirnoff SYSCTL_OID(parent, nbr, name, \
8480a5a3ccbSGleb Smirnoff CTLTYPE_INT | CTLFLAG_MPSAFE | CTLFLAG_RD | (access), \
849f0188618SHans Petter Selasky (ptr), 0, sysctl_handle_uma_zone_cur, "I", descr); \
8506007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
8516007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_INT)
852f0188618SHans Petter Selasky
8530a5a3ccbSGleb Smirnoff #define SYSCTL_ADD_UMA_CUR(ctx, parent, nbr, name, access, ptr, descr) \
854f0188618SHans Petter Selasky ({ \
855f0188618SHans Petter Selasky uma_zone_t __ptr = (ptr); \
8566007751fSHans Petter Selasky CTASSERT(((access) & CTLTYPE) == 0 || \
8576007751fSHans Petter Selasky ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_INT); \
8580a5a3ccbSGleb Smirnoff sysctl_add_oid(ctx, parent, nbr, name, \
8590a5a3ccbSGleb Smirnoff CTLTYPE_INT | CTLFLAG_MPSAFE | CTLFLAG_RD | (access), \
8601e1f3941SEd Schouten __ptr, 0, sysctl_handle_uma_zone_cur, "I", __DESCR(descr), \
8611e1f3941SEd Schouten NULL); \
862f0188618SHans Petter Selasky })
8630a5a3ccbSGleb Smirnoff
864003ffd57SWarner Losh /* OID expressing a sbintime_t as microseconds */
865003ffd57SWarner Losh #define SYSCTL_SBINTIME_USEC(parent, nbr, name, access, ptr, descr) \
866003ffd57SWarner Losh SYSCTL_OID(parent, nbr, name, \
867003ffd57SWarner Losh CTLTYPE_INT | CTLFLAG_MPSAFE | CTLFLAG_RD | (access), \
868003ffd57SWarner Losh (ptr), 0, sysctl_usec_to_sbintime, "Q", descr); \
869003ffd57SWarner Losh CTASSERT(((access) & CTLTYPE) == 0 || \
870003ffd57SWarner Losh ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S64)
871003ffd57SWarner Losh #define SYSCTL_ADD_SBINTIME_USEC(ctx, parent, nbr, name, access, ptr, descr) \
872003ffd57SWarner Losh ({ \
873003ffd57SWarner Losh sbintime_t *__ptr = (ptr); \
874003ffd57SWarner Losh CTASSERT(((access) & CTLTYPE) == 0 || \
875003ffd57SWarner Losh ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S64); \
876003ffd57SWarner Losh sysctl_add_oid(ctx, parent, nbr, name, \
877003ffd57SWarner Losh CTLTYPE_INT | CTLFLAG_MPSAFE | CTLFLAG_RD | (access), \
878003ffd57SWarner Losh __ptr, 0, sysctl_usec_to_sbintime, "Q", __DESCR(descr), \
879003ffd57SWarner Losh NULL); \
880003ffd57SWarner Losh })
881003ffd57SWarner Losh
882003ffd57SWarner Losh /* OID expressing a sbintime_t as milliseconds */
883003ffd57SWarner Losh #define SYSCTL_SBINTIME_MSEC(parent, nbr, name, access, ptr, descr) \
884003ffd57SWarner Losh SYSCTL_OID(parent, nbr, name, \
885003ffd57SWarner Losh CTLTYPE_INT | CTLFLAG_MPSAFE | CTLFLAG_RD | (access), \
886003ffd57SWarner Losh (ptr), 0, sysctl_msec_to_sbintime, "Q", descr); \
887003ffd57SWarner Losh CTASSERT(((access) & CTLTYPE) == 0 || \
888003ffd57SWarner Losh ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S64)
889003ffd57SWarner Losh #define SYSCTL_ADD_SBINTIME_MSEC(ctx, parent, nbr, name, access, ptr, descr) \
890003ffd57SWarner Losh ({ \
891003ffd57SWarner Losh sbintime_t *__ptr = (ptr); \
892003ffd57SWarner Losh CTASSERT(((access) & CTLTYPE) == 0 || \
893003ffd57SWarner Losh ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S64); \
894003ffd57SWarner Losh sysctl_add_oid(ctx, parent, nbr, name, \
895003ffd57SWarner Losh CTLTYPE_INT | CTLFLAG_MPSAFE | CTLFLAG_RD | (access), \
896003ffd57SWarner Losh __ptr, 0, sysctl_msec_to_sbintime, "Q", __DESCR(descr), \
897003ffd57SWarner Losh NULL); \
898003ffd57SWarner Losh })
899003ffd57SWarner Losh
9000f702183SJohn Baldwin /* OID expressing a struct timeval as seconds */
9010f702183SJohn Baldwin #define SYSCTL_TIMEVAL_SEC(parent, nbr, name, access, ptr, descr) \
9020f702183SJohn Baldwin SYSCTL_OID(parent, nbr, name, \
9030f702183SJohn Baldwin CTLTYPE_INT | CTLFLAG_MPSAFE | CTLFLAG_RD | (access), \
9040f702183SJohn Baldwin (ptr), 0, sysctl_sec_to_timeval, "I", descr); \
9050f702183SJohn Baldwin CTASSERT(((access) & CTLTYPE) == 0 || \
9060f702183SJohn Baldwin ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_INT)
9070f702183SJohn Baldwin #define SYSCTL_ADD_TIMEVAL_SEC(ctx, parent, nbr, name, access, ptr, descr) \
9080f702183SJohn Baldwin ({ \
9090f702183SJohn Baldwin struct timeval *__ptr = (ptr); \
9100f702183SJohn Baldwin CTASSERT(((access) & CTLTYPE) == 0 || \
9110f702183SJohn Baldwin ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_INT); \
9120f702183SJohn Baldwin sysctl_add_oid(ctx, parent, nbr, name, \
9130f702183SJohn Baldwin CTLTYPE_INT | CTLFLAG_MPSAFE | CTLFLAG_RD | (access), \
9140f702183SJohn Baldwin __ptr, 0, sysctl_sec_to_timeval, "I", __DESCR(descr), \
9150f702183SJohn Baldwin NULL); \
9160f702183SJohn Baldwin })
9170f702183SJohn Baldwin
918c075ea46SHans Petter Selasky #define SYSCTL_FOREACH(oidp, list) \
919c075ea46SHans Petter Selasky RB_FOREACH(oidp, sysctl_oid_list, list)
920c075ea46SHans Petter Selasky
921df67e9f2SJohn Baldwin /*
9227f417bfaSPedro F. Giffuni * A macro to generate a read-only sysctl to indicate the presence of optional
923df67e9f2SJohn Baldwin * kernel features.
924df67e9f2SJohn Baldwin */
92513a83707SEd Schouten #define FEATURE(name, desc) \
926977ffc4cSEd Schouten SYSCTL_INT_WITH_LABEL(_kern_features, OID_AUTO, name, \
927977ffc4cSEd Schouten CTLFLAG_RD | CTLFLAG_CAPRD, SYSCTL_NULL_INT_PTR, 1, desc, "feature")
92846f3a29eSKonstantin Belousov /* Same for the dynamic registration. */
92946f3a29eSKonstantin Belousov #define FEATURE_ADD(name, desc) \
93046f3a29eSKonstantin Belousov sysctl_add_oid(NULL, SYSCTL_CHILDREN(&sysctl___kern_features), \
93146f3a29eSKonstantin Belousov OID_AUTO, name, \
93246f3a29eSKonstantin Belousov CTLFLAG_RD | CTLFLAG_CAPRD | CTLTYPE_INT | CTLFLAG_MPSAFE, \
93346f3a29eSKonstantin Belousov NULL, 1, sysctl_handle_int, "I", desc, "feature");
934df67e9f2SJohn Baldwin
935664a31e4SPeter Wemm #endif /* _KERNEL */
936df8bae1dSRodney W. Grimes
937df8bae1dSRodney W. Grimes /*
938df8bae1dSRodney W. Grimes * Top-level identifiers
939df8bae1dSRodney W. Grimes */
940382e01c8SKonstantin Belousov #define CTL_SYSCTL 0 /* "magic" numbers */
941df8bae1dSRodney W. Grimes #define CTL_KERN 1 /* "high kernel": proc, limits */
942df8bae1dSRodney W. Grimes #define CTL_VM 2 /* virtual memory */
9431b47f724SJeffrey Hsu #define CTL_VFS 3 /* filesystem, mount type is next */
944df8bae1dSRodney W. Grimes #define CTL_NET 4 /* network, see socket.h */
945df8bae1dSRodney W. Grimes #define CTL_DEBUG 5 /* debugging parameters */
946df8bae1dSRodney W. Grimes #define CTL_HW 6 /* generic cpu/io */
947df8bae1dSRodney W. Grimes #define CTL_MACHDEP 7 /* machine dependent */
948df8bae1dSRodney W. Grimes #define CTL_USER 8 /* user-level */
9498a6472b7SPeter Dufault #define CTL_P1003_1B 9 /* POSIX 1003.1B */
950917e476dSPeter Dufault
951df8bae1dSRodney W. Grimes /*
952382e01c8SKonstantin Belousov * CTL_SYSCTL identifiers
953382e01c8SKonstantin Belousov */
954382e01c8SKonstantin Belousov #define CTL_SYSCTL_DEBUG 0 /* printf all nodes */
955382e01c8SKonstantin Belousov #define CTL_SYSCTL_NAME 1 /* string name of OID */
95692e17803SRyan Moeller #define CTL_SYSCTL_NEXT 2 /* next OID, honoring CTLFLAG_SKIP */
957382e01c8SKonstantin Belousov #define CTL_SYSCTL_NAME2OID 3 /* int array of name */
958382e01c8SKonstantin Belousov #define CTL_SYSCTL_OIDFMT 4 /* OID's kind and format */
959382e01c8SKonstantin Belousov #define CTL_SYSCTL_OIDDESCR 5 /* OID's description */
960382e01c8SKonstantin Belousov #define CTL_SYSCTL_OIDLABEL 6 /* aggregation label */
96192e17803SRyan Moeller #define CTL_SYSCTL_NEXTNOSKIP 7 /* next OID, ignoring CTLFLAG_SKIP */
962382e01c8SKonstantin Belousov
963382e01c8SKonstantin Belousov /*
964df8bae1dSRodney W. Grimes * CTL_KERN identifiers
965df8bae1dSRodney W. Grimes */
966df8bae1dSRodney W. Grimes #define KERN_OSTYPE 1 /* string: system version */
967df8bae1dSRodney W. Grimes #define KERN_OSRELEASE 2 /* string: system release */
968df8bae1dSRodney W. Grimes #define KERN_OSREV 3 /* int: system revision */
969df8bae1dSRodney W. Grimes #define KERN_VERSION 4 /* string: compile time info */
970df8bae1dSRodney W. Grimes #define KERN_MAXVNODES 5 /* int: max vnodes */
971df8bae1dSRodney W. Grimes #define KERN_MAXPROC 6 /* int: max processes */
972df8bae1dSRodney W. Grimes #define KERN_MAXFILES 7 /* int: max open files */
973df8bae1dSRodney W. Grimes #define KERN_ARGMAX 8 /* int: max arguments to exec */
974df8bae1dSRodney W. Grimes #define KERN_SECURELVL 9 /* int: system security level */
975df8bae1dSRodney W. Grimes #define KERN_HOSTNAME 10 /* string: hostname */
976df8bae1dSRodney W. Grimes #define KERN_HOSTID 11 /* int: host identifier */
977df8bae1dSRodney W. Grimes #define KERN_CLOCKRATE 12 /* struct: struct clockrate */
97862a573d9SMateusz Guzik /* was: #define KERN_VNODE 13 ; disabled in 2003 and removed in 2023 */
979df8bae1dSRodney W. Grimes #define KERN_PROC 14 /* struct: process entries */
980df8bae1dSRodney W. Grimes #define KERN_FILE 15 /* struct: file entries */
981df8bae1dSRodney W. Grimes #define KERN_PROF 16 /* node: kernel profiling info */
982df8bae1dSRodney W. Grimes #define KERN_POSIX1 17 /* int: POSIX.1 version */
983df8bae1dSRodney W. Grimes #define KERN_NGROUPS 18 /* int: # of supplemental group ids */
984df8bae1dSRodney W. Grimes #define KERN_JOB_CONTROL 19 /* int: is job control available */
985df8bae1dSRodney W. Grimes #define KERN_SAVED_IDS 20 /* int: saved set-user/group-ID */
986df8bae1dSRodney W. Grimes #define KERN_BOOTTIME 21 /* struct: time kernel was booted */
987949f380fSGarrett Wollman #define KERN_NISDOMAINNAME 22 /* string: YP domain name */
98857034e74SGarrett Wollman #define KERN_UPDATEINTERVAL 23 /* int: update process sleep time */
989a5d47238SEivind Eklund #define KERN_OSRELDATE 24 /* int: kernel release date */
9903f31c649SGarrett Wollman #define KERN_NTP_PLL 25 /* node: NTP PLL control */
99163b46ee5SGarrett Wollman #define KERN_BOOTFILE 26 /* string: name of booted kernel */
992e6373c9eSGuido van Rooij #define KERN_MAXFILESPERPROC 27 /* int: max open files per proc */
993e6373c9eSGuido van Rooij #define KERN_MAXPROCPERUID 28 /* int: max processes per uid */
99489c9c53dSPoul-Henning Kamp #define KERN_DUMPDEV 29 /* struct cdev *: device to dump on */
9958c9b80bcSGarrett Wollman #define KERN_IPC 30 /* node: anything related to IPC */
9968c9b80bcSGarrett Wollman #define KERN_DUMMY 31 /* unused */
99799ac3bc8SPeter Wemm #define KERN_PS_STRINGS 32 /* int: address of PS_STRINGS */
99899ac3bc8SPeter Wemm #define KERN_USRSTACK 33 /* int: address of USRSTACK */
99957308494SJoerg Wunsch #define KERN_LOGSIGEXIT 34 /* int: do we log sigexit procs? */
100037336173SGarrett Wollman #define KERN_IOV_MAX 35 /* int: value of UIO_MAXIOV */
100182068fe7SPawel Jakub Dawidek #define KERN_HOSTUUID 36 /* string: host UUID identifier */
1002ee9f4661SAlexander Kabaev #define KERN_ARND 37 /* int: from arc4rand() */
10037ed6b78bSGleb Smirnoff #define KERN_MAXPHYS 38 /* int: MAXPHYS value */
1004eca39864SKonstantin Belousov #define KERN_LOCKF 39 /* struct: lockf reports */
1005c901836cSGarrett Wollman /*
1006df8bae1dSRodney W. Grimes * KERN_PROC subtypes
1007df8bae1dSRodney W. Grimes */
1008df8bae1dSRodney W. Grimes #define KERN_PROC_ALL 0 /* everything */
1009df8bae1dSRodney W. Grimes #define KERN_PROC_PID 1 /* by process id */
1010df8bae1dSRodney W. Grimes #define KERN_PROC_PGRP 2 /* by process group id */
1011df8bae1dSRodney W. Grimes #define KERN_PROC_SESSION 3 /* by session of pid */
1012df8bae1dSRodney W. Grimes #define KERN_PROC_TTY 4 /* by controlling tty */
1013df8bae1dSRodney W. Grimes #define KERN_PROC_UID 5 /* by effective uid */
1014df8bae1dSRodney W. Grimes #define KERN_PROC_RUID 6 /* by real uid */
1015b9df5231SPoul-Henning Kamp #define KERN_PROC_ARGS 7 /* get/set arguments/proctitle */
1016db6d73dfSScott Long #define KERN_PROC_PROC 8 /* only return procs */
1017baf731e6SRobert Drehmel #define KERN_PROC_SV_NAME 9 /* get syscall vector name */
1018524b369bSGarance A Drosehn #define KERN_PROC_RGID 10 /* by real group id */
1019eff70becSGarance A Drosehn #define KERN_PROC_GID 11 /* by effective group id */
1020fe769cddSDavid Schultz #define KERN_PROC_PATHNAME 12 /* path to executable */
102143151ee6SPeter Wemm #define KERN_PROC_OVMMAP 13 /* Old VM map entries for process */
102243151ee6SPeter Wemm #define KERN_PROC_OFILEDESC 14 /* Old file descriptors for process */
10231cc8c45cSRobert Watson #define KERN_PROC_KSTACK 15 /* Kernel stacks for process */
10242648efa6SDaniel Eischen #define KERN_PROC_INC_THREAD 0x10 /*
10252648efa6SDaniel Eischen * modifier for pid, pgrp, tty,
1026eff70becSGarance A Drosehn * uid, ruid, gid, rgid and proc
102743151ee6SPeter Wemm * This effectively uses 16-31
10282648efa6SDaniel Eischen */
102943151ee6SPeter Wemm #define KERN_PROC_VMMAP 32 /* VM map entries for process */
103043151ee6SPeter Wemm #define KERN_PROC_FILEDESC 33 /* File descriptors for process */
1031254d03c5SBrooks Davis #define KERN_PROC_GROUPS 34 /* process groups */
1032c5cfcb1cSMikolaj Golub #define KERN_PROC_ENV 35 /* get environment */
1033c5cfcb1cSMikolaj Golub #define KERN_PROC_AUXV 36 /* get ELF auxiliary vector */
10349e7d0583SMikolaj Golub #define KERN_PROC_RLIMIT 37 /* process resource limits */
1035a68d1ecaSMikolaj Golub #define KERN_PROC_PS_STRINGS 38 /* get ps_strings location */
10366ce13747SMikolaj Golub #define KERN_PROC_UMASK 39 /* process umask */
1037903712c9SMikolaj Golub #define KERN_PROC_OSREL 40 /* osreldate for process binary */
103880c3af4eSKonstantin Belousov #define KERN_PROC_SIGTRAMP 41 /* signal trampoline location */
1039bfda9935SMateusz Guzik #define KERN_PROC_CWD 42 /* process current working directory */
1040b577e693SMateusz Guzik #define KERN_PROC_NFDS 43 /* number of open file descriptors */
104148fcb463SKonstantin Belousov #define KERN_PROC_SIGFASTBLK 44 /* address of fastsigblk magic word */
10423ce04acaSMark Johnston #define KERN_PROC_VM_LAYOUT 45 /* virtual address space layout info */
1043*c85d3064SKonstantin Belousov #define KERN_PROC_RLIMIT_USAGE 46 /* array of rlim_t */
1044df8bae1dSRodney W. Grimes
1045df8bae1dSRodney W. Grimes /*
10468c9b80bcSGarrett Wollman * KERN_IPC identifiers
10478c9b80bcSGarrett Wollman */
10488c9b80bcSGarrett Wollman #define KIPC_MAXSOCKBUF 1 /* int: max size of a socket buffer */
10498c9b80bcSGarrett Wollman #define KIPC_SOCKBUF_WASTE 2 /* int: wastage factor in sockbuf */
10508c9b80bcSGarrett Wollman #define KIPC_SOMAXCONN 3 /* int: max length of connection q */
10518c9b80bcSGarrett Wollman #define KIPC_MAX_LINKHDR 4 /* int: max length of link header */
10528c9b80bcSGarrett Wollman #define KIPC_MAX_PROTOHDR 5 /* int: max length of network header */
10538c9b80bcSGarrett Wollman #define KIPC_MAX_HDR 6 /* int: max total length of headers */
10548c9b80bcSGarrett Wollman #define KIPC_MAX_DATALEN 7 /* int: max length of data? */
10558c9b80bcSGarrett Wollman
10568c9b80bcSGarrett Wollman /*
1057df8bae1dSRodney W. Grimes * CTL_HW identifiers
1058df8bae1dSRodney W. Grimes */
1059df8bae1dSRodney W. Grimes #define HW_MACHINE 1 /* string: machine class */
1060df8bae1dSRodney W. Grimes #define HW_MODEL 2 /* string: specific machine model */
1061df8bae1dSRodney W. Grimes #define HW_NCPU 3 /* int: number of cpus */
1062df8bae1dSRodney W. Grimes #define HW_BYTEORDER 4 /* int: machine byte order */
1063df8bae1dSRodney W. Grimes #define HW_PHYSMEM 5 /* int: total memory */
1064df8bae1dSRodney W. Grimes #define HW_USERMEM 6 /* int: non-kernel memory */
1065df8bae1dSRodney W. Grimes #define HW_PAGESIZE 7 /* int: software page size */
1066df8bae1dSRodney W. Grimes #define HW_DISKNAMES 8 /* strings: disk drive names */
1067df8bae1dSRodney W. Grimes #define HW_DISKSTATS 9 /* struct: diskstats[] */
1068501c2393SGarrett Wollman #define HW_FLOATINGPT 10 /* int: has HW floating point? */
1069664f8517SKATO Takenori #define HW_MACHINE_ARCH 11 /* string: machine architecture */
1070a0915044SWes Peters #define HW_REALMEM 12 /* int: 'real' memory */
1071df8bae1dSRodney W. Grimes
1072df8bae1dSRodney W. Grimes /*
1073df8bae1dSRodney W. Grimes * CTL_USER definitions
1074df8bae1dSRodney W. Grimes */
1075df8bae1dSRodney W. Grimes #define USER_CS_PATH 1 /* string: _CS_PATH */
1076df8bae1dSRodney W. Grimes #define USER_BC_BASE_MAX 2 /* int: BC_BASE_MAX */
1077df8bae1dSRodney W. Grimes #define USER_BC_DIM_MAX 3 /* int: BC_DIM_MAX */
1078df8bae1dSRodney W. Grimes #define USER_BC_SCALE_MAX 4 /* int: BC_SCALE_MAX */
1079df8bae1dSRodney W. Grimes #define USER_BC_STRING_MAX 5 /* int: BC_STRING_MAX */
1080df8bae1dSRodney W. Grimes #define USER_COLL_WEIGHTS_MAX 6 /* int: COLL_WEIGHTS_MAX */
1081df8bae1dSRodney W. Grimes #define USER_EXPR_NEST_MAX 7 /* int: EXPR_NEST_MAX */
1082df8bae1dSRodney W. Grimes #define USER_LINE_MAX 8 /* int: LINE_MAX */
1083df8bae1dSRodney W. Grimes #define USER_RE_DUP_MAX 9 /* int: RE_DUP_MAX */
1084df8bae1dSRodney W. Grimes #define USER_POSIX2_VERSION 10 /* int: POSIX2_VERSION */
1085df8bae1dSRodney W. Grimes #define USER_POSIX2_C_BIND 11 /* int: POSIX2_C_BIND */
1086df8bae1dSRodney W. Grimes #define USER_POSIX2_C_DEV 12 /* int: POSIX2_C_DEV */
1087df8bae1dSRodney W. Grimes #define USER_POSIX2_CHAR_TERM 13 /* int: POSIX2_CHAR_TERM */
1088df8bae1dSRodney W. Grimes #define USER_POSIX2_FORT_DEV 14 /* int: POSIX2_FORT_DEV */
1089df8bae1dSRodney W. Grimes #define USER_POSIX2_FORT_RUN 15 /* int: POSIX2_FORT_RUN */
1090df8bae1dSRodney W. Grimes #define USER_POSIX2_LOCALEDEF 16 /* int: POSIX2_LOCALEDEF */
1091df8bae1dSRodney W. Grimes #define USER_POSIX2_SW_DEV 17 /* int: POSIX2_SW_DEV */
1092df8bae1dSRodney W. Grimes #define USER_POSIX2_UPE 18 /* int: POSIX2_UPE */
1093df8bae1dSRodney W. Grimes #define USER_STREAM_MAX 19 /* int: POSIX2_STREAM_MAX */
1094df8bae1dSRodney W. Grimes #define USER_TZNAME_MAX 20 /* int: POSIX2_TZNAME_MAX */
1095147eea39SStefan Eßer #define USER_LOCALBASE 21 /* string: _PATH_LOCALBASE */
1096df8bae1dSRodney W. Grimes
10978a6472b7SPeter Dufault #define CTL_P1003_1B_ASYNCHRONOUS_IO 1 /* boolean */
10988a6472b7SPeter Dufault #define CTL_P1003_1B_MAPPED_FILES 2 /* boolean */
10998a6472b7SPeter Dufault #define CTL_P1003_1B_MEMLOCK 3 /* boolean */
11008a6472b7SPeter Dufault #define CTL_P1003_1B_MEMLOCK_RANGE 4 /* boolean */
11018a6472b7SPeter Dufault #define CTL_P1003_1B_MEMORY_PROTECTION 5 /* boolean */
11028a6472b7SPeter Dufault #define CTL_P1003_1B_MESSAGE_PASSING 6 /* boolean */
11038a6472b7SPeter Dufault #define CTL_P1003_1B_PRIORITIZED_IO 7 /* boolean */
11048a6472b7SPeter Dufault #define CTL_P1003_1B_PRIORITY_SCHEDULING 8 /* boolean */
11058a6472b7SPeter Dufault #define CTL_P1003_1B_REALTIME_SIGNALS 9 /* boolean */
11068a6472b7SPeter Dufault #define CTL_P1003_1B_SEMAPHORES 10 /* boolean */
11078a6472b7SPeter Dufault #define CTL_P1003_1B_FSYNC 11 /* boolean */
11088a6472b7SPeter Dufault #define CTL_P1003_1B_SHARED_MEMORY_OBJECTS 12 /* boolean */
11098a6472b7SPeter Dufault #define CTL_P1003_1B_SYNCHRONIZED_IO 13 /* boolean */
11108a6472b7SPeter Dufault #define CTL_P1003_1B_TIMERS 14 /* boolean */
11118a6472b7SPeter Dufault #define CTL_P1003_1B_AIO_LISTIO_MAX 15 /* int */
11128a6472b7SPeter Dufault #define CTL_P1003_1B_AIO_MAX 16 /* int */
11138a6472b7SPeter Dufault #define CTL_P1003_1B_AIO_PRIO_DELTA_MAX 17 /* int */
11148a6472b7SPeter Dufault #define CTL_P1003_1B_DELAYTIMER_MAX 18 /* int */
11158a6472b7SPeter Dufault #define CTL_P1003_1B_MQ_OPEN_MAX 19 /* int */
11168a6472b7SPeter Dufault #define CTL_P1003_1B_PAGESIZE 20 /* int */
11178a6472b7SPeter Dufault #define CTL_P1003_1B_RTSIG_MAX 21 /* int */
11188a6472b7SPeter Dufault #define CTL_P1003_1B_SEM_NSEMS_MAX 22 /* int */
11198a6472b7SPeter Dufault #define CTL_P1003_1B_SEM_VALUE_MAX 23 /* int */
11208a6472b7SPeter Dufault #define CTL_P1003_1B_SIGQUEUE_MAX 24 /* int */
11218a6472b7SPeter Dufault #define CTL_P1003_1B_TIMER_MAX 25 /* int */
11228a6472b7SPeter Dufault
1123664a31e4SPeter Wemm #ifdef _KERNEL
1124df8bae1dSRodney W. Grimes
1125153f46edSAlan Somers #define CTL_P1003_1B_MAXID 26
1126153f46edSAlan Somers
1127ce02431fSDoug Rabson /*
1128ce02431fSDoug Rabson * Declare some common oids.
1129ce02431fSDoug Rabson */
1130ce02431fSDoug Rabson extern struct sysctl_oid_list sysctl__children;
1131ce02431fSDoug Rabson SYSCTL_DECL(_kern);
1132df67e9f2SJohn Baldwin SYSCTL_DECL(_kern_features);
1133b37ffd31SRobert Watson SYSCTL_DECL(_kern_ipc);
1134cc43c38cSRobert Watson SYSCTL_DECL(_kern_proc);
11359727e637SJeff Roberson SYSCTL_DECL(_kern_sched);
11368df78c41SJeff Roberson SYSCTL_DECL(_kern_sched_stats);
1137ce02431fSDoug Rabson SYSCTL_DECL(_sysctl);
1138ce02431fSDoug Rabson SYSCTL_DECL(_vm);
1139b276ae6fSAlan Cox SYSCTL_DECL(_vm_stats);
1140b276ae6fSAlan Cox SYSCTL_DECL(_vm_stats_misc);
1141ce02431fSDoug Rabson SYSCTL_DECL(_vfs);
1142ce02431fSDoug Rabson SYSCTL_DECL(_net);
1143ce02431fSDoug Rabson SYSCTL_DECL(_debug);
1144c794254dSPoul-Henning Kamp SYSCTL_DECL(_debug_sizeof);
1145e8fbbcdfSWarner Losh SYSCTL_DECL(_dev);
1146ce02431fSDoug Rabson SYSCTL_DECL(_hw);
1147eb0d6cdeSPoul-Henning Kamp SYSCTL_DECL(_hw_bus);
1148e8fbbcdfSWarner Losh SYSCTL_DECL(_hw_bus_devices);
1149ce02431fSDoug Rabson SYSCTL_DECL(_machdep);
1150de890ea4SScott Long SYSCTL_DECL(_machdep_mitigations);
1151ce02431fSDoug Rabson SYSCTL_DECL(_user);
1152c6dfea0eSMarcel Moolenaar SYSCTL_DECL(_compat);
1153d9949cb2SRobert Watson SYSCTL_DECL(_regression);
11545702e096SRobert Watson SYSCTL_DECL(_security);
11555702e096SRobert Watson SYSCTL_DECL(_security_bsd);
1156ce02431fSDoug Rabson
1157356be134SZhenlei Huang extern const char machine[];
1158356be134SZhenlei Huang extern const char osrelease[];
1159356be134SZhenlei Huang extern const char ostype[];
1160356be134SZhenlei Huang extern const char kern_ident[];
1161b5e8ce9fSBruce Evans
1162bd3cdc31SAndrzej Bialecki /* Dynamic oid handling */
1163bd3cdc31SAndrzej Bialecki struct sysctl_oid *sysctl_add_oid(struct sysctl_ctx_list *clist,
116443688a78SPawel Jakub Dawidek struct sysctl_oid_list *parent, int nbr, const char *name, int kind,
1165f17aaa51SKonstantin Belousov void *arg1, intmax_t arg2, int (*handler)(SYSCTL_HANDLER_ARGS),
11661e1f3941SEd Schouten const char *fmt, const char *descr, const char *label);
1167e4cd31ddSJeff Roberson int sysctl_remove_name(struct sysctl_oid *parent, const char *name, int del,
1168e4cd31ddSJeff Roberson int recurse);
1169cd17ceaaSPeter Wemm void sysctl_rename_oid(struct sysctl_oid *oidp, const char *name);
117021885af5SDag-Erling Smørgrav int sysctl_move_oid(struct sysctl_oid *oidp,
117121885af5SDag-Erling Smørgrav struct sysctl_oid_list *parent);
1172bd3cdc31SAndrzej Bialecki int sysctl_remove_oid(struct sysctl_oid *oidp, int del, int recurse);
1173bd3cdc31SAndrzej Bialecki int sysctl_ctx_init(struct sysctl_ctx_list *clist);
1174bd3cdc31SAndrzej Bialecki int sysctl_ctx_free(struct sysctl_ctx_list *clist);
1175bd3cdc31SAndrzej Bialecki struct sysctl_ctx_entry *sysctl_ctx_entry_add(struct sysctl_ctx_list *clist,
1176bd3cdc31SAndrzej Bialecki struct sysctl_oid *oidp);
1177bd3cdc31SAndrzej Bialecki struct sysctl_ctx_entry *sysctl_ctx_entry_find(struct sysctl_ctx_list *clist,
1178bd3cdc31SAndrzej Bialecki struct sysctl_oid *oidp);
1179bd3cdc31SAndrzej Bialecki int sysctl_ctx_entry_del(struct sysctl_ctx_list *clist,
1180bd3cdc31SAndrzej Bialecki struct sysctl_oid *oidp);
1181bd3cdc31SAndrzej Bialecki
1182b40ce416SJulian Elischer int kernel_sysctl(struct thread *td, int *name, u_int namelen, void *old,
118343688a78SPawel Jakub Dawidek size_t *oldlenp, void *new, size_t newlen, size_t *retval,
118443688a78SPawel Jakub Dawidek int flags);
118543688a78SPawel Jakub Dawidek int kernel_sysctlbyname(struct thread *td, char *name, void *old,
118643688a78SPawel Jakub Dawidek size_t *oldlenp, void *new, size_t newlen, size_t *retval,
118743688a78SPawel Jakub Dawidek int flags);
1188b40ce416SJulian Elischer int userland_sysctl(struct thread *td, int *name, u_int namelen, void *old,
118910f7b12cSBrooks Davis size_t *oldlenp, int inkernel, const void *new, size_t newlen,
1190a7bc3102SPeter Wemm size_t *retval, int flags);
1191226420a4SBrian Feldman int sysctl_find_oid(int *name, u_int namelen, struct sysctl_oid **noid,
1192226420a4SBrian Feldman int *nindx, struct sysctl_req *req);
11937665e341SMateusz Guzik void sysctl_wlock(void);
11947665e341SMateusz Guzik void sysctl_wunlock(void);
119547934cefSDon Lewis int sysctl_wire_old_buffer(struct sysctl_req *req, size_t len);
1196d05b53e0SMateusz Guzik int kern___sysctlbyname(struct thread *td, const char *name,
1197d05b53e0SMateusz Guzik size_t namelen, void *old, size_t *oldlenp, void *new,
1198d05b53e0SMateusz Guzik size_t newlen, size_t *retval, int flags, bool inkernel);
11995955221aSGarrett Wollman
12004e657159SMatthew D Fleming struct sbuf;
12014e657159SMatthew D Fleming struct sbuf *sbuf_new_for_sysctl(struct sbuf *, char *, int,
12024e657159SMatthew D Fleming struct sysctl_req *);
1203664a31e4SPeter Wemm #else /* !_KERNEL */
1204df8bae1dSRodney W. Grimes #include <sys/cdefs.h>
120556ee5c55SWarner Losh #include <sys/_types.h>
120656ee5c55SWarner Losh #ifndef _SIZE_T_DECLARED
120756ee5c55SWarner Losh typedef __size_t size_t;
120856ee5c55SWarner Losh #define _SIZE_T_DECLARED
120956ee5c55SWarner Losh #endif
1210df8bae1dSRodney W. Grimes
1211df8bae1dSRodney W. Grimes __BEGIN_DECLS
121256ee5c55SWarner Losh int sysctl(const int *, unsigned int, void *, size_t *, const void *, size_t);
121362399df2SEd Schouten int sysctlbyname(const char *, void *, size_t *, const void *, size_t);
1214789f12feSAlfred Perlstein int sysctlnametomib(const char *, int *, size_t *);
1215df8bae1dSRodney W. Grimes __END_DECLS
1216664a31e4SPeter Wemm #endif /* _KERNEL */
1217dedb3ba6SBruce Evans
1218df8bae1dSRodney W. Grimes #endif /* !_SYS_SYSCTL_H_ */
1219