xref: /freebsd/sys/sys/sysctl.h (revision c85d3064c454bde9f1c0cfbb6f42c0ac9fa229e9)
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