|
const std = @import("../std.zig"); const assert = std.debug.assert; const maxInt = std.math.maxInt; const builtin = @import("builtin"); const iovec = std.os.iovec; const iovec_const = std.os.iovec_const; extern "c" fn __errno() *c_int; |
_errno |
pub const _errno = __errno; |
dl_iterate_phdr_callback |
pub const dl_iterate_phdr_callback = *const fn (info: *dl_phdr_info, size: usize, data: ?*anyopaque) callconv(.C) c_int; pub extern "c" fn dl_iterate_phdr(callback: dl_iterate_phdr_callback, data: ?*anyopaque) c_int; pub extern "c" fn arc4random_buf(buf: [*]u8, len: usize) void; pub extern "c" fn getthrid() pid_t; pub extern "c" fn pipe2(fds: *[2]fd_t, flags: u32) c_int; pub extern "c" fn getdents(fd: c_int, buf_ptr: [*]u8, nbytes: usize) c_int; pub extern "c" fn sigaltstack(ss: ?*stack_t, old_ss: ?*stack_t) c_int; |
pthread_mutex_t |
pub const pthread_mutex_t = extern struct { inner: ?*anyopaque = null, }; |
pthread_cond_t |
pub const pthread_cond_t = extern struct { inner: ?*anyopaque = null, }; |
pthread_rwlock_t |
pub const pthread_rwlock_t = extern struct { ptr: ?*anyopaque = null, }; |
pthread_spinlock_t |
pub const pthread_spinlock_t = extern struct { inner: ?*anyopaque = null, }; |
pthread_attr_t |
pub const pthread_attr_t = extern struct { inner: ?*anyopaque = null, }; |
pthread_key_t |
pub const pthread_key_t = c_int; |
sem_t |
pub const sem_t = ?*opaque {}; pub extern "c" fn posix_memalign(memptr: *?*anyopaque, alignment: usize, size: usize) c_int; pub extern "c" fn pledge(promises: ?[*:0]const u8, execpromises: ?[*:0]const u8) c_int; pub extern "c" fn unveil(path: ?[*:0]const u8, permissions: ?[*:0]const u8) c_int; pub extern "c" fn pthread_set_name_np(thread: std.c.pthread_t, name: [*:0]const u8) void; pub extern "c" fn pthread_get_name_np(thread: std.c.pthread_t, name: [*:0]u8, len: usize) void; // https://github.com/openbsd/src/blob/2207c4325726fdc5c4bcd0011af0fdf7d3dab137/sys/sys/futex.h |
FUTEX_WAIT |
pub const FUTEX_WAIT = 1; |
FUTEX_WAKE |
pub const FUTEX_WAKE = 2; |
FUTEX_REQUEUE |
pub const FUTEX_REQUEUE = 3; |
FUTEX_PRIVATE_FLAG |
pub const FUTEX_PRIVATE_FLAG = 128; pub extern "c" fn futex(uaddr: ?*const volatile u32, op: c_int, val: c_int, timeout: ?*const timespec, uaddr2: ?*const volatile u32) c_int; |
login_cap_t |
pub const login_cap_t = extern struct { lc_class: ?[*:0]const u8, lc_cap: ?[*:0]const u8, lc_style: ?[*:0]const u8, }; pub extern "c" fn login_getclass(class: ?[*:0]const u8) ?*login_cap_t; pub extern "c" fn login_getstyle(lc: *login_cap_t, style: ?[*:0]const u8, atype: ?[*:0]const u8) ?[*:0]const u8; pub extern "c" fn login_getcapbool(lc: *login_cap_t, cap: [*:0]const u8, def: c_int) c_int; pub extern "c" fn login_getcapnum(lc: *login_cap_t, cap: [*:0]const u8, def: i64, err: i64) i64; pub extern "c" fn login_getcapsize(lc: *login_cap_t, cap: [*:0]const u8, def: i64, err: i64) i64; pub extern "c" fn login_getcapstr(lc: *login_cap_t, cap: [*:0]const u8, def: [*:0]const u8, err: [*:0]const u8) [*:0]const u8; pub extern "c" fn login_getcaptime(lc: *login_cap_t, cap: [*:0]const u8, def: i64, err: i64) i64; pub extern "c" fn login_close(lc: *login_cap_t) void; pub extern "c" fn setclasscontext(class: [*:0]const u8, flags: c_uint) c_int; pub extern "c" fn setusercontext(lc: *login_cap_t, pwd: *passwd, uid: uid_t, flags: c_uint) c_int; |
auth_session_t |
pub const auth_session_t = opaque {}; pub extern "c" fn auth_userokay(name: [*:0]const u8, style: ?[*:0]const u8, arg_type: ?[*:0]const u8, password: ?[*:0]const u8) c_int; pub extern "c" fn auth_approval(as: ?*auth_session_t, ?*login_cap_t, name: ?[*:0]const u8, type: ?[*:0]const u8) c_int; pub extern "c" fn auth_userchallenge(name: [*:0]const u8, style: ?[*:0]const u8, arg_type: ?[*:0]const u8, chappengep: *?[*:0]const u8) ?*auth_session_t; pub extern "c" fn auth_userresponse(as: *auth_session_t, response: [*:0]const u8, more: c_int) c_int; pub extern "c" fn auth_usercheck(name: [*:0]const u8, style: ?[*:0]const u8, arg_type: ?[*:0]const u8, password: ?[*:0]const u8) ?*auth_session_t; pub extern "c" fn auth_open() ?*auth_session_t; pub extern "c" fn auth_close(as: *auth_session_t) c_int; pub extern "c" fn auth_setdata(as: *auth_session_t, ptr: *anyopaque, len: usize) c_int; pub extern "c" fn auth_setitem(as: *auth_session_t, item: auth_item_t, value: [*:0]const u8) c_int; pub extern "c" fn auth_getitem(as: *auth_session_t, item: auth_item_t) ?[*:0]const u8; pub extern "c" fn auth_setoption(as: *auth_session_t, n: [*:0]const u8, v: [*:0]const u8) c_int; pub extern "c" fn auth_setstate(as: *auth_session_t, s: c_int) void; pub extern "c" fn auth_getstate(as: *auth_session_t) c_int; pub extern "c" fn auth_clean(as: *auth_session_t) void; pub extern "c" fn auth_clrenv(as: *auth_session_t) void; pub extern "c" fn auth_clroption(as: *auth_session_t, option: [*:0]const u8) void; pub extern "c" fn auth_clroptions(as: *auth_session_t) void; pub extern "c" fn auth_setenv(as: *auth_session_t) void; pub extern "c" fn auth_getvalue(as: *auth_session_t, what: [*:0]const u8) ?[*:0]const u8; pub extern "c" fn auth_verify(as: ?*auth_session_t, style: ?[*:0]const u8, name: ?[*:0]const u8, ...) ?*auth_session_t; pub extern "c" fn auth_call(as: *auth_session_t, path: [*:0]const u8, ...) c_int; pub extern "c" fn auth_challenge(as: *auth_session_t) [*:0]const u8; pub extern "c" fn auth_check_expire(as: *auth_session_t) i64; pub extern "c" fn auth_check_change(as: *auth_session_t) i64; pub extern "c" fn auth_getpwd(as: *auth_session_t) ?*passwd; pub extern "c" fn auth_setpwd(as: *auth_session_t, pwd: *passwd) c_int; pub extern "c" fn auth_mkvalue(value: [*:0]const u8) ?[*:0]const u8; pub extern "c" fn auth_cat(file: [*:0]const u8) c_int; pub extern "c" fn auth_checknologin(lc: *login_cap_t) void; // TODO: auth_set_va_list requires zig support for va_list type (#515) |
passwd |
pub const passwd = extern struct { pw_name: ?[*:0]const u8, // user name pw_passwd: ?[*:0]const u8, // encrypted password pw_uid: uid_t, // user uid pw_gid: gid_t, // user gid pw_change: time_t, // password change time pw_class: ?[*:0]const u8, // user access class pw_gecos: ?[*:0]const u8, // Honeywell login info pw_dir: ?[*:0]const u8, // home directory pw_shell: ?[*:0]const u8, // default shell pw_expire: time_t, // account expiration }; pub extern "c" fn getpwuid(uid: uid_t) ?*passwd; pub extern "c" fn getpwnam(name: [*:0]const u8) ?*passwd; pub extern "c" fn getpwuid_shadow(uid: uid_t) ?*passwd; pub extern "c" fn getpwnam_shadow(name: [*:0]const u8) ?*passwd; pub extern "c" fn getpwnam_r(name: [*:0]const u8, pw: *passwd, buf: [*]u8, buflen: usize, pwretp: *?*passwd) c_int; pub extern "c" fn getpwuid_r(uid: uid_t, pw: *passwd, buf: [*]u8, buflen: usize, pwretp: *?*passwd) c_int; pub extern "c" fn getpwent() ?*passwd; pub extern "c" fn setpwent() void; pub extern "c" fn endpwent() void; pub extern "c" fn setpassent(stayopen: c_int) c_int; pub extern "c" fn uid_from_user(name: [*:0]const u8, uid: *uid_t) c_int; pub extern "c" fn user_from_uid(uid: uid_t, noname: c_int) ?[*:0]const u8; pub extern "c" fn bcrypt_gensalt(log_rounds: u8) [*:0]const u8; pub extern "c" fn bcrypt(pass: [*:0]const u8, salt: [*:0]const u8) ?[*:0]const u8; pub extern "c" fn bcrypt_newhash(pass: [*:0]const u8, log_rounds: c_int, hash: [*]u8, hashlen: usize) c_int; pub extern "c" fn bcrypt_checkpass(pass: [*:0]const u8, goodhash: [*:0]const u8) c_int; pub extern "c" fn pw_dup(pw: *const passwd) ?*passwd; |
blkcnt_t |
pub const blkcnt_t = i64; |
blksize_t |
pub const blksize_t = i32; |
clock_t |
pub const clock_t = i64; |
dev_t |
pub const dev_t = i32; |
fd_t |
pub const fd_t = c_int; |
gid_t |
pub const gid_t = u32; |
ino_t |
pub const ino_t = u64; |
mode_t |
pub const mode_t = u32; |
nlink_t |
pub const nlink_t = u32; |
off_t |
pub const off_t = i64; |
pid_t |
pub const pid_t = i32; |
socklen_t |
pub const socklen_t = u32; |
time_t |
pub const time_t = i64; |
uid_t |
pub const uid_t = u32; |
Kevent Renamed from |
pub const Kevent = extern struct { ident: usize, filter: c_short, flags: u16, fflags: c_uint, data: i64, udata: usize, }; // Modes and flags for dlopen() // include/dlfcn.h |
RTLD |
pub const RTLD = struct { pub const LAZY = 1; pub const NOW = 2; pub const GLOBAL = 0x100; pub const LOCAL = 0x000; pub const TRACE = 0x200; }; |
dl_phdr_infoBind function calls lazily. Bind function calls immediately. Make symbols globally available. Opposite of GLOBAL, and the default. Trace loaded objects and exit. |
pub const dl_phdr_info = extern struct { dlpi_addr: std.elf.Addr, dlpi_name: ?[*:0]const u8, dlpi_phdr: [*]std.elf.Phdr, dlpi_phnum: std.elf.Half, }; |
Flock |
pub const Flock = extern struct { start: off_t, len: off_t, pid: pid_t, type: c_short, whence: c_short, }; |
addrinfo |
pub const addrinfo = extern struct { flags: c_int, family: c_int, socktype: c_int, protocol: c_int, addrlen: socklen_t, addr: ?*sockaddr, canonname: ?[*:0]u8, next: ?*addrinfo, }; |
EAI |
pub const EAI = enum(c_int) { ADDRFAMILY = -9, AGAIN = -3, BADFLAGS = -1, FAIL = -4, FAMILY = -6, MEMORY = -10, NODATA = -5, NONAME = -2, SERVICE = -8, SOCKTYPE = -7, SYSTEM = -11, BADHINTS = -12, PROTOCOL = -13, OVERFLOW = -14, _, }; |
EAI_MAXaddress family for hostname not supported name could not be resolved at this time flags parameter had an invalid value non-recoverable failure in name resolution address family not recognized memory allocation failure no address associated with hostname name does not resolve service not recognized for socket type intended socket type was not recognized system error returned in errno invalid value for hints resolved protocol is unknown argument buffer overflow |
pub const EAI_MAX = 15; |
msghdr |
pub const msghdr = extern struct { name: ?*sockaddr, namelen: socklen_t, iov: [*]iovec, iovlen: c_uint, control: ?*anyopaque, controllen: socklen_t, flags: c_int, }; |
msghdr_constoptional address size of address scatter/gather array # elements in iov ancillary data ancillary data buffer len flags on received message |
pub const msghdr_const = extern struct { name: ?*const sockaddr, namelen: socklen_t, iov: [*]const iovec_const, iovlen: c_uint, control: ?*const anyopaque, controllen: socklen_t, flags: c_int, }; |
Statoptional address size of address scatter/gather array # elements in iov ancillary data ancillary data buffer len flags on received message |
pub const Stat = extern struct { mode: mode_t, dev: dev_t, ino: ino_t, nlink: nlink_t, uid: uid_t, gid: gid_t, rdev: dev_t, atim: timespec, mtim: timespec, ctim: timespec, size: off_t, blocks: blkcnt_t, blksize: blksize_t, flags: u32, gen: u32, birthtim: timespec, |
atime() |
pub fn atime(self: @This()) timespec { return self.atim; } |
mtime() |
pub fn mtime(self: @This()) timespec { return self.mtim; } |
ctime() |
pub fn ctime(self: @This()) timespec { return self.ctim; } |
birthtime() |
pub fn birthtime(self: @This()) timespec { return self.birthtim; } }; |
timespec |
pub const timespec = extern struct { tv_sec: time_t, tv_nsec: c_long, }; |
timeval |
pub const timeval = extern struct { tv_sec: time_t, tv_usec: c_long, }; |
timezone |
pub const timezone = extern struct { tz_minuteswest: c_int, tz_dsttime: c_int, }; |
MAXNAMLEN |
pub const MAXNAMLEN = 255; |
dirent |
pub const dirent = extern struct { d_fileno: ino_t, d_off: off_t, d_reclen: u16, d_type: u8, d_namlen: u8, __d_padding: [4]u8, d_name: [MAXNAMLEN + 1]u8, |
reclen() |
pub fn reclen(self: dirent) u16 { return self.d_reclen; } }; |
in_port_t |
pub const in_port_t = u16; |
sa_family_t |
pub const sa_family_t = u8; |
sockaddr |
pub const sockaddr = extern struct { len: u8, family: sa_family_t, data: [14]u8, pub const SS_MAXSIZE = 256; pub const storage = extern struct { len: u8 align(8), family: sa_family_t, padding: [254]u8 = undefined, comptime { assert(@sizeOf(storage) == SS_MAXSIZE); assert(@alignOf(storage) == 8); } }; pub const in = extern struct { len: u8 = @sizeOf(in), family: sa_family_t = AF.INET, port: in_port_t, addr: u32, zero: [8]u8 = [8]u8{ 0, 0, 0, 0, 0, 0, 0, 0 }, }; pub const in6 = extern struct { len: u8 = @sizeOf(in6), family: sa_family_t = AF.INET6, port: in_port_t, flowinfo: u32, addr: [16]u8, scope_id: u32, }; pub const un = extern struct { len: u8 = @sizeOf(un), family: sa_family_t = AF.LOCAL, path: [104]u8, }; }; |
AItotal length address family actually longer; address value Definitions for UNIX IPC domain. total sockaddr length path name |
pub const AI = struct { pub const PASSIVE = 1; pub const CANONNAME = 2; pub const NUMERICHOST = 4; pub const NUMERICSERV = 16; pub const ADDRCONFIG = 64; }; |
PATH_MAXget address to use bind() fill ai_canonname prevent host name resolution prevent service name resolution only if any address is assigned |
pub const PATH_MAX = 1024; |
NAME_MAX |
pub const NAME_MAX = 255; |
IOV_MAX |
pub const IOV_MAX = 1024; |
STDIN_FILENO |
pub const STDIN_FILENO = 0; |
STDOUT_FILENO |
pub const STDOUT_FILENO = 1; |
STDERR_FILENO |
pub const STDERR_FILENO = 2; |
PROT |
pub const PROT = struct { pub const NONE = 0; pub const READ = 1; pub const WRITE = 2; pub const EXEC = 4; }; |
CLOCK |
pub const CLOCK = struct { pub const REALTIME = 0; pub const PROCESS_CPUTIME_ID = 2; pub const MONOTONIC = 3; pub const THREAD_CPUTIME_ID = 4; }; |
MAP |
pub const MAP = struct { pub const FAILED = @as(*anyopaque, @ptrFromInt(maxInt(usize))); pub const SHARED = 0x0001; pub const PRIVATE = 0x0002; pub const FIXED = 0x0010; pub const RENAME = 0; pub const NORESERVE = 0; pub const INHERIT = 0; pub const HASSEMAPHORE = 0; pub const TRYFIXED = 0; pub const FILE = 0; pub const ANON = 0x1000; pub const ANONYMOUS = ANON; pub const STACK = 0x4000; pub const CONCEAL = 0x8000; }; |
MSF |
pub const MSF = struct { pub const ASYNC = 1; pub const INVALIDATE = 2; pub const SYNC = 4; }; |
W |
pub const W = struct { pub const NOHANG = 1; pub const UNTRACED = 2; pub const CONTINUED = 8; |
EXITSTATUS() |
pub fn EXITSTATUS(s: u32) u8 { return @as(u8, @intCast((s >> 8) & 0xff)); } |
TERMSIG() |
pub fn TERMSIG(s: u32) u32 { return (s & 0x7f); } |
STOPSIG() |
pub fn STOPSIG(s: u32) u32 { return EXITSTATUS(s); } |
IFEXITED() |
pub fn IFEXITED(s: u32) bool { return TERMSIG(s) == 0; } |
IFCONTINUED() |
pub fn IFCONTINUED(s: u32) bool { return ((s & 0o177777) == 0o177777); } |
IFSTOPPED() |
pub fn IFSTOPPED(s: u32) bool { return (s & 0xff == 0o177); } |
IFSIGNALED() |
pub fn IFSIGNALED(s: u32) bool { return (((s) & 0o177) != 0o177) and (((s) & 0o177) != 0); } }; |
SA |
pub const SA = struct { pub const ONSTACK = 0x0001; pub const RESTART = 0x0002; pub const RESETHAND = 0x0004; pub const NOCLDSTOP = 0x0008; pub const NODEFER = 0x0010; pub const NOCLDWAIT = 0x0020; pub const SIGINFO = 0x0040; }; // access function |
F_OK |
pub const F_OK = 0; // test for existence of file |
X_OK |
pub const X_OK = 1; // test for execute or search permission |
W_OK |
pub const W_OK = 2; // test for write permission |
R_OK |
pub const R_OK = 4; // test for read permission |
O |
pub const O = struct { pub const RDONLY = 0x00000000; pub const WRONLY = 0x00000001; pub const RDWR = 0x00000002; pub const ACCMODE = 0x00000003; pub const NONBLOCK = 0x00000004; pub const APPEND = 0x00000008; pub const SHLOCK = 0x00000010; pub const EXLOCK = 0x00000020; pub const ASYNC = 0x00000040; pub const SYNC = 0x00000080; pub const NOFOLLOW = 0x00000100; pub const CREAT = 0x00000200; pub const TRUNC = 0x00000400; pub const EXCL = 0x00000800; pub const NOCTTY = 0x00008000; pub const DSYNC = SYNC; pub const RSYNC = SYNC; pub const DIRECTORY = 0x20000; pub const CLOEXEC = 0x10000; }; |
Fopen for reading only open for writing only open for reading and writing mask for above modes no delay set append mode open with shared file lock open with exclusive file lock signal pgrp when data ready synchronous writes don't follow symlinks on the last create if nonexistent truncate to zero length error if already exists don't assign controlling terminal write: I/O data completion read: I/O completion as for write fail if not a directory set close on exec |
pub const F = struct { pub const DUPFD = 0; pub const GETFD = 1; pub const SETFD = 2; pub const GETFL = 3; pub const SETFL = 4; pub const GETOWN = 5; pub const SETOWN = 6; pub const GETLK = 7; pub const SETLK = 8; pub const SETLKW = 9; pub const RDLCK = 1; pub const UNLCK = 2; pub const WRLCK = 3; }; |
LOCK |
pub const LOCK = struct { pub const SH = 0x01; pub const EX = 0x02; pub const NB = 0x04; pub const UN = 0x08; }; |
FD_CLOEXEC |
pub const FD_CLOEXEC = 1; |
SEEK |
pub const SEEK = struct { pub const SET = 0; pub const CUR = 1; pub const END = 2; }; |
SOCK |
pub const SOCK = struct { pub const STREAM = 1; pub const DGRAM = 2; pub const RAW = 3; pub const RDM = 4; pub const SEQPACKET = 5; pub const CLOEXEC = 0x8000; pub const NONBLOCK = 0x4000; }; |
SO |
pub const SO = struct { pub const DEBUG = 0x0001; pub const ACCEPTCONN = 0x0002; pub const REUSEADDR = 0x0004; pub const KEEPALIVE = 0x0008; pub const DONTROUTE = 0x0010; pub const BROADCAST = 0x0020; pub const USELOOPBACK = 0x0040; pub const LINGER = 0x0080; pub const OOBINLINE = 0x0100; pub const REUSEPORT = 0x0200; pub const TIMESTAMP = 0x0800; pub const BINDANY = 0x1000; pub const ZEROIZE = 0x2000; pub const SNDBUF = 0x1001; pub const RCVBUF = 0x1002; pub const SNDLOWAT = 0x1003; pub const RCVLOWAT = 0x1004; pub const SNDTIMEO = 0x1005; pub const RCVTIMEO = 0x1006; pub const ERROR = 0x1007; pub const TYPE = 0x1008; pub const NETPROC = 0x1020; pub const RTABLE = 0x1021; pub const PEERCRED = 0x1022; pub const SPLICE = 0x1023; pub const DOMAIN = 0x1024; pub const PROTOCOL = 0x1025; }; |
SOL |
pub const SOL = struct { pub const SOCKET = 0xffff; }; |
PF |
pub const PF = struct { pub const UNSPEC = AF.UNSPEC; pub const LOCAL = AF.LOCAL; pub const UNIX = AF.UNIX; pub const INET = AF.INET; pub const APPLETALK = AF.APPLETALK; pub const INET6 = AF.INET6; pub const DECnet = AF.DECnet; pub const KEY = AF.KEY; pub const ROUTE = AF.ROUTE; pub const SNA = AF.SNA; pub const MPLS = AF.MPLS; pub const BLUETOOTH = AF.BLUETOOTH; pub const ISDN = AF.ISDN; pub const MAX = AF.MAX; }; |
AF |
pub const AF = struct { pub const UNSPEC = 0; pub const UNIX = 1; pub const LOCAL = UNIX; pub const INET = 2; pub const APPLETALK = 16; pub const INET6 = 24; pub const KEY = 30; pub const ROUTE = 17; pub const SNA = 11; pub const MPLS = 33; pub const BLUETOOTH = 32; pub const ISDN = 26; pub const MAX = 36; }; |
DT |
pub const DT = struct { pub const UNKNOWN = 0; pub const FIFO = 1; pub const CHR = 2; pub const DIR = 4; pub const BLK = 6; pub const REG = 8; pub const LNK = 10; pub const SOCK = 12; pub const WHT = 14; // XXX }; |
EV_ADD |
pub const EV_ADD = 0x0001; |
EV_DELETE |
pub const EV_DELETE = 0x0002; |
EV_ENABLE |
pub const EV_ENABLE = 0x0004; |
EV_DISABLE |
pub const EV_DISABLE = 0x0008; |
EV_ONESHOT |
pub const EV_ONESHOT = 0x0010; |
EV_CLEAR |
pub const EV_CLEAR = 0x0020; |
EV_RECEIPT |
pub const EV_RECEIPT = 0x0040; |
EV_DISPATCH |
pub const EV_DISPATCH = 0x0080; |
EV_FLAG1 |
pub const EV_FLAG1 = 0x2000; |
EV_ERROR |
pub const EV_ERROR = 0x4000; |
EV_EOF |
pub const EV_EOF = 0x8000; |
EVFILT_READ |
pub const EVFILT_READ = -1; |
EVFILT_WRITE |
pub const EVFILT_WRITE = -2; |
EVFILT_AIO |
pub const EVFILT_AIO = -3; |
EVFILT_VNODE |
pub const EVFILT_VNODE = -4; |
EVFILT_PROC |
pub const EVFILT_PROC = -5; |
EVFILT_SIGNAL |
pub const EVFILT_SIGNAL = -6; |
EVFILT_TIMER |
pub const EVFILT_TIMER = -7; |
EVFILT_EXCEPT |
pub const EVFILT_EXCEPT = -9; // data/hint flags for EVFILT_{READ|WRITE} |
NOTE_LOWAT |
pub const NOTE_LOWAT = 0x0001; |
NOTE_EOF |
pub const NOTE_EOF = 0x0002; // data/hint flags for EVFILT_EXCEPT and EVFILT_{READ|WRITE} |
NOTE_OOB |
pub const NOTE_OOB = 0x0004; // data/hint flags for EVFILT_VNODE |
NOTE_DELETE |
pub const NOTE_DELETE = 0x0001; |
NOTE_WRITE |
pub const NOTE_WRITE = 0x0002; |
NOTE_EXTEND |
pub const NOTE_EXTEND = 0x0004; |
NOTE_ATTRIB |
pub const NOTE_ATTRIB = 0x0008; |
NOTE_LINK |
pub const NOTE_LINK = 0x0010; |
NOTE_RENAME |
pub const NOTE_RENAME = 0x0020; |
NOTE_REVOKE |
pub const NOTE_REVOKE = 0x0040; |
NOTE_TRUNCATE |
pub const NOTE_TRUNCATE = 0x0080; // data/hint flags for EVFILT_PROC |
NOTE_EXIT |
pub const NOTE_EXIT = 0x80000000; |
NOTE_FORK |
pub const NOTE_FORK = 0x40000000; |
NOTE_EXEC |
pub const NOTE_EXEC = 0x20000000; |
NOTE_PDATAMASK |
pub const NOTE_PDATAMASK = 0x000fffff; |
NOTE_PCTRLMASK |
pub const NOTE_PCTRLMASK = 0xf0000000; |
NOTE_TRACK |
pub const NOTE_TRACK = 0x00000001; |
NOTE_TRACKERR |
pub const NOTE_TRACKERR = 0x00000002; |
NOTE_CHILD |
pub const NOTE_CHILD = 0x00000004; // data/hint flags for EVFILT_DEVICE |
NOTE_CHANGE |
pub const NOTE_CHANGE = 0x00000001; |
T |
pub const T = struct { pub const IOCCBRK = 0x2000747a; pub const IOCCDTR = 0x20007478; pub const IOCCONS = 0x80047462; pub const IOCDCDTIMESTAMP = 0x40107458; pub const IOCDRAIN = 0x2000745e; pub const IOCEXCL = 0x2000740d; pub const IOCEXT = 0x80047460; pub const IOCFLAG_CDTRCTS = 0x10; pub const IOCFLAG_CLOCAL = 0x2; pub const IOCFLAG_CRTSCTS = 0x4; pub const IOCFLAG_MDMBUF = 0x8; pub const IOCFLAG_SOFTCAR = 0x1; pub const IOCFLUSH = 0x80047410; pub const IOCGETA = 0x402c7413; pub const IOCGETD = 0x4004741a; pub const IOCGFLAGS = 0x4004745d; pub const IOCGLINED = 0x40207442; pub const IOCGPGRP = 0x40047477; pub const IOCGQSIZE = 0x40047481; pub const IOCGRANTPT = 0x20007447; pub const IOCGSID = 0x40047463; pub const IOCGSIZE = 0x40087468; pub const IOCGWINSZ = 0x40087468; pub const IOCMBIC = 0x8004746b; pub const IOCMBIS = 0x8004746c; pub const IOCMGET = 0x4004746a; pub const IOCMSET = 0x8004746d; pub const IOCM_CAR = 0x40; pub const IOCM_CD = 0x40; pub const IOCM_CTS = 0x20; pub const IOCM_DSR = 0x100; pub const IOCM_DTR = 0x2; pub const IOCM_LE = 0x1; pub const IOCM_RI = 0x80; pub const IOCM_RNG = 0x80; pub const IOCM_RTS = 0x4; pub const IOCM_SR = 0x10; pub const IOCM_ST = 0x8; pub const IOCNOTTY = 0x20007471; pub const IOCNXCL = 0x2000740e; pub const IOCOUTQ = 0x40047473; pub const IOCPKT = 0x80047470; pub const IOCPKT_DATA = 0x0; pub const IOCPKT_DOSTOP = 0x20; pub const IOCPKT_FLUSHREAD = 0x1; pub const IOCPKT_FLUSHWRITE = 0x2; pub const IOCPKT_IOCTL = 0x40; pub const IOCPKT_NOSTOP = 0x10; pub const IOCPKT_START = 0x8; pub const IOCPKT_STOP = 0x4; pub const IOCPTMGET = 0x40287446; pub const IOCPTSNAME = 0x40287448; pub const IOCRCVFRAME = 0x80087445; pub const IOCREMOTE = 0x80047469; pub const IOCSBRK = 0x2000747b; pub const IOCSCTTY = 0x20007461; pub const IOCSDTR = 0x20007479; pub const IOCSETA = 0x802c7414; pub const IOCSETAF = 0x802c7416; pub const IOCSETAW = 0x802c7415; pub const IOCSETD = 0x8004741b; pub const IOCSFLAGS = 0x8004745c; pub const IOCSIG = 0x2000745f; pub const IOCSLINED = 0x80207443; pub const IOCSPGRP = 0x80047476; pub const IOCSQSIZE = 0x80047480; pub const IOCSSIZE = 0x80087467; pub const IOCSTART = 0x2000746e; pub const IOCSTAT = 0x80047465; pub const IOCSTI = 0x80017472; pub const IOCSTOP = 0x2000746f; pub const IOCSWINSZ = 0x80087467; pub const IOCUCNTL = 0x80047466; pub const IOCXMTFRAME = 0x80087444; }; // BSD Authentication |
auth_item_t |
pub const auth_item_t = c_int; |
AUTHV |
pub const AUTHV = struct { pub const ALL: auth_item_t = 0; pub const CHALLENGE: auth_item_t = 1; pub const CLASS: auth_item_t = 2; pub const NAME: auth_item_t = 3; pub const SERVICE: auth_item_t = 4; pub const STYLE: auth_item_t = 5; pub const INTERACTIVE: auth_item_t = 6; }; |
BI |
pub const BI = struct { pub const AUTH = "authorize"; // Accepted authentication pub const REJECT = "reject"; // Rejected authentication pub const CHALLENGE = "reject challenge"; // Reject with a challenge pub const SILENT = "reject silent"; // Reject silently pub const REMOVE = "remove"; // remove file on error pub const ROOTOKAY = "authorize root"; // root authenticated pub const SECURE = "authorize secure"; // okay on non-secure line pub const SETENV = "setenv"; // set environment variable pub const UNSETENV = "unsetenv"; // unset environment variable pub const VALUE = "value"; // set local variable pub const EXPIRED = "reject expired"; // account expired pub const PWEXPIRED = "reject pwexpired"; // password expired pub const FDPASS = "fd"; // child is passing an fd }; |
AUTH |
pub const AUTH = struct { pub const OKAY: c_int = 0x01; // user authenticated pub const ROOTOKAY: c_int = 0x02; // authenticated as root pub const SECURE: c_int = 0x04; // secure login pub const SILENT: c_int = 0x08; // silent rejection pub const CHALLENGE: c_int = 0x10; // a challenge was given pub const EXPIRED: c_int = 0x20; // account expired pub const PWEXPIRED: c_int = 0x40; // password expired pub const ALLOW: c_int = (OKAY | ROOTOKAY | SECURE); }; // Term |
V |
pub const V = struct { pub const EOF = 0; // ICANON pub const EOL = 1; // ICANON pub const EOL2 = 2; // ICANON pub const ERASE = 3; // ICANON pub const WERASE = 4; // ICANON pub const KILL = 5; // ICANON pub const REPRINT = 6; // ICANON // 7 spare 1 pub const INTR = 8; // ISIG pub const QUIT = 9; // ISIG pub const SUSP = 10; // ISIG pub const DSUSP = 11; // ISIG pub const START = 12; // IXON, IXOFF pub const STOP = 13; // IXON, IXOFF pub const LNEXT = 14; // IEXTEN pub const DISCARD = 15; // IEXTEN pub const MIN = 16; // !ICANON pub const TIME = 17; // !ICANON pub const STATUS = 18; // ICANON // 19 spare 2 }; |
tcflag_t |
pub const tcflag_t = c_uint; |
speed_t |
pub const speed_t = c_uint; |
cc_t |
pub const cc_t = u8; |
NCCS |
pub const NCCS = 20; // Input flags - software input processing |
IGNBRK |
pub const IGNBRK: tcflag_t = 0x00000001; // ignore BREAK condition |
BRKINT |
pub const BRKINT: tcflag_t = 0x00000002; // map BREAK to SIGINT |
IGNPAR |
pub const IGNPAR: tcflag_t = 0x00000004; // ignore (discard) parity errors |
PARMRK |
pub const PARMRK: tcflag_t = 0x00000008; // mark parity and framing errors |
INPCK |
pub const INPCK: tcflag_t = 0x00000010; // enable checking of parity errors |
ISTRIP |
pub const ISTRIP: tcflag_t = 0x00000020; // strip 8th bit off chars |
INLCR |
pub const INLCR: tcflag_t = 0x00000040; // map NL into CR |
IGNCR |
pub const IGNCR: tcflag_t = 0x00000080; // ignore CR |
ICRNL |
pub const ICRNL: tcflag_t = 0x00000100; // map CR to NL (ala CRMOD) |
IXON |
pub const IXON: tcflag_t = 0x00000200; // enable output flow control |
IXOFF |
pub const IXOFF: tcflag_t = 0x00000400; // enable input flow control |
IXANY |
pub const IXANY: tcflag_t = 0x00000800; // any char will restart after stop |
IUCLC |
pub const IUCLC: tcflag_t = 0x00001000; // translate upper to lower case |
IMAXBEL |
pub const IMAXBEL: tcflag_t = 0x00002000; // ring bell on input queue full // Output flags - software output processing |
OPOST |
pub const OPOST: tcflag_t = 0x00000001; // enable following output processing |
ONLCR |
pub const ONLCR: tcflag_t = 0x00000002; // map NL to CR-NL (ala CRMOD) |
OXTABS |
pub const OXTABS: tcflag_t = 0x00000004; // expand tabs to spaces |
ONOEOT |
pub const ONOEOT: tcflag_t = 0x00000008; // discard EOT's (^D) on output |
OCRNL |
pub const OCRNL: tcflag_t = 0x00000010; // map CR to NL |
OLCUC |
pub const OLCUC: tcflag_t = 0x00000020; // translate lower case to upper case |
ONOCR |
pub const ONOCR: tcflag_t = 0x00000040; // No CR output at column 0 |
ONLRET |
pub const ONLRET: tcflag_t = 0x00000080; // NL performs the CR function // Control flags - hardware control of terminal |
CIGNORE |
pub const CIGNORE: tcflag_t = 0x00000001; // ignore control flags |
CSIZE |
pub const CSIZE: tcflag_t = 0x00000300; // character size mask |
CS5 |
pub const CS5: tcflag_t = 0x00000000; // 5 bits (pseudo) |
CS6 |
pub const CS6: tcflag_t = 0x00000100; // 6 bits |
CS7 |
pub const CS7: tcflag_t = 0x00000200; // 7 bits |
CS8 |
pub const CS8: tcflag_t = 0x00000300; // 8 bits |
CSTOPB |
pub const CSTOPB: tcflag_t = 0x00000400; // send 2 stop bits |
CREAD |
pub const CREAD: tcflag_t = 0x00000800; // enable receiver |
PARENB |
pub const PARENB: tcflag_t = 0x00001000; // parity enable |
PARODD |
pub const PARODD: tcflag_t = 0x00002000; // odd parity, else even |
HUPCL |
pub const HUPCL: tcflag_t = 0x00004000; // hang up on last close |
CLOCAL |
pub const CLOCAL: tcflag_t = 0x00008000; // ignore modem status lines |
CRTSCTS |
pub const CRTSCTS: tcflag_t = 0x00010000; // RTS/CTS full-duplex flow control |
CRTS_IFLOW |
pub const CRTS_IFLOW: tcflag_t = CRTSCTS; // XXX compat |
CCTS_OFLOW |
pub const CCTS_OFLOW: tcflag_t = CRTSCTS; // XXX compat |
MDMBUF |
pub const MDMBUF: tcflag_t = 0x00100000; // DTR/DCD hardware flow control |
CHWFLOW |
pub const CHWFLOW: tcflag_t = (MDMBUF | CRTSCTS); // all types of hw flow control |
termios |
pub const termios = extern struct { iflag: tcflag_t, // input flags oflag: tcflag_t, // output flags cflag: tcflag_t, // control flags lflag: tcflag_t, // local flags cc: [NCCS]cc_t, // control chars ispeed: c_int, // input speed ospeed: c_int, // output speed }; // Commands passed to tcsetattr() for setting the termios structure. |
TCSA |
pub const TCSA = struct { pub const NOW = 0; // make change immediate pub const DRAIN = 1; // drain output, then change pub const FLUSH = 2; // drain output, flush input pub const SOFT = 0x10; // flag - don't alter h.w. state }; // Standard speeds |
B0 |
pub const B0 = 0; |
B50 |
pub const B50 = 50; |
B75 |
pub const B75 = 75; |
B110 |
pub const B110 = 110; |
B134 |
pub const B134 = 134; |
B150 |
pub const B150 = 150; |
B200 |
pub const B200 = 200; |
B300 |
pub const B300 = 300; |
B600 |
pub const B600 = 600; |
B1200 |
pub const B1200 = 1200; |
B1800 |
pub const B1800 = 1800; |
B2400 |
pub const B2400 = 2400; |
B4800 |
pub const B4800 = 4800; |
B9600 |
pub const B9600 = 9600; |
B19200 |
pub const B19200 = 19200; |
B38400 |
pub const B38400 = 38400; |
B7200 |
pub const B7200 = 7200; |
B14400 |
pub const B14400 = 14400; |
B28800 |
pub const B28800 = 28800; |
B57600 |
pub const B57600 = 57600; |
B76800 |
pub const B76800 = 76800; |
B115200 |
pub const B115200 = 115200; |
B230400 |
pub const B230400 = 230400; |
EXTA |
pub const EXTA = 19200; |
EXTB |
pub const EXTB = 38400; |
TCIFLUSH |
pub const TCIFLUSH = 1; |
TCOFLUSH |
pub const TCOFLUSH = 2; |
TCIOFLUSH |
pub const TCIOFLUSH = 3; |
TCOOFF |
pub const TCOOFF = 1; |
TCOON |
pub const TCOON = 2; |
TCIOFF |
pub const TCIOFF = 3; |
TCION |
pub const TCION = 4; |
winsize |
pub const winsize = extern struct { ws_row: c_ushort, ws_col: c_ushort, ws_xpixel: c_ushort, ws_ypixel: c_ushort, }; const NSIG = 33; |
SIG |
pub const SIG = struct { pub const DFL = @as(?Sigaction.handler_fn, @ptrFromInt(0)); pub const IGN = @as(?Sigaction.handler_fn, @ptrFromInt(1)); pub const ERR = @as(?Sigaction.handler_fn, @ptrFromInt(maxInt(usize))); pub const CATCH = @as(?Sigaction.handler_fn, @ptrFromInt(2)); pub const HOLD = @as(?Sigaction.handler_fn, @ptrFromInt(3)); pub const HUP = 1; pub const INT = 2; pub const QUIT = 3; pub const ILL = 4; pub const TRAP = 5; pub const ABRT = 6; pub const IOT = ABRT; pub const EMT = 7; pub const FPE = 8; pub const KILL = 9; pub const BUS = 10; pub const SEGV = 11; pub const SYS = 12; pub const PIPE = 13; pub const ALRM = 14; pub const TERM = 15; pub const URG = 16; pub const STOP = 17; pub const TSTP = 18; pub const CONT = 19; pub const CHLD = 20; pub const TTIN = 21; pub const TTOU = 22; pub const IO = 23; pub const XCPU = 24; pub const XFSZ = 25; pub const VTALRM = 26; pub const PROF = 27; pub const WINCH = 28; pub const INFO = 29; pub const USR1 = 30; pub const USR2 = 31; pub const PWR = 32; pub const BLOCK = 1; pub const UNBLOCK = 2; pub const SETMASK = 3; }; |
Sigaction Renamed from |
pub const Sigaction = extern struct { pub const handler_fn = *const fn (c_int) align(1) callconv(.C) void; pub const sigaction_fn = *const fn (c_int, *const siginfo_t, ?*const anyopaque) callconv(.C) void; handler: extern union { handler: ?handler_fn, sigaction: ?sigaction_fn, }, mask: sigset_t, flags: c_uint, }; |
sigvalsignal handler signal mask to apply signal options |
pub const sigval = extern union { int: c_int, ptr: ?*anyopaque, }; |
siginfo_t |
pub const siginfo_t = extern struct { signo: c_int, code: c_int, errno: c_int, data: extern union { proc: extern struct { pid: pid_t, pdata: extern union { kill: extern struct { uid: uid_t, value: sigval, }, cld: extern struct { utime: clock_t, stime: clock_t, status: c_int, }, }, }, fault: extern struct { addr: ?*anyopaque, trapno: c_int, }, __pad: [128 - 3 * @sizeOf(c_int)]u8, }, }; comptime { if (@sizeOf(usize) == 4) std.debug.assert(@sizeOf(siginfo_t) == 128) else // Take into account the padding between errno and data fields. std.debug.assert(@sizeOf(siginfo_t) == 136); } pub usingnamespace switch (builtin.cpu.arch) { .x86_64 => struct {}, else => struct {}, }; |
ucontext_t |
pub const ucontext_t = switch (builtin.cpu.arch) { .x86_64 => extern struct { sc_rdi: c_long, sc_rsi: c_long, sc_rdx: c_long, sc_rcx: c_long, sc_r8: c_long, sc_r9: c_long, sc_r10: c_long, sc_r11: c_long, sc_r12: c_long, sc_r13: c_long, sc_r14: c_long, sc_r15: c_long, sc_rbp: c_long, sc_rbx: c_long, sc_rax: c_long, sc_gs: c_long, sc_fs: c_long, sc_es: c_long, sc_ds: c_long, sc_trapno: c_long, sc_err: c_long, sc_rip: c_long, sc_cs: c_long, sc_rflags: c_long, sc_rsp: c_long, sc_ss: c_long, sc_fpstate: *anyopaque, // struct fxsave64 * __sc_unused: c_int, sc_mask: c_int, sc_cookie: c_long, }, .aarch64 => extern struct { __sc_unused: c_int, sc_mask: c_int, sc_sp: c_ulong, sc_lr: c_ulong, sc_elr: c_ulong, sc_spsr: c_ulong, sc_x: [30]c_ulong, sc_cookie: c_long, }, else => @compileError("missing ucontext_t type definition"), }; |
sigset_t |
pub const sigset_t = c_uint; |
empty_sigset |
pub const empty_sigset: sigset_t = 0; |
E |
pub const E = enum(u16) { SUCCESS = 0, PERM = 1, // Operation not permitted NOENT = 2, // No such file or directory SRCH = 3, // No such process INTR = 4, // Interrupted system call IO = 5, // Input/output error NXIO = 6, // Device not configured @"2BIG" = 7, // Argument list too long NOEXEC = 8, // Exec format error BADF = 9, // Bad file descriptor CHILD = 10, // No child processes DEADLK = 11, // Resource deadlock avoided // 11 was AGAIN NOMEM = 12, // Cannot allocate memory ACCES = 13, // Permission denied FAULT = 14, // Bad address NOTBLK = 15, // Block device required BUSY = 16, // Device busy EXIST = 17, // File exists XDEV = 18, // Cross-device link NODEV = 19, // Operation not supported by device NOTDIR = 20, // Not a directory ISDIR = 21, // Is a directory INVAL = 22, // Invalid argument NFILE = 23, // Too many open files in system MFILE = 24, // Too many open files NOTTY = 25, // Inappropriate ioctl for device TXTBSY = 26, // Text file busy FBIG = 27, // File too large NOSPC = 28, // No space left on device SPIPE = 29, // Illegal seek ROFS = 30, // Read-only file system MLINK = 31, // Too many links PIPE = 32, // Broken pipe // math software DOM = 33, // Numerical argument out of domain RANGE = 34, // Result too large or too small // non-blocking and interrupt i/o // also: WOULDBLOCK: operation would block AGAIN = 35, // Resource temporarily unavailable INPROGRESS = 36, // Operation now in progress ALREADY = 37, // Operation already in progress // ipc/network software -- argument errors NOTSOCK = 38, // Socket operation on non-socket DESTADDRREQ = 39, // Destination address required MSGSIZE = 40, // Message too long PROTOTYPE = 41, // Protocol wrong type for socket NOPROTOOPT = 42, // Protocol option not available PROTONOSUPPORT = 43, // Protocol not supported SOCKTNOSUPPORT = 44, // Socket type not supported OPNOTSUPP = 45, // Operation not supported PFNOSUPPORT = 46, // Protocol family not supported AFNOSUPPORT = 47, // Address family not supported by protocol family ADDRINUSE = 48, // Address already in use ADDRNOTAVAIL = 49, // Can't assign requested address // ipc/network software -- operational errors NETDOWN = 50, // Network is down NETUNREACH = 51, // Network is unreachable NETRESET = 52, // Network dropped connection on reset CONNABORTED = 53, // Software caused connection abort CONNRESET = 54, // Connection reset by peer NOBUFS = 55, // No buffer space available ISCONN = 56, // Socket is already connected NOTCONN = 57, // Socket is not connected SHUTDOWN = 58, // Can't send after socket shutdown TOOMANYREFS = 59, // Too many references: can't splice TIMEDOUT = 60, // Operation timed out CONNREFUSED = 61, // Connection refused LOOP = 62, // Too many levels of symbolic links NAMETOOLONG = 63, // File name too long // should be rearranged HOSTDOWN = 64, // Host is down HOSTUNREACH = 65, // No route to host NOTEMPTY = 66, // Directory not empty // quotas & mush PROCLIM = 67, // Too many processes USERS = 68, // Too many users DQUOT = 69, // Disc quota exceeded // Network File System STALE = 70, // Stale NFS file handle REMOTE = 71, // Too many levels of remote in path BADRPC = 72, // RPC struct is bad RPCMISMATCH = 73, // RPC version wrong PROGUNAVAIL = 74, // RPC prog. not avail PROGMISMATCH = 75, // Program version wrong PROCUNAVAIL = 76, // Bad procedure for program NOLCK = 77, // No locks available NOSYS = 78, // Function not implemented FTYPE = 79, // Inappropriate file type or format AUTH = 80, // Authentication error NEEDAUTH = 81, // Need authenticator IPSEC = 82, // IPsec processing failure NOATTR = 83, // Attribute not found // Wide/multibyte-character handling, ISO/IEC 9899/AMD1:1995 ILSEQ = 84, // Illegal byte sequence NOMEDIUM = 85, // No medium found MEDIUMTYPE = 86, // Wrong medium type OVERFLOW = 87, // Value too large to be stored in data type CANCELED = 88, // Operation canceled IDRM = 89, // Identifier removed NOMSG = 90, // No message of desired type NOTSUP = 91, // Not supported BADMSG = 92, // Bad or Corrupt message NOTRECOVERABLE = 93, // State not recoverable OWNERDEAD = 94, // Previous owner died PROTO = 95, // Protocol error _, }; const _MAX_PAGE_SHIFT = switch (builtin.cpu.arch) { .x86 => 12, .sparc64 => 13, }; |
MINSIGSTKSZNo error occurred. |
pub const MINSIGSTKSZ = 1 << _MAX_PAGE_SHIFT; |
SIGSTKSZ |
pub const SIGSTKSZ = MINSIGSTKSZ + (1 << _MAX_PAGE_SHIFT) * 4; |
SS_ONSTACK |
pub const SS_ONSTACK = 0x0001; |
SS_DISABLE |
pub const SS_DISABLE = 0x0004; |
stack_t |
pub const stack_t = extern struct { sp: [*]u8, size: usize, flags: c_int, }; |
S |
pub const S = struct { pub const IFMT = 0o170000; pub const IFIFO = 0o010000; pub const IFCHR = 0o020000; pub const IFDIR = 0o040000; pub const IFBLK = 0o060000; pub const IFREG = 0o100000; pub const IFLNK = 0o120000; pub const IFSOCK = 0o140000; pub const ISUID = 0o4000; pub const ISGID = 0o2000; pub const ISVTX = 0o1000; pub const IRWXU = 0o700; pub const IRUSR = 0o400; pub const IWUSR = 0o200; pub const IXUSR = 0o100; pub const IRWXG = 0o070; pub const IRGRP = 0o040; pub const IWGRP = 0o020; pub const IXGRP = 0o010; pub const IRWXO = 0o007; pub const IROTH = 0o004; pub const IWOTH = 0o002; pub const IXOTH = 0o001; |
ISFIFO() |
pub fn ISFIFO(m: u32) bool { return m & IFMT == IFIFO; } |
ISCHR() |
pub fn ISCHR(m: u32) bool { return m & IFMT == IFCHR; } |
ISDIR() |
pub fn ISDIR(m: u32) bool { return m & IFMT == IFDIR; } |
ISBLK() |
pub fn ISBLK(m: u32) bool { return m & IFMT == IFBLK; } |
ISREG() |
pub fn ISREG(m: u32) bool { return m & IFMT == IFREG; } |
ISLNK() |
pub fn ISLNK(m: u32) bool { return m & IFMT == IFLNK; } |
ISSOCK() |
pub fn ISSOCK(m: u32) bool { return m & IFMT == IFSOCK; } }; |
AT |
pub const AT = struct { pub const FDCWD = -100; pub const EACCESS = 0x01; pub const SYMLINK_NOFOLLOW = 0x02; pub const SYMLINK_FOLLOW = 0x04; pub const REMOVEDIR = 0x08; }; |
HOST_NAME_MAXMagic value that specify the use of the current working directory to determine the target of relative file paths in the openat() and similar syscalls. Check access using effective user and group ID Do not follow symbolic links Follow symbolic link Remove directory instead of file |
pub const HOST_NAME_MAX = 255; |
IPPROTO |
pub const IPPROTO = struct { pub const IP = 0; pub const HOPOPTS = IP; pub const ICMP = 1; pub const IGMP = 2; pub const GGP = 3; pub const IPV4 = IPIP; pub const IPIP = 4; pub const TCP = 6; pub const EGP = 8; pub const PUP = 12; pub const UDP = 17; pub const IDP = 22; pub const TP = 29; pub const IPV6 = 41; pub const ROUTING = 43; pub const FRAGMENT = 44; pub const RSVP = 46; pub const GRE = 47; pub const ESP = 50; pub const AH = 51; pub const MOBILE = 55; pub const IPV6_ICMP = 58; pub const ICMPV6 = 58; pub const NONE = 59; pub const DSTOPTS = 60; pub const EON = 80; pub const ETHERIP = 97; pub const ENCAP = 98; pub const PIM = 103; pub const IPCOMP = 108; pub const VRRP = 112; pub const CARP = 112; pub const PFSYNC = 240; pub const RAW = 255; }; |
rlimit_resourcedummy for IP IP6 hop-by-hop options control message protocol group mgmt protocol gateway^2 (deprecated) IP header IP inside IP tcp exterior gateway protocol pup user datagram protocol xns idp tp-4 w/ class negotiation IP6 header IP6 routing header IP6 fragmentation header resource reservation GRE encaps RFC 1701 encap. security payload authentication header IP Mobility RFC 2004 IPv6 ICMP ICMP6 IP6 no next header IP6 destination option ISO cnlp Ethernet-in-IP encapsulation header Protocol indep. multicast IP Payload Comp. Protocol VRRP RFC 2338 Common Address Resolution Protocol PFSYNC raw IP packet |
pub const rlimit_resource = enum(c_int) { CPU, FSIZE, DATA, STACK, CORE, RSS, MEMLOCK, NPROC, NOFILE, _, }; |
rlim_t |
pub const rlim_t = u64; |
RLIM |
pub const RLIM = struct { pub const INFINITY: rlim_t = (1 << 63) - 1; pub const SAVED_MAX = INFINITY; pub const SAVED_CUR = INFINITY; }; |
rlimitNo limit |
pub const rlimit = extern struct { cur: rlim_t, max: rlim_t, }; |
SHUTSoft limit Hard limit |
pub const SHUT = struct { pub const RD = 0; pub const WR = 1; pub const RDWR = 2; }; |
nfds_t |
pub const nfds_t = c_uint; |
pollfd |
pub const pollfd = extern struct { fd: fd_t, events: c_short, revents: c_short, }; |
POLL |
pub const POLL = struct { pub const IN = 0x0001; pub const PRI = 0x0002; pub const OUT = 0x0004; pub const ERR = 0x0008; pub const HUP = 0x0010; pub const NVAL = 0x0020; pub const RDNORM = 0x0040; pub const NORM = RDNORM; pub const WRNORM = OUT; pub const RDBAND = 0x0080; pub const WRBAND = 0x0100; }; |
CTL |
pub const CTL = struct { pub const UNSPEC = 0; pub const KERN = 1; pub const VM = 2; pub const FS = 3; pub const NET = 4; pub const DEBUG = 5; pub const HW = 6; pub const MACHDEP = 7; pub const DDB = 9; pub const VFS = 10; }; |
KERN |
pub const KERN = struct { pub const OSTYPE = 1; pub const OSRELEASE = 2; pub const OSREV = 3; pub const VERSION = 4; pub const MAXVNODES = 5; pub const MAXPROC = 6; pub const MAXFILES = 7; pub const ARGMAX = 8; pub const SECURELVL = 9; pub const HOSTNAME = 10; pub const HOSTID = 11; pub const CLOCKRATE = 12; pub const PROF = 16; pub const POSIX1 = 17; pub const NGROUPS = 18; pub const JOB_CONTROL = 19; pub const SAVED_IDS = 20; pub const BOOTTIME = 21; pub const DOMAINNAME = 22; pub const MAXPARTITIONS = 23; pub const RAWPARTITION = 24; pub const MAXTHREAD = 25; pub const NTHREADS = 26; pub const OSVERSION = 27; pub const SOMAXCONN = 28; pub const SOMINCONN = 29; pub const NOSUIDCOREDUMP = 32; pub const FSYNC = 33; pub const SYSVMSG = 34; pub const SYSVSEM = 35; pub const SYSVSHM = 36; pub const MSGBUFSIZE = 38; pub const MALLOCSTATS = 39; pub const CPTIME = 40; pub const NCHSTATS = 41; pub const FORKSTAT = 42; pub const NSELCOLL = 43; pub const TTY = 44; pub const CCPU = 45; pub const FSCALE = 46; pub const NPROCS = 47; pub const MSGBUF = 48; pub const POOL = 49; pub const STACKGAPRANDOM = 50; pub const SYSVIPC_INFO = 51; pub const ALLOWKMEM = 52; pub const WITNESSWATCH = 53; pub const SPLASSERT = 54; pub const PROC_ARGS = 55; pub const NFILES = 56; pub const TTYCOUNT = 57; pub const NUMVNODES = 58; pub const MBSTAT = 59; pub const WITNESS = 60; pub const SEMINFO = 61; pub const SHMINFO = 62; pub const INTRCNT = 63; pub const WATCHDOG = 64; pub const ALLOWDT = 65; pub const PROC = 66; pub const MAXCLUSTERS = 67; pub const EVCOUNT = 68; pub const TIMECOUNTER = 69; pub const MAXLOCKSPERUID = 70; pub const CPTIME2 = 71; pub const CACHEPCT = 72; pub const FILE = 73; pub const WXABORT = 74; pub const CONSDEV = 75; pub const NETLIVELOCKS = 76; pub const POOL_DEBUG = 77; pub const PROC_CWD = 78; pub const PROC_NOBROADCASTKILL = 79; pub const PROC_VMMAP = 80; pub const GLOBAL_PTRACE = 81; pub const CONSBUFSIZE = 82; pub const CONSBUF = 83; pub const AUDIO = 84; pub const CPUSTATS = 85; pub const PFSTATUS = 86; pub const TIMEOUT_STATS = 87; pub const UTC_OFFSET = 88; pub const VIDEO = 89; pub const PROC_ALL = 0; pub const PROC_PID = 1; pub const PROC_PGRP = 2; pub const PROC_SESSION = 3; pub const PROC_TTY = 4; pub const PROC_UID = 5; pub const PROC_RUID = 6; pub const PROC_KTHREAD = 7; pub const PROC_SHOW_THREADS = 0x40000000; pub const PROC_ARGV = 1; pub const PROC_NARGV = 2; pub const PROC_ENV = 3; pub const PROC_NENV = 4; }; |
HW |
pub const HW = struct { pub const MACHINE = 1; pub const MODEL = 2; pub const NCPU = 3; pub const BYTEORDER = 4; pub const PHYSMEM = 5; pub const USERMEM = 6; pub const PAGESIZE = 7; pub const DISKNAMES = 8; pub const DISKSTATS = 9; pub const DISKCOUNT = 10; pub const SENSORS = 11; pub const CPUSPEED = 12; pub const SETPERF = 13; pub const VENDOR = 14; pub const PRODUCT = 15; pub const VERSION = 16; pub const SERIALNO = 17; pub const UUID = 18; pub const PHYSMEM64 = 19; pub const USERMEM64 = 20; pub const NCPUFOUND = 21; pub const ALLOWPOWERDOWN = 22; pub const PERFPOLICY = 23; pub const SMT = 24; pub const NCPUONLINE = 25; pub const POWER = 26; }; |
PTHREAD_STACK_MIN |
pub const PTHREAD_STACK_MIN = switch (builtin.cpu.arch) { .sparc64 => 1 << 13, .mips64 => 1 << 14, else => 1 << 12, }; |
Generated by zstd-browse2 on 2023-11-04 14:12:15 -0400. |