1.\" Copyright (c) 1993 2.\" The Regents of the University of California. All rights reserved. 3.\" 4.\" Redistribution and use in source and binary forms, with or without 5.\" modification, are permitted provided that the following conditions 6.\" are met: 7.\" 1. Redistributions of source code must retain the above copyright 8.\" notice, this list of conditions and the following disclaimer. 9.\" 2. Redistributions in binary form must reproduce the above copyright 10.\" notice, this list of conditions and the following disclaimer in the 11.\" documentation and/or other materials provided with the distribution. 12.\" 3. All advertising materials mentioning features or use of this software 13.\" must display the following acknowledgement: 14.\" This product includes software developed by the University of 15.\" California, Berkeley and its contributors. 16.\" 4. Neither the name of the University nor the names of its contributors 17.\" may be used to endorse or promote products derived from this software 18.\" without specific prior written permission. 19.\" 20.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 21.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 22.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 23.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 24.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 25.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 26.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 27.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 28.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 29.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 30.\" SUCH DAMAGE. 31.\" 32.\" @(#)sysctl.3 8.4 (Berkeley) 5/9/95 33.\" 34.Dd May 9, 1995 35.Dt SYSCTL 3 36.Os 37.Sh NAME 38.Nm sysctl , 39.Nm sysctlbyname 40.Nd get or set system information 41.Sh SYNOPSIS 42.Fd #include <sys/types.h> 43.Fd #include <sys/sysctl.h> 44.Ft int 45.Fn sysctl "int *name" "u_int namelen" "void *oldp" "size_t *oldlenp" "void *newp" "size_t newlen" 46.Ft int 47.Fn sysctlbyname "const char *name" "void *oldp" "size_t *oldlenp" "void *newp" "size_t newlen" 48.Sh DESCRIPTION 49The 50.Fn sysctl 51function retrieves system information and allows processes with 52appropriate privileges to set system information. 53The information available from 54.Fn sysctl 55consists of integers, strings, and tables. 56Information may be retrieved and set from the command interface 57using the 58.Xr sysctl 8 59utility. 60.Pp 61Unless explicitly noted below, 62.Fn sysctl 63returns a consistent snapshot of the data requested. 64Consistency is obtained by locking the destination 65buffer into memory so that the data may be copied out without blocking. 66Calls to 67.Fn sysctl 68are serialized to avoid deadlock. 69.Pp 70The state is described using a ``Management Information Base'' (MIB) 71style name, listed in 72.Fa name , 73which is a 74.Fa namelen 75length array of integers. 76.Pp 77The 78.Fn sysctlbyname 79function accepts an ascii representation of the name and internally 80looks up the integer name vector. Apart from that, it behaves the same 81as the standard 82.Fn sysctl 83function. 84.Pp 85The information is copied into the buffer specified by 86.Fa oldp . 87The size of the buffer is given by the location specified by 88.Fa oldlenp 89before the call, 90and that location gives the amount of data copied after a successful call 91and after a call that returns with the error code ENOMEM. 92If the amount of data available is greater 93than the size of the buffer supplied, 94the call supplies as much data as fits in the buffer provided 95and returns with the error code ENOMEM. 96If the old value is not desired, 97.Fa oldp 98and 99.Fa oldlenp 100should be set to NULL. 101.Pp 102The size of the available data can be determined by calling 103.Fn sysctl 104with a NULL parameter for 105.Fa oldp . 106The size of the available data will be returned in the location pointed to by 107.Fa oldlenp . 108For some operations, the amount of space may change often. 109For these operations, 110the system attempts to round up so that the returned size is 111large enough for a call to return the data shortly thereafter. 112.Pp 113To set a new value, 114.Fa newp 115is set to point to a buffer of length 116.Fa newlen 117from which the requested value is to be taken. 118If a new value is not to be set, 119.Fa newp 120should be set to NULL and 121.Fa newlen 122set to 0. 123.Pp 124The top level names are defined with a CTL_ prefix in 125.Pa <sys/sysctl.h> , 126and are as follows. 127The next and subsequent levels down are found in the include files 128listed here, and described in separate sections below. 129.Pp 130.Bl -column CTLXMACHDEPXXX "Next level namesXXXXXX" -offset indent 131.It Sy Pa Name Next level names Description 132.It CTL\_DEBUG sys/sysctl.h Debugging 133.It CTL\_VFS sys/mount.h Filesystem 134.It CTL\_HW sys/sysctl.h Generic CPU, I/O 135.It CTL\_KERN sys/sysctl.h High kernel limits 136.It CTL\_MACHDEP sys/sysctl.h Machine dependent 137.It CTL\_NET sys/socket.h Networking 138.It CTL\_USER sys/sysctl.h User-level 139.It CTL\_VM vm/vm_param.h Virtual memory 140.El 141.Pp 142For example, the following retrieves the maximum number of processes allowed 143in the system: 144.Pp 145.Bd -literal -offset indent -compact 146int mib[2], maxproc; 147size_t len; 148 149mib[0] = CTL_KERN; 150mib[1] = KERN_MAXPROC; 151len = sizeof(maxproc); 152sysctl(mib, 2, &maxproc, &len, NULL, 0); 153.Ed 154.Pp 155To retrieve the standard search path for the system utilities: 156.Pp 157.Bd -literal -offset indent -compact 158int mib[2]; 159size_t len; 160char *p; 161 162mib[0] = CTL_USER; 163mib[1] = USER_CS_PATH; 164sysctl(mib, 2, NULL, &len, NULL, 0); 165p = malloc(len); 166sysctl(mib, 2, p, &len, NULL, 0); 167.Ed 168.Sh CTL_DEBUG 169The debugging variables vary from system to system. 170A debugging variable may be added or deleted without need to recompile 171.Fn sysctl 172to know about it. 173Each time it runs, 174.Fn sysctl 175gets the list of debugging variables from the kernel and 176displays their current values. 177The system defines twenty 178.Ns ( Va struct ctldebug ) 179variables named 180.Nm debug0 181through 182.Nm debug19 . 183They are declared as separate variables so that they can be 184individually initialized at the location of their associated variable. 185The loader prevents multiple use of the same variable by issuing errors 186if a variable is initialized in more than one place. 187For example, to export the variable 188.Nm dospecialcheck 189as a debugging variable, the following declaration would be used: 190.Bd -literal -offset indent -compact 191int dospecialcheck = 1; 192struct ctldebug debug5 = { "dospecialcheck", &dospecialcheck }; 193.Ed 194.Sh CTL_VFS 195A distinguished second level name, VFS_GENERIC, 196is used to get general information about all filesystems. 197One of its third level identifiers is VFS_MAXTYPENUM 198that gives the highest valid filesystem type number. 199Its other third level identifier is VFS_CONF that 200returns configuration information about the filesystem 201type given as a fourth level identifier (see 202.Xr getvfsbyname 3 203as an example of its use). 204The remaining second level identifiers are the 205filesystem type number returned by a 206.Xr statfs 2 207call or from VFS_CONF. 208The third level identifiers available for each filesystem 209are given in the header file that defines the mount 210argument structure for that filesystem. 211.Sh CTL_HW 212The string and integer information available for the CTL_HW level 213is detailed below. 214The changeable column shows whether a process with appropriate 215privilege may change the value. 216.Bl -column "Second level nameXXXXXX" integerXXX -offset indent 217.It Sy Pa Second level name Type Changeable 218.It HW\_MACHINE string no 219.It HW\_MODEL string no 220.It HW\_NCPU integer no 221.It HW\_BYTEORDER integer no 222.It HW\_PHYSMEM integer no 223.It HW\_USERMEM integer no 224.It HW\_PAGESIZE integer no 225.It HW\_FLOATINGPOINT integer no 226.It HW\_MACHINE\_ARCH string no 227.\".It HW\_DISKNAMES integer no 228.\".It HW\_DISKSTATS integer no 229.El 230.Pp 231.Bl -tag -width "123456" 232.It Li HW_MACHINE 233The machine class. 234.It Li HW_MODEL 235The machine model 236.It Li HW_NCPU 237The number of cpus. 238.ne 1i 239.It Li HW_BYTEORDER 240The byteorder (4,321, or 1,234). 241.It Li HW_PHYSMEM 242The bytes of physical memory. 243.It Li HW_USERMEM 244The bytes of non-kernel memory. 245.It Li HW_PAGESIZE 246The software page size. 247.It Li HW_FLOATINGPOINT 248Nonzero if the floating point support is in hardware. 249.It Li HW_MACHINE_ARCH 250The machine dependent architecture type. 251.\".It Fa HW_DISKNAMES 252.\".It Fa HW_DISKSTATS 253.El 254.Sh CTL_KERN 255The string and integer information available for the CTL_KERN level 256is detailed below. 257The changeable column shows whether a process with appropriate 258privilege may change the value. 259The types of data currently available are process information, 260system vnodes, the open file entries, routing table entries, 261virtual memory statistics, load average history, and clock rate 262information. 263.Bl -column "KERNXMAXFILESPERPROCXXX" "struct clockrateXXX" -offset indent 264.It Sy Pa Second level name Type Changeable 265.It KERN\_ARGMAX integer no 266.It KERN\_BOOTFILE string yes 267.It KERN\_BOOTTIME struct timeval no 268.It KERN\_CLOCKRATE struct clockinfo no 269.It KERN\_FILE struct file no 270.It KERN\_HOSTID integer yes 271.It KERN\_HOSTNAME string yes 272.It KERN\_JOB\_CONTROL integer no 273.It KERN\_MAXFILES integer yes 274.It KERN\_MAXFILESPERPROC integer yes 275.It KERN\_MAXPROC integer no 276.It KERN\_MAXPROCPERUID integer yes 277.It KERN\_MAXVNODES integer yes 278.It KERN\_NGROUPS integer no 279.It KERN\_NISDOMAINNAME string yes 280.It KERN\_OSRELDATE integer no 281.It KERN\_OSRELEASE string no 282.It KERN\_OSREV integer no 283.It KERN\_OSTYPE string no 284.It KERN\_POSIX1 integer no 285.It KERN\_PROC struct proc no 286.It KERN\_PROF node not applicable 287.It KERN\_SAVED\_IDS integer no 288.It KERN\_SECURELVL integer raise only 289.It KERN\_UPDATEINTERVAL integer no 290.It KERN\_VERSION string no 291.It KERN\_VNODE struct vnode no 292.El 293.ne 1i 294.Pp 295.Bl -tag -width "123456" 296.It Li KERN_ARGMAX 297The maximum bytes of argument to 298.Xr execve 2 . 299.It Li KERN_BOOTFILE 300The full pathname of the file from which the kernel was loaded. 301.It Li KERN_BOOTTIME 302A 303.Va struct timeval 304structure is returned. 305This structure contains the time that the system was booted. 306.It Li KERN_CLOCKRATE 307A 308.Va struct clockinfo 309structure is returned. 310This structure contains the clock, statistics clock and profiling clock 311frequencies, the number of micro-seconds per hz tick and the skew rate. 312.It Li KERN_FILE 313Return the entire file table. 314The returned data consists of a single 315.Va struct filehead 316followed by an array of 317.Va struct file , 318whose size depends on the current number of such objects in the system. 319.It Li KERN_HOSTID 320Get or set the host id. 321.It Li KERN_HOSTNAME 322Get or set the hostname. 323.It Li KERN_JOB_CONTROL 324Return 1 if job control is available on this system, otherwise 0. 325.It Li KERN_MAXFILES 326The maximum number of files that may be open in the system. 327.It Li KERN_MAXFILESPERPROC 328The maximum number of files that may be open for a single process. 329This limit only applies to processes with an effective uid of nonzero 330at the time of the open request. 331Files that have already been opened are not affected if the limit 332or the effective uid is changed. 333.It Li KERN_MAXPROC 334The maximum number of concurrent processes the system will allow. 335.It Li KERN_MAXPROCPERUID 336The maximum number of concurrent processes the system will allow 337for a single effective uid. 338This limit only applies to processes with an effective uid of nonzero 339at the time of a fork request. 340Processes that have already been started are not affected if the limit 341is changed. 342.It Li KERN_MAXVNODES 343The maximum number of vnodes available on the system. 344.It Li KERN_NGROUPS 345The maximum number of supplemental groups. 346.It Li KERN_NISDOMAINNAME 347The name of the current YP/NIS domain. 348.It Li KERN_OSRELDATE 349The system release date in YYYYMM format 350(January 1996 is encoded as 199601). 351.It Li KERN_OSRELEASE 352The system release string. 353.It Li KERN_OSREV 354The system revision string. 355.It Li KERN_OSTYPE 356The system type string. 357.It Li KERN_POSIX1 358The version of ISO/IEC 9945 (POSIX 1003.1) with which the system 359attempts to comply. 360.It Li KERN_PROC 361Return the entire process table, or a subset of it. 362An array of 363.Va struct kinfo_proc 364structures is returned, 365whose size depends on the current number of such objects in the system. 366The third and fourth level names are as follows: 367.Bl -column "Third level nameXXXXXX" "Fourth level is:XXXXXX" -offset indent 368.It Pa Third level name Fourth level is: 369.It KERN\_PROC\_ALL None 370.It KERN\_PROC\_PID A process ID 371.It KERN\_PROC\_PGRP A process group 372.It KERN\_PROC\_TTY A tty device 373.It KERN\_PROC\_UID A user ID 374.It KERN\_PROC\_RUID A real user ID 375.El 376.It Li KERN_PROF 377Return profiling information about the kernel. 378If the kernel is not compiled for profiling, 379attempts to retrieve any of the KERN_PROF values will 380fail with EOPNOTSUPP. 381The third level names for the string and integer profiling information 382is detailed below. 383The changeable column shows whether a process with appropriate 384privilege may change the value. 385.Bl -column "GPROFXGMONPARAMXXX" "struct gmonparamXXX" -offset indent 386.It Sy Pa Third level name Type Changeable 387.It GPROF\_STATE integer yes 388.It GPROF\_COUNT u_short[\|] yes 389.It GPROF\_FROMS u_short[\|] yes 390.It GPROF\_TOS struct tostruct yes 391.It GPROF\_GMONPARAM struct gmonparam no 392.El 393.Pp 394The variables are as follows: 395.Bl -tag -width "123456" 396.It Li GPROF_STATE 397Returns GMON_PROF_ON or GMON_PROF_OFF to show that profiling 398is running or stopped. 399.It Li GPROF_COUNT 400Array of statistical program counter counts. 401.It Li GPROF_FROMS 402Array indexed by program counter of call-from points. 403.It Li GPROF_TOS 404Array of 405.Va struct tostruct 406describing destination of calls and their counts. 407.It Li GPROF_GMONPARAM 408Structure giving the sizes of the above arrays. 409.El 410.ne 1i 411.It Li KERN_SAVED_IDS 412Returns 1 if saved set-group and saved set-user ID is available. 413.It Li KERN_SECURELVL 414The system security level. 415This level may be raised by processes with appropriate privilege. 416It may not be lowered. 417.It Li KERN_VERSION 418The system version string. 419.It Li KERN_VNODE 420Return the entire vnode table. 421Note, the vnode table is not necessarily a consistent snapshot of 422the system. 423The returned data consists of an array whose size depends on the 424current number of such objects in the system. 425Each element of the array contains the kernel address of a vnode 426.Va struct vnode * 427followed by the vnode itself 428.Va struct vnode . 429.It Li KERN_UPDATEINTERVAL 430The interval between 431.Xr sync 2 432calls in the 433.Xr update 4 434process. 435.El 436.Sh CTL_MACHDEP 437The set of variables defined is architecture dependent. 438The following variables are defined for the i386 architecture. 439.Bl -column "CONSOLE_DEVICEXXX" "struct bootinfoXXX" -offset indent 440.It Sy Pa Second level name Type Changeable 441.It Li CPU_CONSDEV dev_t no 442.It Li CPU_ADJKERNTZ int yes 443.It Li CPU_DISRTCSET int yes 444.It Li CPU_BOOTINFO struct bootinfo no 445.It Li CPU_WALLCLOCK int yes 446.El 447.Sh CTL_NET 448The string and integer information available for the CTL_NET level 449is detailed below. 450The changeable column shows whether a process with appropriate 451privilege may change the value. 452.Bl -column "Second level nameXXXXXX" "routing messagesXXX" -offset indent 453.It Sy Pa Second level name Type Changeable 454.It PF\_ROUTE routing messages no 455.It PF\_INET internet values yes 456.El 457.Pp 458.Bl -tag -width "123456" 459.It Li PF_ROUTE 460Return the entire routing table or a subset of it. 461The data is returned as a sequence of routing messages (see 462.Xr route 4 463for the header file, format and meaning). 464The length of each message is contained in the message header. 465.Pp 466The third level name is a protocol number, which is currently always 0. 467The fourth level name is an address family, which may be set to 0 to 468select all address families. 469The fifth and sixth level names are as follows: 470.Bl -column "Fifth level nameXXXXXX" "Sixth level is:XXX" -offset indent 471.It Pa Fifth level name Sixth level is: 472.It NET\_RT\_FLAGS rtflags 473.It NET\_RT\_DUMP None 474.It NET\_RT\_IFLIST None 475.El 476.It Li PF_INET 477Get or set various global information about the internet protocols. 478The third level name is the protocol. 479The fourth level name is the variable name. 480The currently defined protocols and names are: 481.ne 1i 482.Bl -column ProtocolXX VariableXX TypeXX ChangeableXX 483.It Pa Protocol Variable Type Changeable 484.It icmp bmcastecho integer yes 485.It icmp maskrepl integer yes 486.It ip forwarding integer yes 487.It ip redirect integer yes 488.It ip ttl integer yes 489.It udp checksum integer yes 490.El 491.Pp 492The variables are as follows: 493.Bl -tag -width "123456" 494.It Li icmp.bmcastecho 495Returns 1 if an ICMP echo request to a broadcast or multicast address is 496to be answered. 497.It Li icmp.maskrepl 498Returns 1 if ICMP network mask requests are to be answered. 499.It Li ip.forwarding 500Returns 1 when IP forwarding is enabled for the host, 501meaning that the host is acting as a router. 502.It Li ip.redirect 503Returns 1 when ICMP redirects may be sent by the host. 504This option is ignored unless the host is routing IP packets, 505and should normally be enabled on all systems. 506.It Li ip.ttl 507The maximum time-to-live (hop count) value for an IP packet sourced by 508the system. 509This value applies to normal transport protocols, not to ICMP. 510.It Li udp.checksum 511Returns 1 when UDP checksums are being computed and checked. 512Disabling UDP checksums is strongly discouraged. 513.El 514.Sh CTL_USER 515The string and integer information available for the CTL_USER level 516is detailed below. 517The changeable column shows whether a process with appropriate 518privilege may change the value. 519.Bl -column "USER_COLL_WEIGHTS_MAXXXX" "integerXXX" -offset indent 520.It Sy Pa Second level name Type Changeable 521.It USER\_BC\_BASE\_MAX integer no 522.It USER\_BC\_DIM\_MAX integer no 523.It USER\_BC\_SCALE\_MAX integer no 524.It USER\_BC\_STRING\_MAX integer no 525.It USER\_COLL\_WEIGHTS\_MAX integer no 526.It USER\_CS\_PATH string no 527.It USER\_EXPR\_NEST\_MAX integer no 528.It USER\_LINE\_MAX integer no 529.It USER\_POSIX2\_CHAR\_TERM integer no 530.It USER\_POSIX2\_C\_BIND integer no 531.It USER\_POSIX2\_C\_DEV integer no 532.It USER\_POSIX2\_FORT\_DEV integer no 533.It USER\_POSIX2\_FORT\_RUN integer no 534.It USER\_POSIX2\_LOCALEDEF integer no 535.It USER\_POSIX2\_SW\_DEV integer no 536.It USER\_POSIX2\_UPE integer no 537.It USER\_POSIX2\_VERSION integer no 538.It USER\_RE\_DUP\_MAX integer no 539.It USER\_STREAM\_MAX integer no 540.It USER\_TZNAME\_MAX integer no 541.El 542.Bl -tag -width "123456" 543.Pp 544.It Li USER_BC_BASE_MAX 545The maximum ibase/obase values in the 546.Xr bc 1 547utility. 548.It Li USER_BC_DIM_MAX 549The maximum array size in the 550.Xr bc 1 551utility. 552.It Li USER_BC_SCALE_MAX 553The maximum scale value in the 554.Xr bc 1 555utility. 556.It Li USER_BC_STRING_MAX 557The maximum string length in the 558.Xr bc 1 559utility. 560.It Li USER_COLL_WEIGHTS_MAX 561The maximum number of weights that can be assigned to any entry of 562the LC_COLLATE order keyword in the locale definition file. 563.It Li USER_CS_PATH 564Return a value for the 565.Ev PATH 566environment variable that finds all the standard utilities. 567.It Li USER_EXPR_NEST_MAX 568The maximum number of expressions that can be nested within 569parenthesis by the 570.Xr expr 1 571utility. 572.It Li USER_LINE_MAX 573The maximum length in bytes of a text-processing utility's input 574line. 575.It Li USER_POSIX2_CHAR_TERM 576Return 1 if the system supports at least one terminal type capable of 577all operations described in POSIX 1003.2, otherwise 0. 578.It Li USER_POSIX2_C_BIND 579Return 1 if the system's C-language development facilities support the 580C-Language Bindings Option, otherwise 0. 581.It Li USER_POSIX2_C_DEV 582Return 1 if the system supports the C-Language Development Utilities Option, 583otherwise 0. 584.It Li USER_POSIX2_FORT_DEV 585Return 1 if the system supports the FORTRAN Development Utilities Option, 586otherwise 0. 587.It Li USER_POSIX2_FORT_RUN 588Return 1 if the system supports the FORTRAN Runtime Utilities Option, 589otherwise 0. 590.It Li USER_POSIX2_LOCALEDEF 591Return 1 if the system supports the creation of locales, otherwise 0. 592.It Li USER_POSIX2_SW_DEV 593Return 1 if the system supports the Software Development Utilities Option, 594otherwise 0. 595.It Li USER_POSIX2_UPE 596Return 1 if the system supports the User Portability Utilities Option, 597otherwise 0. 598.It Li USER_POSIX2_VERSION 599The version of POSIX 1003.2 with which the system attempts to comply. 600.It Li USER_RE_DUP_MAX 601The maximum number of repeated occurrences of a regular expression 602permitted when using interval notation. 603.ne 1i 604.It Li USER_STREAM_MAX 605The minimum maximum number of streams that a process may have open 606at any one time. 607.It Li USER_TZNAME_MAX 608The minimum maximum number of types supported for the name of a 609timezone. 610.El 611.Sh CTL_VM 612The string and integer information available for the CTL_VM level 613is detailed below. 614The changeable column shows whether a process with appropriate 615privilege may change the value. 616.Bl -column "Second level nameXXXXXX" "struct loadavgXXX" -offset indent 617.It Sy Pa Second level name Type Changeable 618.It VM\_LOADAVG struct loadavg no 619.It VM\_METER struct vmtotal no 620.It VM\_PAGEOUT\_ALGORITHM integer yes 621.It VM\_SWAPPING\_ENABLED integer maybe 622.It VM\_V\_CACHE\_MAX integer yes 623.It VM\_V\_CACHE\_MIN integer yes 624.It VM\_V\_FREE\_MIN integer yes 625.It VM\_V\_FREE\_RESERVED integer yes 626.It VM\_V\_FREE\_TARGET integer yes 627.It VM\_V\_INACTIVE\_TARGET integer yes 628.It VM\_V\_PAGEOUT\_FREE\_MIN integer yes 629.El 630.Pp 631.Bl -tag -width "123456" 632.It Li VM_LOADAVG 633Return the load average history. 634The returned data consists of a 635.Va struct loadavg . 636.It Li VM_METER 637Return the system wide virtual memory statistics. 638The returned data consists of a 639.Va struct vmtotal . 640.It Li VM_PAGEOUT_ALGORITHM 6410 if the statistics-based page management algorithm is in use 642or 1 if the near-LRU algorithm is in use. 643.It Li VM_SWAPPING_ENABLED 6441 if process swapping is enabled or 0 if disabled. This variable is 645permanently set to 0 if the kernel was built with swapping disabled. 646.It Li VM_V_CACHE_MAX 647Maximum desired size of the cache queue. 648.It Li VM_V_CACHE_MIN 649Minimum desired size of the cache queue. If the cache queue size 650falls very far below this value, the pageout daemon is awakened. 651.It Li VM_V_FREE_MIN 652Minimum amount of memory (cache memory plus free memory) 653required to be available before a process waiting on memory will be 654awakened. 655.It Li VM_V_FREE_RESERVED 656Processes will awaken the pageout daemon and wait for memory if the 657number of free and cached pages drops below this value. 658.It Li VM_V_FREE_TARGET 659The total amount of free memory (including cache memory) that the 660pageout daemon tries to maintain. 661.It Li VM_V_INACTIVE_TARGET 662The desired number of inactive pages that the pageout daemon should 663achieve when it runs. Inactive pages can be quickly inserted into 664process address space when needed. 665.It Li VM_V_PAGEOUT_FREE_MIN 666If the amount of free and cache memory falls below this value, the 667pageout daemon will enter "memory conserving mode" to avoid deadlock. 668.El 669.Sh RETURN VALUES 670.Fn sysctl 671and 672.Fn sysctlbyname 673return 0 when successful. 674Otherwise \-1 is returned and 675.Va errno 676is set appropriately. 677.Sh ERRORS 678The following errors may be reported: 679.Bl -tag -width Er 680.It Bq Er EFAULT 681The buffer 682.Fa name , 683.Fa oldp , 684.Fa newp , 685or length pointer 686.Fa oldlenp 687contains an invalid address. 688.It Bq Er EINVAL 689The 690.Fa name 691array is less than two or greater than CTL_MAXNAME. 692.It Bq Er EINVAL 693A non-null 694.Fa newp 695is given and its specified length in 696.Fa newlen 697is too large or too small. 698.It Bq Er ENOMEM 699The length pointed to by 700.Fa oldlenp 701is too short to hold the requested value. 702.It Bq Er ENOTDIR 703The 704.Fa name 705array specifies an intermediate rather than terminal name. 706.It Bq Er EOPNOTSUPP 707The 708.Fa name 709array specifies a value that is unknown. 710.It Bq Er EPERM 711An attempt is made to set a read-only value. 712.It Bq Er EPERM 713A process without appropriate privilege attempts to set a value. 714.El 715.Sh FILES 716.Bl -tag -width <netinet/icmpXvar.h> -compact 717.It Pa <sys/sysctl.h> 718definitions for top level identifiers, second level kernel and hardware 719identifiers, and user level identifiers 720.It Pa <sys/socket.h> 721definitions for second level network identifiers 722.It Pa <sys/gmon.h> 723definitions for third level profiling identifiers 724.It Pa <vm/vm_param.h> 725definitions for second level virtual memory identifiers 726.It Pa <netinet/in.h> 727definitions for third level Internet identifiers and 728fourth level IP identifiers 729.It Pa <netinet/icmp_var.h> 730definitions for fourth level ICMP identifiers 731.It Pa <netinet/udp_var.h> 732definitions for fourth level UDP identifiers 733.El 734.Sh SEE ALSO 735.Xr sysconf 3 , 736.Xr sysctl 3 737.Sh HISTORY 738The 739.Fn sysctl 740function first appeared in 741.Bx 4.4 . 742