2
0

sysctlh.inc 42 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877
  1. {
  2. This file is part of the Free Pascal run time library.
  3. Copyright (c) 2001 by Marco van de Voort
  4. The OS dependant sysctl constants.
  5. See the file COPYING.FPC, included in this distribution,
  6. for details about the copyright.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  10. **********************************************************************}
  11. CONST
  12. {
  13. * Definitions for sysctl call. The sysctl call uses a hierarchical name
  14. * for objects that can be examined or modified. The name is expressed as
  15. * a sequence of integers. Like a file path name, the meaning of each
  16. * component depends on its place in the hierarchy. The top-level and kern
  17. * identifiers are defined here, and other identifiers are defined in the
  18. * respective subsystem header files.
  19. }
  20. CTL_MAXNAME = 12; { largest number of components supported }
  21. {
  22. * Each subsystem defined by sysctl defines a list of variables
  23. * for that subsystem. Each name is either a node with further
  24. * levels defined below it, or it is a leaf of some particular
  25. * type given below. Each sysctl level defines a set of name/type
  26. * pairs to be used by sysctl(1) in manipulating the subsystem.
  27. }
  28. Type
  29. ctlname = record
  30. ctl_name : pchar; { subsystem name }
  31. ctl_type : cint { type of name }
  32. End;
  33. Const
  34. CTLTYPE = $f; { Mask for the type }
  35. CTLTYPE_NODE = 1; { name is a node }
  36. CTLTYPE_INT = 2; { name describes an integer }
  37. CTLTYPE_STRING = 3; { name describes a string }
  38. CTLTYPE_QUAD = 4; { name describes a 64-bit number }
  39. CTLTYPE_OPAQUE = 5; { name describes a structure }
  40. CTLTYPE_STRUCT = CTLTYPE_OPAQUE; { name describes a structure }
  41. CTLTYPE_UINT = 6; { name describes an unsigned integer }
  42. CTLTYPE_LONG = 7; { name describes a long }
  43. CTLTYPE_ULONG = 8; { name describes an unsigned long }
  44. CTLFLAG_RD = $80000000; { Allow reads of variable }
  45. CTLFLAG_WR = $40000000; { Allow writes to the variable }
  46. CTLFLAG_RW = (CTLFLAG_RD OR CTLFLAG_WR);
  47. CTLFLAG_NOLOCK = $20000000; { XXX Don't Lock }
  48. CTLFLAG_ANYBODY = $10000000; { All users can set this var }
  49. CTLFLAG_SECURE = $8000000; { Permit set only if securelevel<=0 }
  50. CTLFLAG_PRISON = $4000000; { Prisoned roots can fiddle }
  51. CTLFLAG_DYN = $2000000; { Dynamic oid - can be freed }
  52. {
  53. * USE THIS instead of a hardwired number from the categories below
  54. * to get dynamically assigned sysctl entries using the linker-set
  55. * technology. This is the way nearly all new sysctl variables should
  56. * be implemented.
  57. * e.g. SYSCTL_INT(_parent, OID_AUTO, name, CTLFLAG_RW, &variable, 0, "");
  58. }
  59. OID_AUTO = (-1);
  60. {
  61. * Top-level identifiers
  62. }
  63. CTL_UNSPEC = 0;
  64. CTL_KERN = 1; { "high kernel": proc, limits }
  65. CTL_VM = 2; { virtual memory }
  66. CTL_VFS = 3; { file system, mount type is next }
  67. CTL_NET = 4; { network, see socket.h }
  68. CTL_DEBUG = 5; { debugging parameters }
  69. CTL_HW = 6; { generic cpu/io }
  70. CTL_MACHDEP = 7; { machine dependent }
  71. CTL_USER = 8; { user-level }
  72. CTL_P1003_1B = 9; { POSIX 1003.1B }
  73. CTL_MAXID = 10; { number of valid top-level ids }
  74. {
  75. * CTL_KERN identifiers
  76. }
  77. KERN_OSTYPE = 1; { string: system version }
  78. KERN_OSRELEASE = 2; { string: system release }
  79. KERN_OSREV = 3; { int: system revision }
  80. KERN_VERSION = 4; { string: compile time info }
  81. KERN_MAXVNODES = 5; { int: max vnodes }
  82. KERN_MAXPROC = 6; { int: max processes }
  83. KERN_MAXFILES = 7; { int: max open files }
  84. KERN_ARGMAX = 8; { int: max arguments to exec }
  85. KERN_SECURELVL = 9; { int: system security level }
  86. KERN_HOSTNAME = 10; { string: hostname }
  87. KERN_HOSTID = 11; { int: host identifier }
  88. KERN_CLOCKRATE = 12; { struct: struct clockrate }
  89. KERN_VNODE = 13; { struct: vnode structures }
  90. KERN_PROC = 14; { struct: process entries }
  91. KERN_FILE = 15; { struct: file entries }
  92. KERN_PROF = 16; { node: kernel profiling info }
  93. KERN_POSIX1 = 17; { int: POSIX.1 version }
  94. KERN_NGROUPS = 18; { int: # of supplemental group ids }
  95. KERN_JOB_CONTROL = 19; { int: is job control available }
  96. KERN_SAVED_IDS = 20; { int: saved set-user/group-ID }
  97. KERN_BOOTTIME = 21; { struct: time kernel was booted }
  98. KERN_NISDOMAINNAME = 22; { string: YP domain name }
  99. KERN_UPDATEINTERVAL = 23; { int: update process sleep time }
  100. KERN_OSRELDATE = 24; { int: OS release date }
  101. KERN_NTP_PLL = 25; { node: NTP PLL control }
  102. KERN_BOOTFILE = 26; { string: name of booted kernel }
  103. KERN_MAXFILESPERPROC = 27; { int: max open files per proc }
  104. KERN_MAXPROCPERUID = 28; { int: max processes per uid }
  105. KERN_DUMPDEV = 29; { dev_t: device to dump on }
  106. KERN_IPC = 30; { node: anything related to IPC }
  107. KERN_DUMMY = 31; { unused }
  108. KERN_PS_STRINGS = 32; { int: address of PS_STRINGS }
  109. KERN_USRSTACK = 33; { int: address of USRSTACK }
  110. KERN_LOGSIGEXIT = 34; { int: do we log sigexit procs? }
  111. KERN_MAXID = 35; { number of valid kern ids }
  112. {
  113. * KERN_PROC subtypes
  114. }
  115. KERN_PROC_ALL = 0; { everything }
  116. KERN_PROC_PID = 1; { by process id }
  117. KERN_PROC_PGRP = 2; { by process group id }
  118. KERN_PROC_SESSION = 3; { by session of pid }
  119. KERN_PROC_TTY = 4; { by controlling tty }
  120. KERN_PROC_UID = 5; { by effective uid }
  121. KERN_PROC_RUID = 6; { by real uid }
  122. KERN_PROC_ARGS = 7; { get/set arguments/proctitle }
  123. {
  124. * KERN_IPC identifiers
  125. }
  126. KIPC_MAXSOCKBUF = 1; { int: max size of a socket buffer }
  127. KIPC_SOCKBUF_WASTE = 2; { int: wastage factor in sockbuf }
  128. KIPC_SOMAXCONN = 3; { int: max length of connection q }
  129. KIPC_MAX_LINKHDR = 4; { int: max length of link header }
  130. KIPC_MAX_PROTOHDR = 5; { int: max length of network header }
  131. KIPC_MAX_HDR = 6; { int: max total length of headers }
  132. KIPC_MAX_DATALEN = 7; { int: max length of data? }
  133. KIPC_MBSTAT = 8; { struct: mbuf usage statistics }
  134. KIPC_NMBCLUSTERS = 9; { int: maximum mbuf clusters }
  135. {
  136. * CTL_HW identifiers
  137. }
  138. HW_MACHINE = 1; { string: machine class }
  139. HW_MODEL = 2; { string: specific machine model }
  140. HW_NCPU = 3; { int: number of cpus }
  141. HW_BYTEORDER = 4; { int: machine byte order }
  142. HW_PHYSMEM = 5; { int: total memory }
  143. HW_USERMEM = 6; { int: non-kernel memory }
  144. HW_PAGESIZE = 7; { int: software page size }
  145. HW_DISKNAMES = 8; { strings: disk drive names }
  146. HW_DISKSTATS = 9; { struct: diskstats[] }
  147. HW_FLOATINGPT = 10; { int: has HW floating point? }
  148. HW_MACHINE_ARCH = 11; { string: machine architecture }
  149. HW_MAXID = 12; { number of valid hw ids }
  150. {
  151. * CTL_USER definitions
  152. }
  153. USER_CS_PATH = 1; { string: _CS_PATH }
  154. USER_BC_BASE_MAX = 2; { int: BC_BASE_MAX }
  155. USER_BC_DIM_MAX = 3; { int: BC_DIM_MAX }
  156. USER_BC_SCALE_MAX = 4; { int: BC_SCALE_MAX }
  157. USER_BC_STRING_MAX = 5; { int: BC_STRING_MAX }
  158. USER_COLL_WEIGHTS_MAX = 6; { int: COLL_WEIGHTS_MAX }
  159. USER_EXPR_NEST_MAX = 7; { int: EXPR_NEST_MAX }
  160. USER_LINE_MAX = 8; { int: LINE_MAX }
  161. USER_RE_DUP_MAX = 9; { int: RE_DUP_MAX }
  162. USER_POSIX2_VERSION = 10; { int: POSIX2_VERSION }
  163. USER_POSIX2_C_BIND = 11; { int: POSIX2_C_BIND }
  164. USER_POSIX2_C_DEV = 12; { int: POSIX2_C_DEV }
  165. USER_POSIX2_CHAR_TERM = 13; { int: POSIX2_CHAR_TERM }
  166. USER_POSIX2_FORT_DEV = 14; { int: POSIX2_FORT_DEV }
  167. USER_POSIX2_FORT_RUN = 15; { int: POSIX2_FORT_RUN }
  168. USER_POSIX2_LOCALEDEF = 16; { int: POSIX2_LOCALEDEF }
  169. USER_POSIX2_SW_DEV = 17; { int: POSIX2_SW_DEV }
  170. USER_POSIX2_UPE = 18; { int: POSIX2_UPE }
  171. USER_STREAM_MAX = 19; { int: POSIX2_STREAM_MAX }
  172. USER_TZNAME_MAX = 20; { int: POSIX2_TZNAME_MAX }
  173. USER_MAXID = 21; { number of valid user ids }
  174. CTL_P1003_1B_ASYNCHRONOUS_IO = 1 ; { boolean }
  175. CTL_P1003_1B_MAPPED_FILES = 2 ; { boolean }
  176. CTL_P1003_1B_MEMLOCK = 3 ; { boolean }
  177. CTL_P1003_1B_MEMLOCK_RANGE = 4 ; { boolean }
  178. CTL_P1003_1B_MEMORY_PROTECTION = 5 ; { boolean }
  179. CTL_P1003_1B_MESSAGE_PASSING = 6 ; { boolean }
  180. CTL_P1003_1B_PRIORITIZED_IO = 7 ; { boolean }
  181. CTL_P1003_1B_PRIORITY_SCHEDULING = 8 ; { boolean }
  182. CTL_P1003_1B_REALTIME_SIGNALS = 9 ; { boolean }
  183. CTL_P1003_1B_SEMAPHORES = 10; { boolean }
  184. CTL_P1003_1B_FSYNC = 11; { boolean }
  185. CTL_P1003_1B_SHARED_MEMORY_OBJECTS = 12; { boolean }
  186. CTL_P1003_1B_SYNCHRONIZED_IO = 13; { boolean }
  187. CTL_P1003_1B_TIMERS = 14; { boolean }
  188. CTL_P1003_1B_AIO_LISTIO_MAX = 15; { int }
  189. CTL_P1003_1B_AIO_MAX = 16; { int }
  190. CTL_P1003_1B_AIO_PRIO_DELTA_MAX = 17; { int }
  191. CTL_P1003_1B_DELAYTIMER_MAX = 18; { int }
  192. CTL_P1003_1B_MQ_OPEN_MAX = 19; { int }
  193. CTL_P1003_1B_PAGESIZE = 20; { int }
  194. CTL_P1003_1B_RTSIG_MAX = 21; { int }
  195. CTL_P1003_1B_SEM_NSEMS_MAX = 22; { int }
  196. CTL_P1003_1B_SEM_VALUE_MAX = 23; { int }
  197. CTL_P1003_1B_SIGQUEUE_MAX = 24; { int }
  198. CTL_P1003_1B_TIMER_MAX = 25; { int }
  199. CTL_P1003_1B_MAXID = 26;
  200. { LongestStringInCtlNames = 21;}
  201. Const
  202. CTL_NAMES : Array[0..9] OF CtlNameRec = (
  203. ( Name: ''; CtlType: 0 ),
  204. ( Name: 'kern'; CtlType : CTLTYPE_NODE ),
  205. ( Name: 'vm'; CtlType : CTLTYPE_NODE ),
  206. ( Name: 'vfs'; CtlType : CTLTYPE_NODE ),
  207. ( Name: 'net'; CtlType : CTLTYPE_NODE ),
  208. ( Name: 'debug'; CtlType : CTLTYPE_NODE ),
  209. ( Name: 'hw'; CtlType : CTLTYPE_NODE ),
  210. ( Name: 'machdep'; CtlType : CTLTYPE_NODE ),
  211. ( Name: 'user'; CtlType : CTLTYPE_NODE ),
  212. ( Name: 'p1003_1b'; CtlType : CTLTYPE_NODE ));
  213. CTL_KERN_NAME : Array[0..34] OF CtlNameRec = (
  214. ( Name: ''; CtlType: 0 ),
  215. ( Name: 'ostype'; CtlType : CTLTYPE_STRING ),
  216. ( Name: 'osrelease'; CtlType : CTLTYPE_STRING ),
  217. ( Name: 'osrevision'; CtlType : CTLTYPE_INT ),
  218. ( Name: 'version'; CtlType : CTLTYPE_STRING ),
  219. ( Name: 'maxvnodes'; CtlType : CTLTYPE_INT ),
  220. ( Name: 'maxproc'; CtlType : CTLTYPE_INT ),
  221. ( Name: 'maxfiles'; CtlType : CTLTYPE_INT ),
  222. ( Name: 'argmax'; CtlType : CTLTYPE_INT ),
  223. ( Name: 'securelevel'; CtlType : CTLTYPE_INT ),
  224. ( Name: 'hostname'; CtlType : CTLTYPE_STRING ),
  225. ( Name: 'hostid'; CtlType : CTLTYPE_UINT ),
  226. ( Name: 'clockrate'; CtlType : CTLTYPE_STRUCT ),
  227. ( Name: 'vnode'; CtlType : CTLTYPE_STRUCT ),
  228. ( Name: 'proc'; CtlType : CTLTYPE_STRUCT ),
  229. ( Name: 'file'; CtlType : CTLTYPE_STRUCT ),
  230. ( Name: 'profiling'; CtlType : CTLTYPE_NODE ),
  231. ( Name: 'posix1version'; CtlType : CTLTYPE_INT ),
  232. ( Name: 'ngroups'; CtlType : CTLTYPE_INT ),
  233. ( Name: 'job_control'; CtlType : CTLTYPE_INT ),
  234. ( Name: 'saved_ids'; CtlType : CTLTYPE_INT ),
  235. ( Name: 'boottime'; CtlType : CTLTYPE_STRUCT ),
  236. ( Name: 'nisdomainname'; CtlType : CTLTYPE_STRING ),
  237. ( Name: 'update'; CtlType : CTLTYPE_INT ),
  238. ( Name: 'osreldate'; CtlType : CTLTYPE_INT ),
  239. ( Name: 'ntp_pll'; CtlType : CTLTYPE_NODE ),
  240. ( Name: 'bootfile'; CtlType : CTLTYPE_STRING ),
  241. ( Name: 'maxfilesperproc'; CtlType : CTLTYPE_INT ),
  242. ( Name: 'maxprocperuid'; CtlType : CTLTYPE_INT ),
  243. ( Name: 'dumpdev'; CtlType : CTLTYPE_STRUCT ), { we lie; don't print as int }
  244. ( Name: 'ipc'; CtlType : CTLTYPE_NODE ),
  245. ( Name: 'dummy'; CtlType : CTLTYPE_INT ),
  246. ( Name: 'ps_strings'; CtlType : CTLTYPE_INT ),
  247. ( Name: 'usrstack'; CtlType : CTLTYPE_INT ),
  248. ( Name: 'logsigexit'; CtlType : CTLTYPE_INT ));
  249. {
  250. * CTL_VFS identifiers
  251. }
  252. CTL_VFS_NAMES : array[0..0] of CTLNameRec = (
  253. ( Name: 'vfsconf'; CtlType : CTLTYPE_STRUCT ));
  254. CTL_HW_NAMES : array[0..10] of CTLNameRec = (
  255. ( Name: ''; CtlType: 0 ),
  256. ( Name: 'machine'; CtlType : CTLTYPE_STRING ),
  257. ( Name: 'model'; CtlType : CTLTYPE_STRING ),
  258. ( Name: 'ncpu'; CtlType : CTLTYPE_INT ),
  259. ( Name: 'byteorder'; CtlType : CTLTYPE_INT ),
  260. ( Name: 'physmem'; CtlType : CTLTYPE_UINT ),
  261. ( Name: 'usermem'; CtlType : CTLTYPE_UINT ),
  262. ( Name: 'pagesize'; CtlType : CTLTYPE_INT ),
  263. ( Name: 'disknames'; CtlType : CTLTYPE_STRUCT ),
  264. ( Name: 'diskstats'; CtlType : CTLTYPE_STRUCT ),
  265. ( Name: 'floatingpoint'; CtlType : CTLTYPE_INT ));
  266. CTL_USER_NAMES : array[0..20] of CTLNameRec = (
  267. ( Name :''; CtlType: 0 ),
  268. ( Name: 'cs_path'; CtlType : CTLTYPE_STRING ),
  269. ( Name: 'bc_base_max'; CtlType : CTLTYPE_INT ),
  270. ( Name: 'bc_dim_max'; CtlType : CTLTYPE_INT ),
  271. ( Name: 'bc_scale_max'; CtlType : CTLTYPE_INT ),
  272. ( Name: 'bc_string_max'; CtlType : CTLTYPE_INT ),
  273. ( Name: 'coll_weights_max'; CtlType : CTLTYPE_INT ),
  274. ( Name: 'expr_nest_max'; CtlType : CTLTYPE_INT ),
  275. ( Name: 'line_max'; CtlType : CTLTYPE_INT ),
  276. ( Name: 're_dup_max'; CtlType : CTLTYPE_INT ),
  277. ( Name: 'posix2_version'; CtlType : CTLTYPE_INT ),
  278. ( Name: 'posix2_c_bind'; CtlType : CTLTYPE_INT ),
  279. ( Name: 'posix2_c_dev'; CtlType : CTLTYPE_INT ),
  280. ( Name: 'posix2_char_term'; CtlType : CTLTYPE_INT ),
  281. ( Name: 'posix2_fort_dev'; CtlType : CTLTYPE_INT ),
  282. ( Name: 'posix2_fort_run'; CtlType : CTLTYPE_INT ),
  283. ( Name: 'posix2_localedef'; CtlType : CTLTYPE_INT ),
  284. ( Name: 'posix2_sw_dev'; CtlType : CTLTYPE_INT ),
  285. ( Name: 'posix2_upe'; CtlType : CTLTYPE_INT ),
  286. ( Name: 'stream_max'; CtlType : CTLTYPE_INT ),
  287. ( Name: 'tzname_max'; CtlType : CTLTYPE_INT ));
  288. CTL_P1003_1B_NAMES : array[0..25] of CTLNameRec = (
  289. ( Name: ''; CtlType: 0 ),
  290. ( Name: 'asynchronous_io'; CtlType : CTLTYPE_INT ),
  291. ( Name: 'mapped_files'; CtlType : CTLTYPE_INT ),
  292. ( Name: 'memlock'; CtlType : CTLTYPE_INT ),
  293. ( Name: 'memlock_range'; CtlType : CTLTYPE_INT ),
  294. ( Name: 'memory_protection'; CtlType : CTLTYPE_INT ),
  295. ( Name: 'message_passing'; CtlType : CTLTYPE_INT ),
  296. ( Name: 'prioritized_io'; CtlType : CTLTYPE_INT ),
  297. ( Name: 'priority_scheduling'; CtlType : CTLTYPE_INT ),
  298. ( Name: 'realtime_signals'; CtlType : CTLTYPE_INT ),
  299. ( Name: 'semaphores'; CtlType : CTLTYPE_INT ),
  300. ( Name: 'fsync'; CtlType : CTLTYPE_INT ),
  301. ( Name: 'shared_memory_objects'; CtlType : CTLTYPE_INT ),
  302. ( Name: 'synchronized_io'; CtlType : CTLTYPE_INT ),
  303. ( Name: 'timers'; CtlType : CTLTYPE_INT ),
  304. ( Name: 'aio_listio_max'; CtlType : CTLTYPE_INT ),
  305. ( Name: 'aio_max'; CtlType : CTLTYPE_INT ),
  306. ( Name: 'aio_prio_delta_max'; CtlType : CTLTYPE_INT ),
  307. ( Name: 'delaytimer_max'; CtlType : CTLTYPE_INT ),
  308. ( Name: 'mq_open_max'; CtlType : CTLTYPE_INT ),
  309. ( Name: 'pagesize'; CtlType : CTLTYPE_INT ),
  310. ( Name: 'rtsig_max'; CtlType : CTLTYPE_INT ),
  311. ( Name: 'nsems_max'; CtlType : CTLTYPE_INT ),
  312. ( Name: 'sem_value_max'; CtlType : CTLTYPE_INT ),
  313. ( Name: 'sigqueue_max'; CtlType : CTLTYPE_INT ),
  314. ( Name: 'timer_max'; CtlType : CTLTYPE_INT ));
  315. const
  316. {
  317. * Types
  318. }
  319. SOCK_STREAM = 1; { stream socket }
  320. SOCK_DGRAM = 2; { datagram socket }
  321. SOCK_RAW = 3; { raw-protocol interface }
  322. SOCK_RDM = 4; { reliably-delivered message }
  323. SOCK_SEQPACKET = 5; { sequenced packet stream }
  324. {
  325. * Address families.
  326. }
  327. AF_UNSPEC = 0; { unspecified }
  328. AF_LOCAL = 1; { local to host (Name:pipes;CtlType: portals) }
  329. AF_UNIX = AF_LOCAL; { backward compatibility }
  330. AF_INET = 2; { internetwork: UDP, TCP, etc. }
  331. AF_IMPLINK = 3; { arpanet imp addresses }
  332. AF_PUP = 4; { pup protocols: e.g. BSP }
  333. AF_CHAOS = 5; { mit CHAOS protocols }
  334. AF_NS = 6; { XEROX NS protocols }
  335. AF_ISO = 7; { ISO protocols }
  336. AF_OSI = AF_ISO;
  337. AF_ECMA = 8; { European computer manufacturers }
  338. AF_DATAKIT = 9; { datakit protocols }
  339. AF_CCITT = 10; { CCITT protocols, X.25 etc }
  340. AF_SNA = 11; { IBM SNA }
  341. AF_DECnet = 12; { DECnet }
  342. AF_DLI = 13; { DEC Direct data link interface }
  343. AF_LAT = 14; { LAT }
  344. AF_HYLINK = 15; { NSC Hyperchannel }
  345. AF_APPLETALK = 16; { Apple Talk }
  346. AF_ROUTE = 17; { Internal Routing Protocol }
  347. AF_LINK = 18; { Link layer interface }
  348. pseudo_AF_XTP = 19; { eXpress Transfer Protocol (Name:no AF) }
  349. AF_COIP = 20; { connection-oriented IP, aka ST II }
  350. AF_CNT = 21; { Computer Network Technology }
  351. pseudo_AF_RTIP = 22; { Help Identify RTIP packets }
  352. AF_IPX = 23; { Novell Internet Protocol }
  353. AF_SIP = 24; { Simple Internet Protocol }
  354. pseudo_AF_PIP = 25; { Help Identify PIP packets }
  355. AF_ISDN = 26; { Integrated Services Digital Network}
  356. AF_E164 = AF_ISDN; { CCITT E.164 recommendation }
  357. pseudo_AF_KEY = 27; { Internal key-management function }
  358. AF_INET6 = 28; { IPv6 }
  359. AF_NATM = 29; { native ATM access }
  360. AF_ATM = 30; { ATM }
  361. pseudo_AF_HDRCMPLT = 31; { Used by BPF to not rewrite headers
  362. * in interface output routine
  363. }
  364. AF_NETGRAPH = 32; { Netgraph sockets }
  365. AF_MAX = 33;
  366. {
  367. * Protocol families, same as address families for now.
  368. }
  369. {
  370. * Definitions for network related sysctl, CTL_NET.
  371. *
  372. * Second level is protocol family.
  373. * Third level is protocol number.
  374. *
  375. * Further levels are defined by the individual families below.
  376. }
  377. NET_MAXID = AF_MAX;
  378. CTL_NET_NAMES : Array[0..32] OF CtlNameRec = (
  379. (Name: '';CtlType: 0 ),
  380. (Name: 'unix';CtlType: CTLTYPE_NODE ),
  381. (Name: 'inet';CtlType: CTLTYPE_NODE ),
  382. (Name: 'implink';CtlType: CTLTYPE_NODE ),
  383. (Name: 'pup';CtlType: CTLTYPE_NODE ),
  384. (Name: 'chaos';CtlType: CTLTYPE_NODE ),
  385. (Name: 'xerox_ns';CtlType: CTLTYPE_NODE ),
  386. (Name: 'iso';CtlType: CTLTYPE_NODE ),
  387. (Name: 'emca';CtlType: CTLTYPE_NODE ),
  388. (Name: 'datakit';CtlType: CTLTYPE_NODE ),
  389. (Name: 'ccitt';CtlType: CTLTYPE_NODE ),
  390. (Name: 'ibm_sna';CtlType: CTLTYPE_NODE ),
  391. (Name: 'decnet';CtlType: CTLTYPE_NODE ),
  392. (Name: 'dec_dli';CtlType: CTLTYPE_NODE ),
  393. (Name: 'lat';CtlType: CTLTYPE_NODE ),
  394. (Name: 'hylink';CtlType: CTLTYPE_NODE ),
  395. (Name: 'appletalk';CtlType: CTLTYPE_NODE ),
  396. (Name: 'route';CtlType: CTLTYPE_NODE ),
  397. (Name: 'link_layer';CtlType: CTLTYPE_NODE ),
  398. (Name: 'xtp';CtlType: CTLTYPE_NODE ),
  399. (Name: 'coip';CtlType: CTLTYPE_NODE ),
  400. (Name: 'cnt';CtlType: CTLTYPE_NODE ),
  401. (Name: 'rtip';CtlType: CTLTYPE_NODE ),
  402. (Name: 'ipx';CtlType: CTLTYPE_NODE ),
  403. (Name: 'sip';CtlType: CTLTYPE_NODE ),
  404. (Name: 'pip';CtlType: CTLTYPE_NODE ),
  405. (Name: 'isdn';CtlType: CTLTYPE_NODE ),
  406. (Name: 'key';CtlType: CTLTYPE_NODE ),
  407. (Name: 'inet6';CtlType: CTLTYPE_NODE ),
  408. (Name: 'natm';CtlType: CTLTYPE_NODE ),
  409. (Name: 'atm';CtlType: CTLTYPE_NODE ),
  410. (Name: 'hdrcomplete';CtlType: CTLTYPE_NODE ),
  411. (Name: 'netgraph';CtlType: CTLTYPE_NODE ));
  412. {
  413. * PF_ROUTE - Routing table
  414. *
  415. * Three additional levels are defined:
  416. * Fourth: address family, 0 is wildcard
  417. * Fifth: type of info, defined below
  418. * Sixth: flag(Name:s) to mask with for NET_RT_FLAGS
  419. }
  420. NET_RT_DUMP = 1; { dump; may limit to a.f. }
  421. NET_RT_FLAGS = 2; { by flags, e.g. RESOLVING }
  422. NET_RT_IFLIST = 3; { survey interface list }
  423. NET_RT_MAXID = 4;
  424. CTL_NET_RT_NAMES : Array[0..3] OF CtlNameRec = (
  425. (Name: '';CtlType: 0 ),
  426. (Name: 'dump';CtlType: CTLTYPE_STRUCT ),
  427. (Name: 'flags';CtlType: CTLTYPE_STRUCT ),
  428. (Name: 'iflist';CtlType: CTLTYPE_STRUCT ));
  429. {
  430. * Possible states of profiling.
  431. }
  432. GMON_PROF_ON = 0;
  433. GMON_PROF_BUSY = 1;
  434. GMON_PROF_ERROR = 2;
  435. GMON_PROF_OFF = 3;
  436. GMON_PROF_HIRES = 4;
  437. {
  438. * Sysctl definitions for extracting profiling information from the kernel.
  439. }
  440. GPROF_STATE = 0; { int: profiling enabling variable }
  441. GPROF_COUNT = 1; { struct: profile tick count buffer }
  442. GPROF_FROMS = 2; { struct: from location hash bucket }
  443. GPROF_TOS = 3; { struct: destination/count structure }
  444. GPROF_GMONPARAM = 4; { struct: profiling parameters (Name:see above) }
  445. {
  446. * CTL_VM identifiers
  447. }
  448. VM_METER = 1; { struct vmmeter }
  449. VM_LOADAVG = 2; { struct loadavg }
  450. VM_V_FREE_MIN = 3; { cnt.v_free_min }
  451. VM_V_FREE_TARGET = 4; { cnt.v_free_target }
  452. VM_V_FREE_RESERVED = 5; { cnt.v_free_reserved }
  453. VM_V_INACTIVE_TARGET = 6; { cnt.v_inactive_target }
  454. VM_V_CACHE_MIN = 7; { cnt.v_cache_max }
  455. VM_V_CACHE_MAX = 8; { cnt.v_cache_min }
  456. VM_V_PAGEOUT_FREE_MIN = 9; { cnt.v_pageout_free_min }
  457. VM_PAGEOUT_ALGORITHM = 10; { pageout algorithm }
  458. VM_SWAPPING_ENABLED = 11; { swapping enabled }
  459. VM_MAXID = 12; { number of valid vm ids }
  460. CTL_VM_NAMES : Array[0..11] OF CtlNameRec = (
  461. (Name: '';CtlType: 0 ),
  462. (Name: 'vmmeter';CtlType: CTLTYPE_STRUCT ),
  463. (Name: 'loadavg';CtlType: CTLTYPE_STRUCT ),
  464. (Name: 'v_free_min';CtlType: CTLTYPE_INT ),
  465. (Name: 'v_free_target';CtlType: CTLTYPE_INT ),
  466. (Name: 'v_free_reserved';CtlType: CTLTYPE_INT ),
  467. (Name: 'v_inactive_target';CtlType: CTLTYPE_INT ),
  468. (Name: 'v_cache_min';CtlType: CTLTYPE_INT ),
  469. (Name: 'v_cache_max';CtlType: CTLTYPE_INT ),
  470. (Name: 'v_pageout_free_min';CtlType: CTLTYPE_INT),
  471. (Name: 'pageout_algorithm';CtlType: CTLTYPE_INT),
  472. (Name: 'swapping_enabled';CtlType: CTLTYPE_INT));
  473. {
  474. * Protocols (Name:RFC 1700)
  475. }
  476. IPPROTO_IP = 0; { dummy for IP }
  477. IPPROTO_HOPOPTS = 0; { IP6 hop-by-hop options }
  478. IPPROTO_ICMP = 1; { control message protocol }
  479. IPPROTO_IGMP = 2; { group mgmt protocol }
  480. IPPROTO_GGP = 3; { gateway^2 (Name:deprecated) }
  481. IPPROTO_IPV4 = 4; { IPv4 encapsulation }
  482. IPPROTO_IPIP = IPPROTO_IPV4; { for compatibility }
  483. IPPROTO_TCP = 6; { tcp }
  484. IPPROTO_ST = 7; { Stream protocol II }
  485. IPPROTO_EGP = 8; { exterior gateway protocol }
  486. IPPROTO_PIGP = 9; { private interior gateway }
  487. IPPROTO_RCCMON = 10; { BBN RCC Monitoring }
  488. IPPROTO_NVPII = 11; { network voice protocol}
  489. IPPROTO_PUP = 12; { pup }
  490. IPPROTO_ARGUS = 13; { Argus }
  491. IPPROTO_EMCON = 14; { EMCON }
  492. IPPROTO_XNET = 15; { Cross Net Debugger }
  493. IPPROTO_CHAOS = 16; { Chaos}
  494. IPPROTO_UDP = 17; { user datagram protocol }
  495. IPPROTO_MUX = 18; { Multiplexing }
  496. IPPROTO_MEAS = 19; { DCN Measurement Subsystems }
  497. IPPROTO_HMP = 20; { Host Monitoring }
  498. IPPROTO_PRM = 21; { Packet Radio Measurement }
  499. IPPROTO_IDP = 22; { xns idp }
  500. IPPROTO_TRUNK1 = 23; { Trunk-1 }
  501. IPPROTO_TRUNK2 = 24; { Trunk-2 }
  502. IPPROTO_LEAF1 = 25; { Leaf-1 }
  503. IPPROTO_LEAF2 = 26; { Leaf-2 }
  504. IPPROTO_RDP = 27; { Reliable Data }
  505. IPPROTO_IRTP = 28; { Reliable Transaction }
  506. IPPROTO_TP = 29; { tp-4 w/ class negotiation }
  507. IPPROTO_BLT = 30; { Bulk Data Transfer }
  508. IPPROTO_NSP = 31; { Network Services }
  509. IPPROTO_INP = 32; { Merit Internodal }
  510. IPPROTO_SEP = 33; { Sequential Exchange }
  511. IPPROTO_3PC = 34; { Third Party Connect }
  512. IPPROTO_IDPR = 35; { InterDomain Policy Routing }
  513. IPPROTO_XTP = 36; { XTP }
  514. IPPROTO_DDP = 37; { Datagram Delivery }
  515. IPPROTO_CMTP = 38; { Control Message Transport }
  516. IPPROTO_TPXX = 39; { TP++ Transport }
  517. IPPROTO_IL = 40; { IL transport protocol }
  518. IPPROTO_IPV6 = 41; { IP6 header }
  519. IPPROTO_SDRP = 42; { Source Demand Routing }
  520. IPPROTO_ROUTING = 43; { IP6 routing header }
  521. IPPROTO_FRAGMENT = 44; { IP6 fragmentation header }
  522. IPPROTO_IDRP = 45; { InterDomain Routing}
  523. IPPROTO_RSVP = 46; { resource reservation }
  524. IPPROTO_GRE = 47; { General Routing Encap. }
  525. IPPROTO_MHRP = 48; { Mobile Host Routing }
  526. IPPROTO_BHA = 49; { BHA }
  527. IPPROTO_ESP = 50; { IP6 Encap Sec. Payload }
  528. IPPROTO_AH = 51; { IP6 Auth Header }
  529. IPPROTO_INLSP = 52; { Integ. Net Layer Security }
  530. IPPROTO_SWIPE = 53; { IP with encryption }
  531. IPPROTO_NHRP = 54; { Next Hop Resolution }
  532. { 55-57: Unassigned }
  533. IPPROTO_ICMPV6 = 58; { ICMP6 }
  534. IPPROTO_NONE = 59; { IP6 no next header }
  535. IPPROTO_DSTOPTS = 60; { IP6 destination option }
  536. IPPROTO_AHIP = 61; { any host internal protocol }
  537. IPPROTO_CFTP = 62; { CFTP }
  538. IPPROTO_HELLO = 63; { 'hello' routing protocol }
  539. IPPROTO_SATEXPAK = 64; { SATNET/Backroom EXPAK }
  540. IPPROTO_KRYPTOLAN = 65; { Kryptolan }
  541. IPPROTO_RVD = 66; { Remote Virtual Disk }
  542. IPPROTO_IPPC = 67; { Pluribus Packet Core }
  543. IPPROTO_ADFS = 68; { Any distributed FS }
  544. IPPROTO_SATMON = 69; { Satnet Monitoring }
  545. IPPROTO_VISA = 70; { VISA Protocol }
  546. IPPROTO_IPCV = 71; { Packet Core Utility }
  547. IPPROTO_CPNX = 72; { Comp. Prot. Net. Executive }
  548. IPPROTO_CPHB = 73; { Comp. Prot. HeartBeat }
  549. IPPROTO_WSN = 74; { Wang Span Network }
  550. IPPROTO_PVP = 75; { Packet Video Protocol }
  551. IPPROTO_BRSATMON = 76; { BackRoom SATNET Monitoring }
  552. IPPROTO_ND = 77; { Sun net disk proto (Name:temp.) }
  553. IPPROTO_WBMON = 78; { WIDEBAND Monitoring }
  554. IPPROTO_WBEXPAK = 79; { WIDEBAND EXPAK }
  555. IPPROTO_EON = 80; { ISO cnlp }
  556. IPPROTO_VMTP = 81; { VMTP }
  557. IPPROTO_SVMTP = 82; { Secure VMTP }
  558. IPPROTO_VINES = 83; { Banyon VINES }
  559. IPPROTO_TTP = 84; { TTP }
  560. IPPROTO_IGP = 85; { NSFNET-IGP }
  561. IPPROTO_DGP = 86; { dissimilar gateway prot. }
  562. IPPROTO_TCF = 87; { TCF }
  563. IPPROTO_IGRP = 88; { Cisco/GXS IGRP }
  564. IPPROTO_OSPFIGP = 89; { OSPFIGP }
  565. IPPROTO_SRPC = 90; { Strite RPC protocol }
  566. IPPROTO_LARP = 91; { Locus Address Resoloution }
  567. IPPROTO_MTP = 92; { Multicast Transport }
  568. IPPROTO_AX25 = 93; { AX.25 Frames }
  569. IPPROTO_IPEIP = 94; { IP encapsulated in IP }
  570. IPPROTO_MICP = 95; { Mobile Int.ing control }
  571. IPPROTO_SCCSP = 96; { Semaphore Comm. security }
  572. IPPROTO_ETHERIP = 97; { Ethernet IP encapsulation }
  573. IPPROTO_ENCAP = 98; { encapsulation header }
  574. IPPROTO_APES = 99; { any private encr. scheme }
  575. IPPROTO_GMTP = 100; { GMTP}
  576. IPPROTO_IPCOMP = 108; { payload compression (Name:IPComp) }
  577. { 101-254: Partly Unassigned }
  578. IPPROTO_PIM = 103; { Protocol Independent Mcast }
  579. IPPROTO_PGM = 113; { PGM }
  580. { 255: Reserved }
  581. { BSD Private, local use, namespace incursion }
  582. IPPROTO_DIVERT = 254; { divert pseudo-protocol }
  583. IPPROTO_RAW = 255; { raw IP packet }
  584. IPPROTO_MAX = 256;
  585. { last return value of *_input(Name:);CtlType: meaning 'all job for this pkt is done'. }
  586. IPPROTO_DONE = 257;
  587. {
  588. * Options for use with [gs]etsockopt at the IP level.
  589. * First word of comment is data type; bool is stored in int.
  590. }
  591. IP_OPTIONS = 1; { buf/ip_opts; set/get IP options }
  592. IP_HDRINCL = 2; { int; header is included with data }
  593. IP_TOS = 3; { int; IP type of service and preced. }
  594. IP_TTL = 4; { int; IP time to live }
  595. IP_RECVOPTS = 5; { bool; receive all IP opts w/dgram }
  596. IP_RECVRETOPTS = 6; { bool; receive IP opts for response }
  597. IP_RECVDSTADDR = 7; { bool; receive IP dst addr w/dgram }
  598. IP_RETOPTS = 8; { ip_opts; set/get IP options }
  599. IP_MULTICAST_IF = 9; { u_char; set/get IP multicast i/f }
  600. IP_MULTICAST_TTL = 10; { u_char; set/get IP multicast ttl }
  601. IP_MULTICAST_LOOP = 11; { u_char; set/get IP multicast loopback }
  602. IP_ADD_MEMBERSHIP = 12; { ip_mreq; add an IP group membership }
  603. IP_DROP_MEMBERSHIP = 13; { ip_mreq; drop an IP group membership }
  604. IP_MULTICAST_VIF = 14; { set/get IP mcast virt. iface }
  605. IP_RSVP_ON = 15; { enable RSVP in kernel }
  606. IP_RSVP_OFF = 16; { disable RSVP in kernel }
  607. IP_RSVP_VIF_ON = 17; { set RSVP per-vif socket }
  608. IP_RSVP_VIF_OFF = 18; { unset RSVP per-vif socket }
  609. IP_PORTRANGE = 19; { int; range to choose for unspec port }
  610. IP_RECVIF = 20; { bool; receive reception if w/dgram }
  611. { for IPSEC }
  612. IP_IPSEC_POLICY = 21; { int; set/get security policy }
  613. IP_FAITH = 22; { bool; accept FAITH'ed connections }
  614. IP_FW_ADD = 50; { add a firewall rule to chain }
  615. IP_FW_DEL = 51; { delete a firewall rule from chain }
  616. IP_FW_FLUSH = 52; { flush firewall rule chain }
  617. IP_FW_ZERO = 53; { clear single/all firewall counter(Name:s) }
  618. IP_FW_GET = 54; { get entire firewall rule chain }
  619. IP_FW_RESETLOG = 55; { reset logging counters }
  620. IP_DUMMYNET_CONFIGURE = 60; { add/configure a dummynet pipe }
  621. IP_DUMMYNET_DEL = 61; { delete a dummynet pipe from chain }
  622. IP_DUMMYNET_FLUSH = 62; { flush dummynet }
  623. IP_DUMMYNET_GET = 64; { get entire dummynet pipes }
  624. {
  625. * Defaults and limits for options
  626. }
  627. IP_DEFAULT_MULTICAST_TTL = 1; { normally limit m'casts to 1 hop }
  628. IP_DEFAULT_MULTICAST_LOOP = 1; { normally hear sends if a member }
  629. IP_MAX_MEMBERSHIPS = 20; { per socket }
  630. {
  631. * Argument for IP_PORTRANGE:
  632. * - which range to search when port is unspecified at bind(Name:) or connect()
  633. }
  634. IP_PORTRANGE_DEFAULT = 0; { default range }
  635. IP_PORTRANGE_HIGH = 1; { 'high' - request firewall bypass }
  636. IP_PORTRANGE_LOW = 2; { 'low' - vouchsafe security }
  637. {
  638. * Definitions for inet sysctl operations.
  639. *
  640. * Third level is protocol number.
  641. * Fourth level is desired variable within that protocol.
  642. }
  643. IPPROTO_MAXID = (IPPROTO_AH + 1); { don't list to IPPROTO_MAX }
  644. CTL_IPPROTO_NAMES : Array[0..51] OF CtlNameRec = (
  645. (Name: 'ip';CtlType: CTLTYPE_NODE ),
  646. (Name: 'icmp';CtlType: CTLTYPE_NODE ),
  647. (Name: 'igmp';CtlType: CTLTYPE_NODE ),
  648. (Name: 'ggp';CtlType: CTLTYPE_NODE ),
  649. (Name: '';CtlType: 0 ),
  650. (Name: '';CtlType: 0 ),
  651. (Name: 'tcp';CtlType: CTLTYPE_NODE ),
  652. (Name: '';CtlType: 0 ),
  653. (Name: 'egp';CtlType: CTLTYPE_NODE ),
  654. (Name: '';CtlType: 0 ),
  655. (Name: '';CtlType: 0 ),
  656. (Name: '';CtlType: 0 ),
  657. (Name: 'pup';CtlType: CTLTYPE_NODE ),
  658. (Name: '';CtlType: 0 ),
  659. (Name: '';CtlType: 0 ),
  660. (Name: '';CtlType: 0 ),
  661. (Name: '';CtlType: 0 ),
  662. (Name: 'udp';CtlType: CTLTYPE_NODE ),
  663. (Name: '';CtlType: 0 ),
  664. (Name: '';CtlType: 0 ),
  665. (Name: '';CtlType: 0 ),
  666. (Name: '';CtlType: 0 ),
  667. (Name: 'idp';CtlType: CTLTYPE_NODE ),
  668. (Name: '';CtlType: 0 ),
  669. (Name: '';CtlType: 0 ),
  670. (Name: '';CtlType: 0 ),
  671. (Name: '';CtlType: 0 ),
  672. (Name: '';CtlType: 0 ),
  673. (Name: '';CtlType: 0 ),
  674. (Name: '';CtlType: 0 ),
  675. (Name: '';CtlType: 0 ),
  676. (Name: '';CtlType: 0 ),
  677. (Name: '';CtlType: 0 ),
  678. (Name: '';CtlType: 0 ),
  679. (Name: '';CtlType: 0 ),
  680. (Name: '';CtlType: 0 ),
  681. (Name: '';CtlType: 0 ),
  682. (Name: '';CtlType: 0 ),
  683. (Name: '';CtlType: 0 ),
  684. (Name: '';CtlType: 0 ),
  685. (Name: '';CtlType: 0 ),
  686. (Name: '';CtlType: 0 ),
  687. (Name: '';CtlType: 0 ),
  688. (Name: '';CtlType: 0 ),
  689. (Name: '';CtlType: 0 ),
  690. (Name: '';CtlType: 0 ),
  691. (Name: '';CtlType: 0 ),
  692. (Name: '';CtlType: 0 ),
  693. (Name: '';CtlType: 0 ),
  694. (Name: '';CtlType: 0 ),
  695. (Name: '';CtlType: 0 ),
  696. (Name: 'ipsec';CtlType: CTLTYPE_NODE ));
  697. {
  698. * Names for IP sysctl objects
  699. }
  700. IPCTL_FORWARDING = 1; { act as router }
  701. IPCTL_SENDREDIRECTS = 2; { may send redirects when forwarding }
  702. IPCTL_DEFTTL = 3; { default TTL }
  703. {$ifdef notyettunable}
  704. IPCTL_DEFMTU = 4; { default MTU }
  705. {$endif}
  706. IPCTL_RTEXPIRE = 5; { cloned route expiration time }
  707. IPCTL_RTMINEXPIRE = 6; { min value for expiration time }
  708. IPCTL_RTMAXCACHE = 7; { trigger level for dynamic expire }
  709. IPCTL_SOURCEROUTE = 8; { may perform source routes }
  710. IPCTL_DIRECTEDBROADCAST = 9; { may re-broadcast received packets }
  711. IPCTL_INTRQMAXLEN = 10; { max length of netisr queue }
  712. IPCTL_INTRQDROPS = 11; { number of netisr q drops }
  713. IPCTL_STATS = 12; { ipstat structure }
  714. IPCTL_ACCEPTSOURCEROUTE = 13; { may accept source routed packets }
  715. IPCTL_FASTFORWARDING = 14; { use fast IP forwarding code }
  716. IPCTL_KEEPFAITH = 15; { FAITH IPv4->IPv6 translater ctl }
  717. IPCTL_GIF_TTL = 16; { default TTL for gif encap packet }
  718. IPCTL_MAXID = 17;
  719. IPCTL_NAMES : Array[0..14] OF CtlNameRec = (
  720. (Name: '';CtlType: 0 ),
  721. (Name: 'forwarding';CtlType: CTLTYPE_INT ),
  722. (Name: 'redirect';CtlType: CTLTYPE_INT ),
  723. (Name: 'ttl';CtlType: CTLTYPE_INT ),
  724. (Name: 'mtu';CtlType: CTLTYPE_INT ),
  725. (Name: 'rtexpire';CtlType: CTLTYPE_INT ),
  726. (Name: 'rtminexpire';CtlType: CTLTYPE_INT ),
  727. (Name: 'rtmaxcache';CtlType: CTLTYPE_INT ),
  728. (Name: 'sourceroute';CtlType: CTLTYPE_INT ),
  729. (Name: 'directed-broadcast';CtlType: CTLTYPE_INT ),
  730. (Name: 'intr-queue-maxlen';CtlType: CTLTYPE_INT ),
  731. (Name: 'intr-queue-drops';CtlType: CTLTYPE_INT ),
  732. (Name: 'stats';CtlType: CTLTYPE_STRUCT ),
  733. (Name: 'accept_sourceroute';CtlType: CTLTYPE_INT ),
  734. (Name: 'fastforwarding';CtlType: CTLTYPE_INT ));
  735. {
  736. * Names for ICMP sysctl objects
  737. }
  738. ICMPCTL_MASKREPL = 1; { allow replies to netmask requests }
  739. ICMPCTL_STATS = 2; { statistics (Name:read-only) }
  740. ICMPCTL_ICMPLIM = 3;
  741. ICMPCTL_MAXID = 4;
  742. ICMPCTL_NAMES : Array[0..3] OF CtlNameRec = (
  743. (Name: '';CtlType: 0 ),
  744. (Name: 'maskrepl';CtlType: CTLTYPE_INT ),
  745. (Name: 'stats';CtlType: CTLTYPE_STRUCT ),
  746. (Name: 'icmplim';CtlType: CTLTYPE_INT ));
  747. {
  748. * Names for ICMP sysctl objects
  749. }
  750. ICMPV6CTL_STATS = 1;
  751. ICMPV6CTL_REDIRACCEPT = 2; { accept/process redirects }
  752. ICMPV6CTL_REDIRTIMEOUT = 3; { redirect cache time }
  753. {$ifdef obsolete} {obsoleted}
  754. ICMPV6CTL_ERRRATELIMIT = 5; { ICMPv6 error rate limitation }
  755. {$endif}
  756. ICMPV6CTL_ND6_PRUNE = 6;
  757. ICMPV6CTL_ND6_DELAY = 8;
  758. ICMPV6CTL_ND6_UMAXTRIES = 9;
  759. ICMPV6CTL_ND6_MMAXTRIES = 10;
  760. ICMPV6CTL_ND6_USELOOPBACK = 11;
  761. //define ICMPV6CTL_ND6_PROXYALL = 12; obsoleted, do not reuse here
  762. ICMPV6CTL_NODEINFO = 13;
  763. ICMPV6CTL_ERRPPSLIMIT = 14; { ICMPv6 error pps limitation }
  764. ICMPV6CTL_ND6_MAXNUDHINT= 15;
  765. ICMPV6CTL_MTUDISC_HIWAT = 16;
  766. ICMPV6CTL_MTUDISC_LOWAT = 17;
  767. ICMPV6CTL_ND6_DEBUG = 18;
  768. ICMPV6CTL_ND6_DRLIST = 19;
  769. ICMPV6CTL_ND6_PRLIST = 20;
  770. ICMPV6CTL_MAXID = 21;
  771. ICMPV6CTL_NAMES : Array[0..20] OF CtlNameRec = (
  772. (Name: '';CtlType: 0 ),
  773. (Name: '';CtlType: 0 ),
  774. (Name: 'rediraccept';CtlType: CTLTYPE_INT ),
  775. (Name: 'redirtimeout';CtlType: CTLTYPE_INT ),
  776. (Name: '';CtlType: 0 ),
  777. (Name: '';CtlType: 0 ),
  778. (Name: 'nd6_prune';CtlType: CTLTYPE_INT ),
  779. (Name: '';CtlType: 0 ),
  780. (Name: 'nd6_delay';CtlType: CTLTYPE_INT ),
  781. (Name: 'nd6_umaxtries';CtlType: CTLTYPE_INT ),
  782. (Name: 'nd6_mmaxtries';CtlType: CTLTYPE_INT ),
  783. (Name: 'nd6_useloopback';CtlType: CTLTYPE_INT ),
  784. (Name: '';CtlType: 0 ),
  785. (Name: 'nodeinfo';CtlType: CTLTYPE_INT ),
  786. (Name: 'errppslimit';CtlType: CTLTYPE_INT ),
  787. (Name: 'nd6_maxnudhint';CtlType: CTLTYPE_INT ),
  788. (Name: 'mtudisc_hiwat';CtlType: CTLTYPE_INT ),
  789. (Name: 'mtudisc_lowat';CtlType: CTLTYPE_INT ),
  790. (Name: 'nd6_debug';CtlType: CTLTYPE_INT ),
  791. (Name: '';CtlType: 0 ),
  792. (Name: '';CtlType: 0 ));
  793. {
  794. * Names for UDP sysctl objects
  795. }
  796. UDPCTL_CHECKSUM = 1; { checksum UDP packets }
  797. UDPCTL_STATS = 2; { statistics (Name:read-only) }
  798. UDPCTL_MAXDGRAM = 3; { max datagram size }
  799. UDPCTL_RECVSPACE = 4; { default receive buffer space }
  800. UDPCTL_PCBLIST = 5; { list of PCBs for UDP sockets }
  801. UDPCTL_MAXID = 6;
  802. UDPCTL_NAMES : Array[0..5] OF CtlNameRec = (
  803. (Name: '';CtlType: 0 ),
  804. (Name: 'checksum';CtlType: CTLTYPE_INT ),
  805. (Name: 'stats';CtlType: CTLTYPE_STRUCT ),
  806. (Name: 'maxdgram';CtlType: CTLTYPE_INT ),
  807. (Name: 'recvspace';CtlType: CTLTYPE_INT ),
  808. (Name: 'pcblist';CtlType: CTLTYPE_STRUCT ));