aboutsummaryrefslogtreecommitdiff
path: root/lib/std/os/bits/linux.zig
diff options
context:
space:
mode:
authorAndrew Kelley <andrew@ziglang.org>2021-09-15 14:46:31 -0700
committerAndrew Kelley <andrew@ziglang.org>2021-09-15 14:51:08 -0700
commitf3ebfcae3882c03da84821abed40167ea07a8c78 (patch)
treef1b759c94cba5b020a9ffb141fc62cb686fc5f04 /lib/std/os/bits/linux.zig
parent111a2dcf3ad53c0c8ad2c9e7c9bd042b81e90c82 (diff)
parent0395b35cee8d4082cc40b0dcd0298f797f42309d (diff)
downloadzig-f3ebfcae3882c03da84821abed40167ea07a8c78.tar.gz
zig-f3ebfcae3882c03da84821abed40167ea07a8c78.zip
Merge remote-tracking branch 'origin/master' into llvm13
Conflicts: * cmake/Findclang.cmake * cmake/Findlld.cmake * cmake/Findllvm.cmake In master branch, more search paths were added to these files with "12" in the path. In this commit I updated them to "13". * src/stage1/codegen.cpp * src/zig_llvm.cpp * src/zig_llvm.h In master branch, ZigLLVMBuildCmpXchg is improved to add `is_single_threaded`. However, the LLVM 13 C API has this already, and in the llvm13 branch, ZigLLVMBuildCmpXchg is deleted in favor of the C API. In this commit I updated stage2 to use the LLVM 13 C API rather than depending on an improved ZigLLVMBuildCmpXchg. Additionally, src/target.zig largestAtomicBits needed to be updated to include the new m68k ISA.
Diffstat (limited to 'lib/std/os/bits/linux.zig')
-rw-r--r--lib/std/os/bits/linux.zig2455
1 files changed, 0 insertions, 2455 deletions
diff --git a/lib/std/os/bits/linux.zig b/lib/std/os/bits/linux.zig
deleted file mode 100644
index 653fb8f1e1..0000000000
--- a/lib/std/os/bits/linux.zig
+++ /dev/null
@@ -1,2455 +0,0 @@
-const std = @import("../../std.zig");
-const maxInt = std.math.maxInt;
-const arch = @import("builtin").target.cpu.arch;
-pub usingnamespace @import("posix.zig");
-
-pub const E = switch (arch) {
- .mips, .mipsel => @import("linux/errno/mips.zig").E,
- .sparc, .sparcel, .sparcv9 => @import("linux/errno/sparc.zig").E,
- else => @import("linux/errno/generic.zig").E,
-};
-
-pub usingnamespace switch (arch) {
- .i386 => @import("linux/i386.zig"),
- .x86_64 => @import("linux/x86_64.zig"),
- .aarch64 => @import("linux/arm64.zig"),
- .arm, .thumb => @import("linux/arm-eabi.zig"),
- .riscv64 => @import("linux/riscv64.zig"),
- .sparcv9 => @import("linux/sparc64.zig"),
- .mips, .mipsel => @import("linux/mips.zig"),
- .powerpc => @import("linux/powerpc.zig"),
- .powerpc64, .powerpc64le => @import("linux/powerpc64.zig"),
- else => struct {},
-};
-
-pub usingnamespace @import("linux/netlink.zig");
-pub usingnamespace @import("linux/prctl.zig");
-pub usingnamespace @import("linux/securebits.zig");
-pub usingnamespace @import("linux/xdp.zig");
-
-const is_mips = arch.isMIPS();
-const is_ppc = arch.isPPC();
-const is_ppc64 = arch.isPPC64();
-const is_sparc = arch.isSPARC();
-
-pub const pid_t = i32;
-pub const fd_t = i32;
-pub const uid_t = u32;
-pub const gid_t = u32;
-pub const clock_t = isize;
-
-pub const NAME_MAX = 255;
-pub const PATH_MAX = 4096;
-pub const IOV_MAX = 1024;
-
-/// Largest hardware address length
-/// e.g. a mac address is a type of hardware address
-pub const MAX_ADDR_LEN = 32;
-
-pub const STDIN_FILENO = 0;
-pub const STDOUT_FILENO = 1;
-pub const STDERR_FILENO = 2;
-
-/// Special value used to indicate openat should use the current working directory
-pub const AT_FDCWD = -100;
-
-/// Do not follow symbolic links
-pub const AT_SYMLINK_NOFOLLOW = 0x100;
-
-/// Remove directory instead of unlinking file
-pub const AT_REMOVEDIR = 0x200;
-
-/// Follow symbolic links.
-pub const AT_SYMLINK_FOLLOW = 0x400;
-
-/// Suppress terminal automount traversal
-pub const AT_NO_AUTOMOUNT = 0x800;
-
-/// Allow empty relative pathname
-pub const AT_EMPTY_PATH = 0x1000;
-
-/// Type of synchronisation required from statx()
-pub const AT_STATX_SYNC_TYPE = 0x6000;
-
-/// - Do whatever stat() does
-pub const AT_STATX_SYNC_AS_STAT = 0x0000;
-
-/// - Force the attributes to be sync'd with the server
-pub const AT_STATX_FORCE_SYNC = 0x2000;
-
-/// - Don't sync attributes with the server
-pub const AT_STATX_DONT_SYNC = 0x4000;
-
-/// Apply to the entire subtree
-pub const AT_RECURSIVE = 0x8000;
-
-/// Default is extend size
-pub const FALLOC_FL_KEEP_SIZE = 0x01;
-
-/// De-allocates range
-pub const FALLOC_FL_PUNCH_HOLE = 0x02;
-
-/// Reserved codepoint
-pub const FALLOC_FL_NO_HIDE_STALE = 0x04;
-
-/// Removes a range of a file without leaving a hole in the file
-pub const FALLOC_FL_COLLAPSE_RANGE = 0x08;
-
-/// Converts a range of file to zeros preferably without issuing data IO
-pub const FALLOC_FL_ZERO_RANGE = 0x10;
-
-/// Inserts space within the file size without overwriting any existing data
-pub const FALLOC_FL_INSERT_RANGE = 0x20;
-
-/// Unshares shared blocks within the file size without overwriting any existing data
-pub const FALLOC_FL_UNSHARE_RANGE = 0x40;
-
-pub const FUTEX_WAIT = 0;
-pub const FUTEX_WAKE = 1;
-pub const FUTEX_FD = 2;
-pub const FUTEX_REQUEUE = 3;
-pub const FUTEX_CMP_REQUEUE = 4;
-pub const FUTEX_WAKE_OP = 5;
-pub const FUTEX_LOCK_PI = 6;
-pub const FUTEX_UNLOCK_PI = 7;
-pub const FUTEX_TRYLOCK_PI = 8;
-pub const FUTEX_WAIT_BITSET = 9;
-pub const FUTEX_WAKE_BITSET = 10;
-pub const FUTEX_WAIT_REQUEUE_PI = 11;
-pub const FUTEX_CMP_REQUEUE_PI = 12;
-
-pub const FUTEX_PRIVATE_FLAG = 128;
-
-pub const FUTEX_CLOCK_REALTIME = 256;
-
-/// page can not be accessed
-pub const PROT_NONE = 0x0;
-
-/// page can be read
-pub const PROT_READ = 0x1;
-
-/// page can be written
-pub const PROT_WRITE = 0x2;
-
-/// page can be executed
-pub const PROT_EXEC = 0x4;
-
-/// page may be used for atomic ops
-pub const PROT_SEM = switch (arch) {
- // TODO: also xtensa
- .mips, .mipsel, .mips64, .mips64el => 0x10,
- else => 0x8,
-};
-
-/// mprotect flag: extend change to start of growsdown vma
-pub const PROT_GROWSDOWN = 0x01000000;
-
-/// mprotect flag: extend change to end of growsup vma
-pub const PROT_GROWSUP = 0x02000000;
-
-/// Share changes
-pub const MAP_SHARED = 0x01;
-
-/// Changes are private
-pub const MAP_PRIVATE = 0x02;
-
-/// share + validate extension flags
-pub const MAP_SHARED_VALIDATE = 0x03;
-
-/// Mask for type of mapping
-pub const MAP_TYPE = 0x0f;
-
-/// Interpret addr exactly
-pub const MAP_FIXED = 0x10;
-
-/// don't use a file
-pub const MAP_ANONYMOUS = if (is_mips) 0x800 else 0x20;
-
-// MAP_ 0x0100 - 0x4000 flags are per architecture
-
-/// populate (prefault) pagetables
-pub const MAP_POPULATE = if (is_mips) 0x10000 else 0x8000;
-
-/// do not block on IO
-pub const MAP_NONBLOCK = if (is_mips) 0x20000 else 0x10000;
-
-/// give out an address that is best suited for process/thread stacks
-pub const MAP_STACK = if (is_mips) 0x40000 else 0x20000;
-
-/// create a huge page mapping
-pub const MAP_HUGETLB = if (is_mips) 0x80000 else 0x40000;
-
-/// perform synchronous page faults for the mapping
-pub const MAP_SYNC = 0x80000;
-
-/// MAP_FIXED which doesn't unmap underlying mapping
-pub const MAP_FIXED_NOREPLACE = 0x100000;
-
-/// For anonymous mmap, memory could be uninitialized
-pub const MAP_UNINITIALIZED = 0x4000000;
-
-pub const FD_CLOEXEC = 1;
-
-pub const F_OK = 0;
-pub const X_OK = 1;
-pub const W_OK = 2;
-pub const R_OK = 4;
-
-pub const WNOHANG = 1;
-pub const WUNTRACED = 2;
-pub const WSTOPPED = 2;
-pub const WEXITED = 4;
-pub const WCONTINUED = 8;
-pub const WNOWAIT = 0x1000000;
-
-// waitid id types
-pub const P = enum(c_uint) {
- ALL = 0,
- PID = 1,
- PGID = 2,
- PIDFD = 3,
- _,
-};
-
-pub usingnamespace if (is_mips)
- struct {
- pub const SA_NOCLDSTOP = 1;
- pub const SA_NOCLDWAIT = 0x10000;
- pub const SA_SIGINFO = 8;
- pub const SA_RESTART = 0x10000000;
- pub const SA_RESETHAND = 0x80000000;
- pub const SA_ONSTACK = 0x08000000;
- pub const SA_NODEFER = 0x40000000;
- pub const SA_RESTORER = 0x04000000;
-
- pub const SIG_BLOCK = 1;
- pub const SIG_UNBLOCK = 2;
- pub const SIG_SETMASK = 3;
- }
-else if (is_sparc)
- struct {
- pub const SA_NOCLDSTOP = 0x8;
- pub const SA_NOCLDWAIT = 0x100;
- pub const SA_SIGINFO = 0x200;
- pub const SA_RESTART = 0x2;
- pub const SA_RESETHAND = 0x4;
- pub const SA_ONSTACK = 0x1;
- pub const SA_NODEFER = 0x20;
- pub const SA_RESTORER = 0x04000000;
-
- pub const SIG_BLOCK = 1;
- pub const SIG_UNBLOCK = 2;
- pub const SIG_SETMASK = 4;
- }
-else
- struct {
- pub const SA_NOCLDSTOP = 1;
- pub const SA_NOCLDWAIT = 2;
- pub const SA_SIGINFO = 4;
- pub const SA_RESTART = 0x10000000;
- pub const SA_RESETHAND = 0x80000000;
- pub const SA_ONSTACK = 0x08000000;
- pub const SA_NODEFER = 0x40000000;
- pub const SA_RESTORER = 0x04000000;
-
- pub const SIG_BLOCK = 0;
- pub const SIG_UNBLOCK = 1;
- pub const SIG_SETMASK = 2;
- };
-
-pub usingnamespace if (is_sparc) struct {
- pub const SIGHUP = 1;
- pub const SIGINT = 2;
- pub const SIGQUIT = 3;
- pub const SIGILL = 4;
- pub const SIGTRAP = 5;
- pub const SIGABRT = 6;
- pub const SIGEMT = 7;
- pub const SIGFPE = 8;
- pub const SIGKILL = 9;
- pub const SIGBUS = 10;
- pub const SIGSEGV = 11;
- pub const SIGSYS = 12;
- pub const SIGPIPE = 13;
- pub const SIGALRM = 14;
- pub const SIGTERM = 15;
- pub const SIGURG = 16;
- pub const SIGSTOP = 17;
- pub const SIGTSTP = 18;
- pub const SIGCONT = 19;
- pub const SIGCHLD = 20;
- pub const SIGTTIN = 21;
- pub const SIGTTOU = 22;
- pub const SIGPOLL = 23;
- pub const SIGXCPU = 24;
- pub const SIGXFSZ = 25;
- pub const SIGVTALRM = 26;
- pub const SIGPROF = 27;
- pub const SIGWINCH = 28;
- pub const SIGLOST = 29;
- pub const SIGUSR1 = 30;
- pub const SIGUSR2 = 31;
- pub const SIGIOT = SIGABRT;
- pub const SIGCLD = SIGCHLD;
- pub const SIGPWR = SIGLOST;
- pub const SIGIO = SIGPOLL;
-} else struct {
- pub const SIGHUP = 1;
- pub const SIGINT = 2;
- pub const SIGQUIT = 3;
- pub const SIGILL = 4;
- pub const SIGTRAP = 5;
- pub const SIGABRT = 6;
- pub const SIGIOT = SIGABRT;
- pub const SIGBUS = 7;
- pub const SIGFPE = 8;
- pub const SIGKILL = 9;
- pub const SIGUSR1 = 10;
- pub const SIGSEGV = 11;
- pub const SIGUSR2 = 12;
- pub const SIGPIPE = 13;
- pub const SIGALRM = 14;
- pub const SIGTERM = 15;
- pub const SIGSTKFLT = 16;
- pub const SIGCHLD = 17;
- pub const SIGCONT = 18;
- pub const SIGSTOP = 19;
- pub const SIGTSTP = 20;
- pub const SIGTTIN = 21;
- pub const SIGTTOU = 22;
- pub const SIGURG = 23;
- pub const SIGXCPU = 24;
- pub const SIGXFSZ = 25;
- pub const SIGVTALRM = 26;
- pub const SIGPROF = 27;
- pub const SIGWINCH = 28;
- pub const SIGIO = 29;
- pub const SIGPOLL = 29;
- pub const SIGPWR = 30;
- pub const SIGSYS = 31;
- pub const SIGUNUSED = SIGSYS;
-};
-
-pub const O_RDONLY = 0o0;
-pub const O_WRONLY = 0o1;
-pub const O_RDWR = 0o2;
-
-pub const kernel_rwf = u32;
-
-/// high priority request, poll if possible
-pub const RWF_HIPRI: kernel_rwf = 0x00000001;
-
-/// per-IO O_DSYNC
-pub const RWF_DSYNC: kernel_rwf = 0x00000002;
-
-/// per-IO O_SYNC
-pub const RWF_SYNC: kernel_rwf = 0x00000004;
-
-/// per-IO, return -EAGAIN if operation would block
-pub const RWF_NOWAIT: kernel_rwf = 0x00000008;
-
-/// per-IO O_APPEND
-pub const RWF_APPEND: kernel_rwf = 0x00000010;
-
-pub const SEEK_SET = 0;
-pub const SEEK_CUR = 1;
-pub const SEEK_END = 2;
-
-pub const SHUT_RD = 0;
-pub const SHUT_WR = 1;
-pub const SHUT_RDWR = 2;
-
-pub const SOCK_STREAM = if (is_mips) 2 else 1;
-pub const SOCK_DGRAM = if (is_mips) 1 else 2;
-pub const SOCK_RAW = 3;
-pub const SOCK_RDM = 4;
-pub const SOCK_SEQPACKET = 5;
-pub const SOCK_DCCP = 6;
-pub const SOCK_PACKET = 10;
-pub const SOCK_CLOEXEC = 0o2000000;
-pub const SOCK_NONBLOCK = if (is_mips) 0o200 else 0o4000;
-
-pub const PF_UNSPEC = 0;
-pub const PF_LOCAL = 1;
-pub const PF_UNIX = PF_LOCAL;
-pub const PF_FILE = PF_LOCAL;
-pub const PF_INET = 2;
-pub const PF_AX25 = 3;
-pub const PF_IPX = 4;
-pub const PF_APPLETALK = 5;
-pub const PF_NETROM = 6;
-pub const PF_BRIDGE = 7;
-pub const PF_ATMPVC = 8;
-pub const PF_X25 = 9;
-pub const PF_INET6 = 10;
-pub const PF_ROSE = 11;
-pub const PF_DECnet = 12;
-pub const PF_NETBEUI = 13;
-pub const PF_SECURITY = 14;
-pub const PF_KEY = 15;
-pub const PF_NETLINK = 16;
-pub const PF_ROUTE = PF_NETLINK;
-pub const PF_PACKET = 17;
-pub const PF_ASH = 18;
-pub const PF_ECONET = 19;
-pub const PF_ATMSVC = 20;
-pub const PF_RDS = 21;
-pub const PF_SNA = 22;
-pub const PF_IRDA = 23;
-pub const PF_PPPOX = 24;
-pub const PF_WANPIPE = 25;
-pub const PF_LLC = 26;
-pub const PF_IB = 27;
-pub const PF_MPLS = 28;
-pub const PF_CAN = 29;
-pub const PF_TIPC = 30;
-pub const PF_BLUETOOTH = 31;
-pub const PF_IUCV = 32;
-pub const PF_RXRPC = 33;
-pub const PF_ISDN = 34;
-pub const PF_PHONET = 35;
-pub const PF_IEEE802154 = 36;
-pub const PF_CAIF = 37;
-pub const PF_ALG = 38;
-pub const PF_NFC = 39;
-pub const PF_VSOCK = 40;
-pub const PF_KCM = 41;
-pub const PF_QIPCRTR = 42;
-pub const PF_SMC = 43;
-pub const PF_XDP = 44;
-pub const PF_MAX = 45;
-
-pub const AF_UNSPEC = PF_UNSPEC;
-pub const AF_LOCAL = PF_LOCAL;
-pub const AF_UNIX = AF_LOCAL;
-pub const AF_FILE = AF_LOCAL;
-pub const AF_INET = PF_INET;
-pub const AF_AX25 = PF_AX25;
-pub const AF_IPX = PF_IPX;
-pub const AF_APPLETALK = PF_APPLETALK;
-pub const AF_NETROM = PF_NETROM;
-pub const AF_BRIDGE = PF_BRIDGE;
-pub const AF_ATMPVC = PF_ATMPVC;
-pub const AF_X25 = PF_X25;
-pub const AF_INET6 = PF_INET6;
-pub const AF_ROSE = PF_ROSE;
-pub const AF_DECnet = PF_DECnet;
-pub const AF_NETBEUI = PF_NETBEUI;
-pub const AF_SECURITY = PF_SECURITY;
-pub const AF_KEY = PF_KEY;
-pub const AF_NETLINK = PF_NETLINK;
-pub const AF_ROUTE = PF_ROUTE;
-pub const AF_PACKET = PF_PACKET;
-pub const AF_ASH = PF_ASH;
-pub const AF_ECONET = PF_ECONET;
-pub const AF_ATMSVC = PF_ATMSVC;
-pub const AF_RDS = PF_RDS;
-pub const AF_SNA = PF_SNA;
-pub const AF_IRDA = PF_IRDA;
-pub const AF_PPPOX = PF_PPPOX;
-pub const AF_WANPIPE = PF_WANPIPE;
-pub const AF_LLC = PF_LLC;
-pub const AF_IB = PF_IB;
-pub const AF_MPLS = PF_MPLS;
-pub const AF_CAN = PF_CAN;
-pub const AF_TIPC = PF_TIPC;
-pub const AF_BLUETOOTH = PF_BLUETOOTH;
-pub const AF_IUCV = PF_IUCV;
-pub const AF_RXRPC = PF_RXRPC;
-pub const AF_ISDN = PF_ISDN;
-pub const AF_PHONET = PF_PHONET;
-pub const AF_IEEE802154 = PF_IEEE802154;
-pub const AF_CAIF = PF_CAIF;
-pub const AF_ALG = PF_ALG;
-pub const AF_NFC = PF_NFC;
-pub const AF_VSOCK = PF_VSOCK;
-pub const AF_KCM = PF_KCM;
-pub const AF_QIPCRTR = PF_QIPCRTR;
-pub const AF_SMC = PF_SMC;
-pub const AF_XDP = PF_XDP;
-pub const AF_MAX = PF_MAX;
-
-pub usingnamespace if (is_mips)
- struct {}
-else if (is_ppc or is_ppc64)
- struct {
- pub const SO_DEBUG = 1;
- pub const SO_REUSEADDR = 2;
- pub const SO_TYPE = 3;
- pub const SO_ERROR = 4;
- pub const SO_DONTROUTE = 5;
- pub const SO_BROADCAST = 6;
- pub const SO_SNDBUF = 7;
- pub const SO_RCVBUF = 8;
- pub const SO_KEEPALIVE = 9;
- pub const SO_OOBINLINE = 10;
- pub const SO_NO_CHECK = 11;
- pub const SO_PRIORITY = 12;
- pub const SO_LINGER = 13;
- pub const SO_BSDCOMPAT = 14;
- pub const SO_REUSEPORT = 15;
- pub const SO_RCVLOWAT = 16;
- pub const SO_SNDLOWAT = 17;
- pub const SO_RCVTIMEO = 18;
- pub const SO_SNDTIMEO = 19;
- pub const SO_PASSCRED = 20;
- pub const SO_PEERCRED = 21;
- pub const SO_ACCEPTCONN = 30;
- pub const SO_PEERSEC = 31;
- pub const SO_SNDBUFFORCE = 32;
- pub const SO_RCVBUFFORCE = 33;
- pub const SO_PROTOCOL = 38;
- pub const SO_DOMAIN = 39;
- }
-else
- struct {
- pub const SO_DEBUG = 1;
- pub const SO_REUSEADDR = 2;
- pub const SO_TYPE = 3;
- pub const SO_ERROR = 4;
- pub const SO_DONTROUTE = 5;
- pub const SO_BROADCAST = 6;
- pub const SO_SNDBUF = 7;
- pub const SO_RCVBUF = 8;
- pub const SO_KEEPALIVE = 9;
- pub const SO_OOBINLINE = 10;
- pub const SO_NO_CHECK = 11;
- pub const SO_PRIORITY = 12;
- pub const SO_LINGER = 13;
- pub const SO_BSDCOMPAT = 14;
- pub const SO_REUSEPORT = 15;
- pub const SO_PASSCRED = 16;
- pub const SO_PEERCRED = 17;
- pub const SO_RCVLOWAT = 18;
- pub const SO_SNDLOWAT = 19;
- pub const SO_RCVTIMEO = 20;
- pub const SO_SNDTIMEO = 21;
- pub const SO_ACCEPTCONN = 30;
- pub const SO_PEERSEC = 31;
- pub const SO_SNDBUFFORCE = 32;
- pub const SO_RCVBUFFORCE = 33;
- pub const SO_PROTOCOL = 38;
- pub const SO_DOMAIN = 39;
- };
-
-pub const SO_SECURITY_AUTHENTICATION = 22;
-pub const SO_SECURITY_ENCRYPTION_TRANSPORT = 23;
-pub const SO_SECURITY_ENCRYPTION_NETWORK = 24;
-
-pub const SO_BINDTODEVICE = 25;
-
-pub const SO_ATTACH_FILTER = 26;
-pub const SO_DETACH_FILTER = 27;
-pub const SO_GET_FILTER = SO_ATTACH_FILTER;
-
-pub const SO_PEERNAME = 28;
-pub const SO_TIMESTAMP_OLD = 29;
-pub const SO_PASSSEC = 34;
-pub const SO_TIMESTAMPNS_OLD = 35;
-pub const SO_MARK = 36;
-pub const SO_TIMESTAMPING_OLD = 37;
-
-pub const SO_RXQ_OVFL = 40;
-pub const SO_WIFI_STATUS = 41;
-pub const SCM_WIFI_STATUS = SO_WIFI_STATUS;
-pub const SO_PEEK_OFF = 42;
-pub const SO_NOFCS = 43;
-pub const SO_LOCK_FILTER = 44;
-pub const SO_SELECT_ERR_QUEUE = 45;
-pub const SO_BUSY_POLL = 46;
-pub const SO_MAX_PACING_RATE = 47;
-pub const SO_BPF_EXTENSIONS = 48;
-pub const SO_INCOMING_CPU = 49;
-pub const SO_ATTACH_BPF = 50;
-pub const SO_DETACH_BPF = SO_DETACH_FILTER;
-pub const SO_ATTACH_REUSEPORT_CBPF = 51;
-pub const SO_ATTACH_REUSEPORT_EBPF = 52;
-pub const SO_CNX_ADVICE = 53;
-pub const SCM_TIMESTAMPING_OPT_STATS = 54;
-pub const SO_MEMINFO = 55;
-pub const SO_INCOMING_NAPI_ID = 56;
-pub const SO_COOKIE = 57;
-pub const SCM_TIMESTAMPING_PKTINFO = 58;
-pub const SO_PEERGROUPS = 59;
-pub const SO_ZEROCOPY = 60;
-pub const SO_TXTIME = 61;
-pub const SCM_TXTIME = SO_TXTIME;
-pub const SO_BINDTOIFINDEX = 62;
-pub const SO_TIMESTAMP_NEW = 63;
-pub const SO_TIMESTAMPNS_NEW = 64;
-pub const SO_TIMESTAMPING_NEW = 65;
-pub const SO_RCVTIMEO_NEW = 66;
-pub const SO_SNDTIMEO_NEW = 67;
-pub const SO_DETACH_REUSEPORT_BPF = 68;
-
-pub const SOL_SOCKET = if (is_mips) 65535 else 1;
-
-pub const SOL_IP = 0;
-pub const SOL_IPV6 = 41;
-pub const SOL_ICMPV6 = 58;
-
-pub const SOL_RAW = 255;
-pub const SOL_DECNET = 261;
-pub const SOL_X25 = 262;
-pub const SOL_PACKET = 263;
-pub const SOL_ATM = 264;
-pub const SOL_AAL = 265;
-pub const SOL_IRDA = 266;
-pub const SOL_NETBEUI = 267;
-pub const SOL_LLC = 268;
-pub const SOL_DCCP = 269;
-pub const SOL_NETLINK = 270;
-pub const SOL_TIPC = 271;
-pub const SOL_RXRPC = 272;
-pub const SOL_PPPOL2TP = 273;
-pub const SOL_BLUETOOTH = 274;
-pub const SOL_PNPIPE = 275;
-pub const SOL_RDS = 276;
-pub const SOL_IUCV = 277;
-pub const SOL_CAIF = 278;
-pub const SOL_ALG = 279;
-pub const SOL_NFC = 280;
-pub const SOL_KCM = 281;
-pub const SOL_TLS = 282;
-pub const SOL_XDP = 283;
-
-pub const SOMAXCONN = 128;
-
-pub const IP_TOS = 1;
-pub const IP_TTL = 2;
-pub const IP_HDRINCL = 3;
-pub const IP_OPTIONS = 4;
-pub const IP_ROUTER_ALERT = 5;
-pub const IP_RECVOPTS = 6;
-pub const IP_RETOPTS = 7;
-pub const IP_PKTINFO = 8;
-pub const IP_PKTOPTIONS = 9;
-pub const IP_PMTUDISC = 10;
-pub const IP_MTU_DISCOVER = 10;
-pub const IP_RECVERR = 11;
-pub const IP_RECVTTL = 12;
-pub const IP_RECVTOS = 13;
-pub const IP_MTU = 14;
-pub const IP_FREEBIND = 15;
-pub const IP_IPSEC_POLICY = 16;
-pub const IP_XFRM_POLICY = 17;
-pub const IP_PASSSEC = 18;
-pub const IP_TRANSPARENT = 19;
-pub const IP_ORIGDSTADDR = 20;
-pub const IP_RECVORIGDSTADDR = IP_ORIGDSTADDR;
-pub const IP_MINTTL = 21;
-pub const IP_NODEFRAG = 22;
-pub const IP_CHECKSUM = 23;
-pub const IP_BIND_ADDRESS_NO_PORT = 24;
-pub const IP_RECVFRAGSIZE = 25;
-pub const IP_MULTICAST_IF = 32;
-pub const IP_MULTICAST_TTL = 33;
-pub const IP_MULTICAST_LOOP = 34;
-pub const IP_ADD_MEMBERSHIP = 35;
-pub const IP_DROP_MEMBERSHIP = 36;
-pub const IP_UNBLOCK_SOURCE = 37;
-pub const IP_BLOCK_SOURCE = 38;
-pub const IP_ADD_SOURCE_MEMBERSHIP = 39;
-pub const IP_DROP_SOURCE_MEMBERSHIP = 40;
-pub const IP_MSFILTER = 41;
-pub const IP_MULTICAST_ALL = 49;
-pub const IP_UNICAST_IF = 50;
-
-pub const IP_RECVRETOPTS = IP_RETOPTS;
-
-pub const IP_PMTUDISC_DONT = 0;
-pub const IP_PMTUDISC_WANT = 1;
-pub const IP_PMTUDISC_DO = 2;
-pub const IP_PMTUDISC_PROBE = 3;
-pub const IP_PMTUDISC_INTERFACE = 4;
-pub const IP_PMTUDISC_OMIT = 5;
-
-pub const IP_DEFAULT_MULTICAST_TTL = 1;
-pub const IP_DEFAULT_MULTICAST_LOOP = 1;
-pub const IP_MAX_MEMBERSHIPS = 20;
-
-// IPv6 socket options
-
-pub const IPV6_ADDRFORM = 1;
-pub const IPV6_2292PKTINFO = 2;
-pub const IPV6_2292HOPOPTS = 3;
-pub const IPV6_2292DSTOPTS = 4;
-pub const IPV6_2292RTHDR = 5;
-pub const IPV6_2292PKTOPTIONS = 6;
-pub const IPV6_CHECKSUM = 7;
-pub const IPV6_2292HOPLIMIT = 8;
-pub const IPV6_NEXTHOP = 9;
-pub const IPV6_AUTHHDR = 10;
-pub const IPV6_FLOWINFO = 11;
-
-pub const IPV6_UNICAST_HOPS = 16;
-pub const IPV6_MULTICAST_IF = 17;
-pub const IPV6_MULTICAST_HOPS = 18;
-pub const IPV6_MULTICAST_LOOP = 19;
-pub const IPV6_ADD_MEMBERSHIP = 20;
-pub const IPV6_DROP_MEMBERSHIP = 21;
-pub const IPV6_ROUTER_ALERT = 22;
-pub const IPV6_MTU_DISCOVER = 23;
-pub const IPV6_MTU = 24;
-pub const IPV6_RECVERR = 25;
-pub const IPV6_V6ONLY = 26;
-pub const IPV6_JOIN_ANYCAST = 27;
-pub const IPV6_LEAVE_ANYCAST = 28;
-
-// IPV6_MTU_DISCOVER values
-pub const IPV6_PMTUDISC_DONT = 0;
-pub const IPV6_PMTUDISC_WANT = 1;
-pub const IPV6_PMTUDISC_DO = 2;
-pub const IPV6_PMTUDISC_PROBE = 3;
-pub const IPV6_PMTUDISC_INTERFACE = 4;
-pub const IPV6_PMTUDISC_OMIT = 5;
-
-// Flowlabel
-pub const IPV6_FLOWLABEL_MGR = 32;
-pub const IPV6_FLOWINFO_SEND = 33;
-pub const IPV6_IPSEC_POLICY = 34;
-pub const IPV6_XFRM_POLICY = 35;
-pub const IPV6_HDRINCL = 36;
-
-// Advanced API (RFC3542) (1)
-pub const IPV6_RECVPKTINFO = 49;
-pub const IPV6_PKTINFO = 50;
-pub const IPV6_RECVHOPLIMIT = 51;
-pub const IPV6_HOPLIMIT = 52;
-pub const IPV6_RECVHOPOPTS = 53;
-pub const IPV6_HOPOPTS = 54;
-pub const IPV6_RTHDRDSTOPTS = 55;
-pub const IPV6_RECVRTHDR = 56;
-pub const IPV6_RTHDR = 57;
-pub const IPV6_RECVDSTOPTS = 58;
-pub const IPV6_DSTOPTS = 59;
-pub const IPV6_RECVPATHMTU = 60;
-pub const IPV6_PATHMTU = 61;
-pub const IPV6_DONTFRAG = 62;
-
-// Advanced API (RFC3542) (2)
-pub const IPV6_RECVTCLASS = 66;
-pub const IPV6_TCLASS = 67;
-
-pub const IPV6_AUTOFLOWLABEL = 70;
-
-// RFC5014: Source address selection
-pub const IPV6_ADDR_PREFERENCES = 72;
-
-pub const IPV6_PREFER_SRC_TMP = 0x0001;
-pub const IPV6_PREFER_SRC_PUBLIC = 0x0002;
-pub const IPV6_PREFER_SRC_PUBTMP_DEFAULT = 0x0100;
-pub const IPV6_PREFER_SRC_COA = 0x0004;
-pub const IPV6_PREFER_SRC_HOME = 0x0400;
-pub const IPV6_PREFER_SRC_CGA = 0x0008;
-pub const IPV6_PREFER_SRC_NONCGA = 0x0800;
-
-// RFC5082: Generalized Ttl Security Mechanism
-pub const IPV6_MINHOPCOUNT = 73;
-
-pub const IPV6_ORIGDSTADDR = 74;
-pub const IPV6_RECVORIGDSTADDR = IPV6_ORIGDSTADDR;
-pub const IPV6_TRANSPARENT = 75;
-pub const IPV6_UNICAST_IF = 76;
-pub const IPV6_RECVFRAGSIZE = 77;
-pub const IPV6_FREEBIND = 78;
-
-pub const MSG_OOB = 0x0001;
-pub const MSG_PEEK = 0x0002;
-pub const MSG_DONTROUTE = 0x0004;
-pub const MSG_CTRUNC = 0x0008;
-pub const MSG_PROXY = 0x0010;
-pub const MSG_TRUNC = 0x0020;
-pub const MSG_DONTWAIT = 0x0040;
-pub const MSG_EOR = 0x0080;
-pub const MSG_WAITALL = 0x0100;
-pub const MSG_FIN = 0x0200;
-pub const MSG_SYN = 0x0400;
-pub const MSG_CONFIRM = 0x0800;
-pub const MSG_RST = 0x1000;
-pub const MSG_ERRQUEUE = 0x2000;
-pub const MSG_NOSIGNAL = 0x4000;
-pub const MSG_MORE = 0x8000;
-pub const MSG_WAITFORONE = 0x10000;
-pub const MSG_BATCH = 0x40000;
-pub const MSG_ZEROCOPY = 0x4000000;
-pub const MSG_FASTOPEN = 0x20000000;
-pub const MSG_CMSG_CLOEXEC = 0x40000000;
-
-pub const DT_UNKNOWN = 0;
-pub const DT_FIFO = 1;
-pub const DT_CHR = 2;
-pub const DT_DIR = 4;
-pub const DT_BLK = 6;
-pub const DT_REG = 8;
-pub const DT_LNK = 10;
-pub const DT_SOCK = 12;
-pub const DT_WHT = 14;
-
-pub const TCGETS = if (is_mips) 0x540D else 0x5401;
-pub const TCSETS = 0x5402;
-pub const TCSETSW = 0x5403;
-pub const TCSETSF = 0x5404;
-pub const TCGETA = 0x5405;
-pub const TCSETA = 0x5406;
-pub const TCSETAW = 0x5407;
-pub const TCSETAF = 0x5408;
-pub const TCSBRK = 0x5409;
-pub const TCXONC = 0x540A;
-pub const TCFLSH = 0x540B;
-pub const TIOCEXCL = 0x540C;
-pub const TIOCNXCL = 0x540D;
-pub const TIOCSCTTY = 0x540E;
-pub const TIOCGPGRP = 0x540F;
-pub const TIOCSPGRP = 0x5410;
-pub const TIOCOUTQ = if (is_mips) 0x7472 else 0x5411;
-pub const TIOCSTI = 0x5412;
-pub const TIOCGWINSZ = if (is_mips or is_ppc64) 0x40087468 else 0x5413;
-pub const TIOCSWINSZ = if (is_mips or is_ppc64) 0x80087467 else 0x5414;
-pub const TIOCMGET = 0x5415;
-pub const TIOCMBIS = 0x5416;
-pub const TIOCMBIC = 0x5417;
-pub const TIOCMSET = 0x5418;
-pub const TIOCGSOFTCAR = 0x5419;
-pub const TIOCSSOFTCAR = 0x541A;
-pub const FIONREAD = if (is_mips) 0x467F else 0x541B;
-pub const TIOCINQ = FIONREAD;
-pub const TIOCLINUX = 0x541C;
-pub const TIOCCONS = 0x541D;
-pub const TIOCGSERIAL = 0x541E;
-pub const TIOCSSERIAL = 0x541F;
-pub const TIOCPKT = 0x5420;
-pub const FIONBIO = 0x5421;
-pub const TIOCNOTTY = 0x5422;
-pub const TIOCSETD = 0x5423;
-pub const TIOCGETD = 0x5424;
-pub const TCSBRKP = 0x5425;
-pub const TIOCSBRK = 0x5427;
-pub const TIOCCBRK = 0x5428;
-pub const TIOCGSID = 0x5429;
-pub const TIOCGRS485 = 0x542E;
-pub const TIOCSRS485 = 0x542F;
-pub const TIOCGPTN = 0x80045430;
-pub const TIOCSPTLCK = 0x40045431;
-pub const TIOCGDEV = 0x80045432;
-pub const TCGETX = 0x5432;
-pub const TCSETX = 0x5433;
-pub const TCSETXF = 0x5434;
-pub const TCSETXW = 0x5435;
-pub const TIOCSIG = 0x40045436;
-pub const TIOCVHANGUP = 0x5437;
-pub const TIOCGPKT = 0x80045438;
-pub const TIOCGPTLCK = 0x80045439;
-pub const TIOCGEXCL = 0x80045440;
-
-pub const EPOLL_CLOEXEC = O_CLOEXEC;
-
-pub const EPOLL_CTL_ADD = 1;
-pub const EPOLL_CTL_DEL = 2;
-pub const EPOLL_CTL_MOD = 3;
-
-pub const EPOLLIN = 0x001;
-pub const EPOLLPRI = 0x002;
-pub const EPOLLOUT = 0x004;
-pub const EPOLLRDNORM = 0x040;
-pub const EPOLLRDBAND = 0x080;
-pub const EPOLLWRNORM = if (is_mips) 0x004 else 0x100;
-pub const EPOLLWRBAND = if (is_mips) 0x100 else 0x200;
-pub const EPOLLMSG = 0x400;
-pub const EPOLLERR = 0x008;
-pub const EPOLLHUP = 0x010;
-pub const EPOLLRDHUP = 0x2000;
-pub const EPOLLEXCLUSIVE = (@as(u32, 1) << 28);
-pub const EPOLLWAKEUP = (@as(u32, 1) << 29);
-pub const EPOLLONESHOT = (@as(u32, 1) << 30);
-pub const EPOLLET = (@as(u32, 1) << 31);
-
-pub const CLOCK_REALTIME = 0;
-pub const CLOCK_MONOTONIC = 1;
-pub const CLOCK_PROCESS_CPUTIME_ID = 2;
-pub const CLOCK_THREAD_CPUTIME_ID = 3;
-pub const CLOCK_MONOTONIC_RAW = 4;
-pub const CLOCK_REALTIME_COARSE = 5;
-pub const CLOCK_MONOTONIC_COARSE = 6;
-pub const CLOCK_BOOTTIME = 7;
-pub const CLOCK_REALTIME_ALARM = 8;
-pub const CLOCK_BOOTTIME_ALARM = 9;
-pub const CLOCK_SGI_CYCLE = 10;
-pub const CLOCK_TAI = 11;
-
-pub const CSIGNAL = 0x000000ff;
-pub const CLONE_VM = 0x00000100;
-pub const CLONE_FS = 0x00000200;
-pub const CLONE_FILES = 0x00000400;
-pub const CLONE_SIGHAND = 0x00000800;
-pub const CLONE_PIDFD = 0x00001000;
-pub const CLONE_PTRACE = 0x00002000;
-pub const CLONE_VFORK = 0x00004000;
-pub const CLONE_PARENT = 0x00008000;
-pub const CLONE_THREAD = 0x00010000;
-pub const CLONE_NEWNS = 0x00020000;
-pub const CLONE_SYSVSEM = 0x00040000;
-pub const CLONE_SETTLS = 0x00080000;
-pub const CLONE_PARENT_SETTID = 0x00100000;
-pub const CLONE_CHILD_CLEARTID = 0x00200000;
-pub const CLONE_DETACHED = 0x00400000;
-pub const CLONE_UNTRACED = 0x00800000;
-pub const CLONE_CHILD_SETTID = 0x01000000;
-pub const CLONE_NEWCGROUP = 0x02000000;
-pub const CLONE_NEWUTS = 0x04000000;
-pub const CLONE_NEWIPC = 0x08000000;
-pub const CLONE_NEWUSER = 0x10000000;
-pub const CLONE_NEWPID = 0x20000000;
-pub const CLONE_NEWNET = 0x40000000;
-pub const CLONE_IO = 0x80000000;
-
-// Flags for the clone3() syscall.
-
-/// Clear any signal handler and reset to SIG_DFL.
-pub const CLONE_CLEAR_SIGHAND = 0x100000000;
-/// Clone into a specific cgroup given the right permissions.
-pub const CLONE_INTO_CGROUP = 0x200000000;
-
-// cloning flags intersect with CSIGNAL so can be used with unshare and clone3 syscalls only.
-
-/// New time namespace
-pub const CLONE_NEWTIME = 0x00000080;
-
-pub const EFD_SEMAPHORE = 1;
-pub const EFD_CLOEXEC = O_CLOEXEC;
-pub const EFD_NONBLOCK = O_NONBLOCK;
-
-pub const MS_RDONLY = 1;
-pub const MS_NOSUID = 2;
-pub const MS_NODEV = 4;
-pub const MS_NOEXEC = 8;
-pub const MS_SYNCHRONOUS = 16;
-pub const MS_REMOUNT = 32;
-pub const MS_MANDLOCK = 64;
-pub const MS_DIRSYNC = 128;
-pub const MS_NOATIME = 1024;
-pub const MS_NODIRATIME = 2048;
-pub const MS_BIND = 4096;
-pub const MS_MOVE = 8192;
-pub const MS_REC = 16384;
-pub const MS_SILENT = 32768;
-pub const MS_POSIXACL = (1 << 16);
-pub const MS_UNBINDABLE = (1 << 17);
-pub const MS_PRIVATE = (1 << 18);
-pub const MS_SLAVE = (1 << 19);
-pub const MS_SHARED = (1 << 20);
-pub const MS_RELATIME = (1 << 21);
-pub const MS_KERNMOUNT = (1 << 22);
-pub const MS_I_VERSION = (1 << 23);
-pub const MS_STRICTATIME = (1 << 24);
-pub const MS_LAZYTIME = (1 << 25);
-pub const MS_NOREMOTELOCK = (1 << 27);
-pub const MS_NOSEC = (1 << 28);
-pub const MS_BORN = (1 << 29);
-pub const MS_ACTIVE = (1 << 30);
-pub const MS_NOUSER = (1 << 31);
-
-pub const MS_RMT_MASK = (MS_RDONLY | MS_SYNCHRONOUS | MS_MANDLOCK | MS_I_VERSION | MS_LAZYTIME);
-
-pub const MS_MGC_VAL = 0xc0ed0000;
-pub const MS_MGC_MSK = 0xffff0000;
-
-pub const MNT_FORCE = 1;
-pub const MNT_DETACH = 2;
-pub const MNT_EXPIRE = 4;
-pub const UMOUNT_NOFOLLOW = 8;
-
-pub const IN_CLOEXEC = O_CLOEXEC;
-pub const IN_NONBLOCK = O_NONBLOCK;
-
-pub const IN_ACCESS = 0x00000001;
-pub const IN_MODIFY = 0x00000002;
-pub const IN_ATTRIB = 0x00000004;
-pub const IN_CLOSE_WRITE = 0x00000008;
-pub const IN_CLOSE_NOWRITE = 0x00000010;
-pub const IN_CLOSE = IN_CLOSE_WRITE | IN_CLOSE_NOWRITE;
-pub const IN_OPEN = 0x00000020;
-pub const IN_MOVED_FROM = 0x00000040;
-pub const IN_MOVED_TO = 0x00000080;
-pub const IN_MOVE = IN_MOVED_FROM | IN_MOVED_TO;
-pub const IN_CREATE = 0x00000100;
-pub const IN_DELETE = 0x00000200;
-pub const IN_DELETE_SELF = 0x00000400;
-pub const IN_MOVE_SELF = 0x00000800;
-pub const IN_ALL_EVENTS = 0x00000fff;
-
-pub const IN_UNMOUNT = 0x00002000;
-pub const IN_Q_OVERFLOW = 0x00004000;
-pub const IN_IGNORED = 0x00008000;
-
-pub const IN_ONLYDIR = 0x01000000;
-pub const IN_DONT_FOLLOW = 0x02000000;
-pub const IN_EXCL_UNLINK = 0x04000000;
-pub const IN_MASK_ADD = 0x20000000;
-
-pub const IN_ISDIR = 0x40000000;
-pub const IN_ONESHOT = 0x80000000;
-
-pub const S_IFMT = 0o170000;
-
-pub const S_IFDIR = 0o040000;
-pub const S_IFCHR = 0o020000;
-pub const S_IFBLK = 0o060000;
-pub const S_IFREG = 0o100000;
-pub const S_IFIFO = 0o010000;
-pub const S_IFLNK = 0o120000;
-pub const S_IFSOCK = 0o140000;
-
-pub const S_ISUID = 0o4000;
-pub const S_ISGID = 0o2000;
-pub const S_ISVTX = 0o1000;
-pub const S_IRUSR = 0o400;
-pub const S_IWUSR = 0o200;
-pub const S_IXUSR = 0o100;
-pub const S_IRWXU = 0o700;
-pub const S_IRGRP = 0o040;
-pub const S_IWGRP = 0o020;
-pub const S_IXGRP = 0o010;
-pub const S_IRWXG = 0o070;
-pub const S_IROTH = 0o004;
-pub const S_IWOTH = 0o002;
-pub const S_IXOTH = 0o001;
-pub const S_IRWXO = 0o007;
-
-pub fn S_ISREG(m: u32) bool {
- return m & S_IFMT == S_IFREG;
-}
-
-pub fn S_ISDIR(m: u32) bool {
- return m & S_IFMT == S_IFDIR;
-}
-
-pub fn S_ISCHR(m: u32) bool {
- return m & S_IFMT == S_IFCHR;
-}
-
-pub fn S_ISBLK(m: u32) bool {
- return m & S_IFMT == S_IFBLK;
-}
-
-pub fn S_ISFIFO(m: u32) bool {
- return m & S_IFMT == S_IFIFO;
-}
-
-pub fn S_ISLNK(m: u32) bool {
- return m & S_IFMT == S_IFLNK;
-}
-
-pub fn S_ISSOCK(m: u32) bool {
- return m & S_IFMT == S_IFSOCK;
-}
-
-pub const UTIME_NOW = 0x3fffffff;
-pub const UTIME_OMIT = 0x3ffffffe;
-
-pub const TFD_NONBLOCK = O_NONBLOCK;
-pub const TFD_CLOEXEC = O_CLOEXEC;
-
-pub const TFD_TIMER_ABSTIME = 1;
-pub const TFD_TIMER_CANCEL_ON_SET = (1 << 1);
-
-pub fn WEXITSTATUS(s: u32) u8 {
- return @intCast(u8, (s & 0xff00) >> 8);
-}
-pub fn WTERMSIG(s: u32) u32 {
- return s & 0x7f;
-}
-pub fn WSTOPSIG(s: u32) u32 {
- return WEXITSTATUS(s);
-}
-pub fn WIFEXITED(s: u32) bool {
- return WTERMSIG(s) == 0;
-}
-pub fn WIFSTOPPED(s: u32) bool {
- return @intCast(u16, ((s & 0xffff) *% 0x10001) >> 8) > 0x7f00;
-}
-pub fn WIFSIGNALED(s: u32) bool {
- return (s & 0xffff) -% 1 < 0xff;
-}
-
-pub const winsize = extern struct {
- ws_row: u16,
- ws_col: u16,
- ws_xpixel: u16,
- ws_ypixel: u16,
-};
-
-/// NSIG is the total number of signals defined.
-/// As signal numbers are sequential, NSIG is one greater than the largest defined signal number.
-pub const NSIG = if (is_mips) 128 else 65;
-
-pub const sigset_t = [1024 / 32]u32;
-
-pub const all_mask: sigset_t = [_]u32{0xffffffff} ** sigset_t.len;
-pub const app_mask: sigset_t = [2]u32{ 0xfffffffc, 0x7fffffff } ++ [_]u32{0xffffffff} ** 30;
-
-pub const k_sigaction = switch (arch) {
- .mips, .mipsel => extern struct {
- flags: c_uint,
- handler: ?fn (c_int) callconv(.C) void,
- mask: [4]c_ulong,
- restorer: fn () callconv(.C) void,
- },
- .mips64, .mips64el => extern struct {
- flags: c_uint,
- handler: ?fn (c_int) callconv(.C) void,
- mask: [2]c_ulong,
- restorer: fn () callconv(.C) void,
- },
- else => extern struct {
- handler: ?fn (c_int) callconv(.C) void,
- flags: c_ulong,
- restorer: fn () callconv(.C) void,
- mask: [2]c_uint,
- },
-};
-
-/// Renamed from `sigaction` to `Sigaction` to avoid conflict with the syscall.
-pub const Sigaction = extern struct {
- pub const handler_fn = fn (c_int) callconv(.C) void;
- pub const sigaction_fn = fn (c_int, *const siginfo_t, ?*const c_void) callconv(.C) void;
-
- handler: extern union {
- handler: ?handler_fn,
- sigaction: ?sigaction_fn,
- },
- mask: sigset_t,
- flags: c_uint,
- restorer: ?fn () callconv(.C) void = null,
-};
-
-pub const SIG_ERR = @intToPtr(?Sigaction.sigaction_fn, maxInt(usize));
-pub const SIG_DFL = @intToPtr(?Sigaction.sigaction_fn, 0);
-pub const SIG_IGN = @intToPtr(?Sigaction.sigaction_fn, 1);
-
-pub const empty_sigset = [_]u32{0} ** @typeInfo(sigset_t).Array.len;
-
-pub const SFD_CLOEXEC = O_CLOEXEC;
-pub const SFD_NONBLOCK = O_NONBLOCK;
-
-pub const signalfd_siginfo = extern struct {
- signo: u32,
- errno: i32,
- code: i32,
- pid: u32,
- uid: uid_t,
- fd: i32,
- tid: u32,
- band: u32,
- overrun: u32,
- trapno: u32,
- status: i32,
- int: i32,
- ptr: u64,
- utime: u64,
- stime: u64,
- addr: u64,
- addr_lsb: u16,
- __pad2: u16,
- syscall: i32,
- call_addr: u64,
- arch: u32,
- __pad: [28]u8,
-};
-
-pub const in_port_t = u16;
-pub const sa_family_t = u16;
-pub const socklen_t = u32;
-
-pub const sockaddr = extern struct {
- family: sa_family_t,
- data: [14]u8,
-};
-
-pub const sockaddr_storage = std.x.os.Socket.Address.Native.Storage;
-
-/// IPv4 socket address
-pub const sockaddr_in = extern struct {
- 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 },
-};
-
-/// IPv6 socket address
-pub const sockaddr_in6 = extern struct {
- family: sa_family_t = AF_INET6,
- port: in_port_t,
- flowinfo: u32,
- addr: [16]u8,
- scope_id: u32,
-};
-
-/// UNIX domain socket address
-pub const sockaddr_un = extern struct {
- family: sa_family_t = AF_UNIX,
- path: [108]u8,
-};
-
-pub const mmsghdr = extern struct {
- msg_hdr: msghdr,
- msg_len: u32,
-};
-
-pub const mmsghdr_const = extern struct {
- msg_hdr: msghdr_const,
- msg_len: u32,
-};
-
-pub const epoll_data = extern union {
- ptr: usize,
- fd: i32,
- @"u32": u32,
- @"u64": u64,
-};
-
-// On x86_64 the structure is packed so that it matches the definition of its
-// 32bit counterpart
-pub const epoll_event = switch (arch) {
- .x86_64 => packed struct {
- events: u32,
- data: epoll_data,
- },
- else => extern struct {
- events: u32,
- data: epoll_data,
- },
-};
-
-pub const _LINUX_CAPABILITY_VERSION_1 = 0x19980330;
-pub const _LINUX_CAPABILITY_U32S_1 = 1;
-
-pub const _LINUX_CAPABILITY_VERSION_2 = 0x20071026;
-pub const _LINUX_CAPABILITY_U32S_2 = 2;
-
-pub const _LINUX_CAPABILITY_VERSION_3 = 0x20080522;
-pub const _LINUX_CAPABILITY_U32S_3 = 2;
-
-pub const VFS_CAP_REVISION_MASK = 0xFF000000;
-pub const VFS_CAP_REVISION_SHIFT = 24;
-pub const VFS_CAP_FLAGS_MASK = ~VFS_CAP_REVISION_MASK;
-pub const VFS_CAP_FLAGS_EFFECTIVE = 0x000001;
-
-pub const VFS_CAP_REVISION_1 = 0x01000000;
-pub const VFS_CAP_U32_1 = 1;
-pub const XATTR_CAPS_SZ_1 = @sizeOf(u32) * (1 + 2 * VFS_CAP_U32_1);
-
-pub const VFS_CAP_REVISION_2 = 0x02000000;
-pub const VFS_CAP_U32_2 = 2;
-pub const XATTR_CAPS_SZ_2 = @sizeOf(u32) * (1 + 2 * VFS_CAP_U32_2);
-
-pub const XATTR_CAPS_SZ = XATTR_CAPS_SZ_2;
-pub const VFS_CAP_U32 = VFS_CAP_U32_2;
-pub const VFS_CAP_REVISION = VFS_CAP_REVISION_2;
-
-pub const vfs_cap_data = extern struct {
- //all of these are mandated as little endian
- //when on disk.
- const Data = struct {
- permitted: u32,
- inheritable: u32,
- };
-
- magic_etc: u32,
- data: [VFS_CAP_U32]Data,
-};
-
-pub const CAP_CHOWN = 0;
-pub const CAP_DAC_OVERRIDE = 1;
-pub const CAP_DAC_READ_SEARCH = 2;
-pub const CAP_FOWNER = 3;
-pub const CAP_FSETID = 4;
-pub const CAP_KILL = 5;
-pub const CAP_SETGID = 6;
-pub const CAP_SETUID = 7;
-pub const CAP_SETPCAP = 8;
-pub const CAP_LINUX_IMMUTABLE = 9;
-pub const CAP_NET_BIND_SERVICE = 10;
-pub const CAP_NET_BROADCAST = 11;
-pub const CAP_NET_ADMIN = 12;
-pub const CAP_NET_RAW = 13;
-pub const CAP_IPC_LOCK = 14;
-pub const CAP_IPC_OWNER = 15;
-pub const CAP_SYS_MODULE = 16;
-pub const CAP_SYS_RAWIO = 17;
-pub const CAP_SYS_CHROOT = 18;
-pub const CAP_SYS_PTRACE = 19;
-pub const CAP_SYS_PACCT = 20;
-pub const CAP_SYS_ADMIN = 21;
-pub const CAP_SYS_BOOT = 22;
-pub const CAP_SYS_NICE = 23;
-pub const CAP_SYS_RESOURCE = 24;
-pub const CAP_SYS_TIME = 25;
-pub const CAP_SYS_TTY_CONFIG = 26;
-pub const CAP_MKNOD = 27;
-pub const CAP_LEASE = 28;
-pub const CAP_AUDIT_WRITE = 29;
-pub const CAP_AUDIT_CONTROL = 30;
-pub const CAP_SETFCAP = 31;
-pub const CAP_MAC_OVERRIDE = 32;
-pub const CAP_MAC_ADMIN = 33;
-pub const CAP_SYSLOG = 34;
-pub const CAP_WAKE_ALARM = 35;
-pub const CAP_BLOCK_SUSPEND = 36;
-pub const CAP_AUDIT_READ = 37;
-pub const CAP_LAST_CAP = CAP_AUDIT_READ;
-
-pub fn cap_valid(x: u8) bool {
- return x >= 0 and x <= CAP_LAST_CAP;
-}
-
-pub fn CAP_TO_MASK(cap: u8) u32 {
- return @as(u32, 1) << @intCast(u5, cap & 31);
-}
-
-pub fn CAP_TO_INDEX(cap: u8) u8 {
- return cap >> 5;
-}
-
-pub const cap_t = extern struct {
- hdrp: *cap_user_header_t,
- datap: *cap_user_data_t,
-};
-
-pub const cap_user_header_t = extern struct {
- version: u32,
- pid: usize,
-};
-
-pub const cap_user_data_t = extern struct {
- effective: u32,
- permitted: u32,
- inheritable: u32,
-};
-
-pub const inotify_event = extern struct {
- wd: i32,
- mask: u32,
- cookie: u32,
- len: u32,
- //name: [?]u8,
-};
-
-pub const dirent64 = extern struct {
- d_ino: u64,
- d_off: u64,
- d_reclen: u16,
- d_type: u8,
- d_name: u8, // field address is the address of first byte of name https://github.com/ziglang/zig/issues/173
-
- pub fn reclen(self: dirent64) u16 {
- return self.d_reclen;
- }
-};
-
-pub const dl_phdr_info = extern struct {
- dlpi_addr: usize,
- dlpi_name: ?[*:0]const u8,
- dlpi_phdr: [*]std.elf.Phdr,
- dlpi_phnum: u16,
-};
-
-pub const CPU_SETSIZE = 128;
-pub const cpu_set_t = [CPU_SETSIZE / @sizeOf(usize)]usize;
-pub const cpu_count_t = std.meta.Int(.unsigned, std.math.log2(CPU_SETSIZE * 8));
-
-pub fn CPU_COUNT(set: cpu_set_t) cpu_count_t {
- var sum: cpu_count_t = 0;
- for (set) |x| {
- sum += @popCount(usize, x);
- }
- return sum;
-}
-
-// TODO port these over
-//#define CPU_SET(i, set) CPU_SET_S(i,sizeof(cpu_set_t),set)
-//#define CPU_CLR(i, set) CPU_CLR_S(i,sizeof(cpu_set_t),set)
-//#define CPU_ISSET(i, set) CPU_ISSET_S(i,sizeof(cpu_set_t),set)
-//#define CPU_AND(d,s1,s2) CPU_AND_S(sizeof(cpu_set_t),d,s1,s2)
-//#define CPU_OR(d,s1,s2) CPU_OR_S(sizeof(cpu_set_t),d,s1,s2)
-//#define CPU_XOR(d,s1,s2) CPU_XOR_S(sizeof(cpu_set_t),d,s1,s2)
-//#define CPU_COUNT(set) CPU_COUNT_S(sizeof(cpu_set_t),set)
-//#define CPU_ZERO(set) CPU_ZERO_S(sizeof(cpu_set_t),set)
-//#define CPU_EQUAL(s1,s2) CPU_EQUAL_S(sizeof(cpu_set_t),s1,s2)
-
-pub const MINSIGSTKSZ = switch (arch) {
- .i386, .x86_64, .arm, .mipsel => 2048,
- .aarch64 => 5120,
- else => @compileError("MINSIGSTKSZ not defined for this architecture"),
-};
-pub const SIGSTKSZ = switch (arch) {
- .i386, .x86_64, .arm, .mipsel => 8192,
- .aarch64 => 16384,
- else => @compileError("SIGSTKSZ not defined for this architecture"),
-};
-
-pub const SS_ONSTACK = 1;
-pub const SS_DISABLE = 2;
-pub const SS_AUTODISARM = 1 << 31;
-
-pub const stack_t = if (is_mips)
- // IRIX compatible stack_t
- extern struct {
- ss_sp: [*]u8,
- ss_size: usize,
- ss_flags: i32,
- }
-else
- extern struct {
- ss_sp: [*]u8,
- ss_flags: i32,
- ss_size: usize,
- };
-
-pub const sigval = extern union {
- int: i32,
- ptr: *c_void,
-};
-
-const siginfo_fields_union = extern union {
- pad: [128 - 2 * @sizeOf(c_int) - @sizeOf(c_long)]u8,
- common: extern struct {
- first: extern union {
- piduid: extern struct {
- pid: pid_t,
- uid: uid_t,
- },
- timer: extern struct {
- timerid: i32,
- overrun: i32,
- },
- },
- second: extern union {
- value: sigval,
- sigchld: extern struct {
- status: i32,
- utime: clock_t,
- stime: clock_t,
- },
- },
- },
- sigfault: extern struct {
- addr: *c_void,
- addr_lsb: i16,
- first: extern union {
- addr_bnd: extern struct {
- lower: *c_void,
- upper: *c_void,
- },
- pkey: u32,
- },
- },
- sigpoll: extern struct {
- band: isize,
- fd: i32,
- },
- sigsys: extern struct {
- call_addr: *c_void,
- syscall: i32,
- arch: u32,
- },
-};
-
-pub const siginfo_t = if (is_mips)
- extern struct {
- signo: i32,
- code: i32,
- errno: i32,
- fields: siginfo_fields_union,
- }
-else
- extern struct {
- signo: i32,
- errno: i32,
- code: i32,
- fields: siginfo_fields_union,
- };
-
-pub const io_uring_params = extern struct {
- sq_entries: u32,
- cq_entries: u32,
- flags: u32,
- sq_thread_cpu: u32,
- sq_thread_idle: u32,
- features: u32,
- wq_fd: u32,
- resv: [3]u32,
- sq_off: io_sqring_offsets,
- cq_off: io_cqring_offsets,
-};
-
-// io_uring_params.features flags
-
-pub const IORING_FEAT_SINGLE_MMAP = 1 << 0;
-pub const IORING_FEAT_NODROP = 1 << 1;
-pub const IORING_FEAT_SUBMIT_STABLE = 1 << 2;
-pub const IORING_FEAT_RW_CUR_POS = 1 << 3;
-pub const IORING_FEAT_CUR_PERSONALITY = 1 << 4;
-pub const IORING_FEAT_FAST_POLL = 1 << 5;
-pub const IORING_FEAT_POLL_32BITS = 1 << 6;
-
-// io_uring_params.flags
-
-/// io_context is polled
-pub const IORING_SETUP_IOPOLL = 1 << 0;
-
-/// SQ poll thread
-pub const IORING_SETUP_SQPOLL = 1 << 1;
-
-/// sq_thread_cpu is valid
-pub const IORING_SETUP_SQ_AFF = 1 << 2;
-
-/// app defines CQ size
-pub const IORING_SETUP_CQSIZE = 1 << 3;
-
-/// clamp SQ/CQ ring sizes
-pub const IORING_SETUP_CLAMP = 1 << 4;
-
-/// attach to existing wq
-pub const IORING_SETUP_ATTACH_WQ = 1 << 5;
-
-/// start with ring disabled
-pub const IORING_SETUP_R_DISABLED = 1 << 6;
-
-pub const io_sqring_offsets = extern struct {
- /// offset of ring head
- head: u32,
-
- /// offset of ring tail
- tail: u32,
-
- /// ring mask value
- ring_mask: u32,
-
- /// entries in ring
- ring_entries: u32,
-
- /// ring flags
- flags: u32,
-
- /// number of sqes not submitted
- dropped: u32,
-
- /// sqe index array
- array: u32,
-
- resv1: u32,
- resv2: u64,
-};
-
-// io_sqring_offsets.flags
-
-/// needs io_uring_enter wakeup
-pub const IORING_SQ_NEED_WAKEUP = 1 << 0;
-
-/// kernel has cqes waiting beyond the cq ring
-pub const IORING_SQ_CQ_OVERFLOW = 1 << 1;
-
-pub const io_cqring_offsets = extern struct {
- head: u32,
- tail: u32,
- ring_mask: u32,
- ring_entries: u32,
- overflow: u32,
- cqes: u32,
- resv: [2]u64,
-};
-
-pub const io_uring_sqe = extern struct {
- opcode: IORING_OP,
- flags: u8,
- ioprio: u16,
- fd: i32,
- off: u64,
- addr: u64,
- len: u32,
- rw_flags: u32,
- user_data: u64,
- buf_index: u16,
- personality: u16,
- splice_fd_in: i32,
- __pad2: [2]u64,
-};
-
-pub const IOSQE_BIT = enum(u8) {
- FIXED_FILE,
- IO_DRAIN,
- IO_LINK,
- IO_HARDLINK,
- ASYNC,
- BUFFER_SELECT,
-
- _,
-};
-
-// io_uring_sqe.flags
-
-/// use fixed fileset
-pub const IOSQE_FIXED_FILE = 1 << @enumToInt(IOSQE_BIT.FIXED_FILE);
-
-/// issue after inflight IO
-pub const IOSQE_IO_DRAIN = 1 << @enumToInt(IOSQE_BIT.IO_DRAIN);
-
-/// links next sqe
-pub const IOSQE_IO_LINK = 1 << @enumToInt(IOSQE_BIT.IO_LINK);
-
-/// like LINK, but stronger
-pub const IOSQE_IO_HARDLINK = 1 << @enumToInt(IOSQE_BIT.IO_HARDLINK);
-
-/// always go async
-pub const IOSQE_ASYNC = 1 << @enumToInt(IOSQE_BIT.ASYNC);
-
-/// select buffer from buf_group
-pub const IOSQE_BUFFER_SELECT = 1 << @enumToInt(IOSQE_BIT.BUFFER_SELECT);
-
-pub const IORING_OP = enum(u8) {
- NOP,
- READV,
- WRITEV,
- FSYNC,
- READ_FIXED,
- WRITE_FIXED,
- POLL_ADD,
- POLL_REMOVE,
- SYNC_FILE_RANGE,
- SENDMSG,
- RECVMSG,
- TIMEOUT,
- TIMEOUT_REMOVE,
- ACCEPT,
- ASYNC_CANCEL,
- LINK_TIMEOUT,
- CONNECT,
- FALLOCATE,
- OPENAT,
- CLOSE,
- FILES_UPDATE,
- STATX,
- READ,
- WRITE,
- FADVISE,
- MADVISE,
- SEND,
- RECV,
- OPENAT2,
- EPOLL_CTL,
- SPLICE,
- PROVIDE_BUFFERS,
- REMOVE_BUFFERS,
- TEE,
-
- _,
-};
-
-// io_uring_sqe.fsync_flags
-pub const IORING_FSYNC_DATASYNC = 1 << 0;
-
-// io_uring_sqe.timeout_flags
-pub const IORING_TIMEOUT_ABS = 1 << 0;
-
-// IO completion data structure (Completion Queue Entry)
-pub const io_uring_cqe = extern struct {
- /// io_uring_sqe.data submission passed back
- user_data: u64,
-
- /// result code for this event
- res: i32,
- flags: u32,
-
- pub fn err(self: io_uring_cqe) E {
- if (self.res > -4096 and self.res < 0) {
- return @intToEnum(E, -self.res);
- }
- return .SUCCESS;
- }
-};
-
-// io_uring_cqe.flags
-
-/// If set, the upper 16 bits are the buffer ID
-pub const IORING_CQE_F_BUFFER = 1 << 0;
-
-pub const IORING_OFF_SQ_RING = 0;
-pub const IORING_OFF_CQ_RING = 0x8000000;
-pub const IORING_OFF_SQES = 0x10000000;
-
-// io_uring_enter flags
-pub const IORING_ENTER_GETEVENTS = 1 << 0;
-pub const IORING_ENTER_SQ_WAKEUP = 1 << 1;
-
-// io_uring_register opcodes and arguments
-pub const IORING_REGISTER = enum(u8) {
- REGISTER_BUFFERS,
- UNREGISTER_BUFFERS,
- REGISTER_FILES,
- UNREGISTER_FILES,
- REGISTER_EVENTFD,
- UNREGISTER_EVENTFD,
- REGISTER_FILES_UPDATE,
- REGISTER_EVENTFD_ASYNC,
- REGISTER_PROBE,
- REGISTER_PERSONALITY,
- UNREGISTER_PERSONALITY,
- REGISTER_RESTRICTIONS,
- REGISTER_ENABLE_RINGS,
-
- _,
-};
-
-pub const io_uring_files_update = extern struct {
- offset: u32,
- resv: u32,
- fds: u64,
-};
-
-pub const IO_URING_OP_SUPPORTED = 1 << 0;
-
-pub const io_uring_probe_op = extern struct {
- op: IORING_OP,
-
- resv: u8,
-
- /// IO_URING_OP_* flags
- flags: u16,
-
- resv2: u32,
-};
-
-pub const io_uring_probe = extern struct {
- /// last opcode supported
- last_op: IORING_OP,
-
- /// Number of io_uring_probe_op following
- ops_len: u8,
-
- resv: u16,
- resv2: u32[3],
-
- // Followed by up to `ops_len` io_uring_probe_op structures
-};
-
-pub const io_uring_restriction = extern struct {
- opcode: u16,
- arg: extern union {
- /// IORING_RESTRICTION_REGISTER_OP
- register_op: IORING_REGISTER,
-
- /// IORING_RESTRICTION_SQE_OP
- sqe_op: IORING_OP,
-
- /// IORING_RESTRICTION_SQE_FLAGS_*
- sqe_flags: u8,
- },
- resv: u8,
- resv2: u32[3],
-};
-
-/// io_uring_restriction->opcode values
-pub const IORING_RESTRICTION = enum(u8) {
- /// Allow an io_uring_register(2) opcode
- REGISTER_OP = 0,
-
- /// Allow an sqe opcode
- SQE_OP = 1,
-
- /// Allow sqe flags
- SQE_FLAGS_ALLOWED = 2,
-
- /// Require sqe flags (these flags must be set on each submission)
- SQE_FLAGS_REQUIRED = 3,
-
- _,
-};
-
-pub const utsname = extern struct {
- sysname: [64:0]u8,
- nodename: [64:0]u8,
- release: [64:0]u8,
- version: [64:0]u8,
- machine: [64:0]u8,
- domainname: [64:0]u8,
-};
-pub const HOST_NAME_MAX = 64;
-
-pub const STATX_TYPE = 0x0001;
-pub const STATX_MODE = 0x0002;
-pub const STATX_NLINK = 0x0004;
-pub const STATX_UID = 0x0008;
-pub const STATX_GID = 0x0010;
-pub const STATX_ATIME = 0x0020;
-pub const STATX_MTIME = 0x0040;
-pub const STATX_CTIME = 0x0080;
-pub const STATX_INO = 0x0100;
-pub const STATX_SIZE = 0x0200;
-pub const STATX_BLOCKS = 0x0400;
-pub const STATX_BASIC_STATS = 0x07ff;
-
-pub const STATX_BTIME = 0x0800;
-
-pub const STATX_ATTR_COMPRESSED = 0x0004;
-pub const STATX_ATTR_IMMUTABLE = 0x0010;
-pub const STATX_ATTR_APPEND = 0x0020;
-pub const STATX_ATTR_NODUMP = 0x0040;
-pub const STATX_ATTR_ENCRYPTED = 0x0800;
-pub const STATX_ATTR_AUTOMOUNT = 0x1000;
-
-pub const statx_timestamp = extern struct {
- tv_sec: i64,
- tv_nsec: u32,
- __pad1: u32,
-};
-
-/// Renamed to `Statx` to not conflict with the `statx` function.
-pub const Statx = extern struct {
- /// Mask of bits indicating filled fields
- mask: u32,
-
- /// Block size for filesystem I/O
- blksize: u32,
-
- /// Extra file attribute indicators
- attributes: u64,
-
- /// Number of hard links
- nlink: u32,
-
- /// User ID of owner
- uid: uid_t,
-
- /// Group ID of owner
- gid: gid_t,
-
- /// File type and mode
- mode: u16,
- __pad1: u16,
-
- /// Inode number
- ino: u64,
-
- /// Total size in bytes
- size: u64,
-
- /// Number of 512B blocks allocated
- blocks: u64,
-
- /// Mask to show what's supported in `attributes`.
- attributes_mask: u64,
-
- /// Last access file timestamp
- atime: statx_timestamp,
-
- /// Creation file timestamp
- btime: statx_timestamp,
-
- /// Last status change file timestamp
- ctime: statx_timestamp,
-
- /// Last modification file timestamp
- mtime: statx_timestamp,
-
- /// Major ID, if this file represents a device.
- rdev_major: u32,
-
- /// Minor ID, if this file represents a device.
- rdev_minor: u32,
-
- /// Major ID of the device containing the filesystem where this file resides.
- dev_major: u32,
-
- /// Minor ID of the device containing the filesystem where this file resides.
- dev_minor: u32,
-
- __pad2: [14]u64,
-};
-
-pub const addrinfo = extern struct {
- flags: i32,
- family: i32,
- socktype: i32,
- protocol: i32,
- addrlen: socklen_t,
- addr: ?*sockaddr,
- canonname: ?[*:0]u8,
- next: ?*addrinfo,
-};
-
-pub const IPPORT_RESERVED = 1024;
-
-pub const IPPROTO_IP = 0;
-pub const IPPROTO_HOPOPTS = 0;
-pub const IPPROTO_ICMP = 1;
-pub const IPPROTO_IGMP = 2;
-pub const IPPROTO_IPIP = 4;
-pub const IPPROTO_TCP = 6;
-pub const IPPROTO_EGP = 8;
-pub const IPPROTO_PUP = 12;
-pub const IPPROTO_UDP = 17;
-pub const IPPROTO_IDP = 22;
-pub const IPPROTO_TP = 29;
-pub const IPPROTO_DCCP = 33;
-pub const IPPROTO_IPV6 = 41;
-pub const IPPROTO_ROUTING = 43;
-pub const IPPROTO_FRAGMENT = 44;
-pub const IPPROTO_RSVP = 46;
-pub const IPPROTO_GRE = 47;
-pub const IPPROTO_ESP = 50;
-pub const IPPROTO_AH = 51;
-pub const IPPROTO_ICMPV6 = 58;
-pub const IPPROTO_NONE = 59;
-pub const IPPROTO_DSTOPTS = 60;
-pub const IPPROTO_MTP = 92;
-pub const IPPROTO_BEETPH = 94;
-pub const IPPROTO_ENCAP = 98;
-pub const IPPROTO_PIM = 103;
-pub const IPPROTO_COMP = 108;
-pub const IPPROTO_SCTP = 132;
-pub const IPPROTO_MH = 135;
-pub const IPPROTO_UDPLITE = 136;
-pub const IPPROTO_MPLS = 137;
-pub const IPPROTO_RAW = 255;
-pub const IPPROTO_MAX = 256;
-
-pub const RR_A = 1;
-pub const RR_CNAME = 5;
-pub const RR_AAAA = 28;
-
-/// Turn off Nagle's algorithm
-pub const TCP_NODELAY = 1;
-/// Limit MSS
-pub const TCP_MAXSEG = 2;
-/// Never send partially complete segments.
-pub const TCP_CORK = 3;
-/// Start keeplives after this period, in seconds
-pub const TCP_KEEPIDLE = 4;
-/// Interval between keepalives
-pub const TCP_KEEPINTVL = 5;
-/// Number of keepalives before death
-pub const TCP_KEEPCNT = 6;
-/// Number of SYN retransmits
-pub const TCP_SYNCNT = 7;
-/// Life time of orphaned FIN-WAIT-2 state
-pub const TCP_LINGER2 = 8;
-/// Wake up listener only when data arrive
-pub const TCP_DEFER_ACCEPT = 9;
-/// Bound advertised window
-pub const TCP_WINDOW_CLAMP = 10;
-/// Information about this connection.
-pub const TCP_INFO = 11;
-/// Block/reenable quick acks
-pub const TCP_QUICKACK = 12;
-/// Congestion control algorithm
-pub const TCP_CONGESTION = 13;
-/// TCP MD5 Signature (RFC2385)
-pub const TCP_MD5SIG = 14;
-/// Use linear timeouts for thin streams
-pub const TCP_THIN_LINEAR_TIMEOUTS = 16;
-/// Fast retrans. after 1 dupack
-pub const TCP_THIN_DUPACK = 17;
-/// How long for loss retry before timeout
-pub const TCP_USER_TIMEOUT = 18;
-/// TCP sock is under repair right now
-pub const TCP_REPAIR = 19;
-pub const TCP_REPAIR_QUEUE = 20;
-pub const TCP_QUEUE_SEQ = 21;
-pub const TCP_REPAIR_OPTIONS = 22;
-/// Enable FastOpen on listeners
-pub const TCP_FASTOPEN = 23;
-pub const TCP_TIMESTAMP = 24;
-/// limit number of unsent bytes in write queue
-pub const TCP_NOTSENT_LOWAT = 25;
-/// Get Congestion Control (optional) info
-pub const TCP_CC_INFO = 26;
-/// Record SYN headers for new connections
-pub const TCP_SAVE_SYN = 27;
-/// Get SYN headers recorded for connection
-pub const TCP_SAVED_SYN = 28;
-/// Get/set window parameters
-pub const TCP_REPAIR_WINDOW = 29;
-/// Attempt FastOpen with connect
-pub const TCP_FASTOPEN_CONNECT = 30;
-/// Attach a ULP to a TCP connection
-pub const TCP_ULP = 31;
-/// TCP MD5 Signature with extensions
-pub const TCP_MD5SIG_EXT = 32;
-/// Set the key for Fast Open (cookie)
-pub const TCP_FASTOPEN_KEY = 33;
-/// Enable TFO without a TFO cookie
-pub const TCP_FASTOPEN_NO_COOKIE = 34;
-pub const TCP_ZEROCOPY_RECEIVE = 35;
-/// Notify bytes available to read as a cmsg on read
-pub const TCP_INQ = 36;
-pub const TCP_CM_INQ = TCP_INQ;
-/// delay outgoing packets by XX usec
-pub const TCP_TX_DELAY = 37;
-
-pub const TCP_REPAIR_ON = 1;
-pub const TCP_REPAIR_OFF = 0;
-/// Turn off without window probes
-pub const TCP_REPAIR_OFF_NO_WP = -1;
-
-pub const tcp_repair_opt = extern struct {
- opt_code: u32,
- opt_val: u32,
-};
-
-pub const tcp_repair_window = extern struct {
- snd_wl1: u32,
- snd_wnd: u32,
- max_window: u32,
- rcv_wnd: u32,
- rcv_wup: u32,
-};
-
-pub const TcpRepairOption = enum {
- TCP_NO_QUEUE,
- TCP_RECV_QUEUE,
- TCP_SEND_QUEUE,
- TCP_QUEUES_NR,
-};
-
-/// why fastopen failed from client perspective
-pub const tcp_fastopen_client_fail = enum {
- /// catch-all
- TFO_STATUS_UNSPEC,
- /// if not in TFO_CLIENT_NO_COOKIE mode
- TFO_COOKIE_UNAVAILABLE,
- /// SYN-ACK did not ack SYN data
- TFO_DATA_NOT_ACKED,
- /// SYN-ACK did not ack SYN data after timeout
- TFO_SYN_RETRANSMITTED,
-};
-
-/// for TCP_INFO socket option
-pub const TCPI_OPT_TIMESTAMPS = 1;
-pub const TCPI_OPT_SACK = 2;
-pub const TCPI_OPT_WSCALE = 4;
-/// ECN was negociated at TCP session init
-pub const TCPI_OPT_ECN = 8;
-/// we received at least one packet with ECT
-pub const TCPI_OPT_ECN_SEEN = 16;
-/// SYN-ACK acked data in SYN sent or rcvd
-pub const TCPI_OPT_SYN_DATA = 32;
-
-pub const nfds_t = usize;
-pub const pollfd = extern struct {
- fd: fd_t,
- events: i16,
- revents: i16,
-};
-
-pub const POLLIN = 0x001;
-pub const POLLPRI = 0x002;
-pub const POLLOUT = 0x004;
-pub const POLLERR = 0x008;
-pub const POLLHUP = 0x010;
-pub const POLLNVAL = 0x020;
-pub const POLLRDNORM = 0x040;
-pub const POLLRDBAND = 0x080;
-
-pub const MFD_CLOEXEC = 0x0001;
-pub const MFD_ALLOW_SEALING = 0x0002;
-pub const MFD_HUGETLB = 0x0004;
-pub const MFD_ALL_FLAGS = MFD_CLOEXEC | MFD_ALLOW_SEALING | MFD_HUGETLB;
-
-pub const HUGETLB_FLAG_ENCODE_SHIFT = 26;
-pub const HUGETLB_FLAG_ENCODE_MASK = 0x3f;
-pub const HUGETLB_FLAG_ENCODE_64KB = 16 << HUGETLB_FLAG_ENCODE_SHIFT;
-pub const HUGETLB_FLAG_ENCODE_512KB = 19 << HUGETLB_FLAG_ENCODE_SHIFT;
-pub const HUGETLB_FLAG_ENCODE_1MB = 20 << HUGETLB_FLAG_ENCODE_SHIFT;
-pub const HUGETLB_FLAG_ENCODE_2MB = 21 << HUGETLB_FLAG_ENCODE_SHIFT;
-pub const HUGETLB_FLAG_ENCODE_8MB = 23 << HUGETLB_FLAG_ENCODE_SHIFT;
-pub const HUGETLB_FLAG_ENCODE_16MB = 24 << HUGETLB_FLAG_ENCODE_SHIFT;
-pub const HUGETLB_FLAG_ENCODE_32MB = 25 << HUGETLB_FLAG_ENCODE_SHIFT;
-pub const HUGETLB_FLAG_ENCODE_256MB = 28 << HUGETLB_FLAG_ENCODE_SHIFT;
-pub const HUGETLB_FLAG_ENCODE_512MB = 29 << HUGETLB_FLAG_ENCODE_SHIFT;
-pub const HUGETLB_FLAG_ENCODE_1GB = 30 << HUGETLB_FLAG_ENCODE_SHIFT;
-pub const HUGETLB_FLAG_ENCODE_2GB = 31 << HUGETLB_FLAG_ENCODE_SHIFT;
-pub const HUGETLB_FLAG_ENCODE_16GB = 34 << HUGETLB_FLAG_ENCODE_SHIFT;
-
-pub const MFD_HUGE_SHIFT = HUGETLB_FLAG_ENCODE_SHIFT;
-pub const MFD_HUGE_MASK = HUGETLB_FLAG_ENCODE_MASK;
-pub const MFD_HUGE_64KB = HUGETLB_FLAG_ENCODE_64KB;
-pub const MFD_HUGE_512KB = HUGETLB_FLAG_ENCODE_512KB;
-pub const MFD_HUGE_1MB = HUGETLB_FLAG_ENCODE_1MB;
-pub const MFD_HUGE_2MB = HUGETLB_FLAG_ENCODE_2MB;
-pub const MFD_HUGE_8MB = HUGETLB_FLAG_ENCODE_8MB;
-pub const MFD_HUGE_16MB = HUGETLB_FLAG_ENCODE_16MB;
-pub const MFD_HUGE_32MB = HUGETLB_FLAG_ENCODE_32MB;
-pub const MFD_HUGE_256MB = HUGETLB_FLAG_ENCODE_256MB;
-pub const MFD_HUGE_512MB = HUGETLB_FLAG_ENCODE_512MB;
-pub const MFD_HUGE_1GB = HUGETLB_FLAG_ENCODE_1GB;
-pub const MFD_HUGE_2GB = HUGETLB_FLAG_ENCODE_2GB;
-pub const MFD_HUGE_16GB = HUGETLB_FLAG_ENCODE_16GB;
-
-pub const RUSAGE_SELF = 0;
-pub const RUSAGE_CHILDREN = -1;
-pub const RUSAGE_THREAD = 1;
-
-pub const rusage = extern struct {
- utime: timeval,
- stime: timeval,
- maxrss: isize,
- ixrss: isize,
- idrss: isize,
- isrss: isize,
- minflt: isize,
- majflt: isize,
- nswap: isize,
- inblock: isize,
- oublock: isize,
- msgsnd: isize,
- msgrcv: isize,
- nsignals: isize,
- nvcsw: isize,
- nivcsw: isize,
- __reserved: [16]isize = [1]isize{0} ** 16,
-};
-
-pub const cc_t = u8;
-pub const speed_t = u32;
-pub const tcflag_t = u32;
-
-pub const NCCS = 32;
-
-pub const B0 = 0o0000000;
-pub const B50 = 0o0000001;
-pub const B75 = 0o0000002;
-pub const B110 = 0o0000003;
-pub const B134 = 0o0000004;
-pub const B150 = 0o0000005;
-pub const B200 = 0o0000006;
-pub const B300 = 0o0000007;
-pub const B600 = 0o0000010;
-pub const B1200 = 0o0000011;
-pub const B1800 = 0o0000012;
-pub const B2400 = 0o0000013;
-pub const B4800 = 0o0000014;
-pub const B9600 = 0o0000015;
-pub const B19200 = 0o0000016;
-pub const B38400 = 0o0000017;
-pub const BOTHER = 0o0010000;
-pub const B57600 = 0o0010001;
-pub const B115200 = 0o0010002;
-pub const B230400 = 0o0010003;
-pub const B460800 = 0o0010004;
-pub const B500000 = 0o0010005;
-pub const B576000 = 0o0010006;
-pub const B921600 = 0o0010007;
-pub const B1000000 = 0o0010010;
-pub const B1152000 = 0o0010011;
-pub const B1500000 = 0o0010012;
-pub const B2000000 = 0o0010013;
-pub const B2500000 = 0o0010014;
-pub const B3000000 = 0o0010015;
-pub const B3500000 = 0o0010016;
-pub const B4000000 = 0o0010017;
-
-pub usingnamespace switch (arch) {
- .powerpc, .powerpc64, .powerpc64le => struct {
- pub const VINTR = 0;
- pub const VQUIT = 1;
- pub const VERASE = 2;
- pub const VKILL = 3;
- pub const VEOF = 4;
- pub const VMIN = 5;
- pub const VEOL = 6;
- pub const VTIME = 7;
- pub const VEOL2 = 8;
- pub const VSWTC = 9;
- pub const VWERASE = 10;
- pub const VREPRINT = 11;
- pub const VSUSP = 12;
- pub const VSTART = 13;
- pub const VSTOP = 14;
- pub const VLNEXT = 15;
- pub const VDISCARD = 16;
- },
- .sparc, .sparcv9 => struct {
- pub const VINTR = 0;
- pub const VQUIT = 1;
- pub const VERASE = 2;
- pub const VKILL = 3;
- pub const VEOF = 4;
- pub const VEOL = 5;
- pub const VEOL2 = 6;
- pub const VSWTC = 7;
- pub const VSTART = 8;
- pub const VSTOP = 9;
- pub const VSUSP = 10;
- pub const VDSUSP = 11;
- pub const VREPRINT = 12;
- pub const VDISCARD = 13;
- pub const VWERASE = 14;
- pub const VLNEXT = 15;
- pub const VMIN = VEOF;
- pub const VTIME = VEOL;
- },
- .mips, .mipsel, .mips64, .mips64el => struct {
- pub const VINTR = 0;
- pub const VQUIT = 1;
- pub const VERASE = 2;
- pub const VKILL = 3;
- pub const VMIN = 4;
- pub const VTIME = 5;
- pub const VEOL2 = 6;
- pub const VSWTC = 7;
- pub const VSWTCH = 7;
- pub const VSTART = 8;
- pub const VSTOP = 9;
- pub const VSUSP = 10;
- pub const VREPRINT = 12;
- pub const VDISCARD = 13;
- pub const VWERASE = 14;
- pub const VLNEXT = 15;
- pub const VEOF = 16;
- pub const VEOL = 17;
- },
- else => struct {
- pub const VINTR = 0;
- pub const VQUIT = 1;
- pub const VERASE = 2;
- pub const VKILL = 3;
- pub const VEOF = 4;
- pub const VTIME = 5;
- pub const VMIN = 6;
- pub const VSWTC = 7;
- pub const VSTART = 8;
- pub const VSTOP = 9;
- pub const VSUSP = 10;
- pub const VEOL = 11;
- pub const VREPRINT = 12;
- pub const VDISCARD = 13;
- pub const VWERASE = 14;
- pub const VLNEXT = 15;
- pub const VEOL2 = 16;
- },
-};
-
-pub const IGNBRK = 1;
-pub const BRKINT = 2;
-pub const IGNPAR = 4;
-pub const PARMRK = 8;
-pub const INPCK = 16;
-pub const ISTRIP = 32;
-pub const INLCR = 64;
-pub const IGNCR = 128;
-pub const ICRNL = 256;
-pub const IUCLC = 512;
-pub const IXON = 1024;
-pub const IXANY = 2048;
-pub const IXOFF = 4096;
-pub const IMAXBEL = 8192;
-pub const IUTF8 = 16384;
-
-pub const OPOST = 1;
-pub const OLCUC = 2;
-pub const ONLCR = 4;
-pub const OCRNL = 8;
-pub const ONOCR = 16;
-pub const ONLRET = 32;
-pub const OFILL = 64;
-pub const OFDEL = 128;
-pub const VTDLY = 16384;
-pub const VT0 = 0;
-pub const VT1 = 16384;
-
-pub const CSIZE = 48;
-pub const CS5 = 0;
-pub const CS6 = 16;
-pub const CS7 = 32;
-pub const CS8 = 48;
-pub const CSTOPB = 64;
-pub const CREAD = 128;
-pub const PARENB = 256;
-pub const PARODD = 512;
-pub const HUPCL = 1024;
-pub const CLOCAL = 2048;
-
-pub const ISIG = 1;
-pub const ICANON = 2;
-pub const ECHO = 8;
-pub const ECHOE = 16;
-pub const ECHOK = 32;
-pub const ECHONL = 64;
-pub const NOFLSH = 128;
-pub const TOSTOP = 256;
-pub const IEXTEN = 32768;
-
-pub const TCSA = enum(c_uint) {
- NOW,
- DRAIN,
- FLUSH,
- _,
-};
-
-pub const termios = extern struct {
- iflag: tcflag_t,
- oflag: tcflag_t,
- cflag: tcflag_t,
- lflag: tcflag_t,
- line: cc_t,
- cc: [NCCS]cc_t,
- ispeed: speed_t,
- ospeed: speed_t,
-};
-
-pub const SIOCGIFINDEX = 0x8933;
-pub const IFNAMESIZE = 16;
-
-pub const ifmap = extern struct {
- mem_start: u32,
- mem_end: u32,
- base_addr: u16,
- irq: u8,
- dma: u8,
- port: u8,
-};
-
-pub const ifreq = extern struct {
- ifrn: extern union {
- name: [IFNAMESIZE]u8,
- },
- ifru: extern union {
- addr: sockaddr,
- dstaddr: sockaddr,
- broadaddr: sockaddr,
- netmask: sockaddr,
- hwaddr: sockaddr,
- flags: i16,
- ivalue: i32,
- mtu: i32,
- map: ifmap,
- slave: [IFNAMESIZE - 1:0]u8,
- newname: [IFNAMESIZE - 1:0]u8,
- data: ?[*]u8,
- },
-};
-
-// doc comments copied from musl
-pub const rlimit_resource = enum(c_int) {
- /// Per-process CPU limit, in seconds.
- CPU,
-
- /// Largest file that can be created, in bytes.
- FSIZE,
-
- /// Maximum size of data segment, in bytes.
- DATA,
-
- /// Maximum size of stack segment, in bytes.
- STACK,
-
- /// Largest core file that can be created, in bytes.
- CORE,
-
- /// Largest resident set size, in bytes.
- /// This affects swapping; processes that are exceeding their
- /// resident set size will be more likely to have physical memory
- /// taken from them.
- RSS,
-
- /// Number of processes.
- NPROC,
-
- /// Number of open files.
- NOFILE,
-
- /// Locked-in-memory address space.
- MEMLOCK,
-
- /// Address space limit.
- AS,
-
- /// Maximum number of file locks.
- LOCKS,
-
- /// Maximum number of pending signals.
- SIGPENDING,
-
- /// Maximum bytes in POSIX message queues.
- MSGQUEUE,
-
- /// Maximum nice priority allowed to raise to.
- /// Nice levels 19 .. -20 correspond to 0 .. 39
- /// values of this resource limit.
- NICE,
-
- /// Maximum realtime priority allowed for non-priviledged
- /// processes.
- RTPRIO,
-
- /// Maximum CPU time in µs that a process scheduled under a real-time
- /// scheduling policy may consume without making a blocking system
- /// call before being forcibly descheduled.
- RTTIME,
-
- _,
-};
-
-pub const rlim_t = u64;
-
-/// No limit
-pub const RLIM_INFINITY = ~@as(rlim_t, 0);
-
-pub const RLIM_SAVED_MAX = RLIM_INFINITY;
-pub const RLIM_SAVED_CUR = RLIM_INFINITY;
-
-pub const rlimit = extern struct {
- /// Soft limit
- cur: rlim_t,
- /// Hard limit
- max: rlim_t,
-};
-
-pub const MADV_NORMAL = 0;
-pub const MADV_RANDOM = 1;
-pub const MADV_SEQUENTIAL = 2;
-pub const MADV_WILLNEED = 3;
-pub const MADV_DONTNEED = 4;
-pub const MADV_FREE = 8;
-pub const MADV_REMOVE = 9;
-pub const MADV_DONTFORK = 10;
-pub const MADV_DOFORK = 11;
-pub const MADV_MERGEABLE = 12;
-pub const MADV_UNMERGEABLE = 13;
-pub const MADV_HUGEPAGE = 14;
-pub const MADV_NOHUGEPAGE = 15;
-pub const MADV_DONTDUMP = 16;
-pub const MADV_DODUMP = 17;
-pub const MADV_WIPEONFORK = 18;
-pub const MADV_KEEPONFORK = 19;
-pub const MADV_COLD = 20;
-pub const MADV_PAGEOUT = 21;
-pub const MADV_HWPOISON = 100;
-pub const MADV_SOFT_OFFLINE = 101;
-
-pub const POSIX_FADV_NORMAL = 0;
-pub const POSIX_FADV_RANDOM = 1;
-pub const POSIX_FADV_SEQUENTIAL = 2;
-pub const POSIX_FADV_WILLNEED = 3;
-pub usingnamespace switch (arch) {
- .s390x => if (@typeInfo(usize).Int.bits == 64)
- struct {
- pub const POSIX_FADV_DONTNEED = 6;
- pub const POSIX_FADV_NOREUSE = 7;
- }
- else
- struct {
- pub const POSIX_FADV_DONTNEED = 4;
- pub const POSIX_FADV_NOREUSE = 5;
- },
- else => struct {
- pub const POSIX_FADV_DONTNEED = 4;
- pub const POSIX_FADV_NOREUSE = 5;
- },
-};
-
-pub const __kernel_timespec = extern struct {
- tv_sec: i64,
- tv_nsec: i64,
-};