1a9643ea8Slogwang /*- 2*22ce4affSfengbojiang * SPDX-License-Identifier: BSD-3-Clause 3*22ce4affSfengbojiang * 4a9643ea8Slogwang * Copyright (c) 1989, 1993 5a9643ea8Slogwang * The Regents of the University of California. All rights reserved. 6a9643ea8Slogwang * 7a9643ea8Slogwang * This code is derived from software contributed to Berkeley by 8a9643ea8Slogwang * Mike Karels at Berkeley Software Design, Inc. 9a9643ea8Slogwang * 10a9643ea8Slogwang * Redistribution and use in source and binary forms, with or without 11a9643ea8Slogwang * modification, are permitted provided that the following conditions 12a9643ea8Slogwang * are met: 13a9643ea8Slogwang * 1. Redistributions of source code must retain the above copyright 14a9643ea8Slogwang * notice, this list of conditions and the following disclaimer. 15a9643ea8Slogwang * 2. Redistributions in binary form must reproduce the above copyright 16a9643ea8Slogwang * notice, this list of conditions and the following disclaimer in the 17a9643ea8Slogwang * documentation and/or other materials provided with the distribution. 18*22ce4affSfengbojiang * 3. Neither the name of the University nor the names of its contributors 19a9643ea8Slogwang * may be used to endorse or promote products derived from this software 20a9643ea8Slogwang * without specific prior written permission. 21a9643ea8Slogwang * 22a9643ea8Slogwang * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 23a9643ea8Slogwang * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 24a9643ea8Slogwang * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 25a9643ea8Slogwang * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 26a9643ea8Slogwang * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 27a9643ea8Slogwang * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 28a9643ea8Slogwang * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 29a9643ea8Slogwang * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 30a9643ea8Slogwang * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 31a9643ea8Slogwang * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 32a9643ea8Slogwang * SUCH DAMAGE. 33a9643ea8Slogwang * 34a9643ea8Slogwang * @(#)sysctl.h 8.1 (Berkeley) 6/2/93 35a9643ea8Slogwang * $FreeBSD$ 36a9643ea8Slogwang */ 37a9643ea8Slogwang 38a9643ea8Slogwang #ifndef _SYS_SYSCTL_H_ 39a9643ea8Slogwang #define _SYS_SYSCTL_H_ 40a9643ea8Slogwang 41*22ce4affSfengbojiang #ifdef _KERNEL 42a9643ea8Slogwang #include <sys/queue.h> 43*22ce4affSfengbojiang #endif 44a9643ea8Slogwang 45a9643ea8Slogwang struct thread; 46a9643ea8Slogwang /* 47a9643ea8Slogwang * Definitions for sysctl call. The sysctl call uses a hierarchical name 48a9643ea8Slogwang * for objects that can be examined or modified. The name is expressed as 49a9643ea8Slogwang * a sequence of integers. Like a file path name, the meaning of each 50a9643ea8Slogwang * component depends on its place in the hierarchy. The top-level and kern 51a9643ea8Slogwang * identifiers are defined here, and other identifiers are defined in the 52a9643ea8Slogwang * respective subsystem header files. 53a9643ea8Slogwang */ 54a9643ea8Slogwang 55a9643ea8Slogwang #define CTL_MAXNAME 24 /* largest number of components supported */ 56a9643ea8Slogwang 57a9643ea8Slogwang /* 58a9643ea8Slogwang * Each subsystem defined by sysctl defines a list of variables 59a9643ea8Slogwang * for that subsystem. Each name is either a node with further 60a9643ea8Slogwang * levels defined below it, or it is a leaf of some particular 61a9643ea8Slogwang * type given below. Each sysctl level defines a set of name/type 62a9643ea8Slogwang * pairs to be used by sysctl(8) in manipulating the subsystem. 63a9643ea8Slogwang */ 64a9643ea8Slogwang struct ctlname { 65a9643ea8Slogwang char *ctl_name; /* subsystem name */ 66a9643ea8Slogwang int ctl_type; /* type of name */ 67a9643ea8Slogwang }; 68a9643ea8Slogwang 69a9643ea8Slogwang #define CTLTYPE 0xf /* mask for the type */ 70a9643ea8Slogwang #define CTLTYPE_NODE 1 /* name is a node */ 71a9643ea8Slogwang #define CTLTYPE_INT 2 /* name describes an integer */ 72a9643ea8Slogwang #define CTLTYPE_STRING 3 /* name describes a string */ 73a9643ea8Slogwang #define CTLTYPE_S64 4 /* name describes a signed 64-bit number */ 74a9643ea8Slogwang #define CTLTYPE_OPAQUE 5 /* name describes a structure */ 75a9643ea8Slogwang #define CTLTYPE_STRUCT CTLTYPE_OPAQUE /* name describes a structure */ 76a9643ea8Slogwang #define CTLTYPE_UINT 6 /* name describes an unsigned integer */ 77a9643ea8Slogwang #define CTLTYPE_LONG 7 /* name describes a long */ 78a9643ea8Slogwang #define CTLTYPE_ULONG 8 /* name describes an unsigned long */ 79a9643ea8Slogwang #define CTLTYPE_U64 9 /* name describes an unsigned 64-bit number */ 80a9643ea8Slogwang #define CTLTYPE_U8 0xa /* name describes an unsigned 8-bit number */ 81a9643ea8Slogwang #define CTLTYPE_U16 0xb /* name describes an unsigned 16-bit number */ 82a9643ea8Slogwang #define CTLTYPE_S8 0xc /* name describes a signed 8-bit number */ 83a9643ea8Slogwang #define CTLTYPE_S16 0xd /* name describes a signed 16-bit number */ 84a9643ea8Slogwang #define CTLTYPE_S32 0xe /* name describes a signed 32-bit number */ 85a9643ea8Slogwang #define CTLTYPE_U32 0xf /* name describes an unsigned 32-bit number */ 86a9643ea8Slogwang 87a9643ea8Slogwang #define CTLFLAG_RD 0x80000000 /* Allow reads of variable */ 88a9643ea8Slogwang #define CTLFLAG_WR 0x40000000 /* Allow writes to the variable */ 89a9643ea8Slogwang #define CTLFLAG_RW (CTLFLAG_RD|CTLFLAG_WR) 90*22ce4affSfengbojiang #define CTLFLAG_DORMANT 0x20000000 /* This sysctl is not active yet */ 91a9643ea8Slogwang #define CTLFLAG_ANYBODY 0x10000000 /* All users can set this var */ 92a9643ea8Slogwang #define CTLFLAG_SECURE 0x08000000 /* Permit set only if securelevel<=0 */ 93a9643ea8Slogwang #define CTLFLAG_PRISON 0x04000000 /* Prisoned roots can fiddle */ 94a9643ea8Slogwang #define CTLFLAG_DYN 0x02000000 /* Dynamic oid - can be freed */ 95a9643ea8Slogwang #define CTLFLAG_SKIP 0x01000000 /* Skip this sysctl when listing */ 96a9643ea8Slogwang #define CTLMASK_SECURE 0x00F00000 /* Secure level */ 97a9643ea8Slogwang #define CTLFLAG_TUN 0x00080000 /* Default value is loaded from getenv() */ 98a9643ea8Slogwang #define CTLFLAG_RDTUN (CTLFLAG_RD|CTLFLAG_TUN) 99a9643ea8Slogwang #define CTLFLAG_RWTUN (CTLFLAG_RW|CTLFLAG_TUN) 100a9643ea8Slogwang #define CTLFLAG_MPSAFE 0x00040000 /* Handler is MP safe */ 101a9643ea8Slogwang #define CTLFLAG_VNET 0x00020000 /* Prisons with vnet can fiddle */ 102a9643ea8Slogwang #define CTLFLAG_DYING 0x00010000 /* Oid is being removed */ 103a9643ea8Slogwang #define CTLFLAG_CAPRD 0x00008000 /* Can be read in capability mode */ 104a9643ea8Slogwang #define CTLFLAG_CAPWR 0x00004000 /* Can be written in capability mode */ 105a9643ea8Slogwang #define CTLFLAG_STATS 0x00002000 /* Statistics, not a tuneable */ 106a9643ea8Slogwang #define CTLFLAG_NOFETCH 0x00001000 /* Don't fetch tunable from getenv() */ 107a9643ea8Slogwang #define CTLFLAG_CAPRW (CTLFLAG_CAPRD|CTLFLAG_CAPWR) 108*22ce4affSfengbojiang /* 109*22ce4affSfengbojiang * This is transient flag to be used until all sysctl handlers are converted 110*22ce4affSfengbojiang * to not lock Giant. 111*22ce4affSfengbojiang * One, and only one of CTLFLAG_MPSAFE or CTLFLAG_NEEDGIANT is required 112*22ce4affSfengbojiang * for SYSCTL_PROC and SYSCTL_NODE. 113*22ce4affSfengbojiang */ 114*22ce4affSfengbojiang #define CTLFLAG_NEEDGIANT 0x00000800 /* Handler require Giant */ 115a9643ea8Slogwang 116a9643ea8Slogwang /* 117a9643ea8Slogwang * Secure level. Note that CTLFLAG_SECURE == CTLFLAG_SECURE1. 118a9643ea8Slogwang * 119a9643ea8Slogwang * Secure when the securelevel is raised to at least N. 120a9643ea8Slogwang */ 121a9643ea8Slogwang #define CTLSHIFT_SECURE 20 122a9643ea8Slogwang #define CTLFLAG_SECURE1 (CTLFLAG_SECURE | (0 << CTLSHIFT_SECURE)) 123a9643ea8Slogwang #define CTLFLAG_SECURE2 (CTLFLAG_SECURE | (1 << CTLSHIFT_SECURE)) 124a9643ea8Slogwang #define CTLFLAG_SECURE3 (CTLFLAG_SECURE | (2 << CTLSHIFT_SECURE)) 125a9643ea8Slogwang 126a9643ea8Slogwang /* 127a9643ea8Slogwang * USE THIS instead of a hardwired number from the categories below 128a9643ea8Slogwang * to get dynamically assigned sysctl entries using the linker-set 129a9643ea8Slogwang * technology. This is the way nearly all new sysctl variables should 130a9643ea8Slogwang * be implemented. 131a9643ea8Slogwang * e.g. SYSCTL_INT(_parent, OID_AUTO, name, CTLFLAG_RW, &variable, 0, ""); 132a9643ea8Slogwang */ 133a9643ea8Slogwang #define OID_AUTO (-1) 134a9643ea8Slogwang 135a9643ea8Slogwang /* 136a9643ea8Slogwang * The starting number for dynamically-assigned entries. WARNING! 137a9643ea8Slogwang * ALL static sysctl entries should have numbers LESS than this! 138a9643ea8Slogwang */ 139a9643ea8Slogwang #define CTL_AUTO_START 0x100 140a9643ea8Slogwang 141a9643ea8Slogwang #ifdef _KERNEL 142a9643ea8Slogwang #include <sys/linker_set.h> 143a9643ea8Slogwang 144a9643ea8Slogwang #ifdef KLD_MODULE 145a9643ea8Slogwang /* XXX allow overspecification of type in external kernel modules */ 146a9643ea8Slogwang #define SYSCTL_CT_ASSERT_MASK CTLTYPE 147a9643ea8Slogwang #else 148a9643ea8Slogwang #define SYSCTL_CT_ASSERT_MASK 0 149a9643ea8Slogwang #endif 150a9643ea8Slogwang 151a9643ea8Slogwang #define SYSCTL_HANDLER_ARGS struct sysctl_oid *oidp, void *arg1, \ 152a9643ea8Slogwang intmax_t arg2, struct sysctl_req *req 153a9643ea8Slogwang 154a9643ea8Slogwang /* definitions for sysctl_req 'lock' member */ 155a9643ea8Slogwang #define REQ_UNWIRED 1 156a9643ea8Slogwang #define REQ_WIRED 2 157a9643ea8Slogwang 158a9643ea8Slogwang /* definitions for sysctl_req 'flags' member */ 159*22ce4affSfengbojiang #ifdef COMPAT_FREEBSD32 160a9643ea8Slogwang #define SCTL_MASK32 1 /* 32 bit emulation */ 161a9643ea8Slogwang #endif 162a9643ea8Slogwang 163a9643ea8Slogwang /* 164a9643ea8Slogwang * This describes the access space for a sysctl request. This is needed 165a9643ea8Slogwang * so that we can use the interface from the kernel or from user-space. 166a9643ea8Slogwang */ 167a9643ea8Slogwang struct sysctl_req { 168a9643ea8Slogwang struct thread *td; /* used for access checking */ 169a9643ea8Slogwang int lock; /* wiring state */ 170a9643ea8Slogwang void *oldptr; 171a9643ea8Slogwang size_t oldlen; 172a9643ea8Slogwang size_t oldidx; 173a9643ea8Slogwang int (*oldfunc)(struct sysctl_req *, const void *, size_t); 174*22ce4affSfengbojiang const void *newptr; 175a9643ea8Slogwang size_t newlen; 176a9643ea8Slogwang size_t newidx; 177a9643ea8Slogwang int (*newfunc)(struct sysctl_req *, void *, size_t); 178a9643ea8Slogwang size_t validlen; 179a9643ea8Slogwang int flags; 180a9643ea8Slogwang }; 181a9643ea8Slogwang 182a9643ea8Slogwang SLIST_HEAD(sysctl_oid_list, sysctl_oid); 183a9643ea8Slogwang 184a9643ea8Slogwang /* 185a9643ea8Slogwang * This describes one "oid" in the MIB tree. Potentially more nodes can 186a9643ea8Slogwang * be hidden behind it, expanded by the handler. 187a9643ea8Slogwang */ 188a9643ea8Slogwang struct sysctl_oid { 189a9643ea8Slogwang struct sysctl_oid_list oid_children; 190a9643ea8Slogwang struct sysctl_oid_list *oid_parent; 191a9643ea8Slogwang SLIST_ENTRY(sysctl_oid) oid_link; 192a9643ea8Slogwang int oid_number; 193a9643ea8Slogwang u_int oid_kind; 194a9643ea8Slogwang void *oid_arg1; 195a9643ea8Slogwang intmax_t oid_arg2; 196a9643ea8Slogwang const char *oid_name; 197a9643ea8Slogwang int (*oid_handler)(SYSCTL_HANDLER_ARGS); 198a9643ea8Slogwang const char *oid_fmt; 199a9643ea8Slogwang int oid_refcnt; 200a9643ea8Slogwang u_int oid_running; 201a9643ea8Slogwang const char *oid_descr; 202*22ce4affSfengbojiang const char *oid_label; 203a9643ea8Slogwang }; 204a9643ea8Slogwang 205a9643ea8Slogwang #define SYSCTL_IN(r, p, l) (r->newfunc)(r, p, l) 206a9643ea8Slogwang #define SYSCTL_OUT(r, p, l) (r->oldfunc)(r, p, l) 207a9643ea8Slogwang #define SYSCTL_OUT_STR(r, p) (r->oldfunc)(r, p, strlen(p) + 1) 208a9643ea8Slogwang 209a9643ea8Slogwang int sysctl_handle_bool(SYSCTL_HANDLER_ARGS); 210a9643ea8Slogwang int sysctl_handle_8(SYSCTL_HANDLER_ARGS); 211a9643ea8Slogwang int sysctl_handle_16(SYSCTL_HANDLER_ARGS); 212a9643ea8Slogwang int sysctl_handle_32(SYSCTL_HANDLER_ARGS); 213a9643ea8Slogwang int sysctl_handle_64(SYSCTL_HANDLER_ARGS); 214a9643ea8Slogwang int sysctl_handle_int(SYSCTL_HANDLER_ARGS); 215a9643ea8Slogwang int sysctl_msec_to_ticks(SYSCTL_HANDLER_ARGS); 216a9643ea8Slogwang int sysctl_handle_long(SYSCTL_HANDLER_ARGS); 217a9643ea8Slogwang int sysctl_handle_string(SYSCTL_HANDLER_ARGS); 218a9643ea8Slogwang int sysctl_handle_opaque(SYSCTL_HANDLER_ARGS); 219a9643ea8Slogwang int sysctl_handle_counter_u64(SYSCTL_HANDLER_ARGS); 220a9643ea8Slogwang int sysctl_handle_counter_u64_array(SYSCTL_HANDLER_ARGS); 221a9643ea8Slogwang 222a9643ea8Slogwang int sysctl_handle_uma_zone_max(SYSCTL_HANDLER_ARGS); 223a9643ea8Slogwang int sysctl_handle_uma_zone_cur(SYSCTL_HANDLER_ARGS); 224a9643ea8Slogwang 225*22ce4affSfengbojiang int sysctl_msec_to_sbintime(SYSCTL_HANDLER_ARGS); 226*22ce4affSfengbojiang int sysctl_usec_to_sbintime(SYSCTL_HANDLER_ARGS); 227*22ce4affSfengbojiang int sysctl_sec_to_timeval(SYSCTL_HANDLER_ARGS); 228*22ce4affSfengbojiang 229a9643ea8Slogwang int sysctl_dpcpu_int(SYSCTL_HANDLER_ARGS); 230a9643ea8Slogwang int sysctl_dpcpu_long(SYSCTL_HANDLER_ARGS); 231a9643ea8Slogwang int sysctl_dpcpu_quad(SYSCTL_HANDLER_ARGS); 232a9643ea8Slogwang 233a9643ea8Slogwang /* 234a9643ea8Slogwang * These functions are used to add/remove an oid from the mib. 235a9643ea8Slogwang */ 236a9643ea8Slogwang void sysctl_register_oid(struct sysctl_oid *oidp); 237*22ce4affSfengbojiang void sysctl_register_disabled_oid(struct sysctl_oid *oidp); 238*22ce4affSfengbojiang void sysctl_enable_oid(struct sysctl_oid *oidp); 239a9643ea8Slogwang void sysctl_unregister_oid(struct sysctl_oid *oidp); 240a9643ea8Slogwang 241a9643ea8Slogwang /* Declare a static oid to allow child oids to be added to it. */ 242a9643ea8Slogwang #define SYSCTL_DECL(name) \ 243a9643ea8Slogwang extern struct sysctl_oid sysctl__##name 244a9643ea8Slogwang 245a9643ea8Slogwang /* Hide these in macros. */ 246a9643ea8Slogwang #define SYSCTL_CHILDREN(oid_ptr) (&(oid_ptr)->oid_children) 247a9643ea8Slogwang #define SYSCTL_PARENT(oid_ptr) \ 248a9643ea8Slogwang (((oid_ptr)->oid_parent != &sysctl__children) ? \ 249a9643ea8Slogwang __containerof((oid_ptr)->oid_parent, struct sysctl_oid, \ 250a9643ea8Slogwang oid_children) : (struct sysctl_oid *)NULL) 251a9643ea8Slogwang #define SYSCTL_STATIC_CHILDREN(oid_name) (&sysctl__##oid_name.oid_children) 252a9643ea8Slogwang 253a9643ea8Slogwang /* === Structs and macros related to context handling. === */ 254a9643ea8Slogwang 255a9643ea8Slogwang /* All dynamically created sysctls can be tracked in a context list. */ 256a9643ea8Slogwang struct sysctl_ctx_entry { 257a9643ea8Slogwang struct sysctl_oid *entry; 258a9643ea8Slogwang TAILQ_ENTRY(sysctl_ctx_entry) link; 259a9643ea8Slogwang }; 260a9643ea8Slogwang 261a9643ea8Slogwang TAILQ_HEAD(sysctl_ctx_list, sysctl_ctx_entry); 262a9643ea8Slogwang 263a9643ea8Slogwang #define SYSCTL_NODE_CHILDREN(parent, name) \ 264a9643ea8Slogwang sysctl__##parent##_##name.oid_children 265a9643ea8Slogwang 266a9643ea8Slogwang #ifndef NO_SYSCTL_DESCR 267a9643ea8Slogwang #define __DESCR(d) d 268a9643ea8Slogwang #else 269a9643ea8Slogwang #define __DESCR(d) "" 270a9643ea8Slogwang #endif 271a9643ea8Slogwang 272*22ce4affSfengbojiang #ifdef notyet 273*22ce4affSfengbojiang #define SYSCTL_ENFORCE_FLAGS(x) \ 274*22ce4affSfengbojiang _Static_assert((((x) & CTLFLAG_MPSAFE) != 0) ^ (((x) & CTLFLAG_NEEDGIANT) != 0), \ 275*22ce4affSfengbojiang "Has to be either CTLFLAG_MPSAFE or CTLFLAG_NEEDGIANT") 276*22ce4affSfengbojiang #else 277*22ce4affSfengbojiang #define SYSCTL_ENFORCE_FLAGS(x) 278*22ce4affSfengbojiang #endif 279*22ce4affSfengbojiang 280a9643ea8Slogwang /* This macro is only for internal use */ 281*22ce4affSfengbojiang #define SYSCTL_OID_RAW(id, parent_child_head, nbr, name, kind, a1, a2, handler, fmt, descr, label) \ 282a9643ea8Slogwang struct sysctl_oid id = { \ 283a9643ea8Slogwang .oid_parent = (parent_child_head), \ 284a9643ea8Slogwang .oid_children = SLIST_HEAD_INITIALIZER(&id.oid_children), \ 285a9643ea8Slogwang .oid_number = (nbr), \ 286a9643ea8Slogwang .oid_kind = (kind), \ 287a9643ea8Slogwang .oid_arg1 = (a1), \ 288a9643ea8Slogwang .oid_arg2 = (a2), \ 289a9643ea8Slogwang .oid_name = (name), \ 290a9643ea8Slogwang .oid_handler = (handler), \ 291a9643ea8Slogwang .oid_fmt = (fmt), \ 292*22ce4affSfengbojiang .oid_descr = __DESCR(descr), \ 293*22ce4affSfengbojiang .oid_label = (label), \ 294a9643ea8Slogwang }; \ 295*22ce4affSfengbojiang DATA_SET(sysctl_set, id); \ 296*22ce4affSfengbojiang SYSCTL_ENFORCE_FLAGS(kind) 297a9643ea8Slogwang 298a9643ea8Slogwang /* This constructs a static "raw" MIB oid. */ 299a9643ea8Slogwang #define SYSCTL_OID(parent, nbr, name, kind, a1, a2, handler, fmt, descr) \ 300*22ce4affSfengbojiang SYSCTL_OID_WITH_LABEL(parent, nbr, name, kind, a1, a2, \ 301*22ce4affSfengbojiang handler, fmt, descr, NULL) 302*22ce4affSfengbojiang 303*22ce4affSfengbojiang #define SYSCTL_OID_WITH_LABEL(parent, nbr, name, kind, a1, a2, handler, fmt, descr, label) \ 304a9643ea8Slogwang static SYSCTL_OID_RAW(sysctl__##parent##_##name, \ 305a9643ea8Slogwang SYSCTL_CHILDREN(&sysctl__##parent), \ 306*22ce4affSfengbojiang nbr, #name, kind, a1, a2, handler, fmt, descr, label) 307a9643ea8Slogwang 308a9643ea8Slogwang /* This constructs a global "raw" MIB oid. */ 309*22ce4affSfengbojiang #define SYSCTL_OID_GLOBAL(parent, nbr, name, kind, a1, a2, handler, fmt, descr, label) \ 310a9643ea8Slogwang SYSCTL_OID_RAW(sysctl__##parent##_##name, \ 311a9643ea8Slogwang SYSCTL_CHILDREN(&sysctl__##parent), \ 312*22ce4affSfengbojiang nbr, #name, kind, a1, a2, handler, fmt, descr, label) 313a9643ea8Slogwang 314a9643ea8Slogwang #define SYSCTL_ADD_OID(ctx, parent, nbr, name, kind, a1, a2, handler, fmt, descr) \ 315*22ce4affSfengbojiang ({ \ 316*22ce4affSfengbojiang SYSCTL_ENFORCE_FLAGS(kind); \ 317*22ce4affSfengbojiang sysctl_add_oid(ctx, parent, nbr, name, kind, a1, a2,handler, \ 318*22ce4affSfengbojiang fmt, __DESCR(descr), NULL); \ 319*22ce4affSfengbojiang }) 320a9643ea8Slogwang 321a9643ea8Slogwang /* This constructs a root node from which other nodes can hang. */ 322a9643ea8Slogwang #define SYSCTL_ROOT_NODE(nbr, name, access, handler, descr) \ 323a9643ea8Slogwang SYSCTL_OID_RAW(sysctl___##name, &sysctl__children, \ 324a9643ea8Slogwang nbr, #name, CTLTYPE_NODE|(access), NULL, 0, \ 325*22ce4affSfengbojiang handler, "N", descr, NULL); \ 326a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 327a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_NODE) 328a9643ea8Slogwang 329a9643ea8Slogwang /* This constructs a node from which other oids can hang. */ 330a9643ea8Slogwang #define SYSCTL_NODE(parent, nbr, name, access, handler, descr) \ 331*22ce4affSfengbojiang SYSCTL_NODE_WITH_LABEL(parent, nbr, name, access, handler, descr, NULL) 332*22ce4affSfengbojiang 333*22ce4affSfengbojiang #define SYSCTL_NODE_WITH_LABEL(parent, nbr, name, access, handler, descr, label) \ 334a9643ea8Slogwang SYSCTL_OID_GLOBAL(parent, nbr, name, CTLTYPE_NODE|(access), \ 335*22ce4affSfengbojiang NULL, 0, handler, "N", descr, label); \ 336*22ce4affSfengbojiang SYSCTL_ENFORCE_FLAGS(access); \ 337a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 338a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_NODE) 339a9643ea8Slogwang 340a9643ea8Slogwang #define SYSCTL_ADD_NODE(ctx, parent, nbr, name, access, handler, descr) \ 341*22ce4affSfengbojiang SYSCTL_ADD_NODE_WITH_LABEL(ctx, parent, nbr, name, access, \ 342*22ce4affSfengbojiang handler, descr, NULL) 343*22ce4affSfengbojiang 344*22ce4affSfengbojiang #define SYSCTL_ADD_NODE_WITH_LABEL(ctx, parent, nbr, name, access, handler, descr, label) \ 345a9643ea8Slogwang ({ \ 346a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 347a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_NODE); \ 348*22ce4affSfengbojiang SYSCTL_ENFORCE_FLAGS(access); \ 349a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, CTLTYPE_NODE|(access), \ 350*22ce4affSfengbojiang NULL, 0, handler, "N", __DESCR(descr), label); \ 351a9643ea8Slogwang }) 352a9643ea8Slogwang 353a9643ea8Slogwang #define SYSCTL_ADD_ROOT_NODE(ctx, nbr, name, access, handler, descr) \ 354a9643ea8Slogwang ({ \ 355a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 356a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_NODE); \ 357*22ce4affSfengbojiang SYSCTL_ENFORCE_FLAGS(access); \ 358a9643ea8Slogwang sysctl_add_oid(ctx, &sysctl__children, nbr, name, \ 359a9643ea8Slogwang CTLTYPE_NODE|(access), \ 360*22ce4affSfengbojiang NULL, 0, handler, "N", __DESCR(descr), NULL); \ 361a9643ea8Slogwang }) 362a9643ea8Slogwang 363a9643ea8Slogwang /* Oid for a string. len can be 0 to indicate '\0' termination. */ 364a9643ea8Slogwang #define SYSCTL_STRING(parent, nbr, name, access, arg, len, descr) \ 365*22ce4affSfengbojiang SYSCTL_OID(parent, nbr, name, \ 366*22ce4affSfengbojiang CTLTYPE_STRING | CTLFLAG_MPSAFE | (access), \ 367a9643ea8Slogwang arg, len, sysctl_handle_string, "A", descr); \ 368a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 369a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_STRING) 370a9643ea8Slogwang 371a9643ea8Slogwang #define SYSCTL_ADD_STRING(ctx, parent, nbr, name, access, arg, len, descr) \ 372a9643ea8Slogwang ({ \ 373a9643ea8Slogwang char *__arg = (arg); \ 374a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 375a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_STRING); \ 376*22ce4affSfengbojiang sysctl_add_oid(ctx, parent, nbr, name, \ 377*22ce4affSfengbojiang CTLTYPE_STRING | CTLFLAG_MPSAFE | (access), \ 378*22ce4affSfengbojiang __arg, len, sysctl_handle_string, "A", __DESCR(descr), \ 379*22ce4affSfengbojiang NULL); \ 380*22ce4affSfengbojiang }) 381*22ce4affSfengbojiang 382*22ce4affSfengbojiang /* Oid for a constant '\0' terminated string. */ 383*22ce4affSfengbojiang #define SYSCTL_CONST_STRING(parent, nbr, name, access, arg, descr) \ 384*22ce4affSfengbojiang SYSCTL_OID(parent, nbr, name, CTLTYPE_STRING | CTLFLAG_MPSAFE | (access),\ 385*22ce4affSfengbojiang __DECONST(char *, arg), 0, sysctl_handle_string, "A", descr); \ 386*22ce4affSfengbojiang CTASSERT(!(access & CTLFLAG_WR)); \ 387*22ce4affSfengbojiang CTASSERT(((access) & CTLTYPE) == 0 || \ 388*22ce4affSfengbojiang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_STRING) 389*22ce4affSfengbojiang 390*22ce4affSfengbojiang #define SYSCTL_ADD_CONST_STRING(ctx, parent, nbr, name, access, arg, descr) \ 391*22ce4affSfengbojiang ({ \ 392*22ce4affSfengbojiang char *__arg = __DECONST(char *, arg); \ 393*22ce4affSfengbojiang CTASSERT(!(access & CTLFLAG_WR)); \ 394*22ce4affSfengbojiang CTASSERT(((access) & CTLTYPE) == 0 || \ 395*22ce4affSfengbojiang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_STRING); \ 396*22ce4affSfengbojiang sysctl_add_oid(ctx, parent, nbr, name, CTLTYPE_STRING | \ 397*22ce4affSfengbojiang CTLFLAG_MPSAFE | (access), __arg, 0, sysctl_handle_string, "A",\ 398*22ce4affSfengbojiang __DESCR(descr), NULL); \ 399a9643ea8Slogwang }) 400a9643ea8Slogwang 401a9643ea8Slogwang /* Oid for a bool. If ptr is NULL, val is returned. */ 402a9643ea8Slogwang #define SYSCTL_NULL_BOOL_PTR ((bool *)NULL) 403a9643ea8Slogwang #define SYSCTL_BOOL(parent, nbr, name, access, ptr, val, descr) \ 404a9643ea8Slogwang SYSCTL_OID(parent, nbr, name, \ 405a9643ea8Slogwang CTLTYPE_U8 | CTLFLAG_MPSAFE | (access), \ 406a9643ea8Slogwang ptr, val, sysctl_handle_bool, "CU", descr); \ 407a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 && \ 408a9643ea8Slogwang sizeof(bool) == sizeof(*(ptr))) 409a9643ea8Slogwang 410a9643ea8Slogwang #define SYSCTL_ADD_BOOL(ctx, parent, nbr, name, access, ptr, val, descr) \ 411a9643ea8Slogwang ({ \ 412a9643ea8Slogwang bool *__ptr = (ptr); \ 413a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0); \ 414a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, \ 415a9643ea8Slogwang CTLTYPE_U8 | CTLFLAG_MPSAFE | (access), \ 416*22ce4affSfengbojiang __ptr, val, sysctl_handle_bool, "CU", __DESCR(descr), \ 417*22ce4affSfengbojiang NULL); \ 418a9643ea8Slogwang }) 419a9643ea8Slogwang 420a9643ea8Slogwang /* Oid for a signed 8-bit int. If ptr is NULL, val is returned. */ 421a9643ea8Slogwang #define SYSCTL_NULL_S8_PTR ((int8_t *)NULL) 422a9643ea8Slogwang #define SYSCTL_S8(parent, nbr, name, access, ptr, val, descr) \ 423a9643ea8Slogwang SYSCTL_OID(parent, nbr, name, \ 424a9643ea8Slogwang CTLTYPE_S8 | CTLFLAG_MPSAFE | (access), \ 425a9643ea8Slogwang ptr, val, sysctl_handle_8, "C", descr); \ 426a9643ea8Slogwang CTASSERT((((access) & CTLTYPE) == 0 || \ 427a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S8) && \ 428a9643ea8Slogwang sizeof(int8_t) == sizeof(*(ptr))) 429a9643ea8Slogwang 430a9643ea8Slogwang #define SYSCTL_ADD_S8(ctx, parent, nbr, name, access, ptr, val, descr) \ 431a9643ea8Slogwang ({ \ 432a9643ea8Slogwang int8_t *__ptr = (ptr); \ 433a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 434a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S8); \ 435a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, \ 436a9643ea8Slogwang CTLTYPE_S8 | CTLFLAG_MPSAFE | (access), \ 437*22ce4affSfengbojiang __ptr, val, sysctl_handle_8, "C", __DESCR(descr), NULL); \ 438a9643ea8Slogwang }) 439a9643ea8Slogwang 440a9643ea8Slogwang /* Oid for an unsigned 8-bit int. If ptr is NULL, val is returned. */ 441a9643ea8Slogwang #define SYSCTL_NULL_U8_PTR ((uint8_t *)NULL) 442a9643ea8Slogwang #define SYSCTL_U8(parent, nbr, name, access, ptr, val, descr) \ 443a9643ea8Slogwang SYSCTL_OID(parent, nbr, name, \ 444a9643ea8Slogwang CTLTYPE_U8 | CTLFLAG_MPSAFE | (access), \ 445a9643ea8Slogwang ptr, val, sysctl_handle_8, "CU", descr); \ 446a9643ea8Slogwang CTASSERT((((access) & CTLTYPE) == 0 || \ 447a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U8) && \ 448a9643ea8Slogwang sizeof(uint8_t) == sizeof(*(ptr))) 449a9643ea8Slogwang 450a9643ea8Slogwang #define SYSCTL_ADD_U8(ctx, parent, nbr, name, access, ptr, val, descr) \ 451a9643ea8Slogwang ({ \ 452a9643ea8Slogwang uint8_t *__ptr = (ptr); \ 453a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 454a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U8); \ 455a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, \ 456a9643ea8Slogwang CTLTYPE_U8 | CTLFLAG_MPSAFE | (access), \ 457*22ce4affSfengbojiang __ptr, val, sysctl_handle_8, "CU", __DESCR(descr), NULL); \ 458a9643ea8Slogwang }) 459a9643ea8Slogwang 460a9643ea8Slogwang /* Oid for a signed 16-bit int. If ptr is NULL, val is returned. */ 461a9643ea8Slogwang #define SYSCTL_NULL_S16_PTR ((int16_t *)NULL) 462a9643ea8Slogwang #define SYSCTL_S16(parent, nbr, name, access, ptr, val, descr) \ 463a9643ea8Slogwang SYSCTL_OID(parent, nbr, name, \ 464a9643ea8Slogwang CTLTYPE_S16 | CTLFLAG_MPSAFE | (access), \ 465a9643ea8Slogwang ptr, val, sysctl_handle_16, "S", descr); \ 466a9643ea8Slogwang CTASSERT((((access) & CTLTYPE) == 0 || \ 467a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S16) && \ 468a9643ea8Slogwang sizeof(int16_t) == sizeof(*(ptr))) 469a9643ea8Slogwang 470a9643ea8Slogwang #define SYSCTL_ADD_S16(ctx, parent, nbr, name, access, ptr, val, descr) \ 471a9643ea8Slogwang ({ \ 472a9643ea8Slogwang int16_t *__ptr = (ptr); \ 473a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 474a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S16); \ 475a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, \ 476a9643ea8Slogwang CTLTYPE_S16 | CTLFLAG_MPSAFE | (access), \ 477*22ce4affSfengbojiang __ptr, val, sysctl_handle_16, "S", __DESCR(descr), NULL); \ 478a9643ea8Slogwang }) 479a9643ea8Slogwang 480a9643ea8Slogwang /* Oid for an unsigned 16-bit int. If ptr is NULL, val is returned. */ 481a9643ea8Slogwang #define SYSCTL_NULL_U16_PTR ((uint16_t *)NULL) 482a9643ea8Slogwang #define SYSCTL_U16(parent, nbr, name, access, ptr, val, descr) \ 483a9643ea8Slogwang SYSCTL_OID(parent, nbr, name, \ 484a9643ea8Slogwang CTLTYPE_U16 | CTLFLAG_MPSAFE | (access), \ 485a9643ea8Slogwang ptr, val, sysctl_handle_16, "SU", descr); \ 486a9643ea8Slogwang CTASSERT((((access) & CTLTYPE) == 0 || \ 487a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U16) && \ 488a9643ea8Slogwang sizeof(uint16_t) == sizeof(*(ptr))) 489a9643ea8Slogwang 490a9643ea8Slogwang #define SYSCTL_ADD_U16(ctx, parent, nbr, name, access, ptr, val, descr) \ 491a9643ea8Slogwang ({ \ 492a9643ea8Slogwang uint16_t *__ptr = (ptr); \ 493a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 494a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U16); \ 495a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, \ 496a9643ea8Slogwang CTLTYPE_U16 | CTLFLAG_MPSAFE | (access), \ 497*22ce4affSfengbojiang __ptr, val, sysctl_handle_16, "SU", __DESCR(descr), NULL); \ 498a9643ea8Slogwang }) 499a9643ea8Slogwang 500a9643ea8Slogwang /* Oid for a signed 32-bit int. If ptr is NULL, val is returned. */ 501a9643ea8Slogwang #define SYSCTL_NULL_S32_PTR ((int32_t *)NULL) 502a9643ea8Slogwang #define SYSCTL_S32(parent, nbr, name, access, ptr, val, descr) \ 503a9643ea8Slogwang SYSCTL_OID(parent, nbr, name, \ 504a9643ea8Slogwang CTLTYPE_S32 | CTLFLAG_MPSAFE | (access), \ 505a9643ea8Slogwang ptr, val, sysctl_handle_32, "I", descr); \ 506a9643ea8Slogwang CTASSERT((((access) & CTLTYPE) == 0 || \ 507a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S32) && \ 508a9643ea8Slogwang sizeof(int32_t) == sizeof(*(ptr))) 509a9643ea8Slogwang 510a9643ea8Slogwang #define SYSCTL_ADD_S32(ctx, parent, nbr, name, access, ptr, val, descr) \ 511a9643ea8Slogwang ({ \ 512a9643ea8Slogwang int32_t *__ptr = (ptr); \ 513a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 514a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S32); \ 515a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, \ 516a9643ea8Slogwang CTLTYPE_S32 | CTLFLAG_MPSAFE | (access), \ 517*22ce4affSfengbojiang __ptr, val, sysctl_handle_32, "I", __DESCR(descr), NULL); \ 518a9643ea8Slogwang }) 519a9643ea8Slogwang 520a9643ea8Slogwang /* Oid for an unsigned 32-bit int. If ptr is NULL, val is returned. */ 521a9643ea8Slogwang #define SYSCTL_NULL_U32_PTR ((uint32_t *)NULL) 522a9643ea8Slogwang #define SYSCTL_U32(parent, nbr, name, access, ptr, val, descr) \ 523a9643ea8Slogwang SYSCTL_OID(parent, nbr, name, \ 524a9643ea8Slogwang CTLTYPE_U32 | CTLFLAG_MPSAFE | (access), \ 525a9643ea8Slogwang ptr, val, sysctl_handle_32, "IU", descr); \ 526a9643ea8Slogwang CTASSERT((((access) & CTLTYPE) == 0 || \ 527a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U32) && \ 528a9643ea8Slogwang sizeof(uint32_t) == sizeof(*(ptr))) 529a9643ea8Slogwang 530a9643ea8Slogwang #define SYSCTL_ADD_U32(ctx, parent, nbr, name, access, ptr, val, descr) \ 531a9643ea8Slogwang ({ \ 532a9643ea8Slogwang uint32_t *__ptr = (ptr); \ 533a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 534a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U32); \ 535a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, \ 536a9643ea8Slogwang CTLTYPE_U32 | CTLFLAG_MPSAFE | (access), \ 537*22ce4affSfengbojiang __ptr, val, sysctl_handle_32, "IU", __DESCR(descr), NULL); \ 538a9643ea8Slogwang }) 539a9643ea8Slogwang 540a9643ea8Slogwang /* Oid for a signed 64-bit int. If ptr is NULL, val is returned. */ 541a9643ea8Slogwang #define SYSCTL_NULL_S64_PTR ((int64_t *)NULL) 542a9643ea8Slogwang #define SYSCTL_S64(parent, nbr, name, access, ptr, val, descr) \ 543a9643ea8Slogwang SYSCTL_OID(parent, nbr, name, \ 544a9643ea8Slogwang CTLTYPE_S64 | CTLFLAG_MPSAFE | (access), \ 545a9643ea8Slogwang ptr, val, sysctl_handle_64, "Q", descr); \ 546a9643ea8Slogwang CTASSERT((((access) & CTLTYPE) == 0 || \ 547a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S64) && \ 548a9643ea8Slogwang sizeof(int64_t) == sizeof(*(ptr))) 549a9643ea8Slogwang 550a9643ea8Slogwang #define SYSCTL_ADD_S64(ctx, parent, nbr, name, access, ptr, val, descr) \ 551a9643ea8Slogwang ({ \ 552a9643ea8Slogwang int64_t *__ptr = (ptr); \ 553a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 554a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S64); \ 555a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, \ 556a9643ea8Slogwang CTLTYPE_S64 | CTLFLAG_MPSAFE | (access), \ 557*22ce4affSfengbojiang __ptr, val, sysctl_handle_64, "Q", __DESCR(descr), NULL); \ 558a9643ea8Slogwang }) 559a9643ea8Slogwang 560a9643ea8Slogwang /* Oid for an unsigned 64-bit int. If ptr is NULL, val is returned. */ 561a9643ea8Slogwang #define SYSCTL_NULL_U64_PTR ((uint64_t *)NULL) 562a9643ea8Slogwang #define SYSCTL_U64(parent, nbr, name, access, ptr, val, descr) \ 563a9643ea8Slogwang SYSCTL_OID(parent, nbr, name, \ 564a9643ea8Slogwang CTLTYPE_U64 | CTLFLAG_MPSAFE | (access), \ 565a9643ea8Slogwang ptr, val, sysctl_handle_64, "QU", descr); \ 566a9643ea8Slogwang CTASSERT((((access) & CTLTYPE) == 0 || \ 567a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U64) && \ 568a9643ea8Slogwang sizeof(uint64_t) == sizeof(*(ptr))) 569a9643ea8Slogwang 570a9643ea8Slogwang #define SYSCTL_ADD_U64(ctx, parent, nbr, name, access, ptr, val, descr) \ 571a9643ea8Slogwang ({ \ 572a9643ea8Slogwang uint64_t *__ptr = (ptr); \ 573a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 574a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U64); \ 575a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, \ 576a9643ea8Slogwang CTLTYPE_U64 | CTLFLAG_MPSAFE | (access), \ 577*22ce4affSfengbojiang __ptr, val, sysctl_handle_64, "QU", __DESCR(descr), NULL); \ 578a9643ea8Slogwang }) 579a9643ea8Slogwang 580a9643ea8Slogwang /* Oid for an int. If ptr is SYSCTL_NULL_INT_PTR, val is returned. */ 581a9643ea8Slogwang #define SYSCTL_NULL_INT_PTR ((int *)NULL) 582a9643ea8Slogwang #define SYSCTL_INT(parent, nbr, name, access, ptr, val, descr) \ 583*22ce4affSfengbojiang SYSCTL_INT_WITH_LABEL(parent, nbr, name, access, ptr, val, descr, NULL) 584*22ce4affSfengbojiang 585*22ce4affSfengbojiang #define SYSCTL_INT_WITH_LABEL(parent, nbr, name, access, ptr, val, descr, label) \ 586*22ce4affSfengbojiang SYSCTL_OID_WITH_LABEL(parent, nbr, name, \ 587a9643ea8Slogwang CTLTYPE_INT | CTLFLAG_MPSAFE | (access), \ 588*22ce4affSfengbojiang ptr, val, sysctl_handle_int, "I", descr, label); \ 589a9643ea8Slogwang CTASSERT((((access) & CTLTYPE) == 0 || \ 590a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_INT) && \ 591a9643ea8Slogwang sizeof(int) == sizeof(*(ptr))) 592a9643ea8Slogwang 593a9643ea8Slogwang #define SYSCTL_ADD_INT(ctx, parent, nbr, name, access, ptr, val, descr) \ 594a9643ea8Slogwang ({ \ 595a9643ea8Slogwang int *__ptr = (ptr); \ 596a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 597a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_INT); \ 598a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, \ 599a9643ea8Slogwang CTLTYPE_INT | CTLFLAG_MPSAFE | (access), \ 600*22ce4affSfengbojiang __ptr, val, sysctl_handle_int, "I", __DESCR(descr), NULL); \ 601a9643ea8Slogwang }) 602a9643ea8Slogwang 603a9643ea8Slogwang /* Oid for an unsigned int. If ptr is NULL, val is returned. */ 604a9643ea8Slogwang #define SYSCTL_NULL_UINT_PTR ((unsigned *)NULL) 605a9643ea8Slogwang #define SYSCTL_UINT(parent, nbr, name, access, ptr, val, descr) \ 606a9643ea8Slogwang SYSCTL_OID(parent, nbr, name, \ 607a9643ea8Slogwang CTLTYPE_UINT | CTLFLAG_MPSAFE | (access), \ 608a9643ea8Slogwang ptr, val, sysctl_handle_int, "IU", descr); \ 609a9643ea8Slogwang CTASSERT((((access) & CTLTYPE) == 0 || \ 610a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_UINT) && \ 611a9643ea8Slogwang sizeof(unsigned) == sizeof(*(ptr))) 612a9643ea8Slogwang 613a9643ea8Slogwang #define SYSCTL_ADD_UINT(ctx, parent, nbr, name, access, ptr, val, descr) \ 614a9643ea8Slogwang ({ \ 615a9643ea8Slogwang unsigned *__ptr = (ptr); \ 616a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 617a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_UINT); \ 618a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, \ 619a9643ea8Slogwang CTLTYPE_UINT | CTLFLAG_MPSAFE | (access), \ 620*22ce4affSfengbojiang __ptr, val, sysctl_handle_int, "IU", __DESCR(descr), NULL); \ 621a9643ea8Slogwang }) 622a9643ea8Slogwang 623a9643ea8Slogwang /* Oid for a long. The pointer must be non NULL. */ 624a9643ea8Slogwang #define SYSCTL_NULL_LONG_PTR ((long *)NULL) 625a9643ea8Slogwang #define SYSCTL_LONG(parent, nbr, name, access, ptr, val, descr) \ 626a9643ea8Slogwang SYSCTL_OID(parent, nbr, name, \ 627a9643ea8Slogwang CTLTYPE_LONG | CTLFLAG_MPSAFE | (access), \ 628a9643ea8Slogwang ptr, val, sysctl_handle_long, "L", descr); \ 629a9643ea8Slogwang CTASSERT((((access) & CTLTYPE) == 0 || \ 630a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_LONG) && \ 631a9643ea8Slogwang sizeof(long) == sizeof(*(ptr))) 632a9643ea8Slogwang 633a9643ea8Slogwang #define SYSCTL_ADD_LONG(ctx, parent, nbr, name, access, ptr, descr) \ 634a9643ea8Slogwang ({ \ 635a9643ea8Slogwang long *__ptr = (ptr); \ 636a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 637a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_LONG); \ 638a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, \ 639a9643ea8Slogwang CTLTYPE_LONG | CTLFLAG_MPSAFE | (access), \ 640*22ce4affSfengbojiang __ptr, 0, sysctl_handle_long, "L", __DESCR(descr), NULL); \ 641a9643ea8Slogwang }) 642a9643ea8Slogwang 643a9643ea8Slogwang /* Oid for an unsigned long. The pointer must be non NULL. */ 644a9643ea8Slogwang #define SYSCTL_NULL_ULONG_PTR ((unsigned long *)NULL) 645a9643ea8Slogwang #define SYSCTL_ULONG(parent, nbr, name, access, ptr, val, descr) \ 646a9643ea8Slogwang SYSCTL_OID(parent, nbr, name, \ 647a9643ea8Slogwang CTLTYPE_ULONG | CTLFLAG_MPSAFE | (access), \ 648a9643ea8Slogwang ptr, val, sysctl_handle_long, "LU", descr); \ 649a9643ea8Slogwang CTASSERT((((access) & CTLTYPE) == 0 || \ 650a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_ULONG) && \ 651a9643ea8Slogwang sizeof(unsigned long) == sizeof(*(ptr))) 652a9643ea8Slogwang 653a9643ea8Slogwang #define SYSCTL_ADD_ULONG(ctx, parent, nbr, name, access, ptr, descr) \ 654a9643ea8Slogwang ({ \ 655a9643ea8Slogwang unsigned long *__ptr = (ptr); \ 656a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 657a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_ULONG); \ 658a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, \ 659a9643ea8Slogwang CTLTYPE_ULONG | CTLFLAG_MPSAFE | (access), \ 660*22ce4affSfengbojiang __ptr, 0, sysctl_handle_long, "LU", __DESCR(descr), NULL); \ 661a9643ea8Slogwang }) 662a9643ea8Slogwang 663a9643ea8Slogwang /* Oid for a quad. The pointer must be non NULL. */ 664a9643ea8Slogwang #define SYSCTL_NULL_QUAD_PTR ((int64_t *)NULL) 665a9643ea8Slogwang #define SYSCTL_QUAD(parent, nbr, name, access, ptr, val, descr) \ 666a9643ea8Slogwang SYSCTL_OID(parent, nbr, name, \ 667a9643ea8Slogwang CTLTYPE_S64 | CTLFLAG_MPSAFE | (access), \ 668a9643ea8Slogwang ptr, val, sysctl_handle_64, "Q", descr); \ 669a9643ea8Slogwang CTASSERT((((access) & CTLTYPE) == 0 || \ 670a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S64) && \ 671a9643ea8Slogwang sizeof(int64_t) == sizeof(*(ptr))) 672a9643ea8Slogwang 673a9643ea8Slogwang #define SYSCTL_ADD_QUAD(ctx, parent, nbr, name, access, ptr, descr) \ 674a9643ea8Slogwang ({ \ 675a9643ea8Slogwang int64_t *__ptr = (ptr); \ 676a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 677a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S64); \ 678a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, \ 679a9643ea8Slogwang CTLTYPE_S64 | CTLFLAG_MPSAFE | (access), \ 680*22ce4affSfengbojiang __ptr, 0, sysctl_handle_64, "Q", __DESCR(descr), NULL); \ 681a9643ea8Slogwang }) 682a9643ea8Slogwang 683a9643ea8Slogwang #define SYSCTL_NULL_UQUAD_PTR ((uint64_t *)NULL) 684a9643ea8Slogwang #define SYSCTL_UQUAD(parent, nbr, name, access, ptr, val, descr) \ 685a9643ea8Slogwang SYSCTL_OID(parent, nbr, name, \ 686a9643ea8Slogwang CTLTYPE_U64 | CTLFLAG_MPSAFE | (access), \ 687a9643ea8Slogwang ptr, val, sysctl_handle_64, "QU", descr); \ 688a9643ea8Slogwang CTASSERT((((access) & CTLTYPE) == 0 || \ 689a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U64) && \ 690a9643ea8Slogwang sizeof(uint64_t) == sizeof(*(ptr))) 691a9643ea8Slogwang 692a9643ea8Slogwang #define SYSCTL_ADD_UQUAD(ctx, parent, nbr, name, access, ptr, descr) \ 693a9643ea8Slogwang ({ \ 694a9643ea8Slogwang uint64_t *__ptr = (ptr); \ 695a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 696a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U64); \ 697a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, \ 698a9643ea8Slogwang CTLTYPE_U64 | CTLFLAG_MPSAFE | (access), \ 699*22ce4affSfengbojiang __ptr, 0, sysctl_handle_64, "QU", __DESCR(descr), NULL); \ 700a9643ea8Slogwang }) 701a9643ea8Slogwang 702a9643ea8Slogwang /* Oid for a CPU dependent variable */ 703a9643ea8Slogwang #define SYSCTL_ADD_UAUTO(ctx, parent, nbr, name, access, ptr, descr) \ 704a9643ea8Slogwang ({ \ 705a9643ea8Slogwang struct sysctl_oid *__ret; \ 706a9643ea8Slogwang CTASSERT((sizeof(uint64_t) == sizeof(*(ptr)) || \ 707a9643ea8Slogwang sizeof(unsigned) == sizeof(*(ptr))) && \ 708a9643ea8Slogwang ((access) & CTLTYPE) == 0); \ 709a9643ea8Slogwang if (sizeof(uint64_t) == sizeof(*(ptr))) { \ 710a9643ea8Slogwang __ret = sysctl_add_oid(ctx, parent, nbr, name, \ 711a9643ea8Slogwang CTLTYPE_U64 | CTLFLAG_MPSAFE | (access), \ 712a9643ea8Slogwang (ptr), 0, sysctl_handle_64, "QU", \ 713*22ce4affSfengbojiang __DESCR(descr), NULL); \ 714a9643ea8Slogwang } else { \ 715a9643ea8Slogwang __ret = sysctl_add_oid(ctx, parent, nbr, name, \ 716a9643ea8Slogwang CTLTYPE_UINT | CTLFLAG_MPSAFE | (access), \ 717a9643ea8Slogwang (ptr), 0, sysctl_handle_int, "IU", \ 718*22ce4affSfengbojiang __DESCR(descr), NULL); \ 719a9643ea8Slogwang } \ 720a9643ea8Slogwang __ret; \ 721a9643ea8Slogwang }) 722a9643ea8Slogwang 723a9643ea8Slogwang /* Oid for a 64-bit unsigned counter(9). The pointer must be non NULL. */ 724a9643ea8Slogwang #define SYSCTL_COUNTER_U64(parent, nbr, name, access, ptr, descr) \ 725a9643ea8Slogwang SYSCTL_OID(parent, nbr, name, \ 726*22ce4affSfengbojiang CTLTYPE_U64 | CTLFLAG_MPSAFE | CTLFLAG_STATS | (access), \ 727a9643ea8Slogwang (ptr), 0, sysctl_handle_counter_u64, "QU", descr); \ 728a9643ea8Slogwang CTASSERT((((access) & CTLTYPE) == 0 || \ 729a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U64) && \ 730a9643ea8Slogwang sizeof(counter_u64_t) == sizeof(*(ptr)) && \ 731a9643ea8Slogwang sizeof(uint64_t) == sizeof(**(ptr))) 732a9643ea8Slogwang 733a9643ea8Slogwang #define SYSCTL_ADD_COUNTER_U64(ctx, parent, nbr, name, access, ptr, descr) \ 734a9643ea8Slogwang ({ \ 735a9643ea8Slogwang counter_u64_t *__ptr = (ptr); \ 736a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 737a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_U64); \ 738a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, \ 739*22ce4affSfengbojiang CTLTYPE_U64 | CTLFLAG_MPSAFE | CTLFLAG_STATS | (access), \ 740*22ce4affSfengbojiang __ptr, 0, sysctl_handle_counter_u64, "QU", __DESCR(descr), \ 741*22ce4affSfengbojiang NULL); \ 742a9643ea8Slogwang }) 743a9643ea8Slogwang 744a9643ea8Slogwang /* Oid for an array of counter(9)s. The pointer and length must be non zero. */ 745a9643ea8Slogwang #define SYSCTL_COUNTER_U64_ARRAY(parent, nbr, name, access, ptr, len, descr) \ 746a9643ea8Slogwang SYSCTL_OID(parent, nbr, name, \ 747*22ce4affSfengbojiang CTLTYPE_OPAQUE | CTLFLAG_MPSAFE | CTLFLAG_STATS | (access), \ 748a9643ea8Slogwang (ptr), (len), sysctl_handle_counter_u64_array, "S", descr); \ 749a9643ea8Slogwang CTASSERT((((access) & CTLTYPE) == 0 || \ 750a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_OPAQUE) && \ 751a9643ea8Slogwang sizeof(counter_u64_t) == sizeof(*(ptr)) && \ 752a9643ea8Slogwang sizeof(uint64_t) == sizeof(**(ptr))) 753a9643ea8Slogwang 754a9643ea8Slogwang #define SYSCTL_ADD_COUNTER_U64_ARRAY(ctx, parent, nbr, name, access, \ 755a9643ea8Slogwang ptr, len, descr) \ 756a9643ea8Slogwang ({ \ 757a9643ea8Slogwang counter_u64_t *__ptr = (ptr); \ 758a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 759a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_OPAQUE); \ 760a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, \ 761*22ce4affSfengbojiang CTLTYPE_OPAQUE | CTLFLAG_MPSAFE | CTLFLAG_STATS | (access), \ 762a9643ea8Slogwang __ptr, len, sysctl_handle_counter_u64_array, "S", \ 763*22ce4affSfengbojiang __DESCR(descr), NULL); \ 764a9643ea8Slogwang }) 765a9643ea8Slogwang 766a9643ea8Slogwang /* Oid for an opaque object. Specified by a pointer and a length. */ 767a9643ea8Slogwang #define SYSCTL_OPAQUE(parent, nbr, name, access, ptr, len, fmt, descr) \ 768*22ce4affSfengbojiang SYSCTL_OID(parent, nbr, name, \ 769*22ce4affSfengbojiang CTLTYPE_OPAQUE | CTLFLAG_MPSAFE | (access), \ 770a9643ea8Slogwang ptr, len, sysctl_handle_opaque, fmt, descr); \ 771a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 772a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_OPAQUE) 773a9643ea8Slogwang 774a9643ea8Slogwang #define SYSCTL_ADD_OPAQUE(ctx, parent, nbr, name, access, ptr, len, fmt, descr) \ 775a9643ea8Slogwang ({ \ 776a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 777a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_OPAQUE); \ 778*22ce4affSfengbojiang sysctl_add_oid(ctx, parent, nbr, name, \ 779*22ce4affSfengbojiang CTLTYPE_OPAQUE | CTLFLAG_MPSAFE | (access), \ 780*22ce4affSfengbojiang ptr, len, sysctl_handle_opaque, fmt, __DESCR(descr), NULL); \ 781a9643ea8Slogwang }) 782a9643ea8Slogwang 783a9643ea8Slogwang /* Oid for a struct. Specified by a pointer and a type. */ 784a9643ea8Slogwang #define SYSCTL_STRUCT(parent, nbr, name, access, ptr, type, descr) \ 785*22ce4affSfengbojiang SYSCTL_OID(parent, nbr, name, \ 786*22ce4affSfengbojiang CTLTYPE_OPAQUE | CTLFLAG_MPSAFE | (access), \ 787a9643ea8Slogwang ptr, sizeof(struct type), sysctl_handle_opaque, \ 788a9643ea8Slogwang "S," #type, descr); \ 789a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 790a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_OPAQUE) 791a9643ea8Slogwang 792a9643ea8Slogwang #define SYSCTL_ADD_STRUCT(ctx, parent, nbr, name, access, ptr, type, descr) \ 793a9643ea8Slogwang ({ \ 794a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 795a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_OPAQUE); \ 796*22ce4affSfengbojiang sysctl_add_oid(ctx, parent, nbr, name, \ 797*22ce4affSfengbojiang CTLTYPE_OPAQUE | CTLFLAG_MPSAFE | (access), \ 798a9643ea8Slogwang (ptr), sizeof(struct type), \ 799*22ce4affSfengbojiang sysctl_handle_opaque, "S," #type, __DESCR(descr), NULL); \ 800a9643ea8Slogwang }) 801a9643ea8Slogwang 802a9643ea8Slogwang /* Oid for a procedure. Specified by a pointer and an arg. */ 803a9643ea8Slogwang #define SYSCTL_PROC(parent, nbr, name, access, ptr, arg, handler, fmt, descr) \ 804a9643ea8Slogwang SYSCTL_OID(parent, nbr, name, (access), \ 805a9643ea8Slogwang ptr, arg, handler, fmt, descr); \ 806a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) != 0) 807a9643ea8Slogwang 808a9643ea8Slogwang #define SYSCTL_ADD_PROC(ctx, parent, nbr, name, access, ptr, arg, handler, fmt, descr) \ 809a9643ea8Slogwang ({ \ 810a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) != 0); \ 811*22ce4affSfengbojiang SYSCTL_ENFORCE_FLAGS(access); \ 812a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, (access), \ 813*22ce4affSfengbojiang (ptr), (arg), (handler), (fmt), __DESCR(descr), NULL); \ 814a9643ea8Slogwang }) 815a9643ea8Slogwang 816a9643ea8Slogwang /* Oid to handle limits on uma(9) zone specified by pointer. */ 817a9643ea8Slogwang #define SYSCTL_UMA_MAX(parent, nbr, name, access, ptr, descr) \ 818a9643ea8Slogwang SYSCTL_OID(parent, nbr, name, \ 819a9643ea8Slogwang CTLTYPE_INT | CTLFLAG_MPSAFE | (access), \ 820a9643ea8Slogwang (ptr), 0, sysctl_handle_uma_zone_max, "I", descr); \ 821a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 822a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_INT) 823a9643ea8Slogwang 824a9643ea8Slogwang #define SYSCTL_ADD_UMA_MAX(ctx, parent, nbr, name, access, ptr, descr) \ 825a9643ea8Slogwang ({ \ 826a9643ea8Slogwang uma_zone_t __ptr = (ptr); \ 827a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 828a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_INT); \ 829a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, \ 830a9643ea8Slogwang CTLTYPE_INT | CTLFLAG_MPSAFE | (access), \ 831*22ce4affSfengbojiang __ptr, 0, sysctl_handle_uma_zone_max, "I", __DESCR(descr), \ 832*22ce4affSfengbojiang NULL); \ 833a9643ea8Slogwang }) 834a9643ea8Slogwang 835a9643ea8Slogwang /* Oid to obtain current use of uma(9) zone specified by pointer. */ 836a9643ea8Slogwang #define SYSCTL_UMA_CUR(parent, nbr, name, access, ptr, descr) \ 837a9643ea8Slogwang SYSCTL_OID(parent, nbr, name, \ 838a9643ea8Slogwang CTLTYPE_INT | CTLFLAG_MPSAFE | CTLFLAG_RD | (access), \ 839a9643ea8Slogwang (ptr), 0, sysctl_handle_uma_zone_cur, "I", descr); \ 840a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 841a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_INT) 842a9643ea8Slogwang 843a9643ea8Slogwang #define SYSCTL_ADD_UMA_CUR(ctx, parent, nbr, name, access, ptr, descr) \ 844a9643ea8Slogwang ({ \ 845a9643ea8Slogwang uma_zone_t __ptr = (ptr); \ 846a9643ea8Slogwang CTASSERT(((access) & CTLTYPE) == 0 || \ 847a9643ea8Slogwang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_INT); \ 848a9643ea8Slogwang sysctl_add_oid(ctx, parent, nbr, name, \ 849a9643ea8Slogwang CTLTYPE_INT | CTLFLAG_MPSAFE | CTLFLAG_RD | (access), \ 850*22ce4affSfengbojiang __ptr, 0, sysctl_handle_uma_zone_cur, "I", __DESCR(descr), \ 851*22ce4affSfengbojiang NULL); \ 852*22ce4affSfengbojiang }) 853*22ce4affSfengbojiang 854*22ce4affSfengbojiang /* OID expressing a sbintime_t as microseconds */ 855*22ce4affSfengbojiang #define SYSCTL_SBINTIME_USEC(parent, nbr, name, access, ptr, descr) \ 856*22ce4affSfengbojiang SYSCTL_OID(parent, nbr, name, \ 857*22ce4affSfengbojiang CTLTYPE_INT | CTLFLAG_MPSAFE | CTLFLAG_RD | (access), \ 858*22ce4affSfengbojiang (ptr), 0, sysctl_usec_to_sbintime, "Q", descr); \ 859*22ce4affSfengbojiang CTASSERT(((access) & CTLTYPE) == 0 || \ 860*22ce4affSfengbojiang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S64) 861*22ce4affSfengbojiang #define SYSCTL_ADD_SBINTIME_USEC(ctx, parent, nbr, name, access, ptr, descr) \ 862*22ce4affSfengbojiang ({ \ 863*22ce4affSfengbojiang sbintime_t *__ptr = (ptr); \ 864*22ce4affSfengbojiang CTASSERT(((access) & CTLTYPE) == 0 || \ 865*22ce4affSfengbojiang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S64); \ 866*22ce4affSfengbojiang sysctl_add_oid(ctx, parent, nbr, name, \ 867*22ce4affSfengbojiang CTLTYPE_INT | CTLFLAG_MPSAFE | CTLFLAG_RD | (access), \ 868*22ce4affSfengbojiang __ptr, 0, sysctl_usec_to_sbintime, "Q", __DESCR(descr), \ 869*22ce4affSfengbojiang NULL); \ 870*22ce4affSfengbojiang }) 871*22ce4affSfengbojiang 872*22ce4affSfengbojiang /* OID expressing a sbintime_t as milliseconds */ 873*22ce4affSfengbojiang #define SYSCTL_SBINTIME_MSEC(parent, nbr, name, access, ptr, descr) \ 874*22ce4affSfengbojiang SYSCTL_OID(parent, nbr, name, \ 875*22ce4affSfengbojiang CTLTYPE_INT | CTLFLAG_MPSAFE | CTLFLAG_RD | (access), \ 876*22ce4affSfengbojiang (ptr), 0, sysctl_msec_to_sbintime, "Q", descr); \ 877*22ce4affSfengbojiang CTASSERT(((access) & CTLTYPE) == 0 || \ 878*22ce4affSfengbojiang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S64) 879*22ce4affSfengbojiang #define SYSCTL_ADD_SBINTIME_MSEC(ctx, parent, nbr, name, access, ptr, descr) \ 880*22ce4affSfengbojiang ({ \ 881*22ce4affSfengbojiang sbintime_t *__ptr = (ptr); \ 882*22ce4affSfengbojiang CTASSERT(((access) & CTLTYPE) == 0 || \ 883*22ce4affSfengbojiang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_S64); \ 884*22ce4affSfengbojiang sysctl_add_oid(ctx, parent, nbr, name, \ 885*22ce4affSfengbojiang CTLTYPE_INT | CTLFLAG_MPSAFE | CTLFLAG_RD | (access), \ 886*22ce4affSfengbojiang __ptr, 0, sysctl_msec_to_sbintime, "Q", __DESCR(descr), \ 887*22ce4affSfengbojiang NULL); \ 888*22ce4affSfengbojiang }) 889*22ce4affSfengbojiang 890*22ce4affSfengbojiang /* OID expressing a struct timeval as seconds */ 891*22ce4affSfengbojiang #define SYSCTL_TIMEVAL_SEC(parent, nbr, name, access, ptr, descr) \ 892*22ce4affSfengbojiang SYSCTL_OID(parent, nbr, name, \ 893*22ce4affSfengbojiang CTLTYPE_INT | CTLFLAG_MPSAFE | CTLFLAG_RD | (access), \ 894*22ce4affSfengbojiang (ptr), 0, sysctl_sec_to_timeval, "I", descr); \ 895*22ce4affSfengbojiang CTASSERT(((access) & CTLTYPE) == 0 || \ 896*22ce4affSfengbojiang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_INT) 897*22ce4affSfengbojiang #define SYSCTL_ADD_TIMEVAL_SEC(ctx, parent, nbr, name, access, ptr, descr) \ 898*22ce4affSfengbojiang ({ \ 899*22ce4affSfengbojiang struct timeval *__ptr = (ptr); \ 900*22ce4affSfengbojiang CTASSERT(((access) & CTLTYPE) == 0 || \ 901*22ce4affSfengbojiang ((access) & SYSCTL_CT_ASSERT_MASK) == CTLTYPE_INT); \ 902*22ce4affSfengbojiang sysctl_add_oid(ctx, parent, nbr, name, \ 903*22ce4affSfengbojiang CTLTYPE_INT | CTLFLAG_MPSAFE | CTLFLAG_RD | (access), \ 904*22ce4affSfengbojiang __ptr, 0, sysctl_sec_to_timeval, "I", __DESCR(descr), \ 905*22ce4affSfengbojiang NULL); \ 906a9643ea8Slogwang }) 907a9643ea8Slogwang 908a9643ea8Slogwang /* 909a9643ea8Slogwang * A macro to generate a read-only sysctl to indicate the presence of optional 910a9643ea8Slogwang * kernel features. 911a9643ea8Slogwang */ 912a9643ea8Slogwang #define FEATURE(name, desc) \ 913*22ce4affSfengbojiang SYSCTL_INT_WITH_LABEL(_kern_features, OID_AUTO, name, \ 914*22ce4affSfengbojiang CTLFLAG_RD | CTLFLAG_CAPRD, SYSCTL_NULL_INT_PTR, 1, desc, "feature") 915a9643ea8Slogwang 916a9643ea8Slogwang #endif /* _KERNEL */ 917a9643ea8Slogwang 918a9643ea8Slogwang /* 919a9643ea8Slogwang * Top-level identifiers 920a9643ea8Slogwang */ 921*22ce4affSfengbojiang #define CTL_SYSCTL 0 /* "magic" numbers */ 922a9643ea8Slogwang #define CTL_KERN 1 /* "high kernel": proc, limits */ 923a9643ea8Slogwang #define CTL_VM 2 /* virtual memory */ 924a9643ea8Slogwang #define CTL_VFS 3 /* filesystem, mount type is next */ 925a9643ea8Slogwang #define CTL_NET 4 /* network, see socket.h */ 926a9643ea8Slogwang #define CTL_DEBUG 5 /* debugging parameters */ 927a9643ea8Slogwang #define CTL_HW 6 /* generic cpu/io */ 928a9643ea8Slogwang #define CTL_MACHDEP 7 /* machine dependent */ 929a9643ea8Slogwang #define CTL_USER 8 /* user-level */ 930a9643ea8Slogwang #define CTL_P1003_1B 9 /* POSIX 1003.1B */ 931a9643ea8Slogwang 932a9643ea8Slogwang /* 933*22ce4affSfengbojiang * CTL_SYSCTL identifiers 934*22ce4affSfengbojiang */ 935*22ce4affSfengbojiang #define CTL_SYSCTL_DEBUG 0 /* printf all nodes */ 936*22ce4affSfengbojiang #define CTL_SYSCTL_NAME 1 /* string name of OID */ 937*22ce4affSfengbojiang #define CTL_SYSCTL_NEXT 2 /* next OID, honoring CTLFLAG_SKIP */ 938*22ce4affSfengbojiang #define CTL_SYSCTL_NAME2OID 3 /* int array of name */ 939*22ce4affSfengbojiang #define CTL_SYSCTL_OIDFMT 4 /* OID's kind and format */ 940*22ce4affSfengbojiang #define CTL_SYSCTL_OIDDESCR 5 /* OID's description */ 941*22ce4affSfengbojiang #define CTL_SYSCTL_OIDLABEL 6 /* aggregation label */ 942*22ce4affSfengbojiang #define CTL_SYSCTL_NEXTNOSKIP 7 /* next OID, ignoring CTLFLAG_SKIP */ 943*22ce4affSfengbojiang 944*22ce4affSfengbojiang /* 945a9643ea8Slogwang * CTL_KERN identifiers 946a9643ea8Slogwang */ 947a9643ea8Slogwang #define KERN_OSTYPE 1 /* string: system version */ 948a9643ea8Slogwang #define KERN_OSRELEASE 2 /* string: system release */ 949a9643ea8Slogwang #define KERN_OSREV 3 /* int: system revision */ 950a9643ea8Slogwang #define KERN_VERSION 4 /* string: compile time info */ 951a9643ea8Slogwang #define KERN_MAXVNODES 5 /* int: max vnodes */ 952a9643ea8Slogwang #define KERN_MAXPROC 6 /* int: max processes */ 953a9643ea8Slogwang #define KERN_MAXFILES 7 /* int: max open files */ 954a9643ea8Slogwang #define KERN_ARGMAX 8 /* int: max arguments to exec */ 955a9643ea8Slogwang #define KERN_SECURELVL 9 /* int: system security level */ 956a9643ea8Slogwang #define KERN_HOSTNAME 10 /* string: hostname */ 957a9643ea8Slogwang #define KERN_HOSTID 11 /* int: host identifier */ 958a9643ea8Slogwang #define KERN_CLOCKRATE 12 /* struct: struct clockrate */ 959a9643ea8Slogwang #define KERN_VNODE 13 /* struct: vnode structures */ 960a9643ea8Slogwang #define KERN_PROC 14 /* struct: process entries */ 961a9643ea8Slogwang #define KERN_FILE 15 /* struct: file entries */ 962a9643ea8Slogwang #define KERN_PROF 16 /* node: kernel profiling info */ 963a9643ea8Slogwang #define KERN_POSIX1 17 /* int: POSIX.1 version */ 964a9643ea8Slogwang #define KERN_NGROUPS 18 /* int: # of supplemental group ids */ 965a9643ea8Slogwang #define KERN_JOB_CONTROL 19 /* int: is job control available */ 966a9643ea8Slogwang #define KERN_SAVED_IDS 20 /* int: saved set-user/group-ID */ 967a9643ea8Slogwang #define KERN_BOOTTIME 21 /* struct: time kernel was booted */ 968a9643ea8Slogwang #define KERN_NISDOMAINNAME 22 /* string: YP domain name */ 969a9643ea8Slogwang #define KERN_UPDATEINTERVAL 23 /* int: update process sleep time */ 970a9643ea8Slogwang #define KERN_OSRELDATE 24 /* int: kernel release date */ 971a9643ea8Slogwang #define KERN_NTP_PLL 25 /* node: NTP PLL control */ 972a9643ea8Slogwang #define KERN_BOOTFILE 26 /* string: name of booted kernel */ 973a9643ea8Slogwang #define KERN_MAXFILESPERPROC 27 /* int: max open files per proc */ 974a9643ea8Slogwang #define KERN_MAXPROCPERUID 28 /* int: max processes per uid */ 975a9643ea8Slogwang #define KERN_DUMPDEV 29 /* struct cdev *: device to dump on */ 976a9643ea8Slogwang #define KERN_IPC 30 /* node: anything related to IPC */ 977a9643ea8Slogwang #define KERN_DUMMY 31 /* unused */ 978a9643ea8Slogwang #define KERN_PS_STRINGS 32 /* int: address of PS_STRINGS */ 979a9643ea8Slogwang #define KERN_USRSTACK 33 /* int: address of USRSTACK */ 980a9643ea8Slogwang #define KERN_LOGSIGEXIT 34 /* int: do we log sigexit procs? */ 981a9643ea8Slogwang #define KERN_IOV_MAX 35 /* int: value of UIO_MAXIOV */ 982a9643ea8Slogwang #define KERN_HOSTUUID 36 /* string: host UUID identifier */ 983a9643ea8Slogwang #define KERN_ARND 37 /* int: from arc4rand() */ 984*22ce4affSfengbojiang #define KERN_MAXPHYS 38 /* int: MAXPHYS value */ 985a9643ea8Slogwang /* 986a9643ea8Slogwang * KERN_PROC subtypes 987a9643ea8Slogwang */ 988a9643ea8Slogwang #define KERN_PROC_ALL 0 /* everything */ 989a9643ea8Slogwang #define KERN_PROC_PID 1 /* by process id */ 990a9643ea8Slogwang #define KERN_PROC_PGRP 2 /* by process group id */ 991a9643ea8Slogwang #define KERN_PROC_SESSION 3 /* by session of pid */ 992a9643ea8Slogwang #define KERN_PROC_TTY 4 /* by controlling tty */ 993a9643ea8Slogwang #define KERN_PROC_UID 5 /* by effective uid */ 994a9643ea8Slogwang #define KERN_PROC_RUID 6 /* by real uid */ 995a9643ea8Slogwang #define KERN_PROC_ARGS 7 /* get/set arguments/proctitle */ 996a9643ea8Slogwang #define KERN_PROC_PROC 8 /* only return procs */ 997a9643ea8Slogwang #define KERN_PROC_SV_NAME 9 /* get syscall vector name */ 998a9643ea8Slogwang #define KERN_PROC_RGID 10 /* by real group id */ 999a9643ea8Slogwang #define KERN_PROC_GID 11 /* by effective group id */ 1000a9643ea8Slogwang #define KERN_PROC_PATHNAME 12 /* path to executable */ 1001a9643ea8Slogwang #define KERN_PROC_OVMMAP 13 /* Old VM map entries for process */ 1002a9643ea8Slogwang #define KERN_PROC_OFILEDESC 14 /* Old file descriptors for process */ 1003a9643ea8Slogwang #define KERN_PROC_KSTACK 15 /* Kernel stacks for process */ 1004a9643ea8Slogwang #define KERN_PROC_INC_THREAD 0x10 /* 1005a9643ea8Slogwang * modifier for pid, pgrp, tty, 1006a9643ea8Slogwang * uid, ruid, gid, rgid and proc 1007a9643ea8Slogwang * This effectively uses 16-31 1008a9643ea8Slogwang */ 1009a9643ea8Slogwang #define KERN_PROC_VMMAP 32 /* VM map entries for process */ 1010a9643ea8Slogwang #define KERN_PROC_FILEDESC 33 /* File descriptors for process */ 1011a9643ea8Slogwang #define KERN_PROC_GROUPS 34 /* process groups */ 1012a9643ea8Slogwang #define KERN_PROC_ENV 35 /* get environment */ 1013a9643ea8Slogwang #define KERN_PROC_AUXV 36 /* get ELF auxiliary vector */ 1014a9643ea8Slogwang #define KERN_PROC_RLIMIT 37 /* process resource limits */ 1015a9643ea8Slogwang #define KERN_PROC_PS_STRINGS 38 /* get ps_strings location */ 1016a9643ea8Slogwang #define KERN_PROC_UMASK 39 /* process umask */ 1017a9643ea8Slogwang #define KERN_PROC_OSREL 40 /* osreldate for process binary */ 1018a9643ea8Slogwang #define KERN_PROC_SIGTRAMP 41 /* signal trampoline location */ 1019a9643ea8Slogwang #define KERN_PROC_CWD 42 /* process current working directory */ 1020a9643ea8Slogwang #define KERN_PROC_NFDS 43 /* number of open file descriptors */ 1021*22ce4affSfengbojiang #define KERN_PROC_SIGFASTBLK 44 /* address of fastsigblk magic word */ 1022a9643ea8Slogwang 1023a9643ea8Slogwang /* 1024a9643ea8Slogwang * KERN_IPC identifiers 1025a9643ea8Slogwang */ 1026a9643ea8Slogwang #define KIPC_MAXSOCKBUF 1 /* int: max size of a socket buffer */ 1027a9643ea8Slogwang #define KIPC_SOCKBUF_WASTE 2 /* int: wastage factor in sockbuf */ 1028a9643ea8Slogwang #define KIPC_SOMAXCONN 3 /* int: max length of connection q */ 1029a9643ea8Slogwang #define KIPC_MAX_LINKHDR 4 /* int: max length of link header */ 1030a9643ea8Slogwang #define KIPC_MAX_PROTOHDR 5 /* int: max length of network header */ 1031a9643ea8Slogwang #define KIPC_MAX_HDR 6 /* int: max total length of headers */ 1032a9643ea8Slogwang #define KIPC_MAX_DATALEN 7 /* int: max length of data? */ 1033a9643ea8Slogwang 1034a9643ea8Slogwang /* 1035a9643ea8Slogwang * CTL_HW identifiers 1036a9643ea8Slogwang */ 1037a9643ea8Slogwang #define HW_MACHINE 1 /* string: machine class */ 1038a9643ea8Slogwang #define HW_MODEL 2 /* string: specific machine model */ 1039a9643ea8Slogwang #define HW_NCPU 3 /* int: number of cpus */ 1040a9643ea8Slogwang #define HW_BYTEORDER 4 /* int: machine byte order */ 1041a9643ea8Slogwang #define HW_PHYSMEM 5 /* int: total memory */ 1042a9643ea8Slogwang #define HW_USERMEM 6 /* int: non-kernel memory */ 1043a9643ea8Slogwang #define HW_PAGESIZE 7 /* int: software page size */ 1044a9643ea8Slogwang #define HW_DISKNAMES 8 /* strings: disk drive names */ 1045a9643ea8Slogwang #define HW_DISKSTATS 9 /* struct: diskstats[] */ 1046a9643ea8Slogwang #define HW_FLOATINGPT 10 /* int: has HW floating point? */ 1047a9643ea8Slogwang #define HW_MACHINE_ARCH 11 /* string: machine architecture */ 1048a9643ea8Slogwang #define HW_REALMEM 12 /* int: 'real' memory */ 1049a9643ea8Slogwang 1050a9643ea8Slogwang /* 1051a9643ea8Slogwang * CTL_USER definitions 1052a9643ea8Slogwang */ 1053a9643ea8Slogwang #define USER_CS_PATH 1 /* string: _CS_PATH */ 1054a9643ea8Slogwang #define USER_BC_BASE_MAX 2 /* int: BC_BASE_MAX */ 1055a9643ea8Slogwang #define USER_BC_DIM_MAX 3 /* int: BC_DIM_MAX */ 1056a9643ea8Slogwang #define USER_BC_SCALE_MAX 4 /* int: BC_SCALE_MAX */ 1057a9643ea8Slogwang #define USER_BC_STRING_MAX 5 /* int: BC_STRING_MAX */ 1058a9643ea8Slogwang #define USER_COLL_WEIGHTS_MAX 6 /* int: COLL_WEIGHTS_MAX */ 1059a9643ea8Slogwang #define USER_EXPR_NEST_MAX 7 /* int: EXPR_NEST_MAX */ 1060a9643ea8Slogwang #define USER_LINE_MAX 8 /* int: LINE_MAX */ 1061a9643ea8Slogwang #define USER_RE_DUP_MAX 9 /* int: RE_DUP_MAX */ 1062a9643ea8Slogwang #define USER_POSIX2_VERSION 10 /* int: POSIX2_VERSION */ 1063a9643ea8Slogwang #define USER_POSIX2_C_BIND 11 /* int: POSIX2_C_BIND */ 1064a9643ea8Slogwang #define USER_POSIX2_C_DEV 12 /* int: POSIX2_C_DEV */ 1065a9643ea8Slogwang #define USER_POSIX2_CHAR_TERM 13 /* int: POSIX2_CHAR_TERM */ 1066a9643ea8Slogwang #define USER_POSIX2_FORT_DEV 14 /* int: POSIX2_FORT_DEV */ 1067a9643ea8Slogwang #define USER_POSIX2_FORT_RUN 15 /* int: POSIX2_FORT_RUN */ 1068a9643ea8Slogwang #define USER_POSIX2_LOCALEDEF 16 /* int: POSIX2_LOCALEDEF */ 1069a9643ea8Slogwang #define USER_POSIX2_SW_DEV 17 /* int: POSIX2_SW_DEV */ 1070a9643ea8Slogwang #define USER_POSIX2_UPE 18 /* int: POSIX2_UPE */ 1071a9643ea8Slogwang #define USER_STREAM_MAX 19 /* int: POSIX2_STREAM_MAX */ 1072a9643ea8Slogwang #define USER_TZNAME_MAX 20 /* int: POSIX2_TZNAME_MAX */ 1073*22ce4affSfengbojiang #define USER_LOCALBASE 21 /* string: _PATH_LOCALBASE */ 1074a9643ea8Slogwang 1075a9643ea8Slogwang #define CTL_P1003_1B_ASYNCHRONOUS_IO 1 /* boolean */ 1076a9643ea8Slogwang #define CTL_P1003_1B_MAPPED_FILES 2 /* boolean */ 1077a9643ea8Slogwang #define CTL_P1003_1B_MEMLOCK 3 /* boolean */ 1078a9643ea8Slogwang #define CTL_P1003_1B_MEMLOCK_RANGE 4 /* boolean */ 1079a9643ea8Slogwang #define CTL_P1003_1B_MEMORY_PROTECTION 5 /* boolean */ 1080a9643ea8Slogwang #define CTL_P1003_1B_MESSAGE_PASSING 6 /* boolean */ 1081a9643ea8Slogwang #define CTL_P1003_1B_PRIORITIZED_IO 7 /* boolean */ 1082a9643ea8Slogwang #define CTL_P1003_1B_PRIORITY_SCHEDULING 8 /* boolean */ 1083a9643ea8Slogwang #define CTL_P1003_1B_REALTIME_SIGNALS 9 /* boolean */ 1084a9643ea8Slogwang #define CTL_P1003_1B_SEMAPHORES 10 /* boolean */ 1085a9643ea8Slogwang #define CTL_P1003_1B_FSYNC 11 /* boolean */ 1086a9643ea8Slogwang #define CTL_P1003_1B_SHARED_MEMORY_OBJECTS 12 /* boolean */ 1087a9643ea8Slogwang #define CTL_P1003_1B_SYNCHRONIZED_IO 13 /* boolean */ 1088a9643ea8Slogwang #define CTL_P1003_1B_TIMERS 14 /* boolean */ 1089a9643ea8Slogwang #define CTL_P1003_1B_AIO_LISTIO_MAX 15 /* int */ 1090a9643ea8Slogwang #define CTL_P1003_1B_AIO_MAX 16 /* int */ 1091a9643ea8Slogwang #define CTL_P1003_1B_AIO_PRIO_DELTA_MAX 17 /* int */ 1092a9643ea8Slogwang #define CTL_P1003_1B_DELAYTIMER_MAX 18 /* int */ 1093a9643ea8Slogwang #define CTL_P1003_1B_MQ_OPEN_MAX 19 /* int */ 1094a9643ea8Slogwang #define CTL_P1003_1B_PAGESIZE 20 /* int */ 1095a9643ea8Slogwang #define CTL_P1003_1B_RTSIG_MAX 21 /* int */ 1096a9643ea8Slogwang #define CTL_P1003_1B_SEM_NSEMS_MAX 22 /* int */ 1097a9643ea8Slogwang #define CTL_P1003_1B_SEM_VALUE_MAX 23 /* int */ 1098a9643ea8Slogwang #define CTL_P1003_1B_SIGQUEUE_MAX 24 /* int */ 1099a9643ea8Slogwang #define CTL_P1003_1B_TIMER_MAX 25 /* int */ 1100a9643ea8Slogwang 1101a9643ea8Slogwang #ifdef _KERNEL 1102a9643ea8Slogwang 1103*22ce4affSfengbojiang #define CTL_P1003_1B_MAXID 26 1104*22ce4affSfengbojiang 1105a9643ea8Slogwang /* 1106a9643ea8Slogwang * Declare some common oids. 1107a9643ea8Slogwang */ 1108a9643ea8Slogwang extern struct sysctl_oid_list sysctl__children; 1109a9643ea8Slogwang SYSCTL_DECL(_kern); 1110a9643ea8Slogwang SYSCTL_DECL(_kern_features); 1111a9643ea8Slogwang SYSCTL_DECL(_kern_ipc); 1112a9643ea8Slogwang SYSCTL_DECL(_kern_proc); 1113a9643ea8Slogwang SYSCTL_DECL(_kern_sched); 1114a9643ea8Slogwang SYSCTL_DECL(_kern_sched_stats); 1115a9643ea8Slogwang SYSCTL_DECL(_sysctl); 1116a9643ea8Slogwang SYSCTL_DECL(_vm); 1117a9643ea8Slogwang SYSCTL_DECL(_vm_stats); 1118a9643ea8Slogwang SYSCTL_DECL(_vm_stats_misc); 1119a9643ea8Slogwang SYSCTL_DECL(_vfs); 1120a9643ea8Slogwang SYSCTL_DECL(_net); 1121a9643ea8Slogwang SYSCTL_DECL(_debug); 1122a9643ea8Slogwang SYSCTL_DECL(_debug_sizeof); 1123a9643ea8Slogwang SYSCTL_DECL(_dev); 1124a9643ea8Slogwang SYSCTL_DECL(_hw); 1125a9643ea8Slogwang SYSCTL_DECL(_hw_bus); 1126a9643ea8Slogwang SYSCTL_DECL(_hw_bus_devices); 1127a9643ea8Slogwang SYSCTL_DECL(_machdep); 1128*22ce4affSfengbojiang SYSCTL_DECL(_machdep_mitigations); 1129a9643ea8Slogwang SYSCTL_DECL(_user); 1130a9643ea8Slogwang SYSCTL_DECL(_compat); 1131a9643ea8Slogwang SYSCTL_DECL(_regression); 1132a9643ea8Slogwang SYSCTL_DECL(_security); 1133a9643ea8Slogwang SYSCTL_DECL(_security_bsd); 1134a9643ea8Slogwang 1135a9643ea8Slogwang extern char machine[]; 1136a9643ea8Slogwang extern char osrelease[]; 1137a9643ea8Slogwang extern char ostype[]; 1138a9643ea8Slogwang extern char kern_ident[]; 1139a9643ea8Slogwang 1140a9643ea8Slogwang /* Dynamic oid handling */ 1141a9643ea8Slogwang struct sysctl_oid *sysctl_add_oid(struct sysctl_ctx_list *clist, 1142a9643ea8Slogwang struct sysctl_oid_list *parent, int nbr, const char *name, int kind, 1143a9643ea8Slogwang void *arg1, intmax_t arg2, int (*handler)(SYSCTL_HANDLER_ARGS), 1144*22ce4affSfengbojiang const char *fmt, const char *descr, const char *label); 1145a9643ea8Slogwang int sysctl_remove_name(struct sysctl_oid *parent, const char *name, int del, 1146a9643ea8Slogwang int recurse); 1147a9643ea8Slogwang void sysctl_rename_oid(struct sysctl_oid *oidp, const char *name); 1148a9643ea8Slogwang int sysctl_move_oid(struct sysctl_oid *oidp, 1149a9643ea8Slogwang struct sysctl_oid_list *parent); 1150a9643ea8Slogwang int sysctl_remove_oid(struct sysctl_oid *oidp, int del, int recurse); 1151a9643ea8Slogwang int sysctl_ctx_init(struct sysctl_ctx_list *clist); 1152a9643ea8Slogwang int sysctl_ctx_free(struct sysctl_ctx_list *clist); 1153a9643ea8Slogwang struct sysctl_ctx_entry *sysctl_ctx_entry_add(struct sysctl_ctx_list *clist, 1154a9643ea8Slogwang struct sysctl_oid *oidp); 1155a9643ea8Slogwang struct sysctl_ctx_entry *sysctl_ctx_entry_find(struct sysctl_ctx_list *clist, 1156a9643ea8Slogwang struct sysctl_oid *oidp); 1157a9643ea8Slogwang int sysctl_ctx_entry_del(struct sysctl_ctx_list *clist, 1158a9643ea8Slogwang struct sysctl_oid *oidp); 1159a9643ea8Slogwang 1160a9643ea8Slogwang int kernel_sysctl(struct thread *td, int *name, u_int namelen, void *old, 1161a9643ea8Slogwang size_t *oldlenp, void *new, size_t newlen, size_t *retval, 1162a9643ea8Slogwang int flags); 1163a9643ea8Slogwang int kernel_sysctlbyname(struct thread *td, char *name, void *old, 1164a9643ea8Slogwang size_t *oldlenp, void *new, size_t newlen, size_t *retval, 1165a9643ea8Slogwang int flags); 1166a9643ea8Slogwang int userland_sysctl(struct thread *td, int *name, u_int namelen, void *old, 1167*22ce4affSfengbojiang size_t *oldlenp, int inkernel, const void *new, size_t newlen, 1168a9643ea8Slogwang size_t *retval, int flags); 1169a9643ea8Slogwang int sysctl_find_oid(int *name, u_int namelen, struct sysctl_oid **noid, 1170a9643ea8Slogwang int *nindx, struct sysctl_req *req); 1171a9643ea8Slogwang void sysctl_wlock(void); 1172a9643ea8Slogwang void sysctl_wunlock(void); 1173a9643ea8Slogwang int sysctl_wire_old_buffer(struct sysctl_req *req, size_t len); 1174*22ce4affSfengbojiang int kern___sysctlbyname(struct thread *td, const char *name, 1175*22ce4affSfengbojiang size_t namelen, void *old, size_t *oldlenp, void *new, 1176*22ce4affSfengbojiang size_t newlen, size_t *retval, int flags, bool inkernel); 1177a9643ea8Slogwang 1178a9643ea8Slogwang struct sbuf; 1179a9643ea8Slogwang struct sbuf *sbuf_new_for_sysctl(struct sbuf *, char *, int, 1180a9643ea8Slogwang struct sysctl_req *); 1181a9643ea8Slogwang #else /* !_KERNEL */ 1182a9643ea8Slogwang #include <sys/cdefs.h> 1183a9643ea8Slogwang 1184a9643ea8Slogwang __BEGIN_DECLS 1185a9643ea8Slogwang int sysctl(const int *, u_int, void *, size_t *, const void *, size_t); 1186a9643ea8Slogwang int sysctlbyname(const char *, void *, size_t *, const void *, size_t); 1187a9643ea8Slogwang int sysctlnametomib(const char *, int *, size_t *); 1188a9643ea8Slogwang __END_DECLS 1189a9643ea8Slogwang #endif /* _KERNEL */ 1190a9643ea8Slogwang 1191a9643ea8Slogwang #endif /* !_SYS_SYSCTL_H_ */ 1192