const linux = @import("linux.zig"); const socklen_t = linux.socklen_t; const iovec = linux.iovec; pub const SYS_restart_syscall = 0; pub const SYS_exit = 1; pub const SYS_fork = 2; pub const SYS_read = 3; pub const SYS_write = 4; pub const SYS_open = 5; pub const SYS_close = 6; pub const SYS_waitpid = 7; pub const SYS_creat = 8; pub const SYS_link = 9; pub const SYS_unlink = 10; pub const SYS_execve = 11; pub const SYS_chdir = 12; pub const SYS_time = 13; pub const SYS_mknod = 14; pub const SYS_chmod = 15; pub const SYS_lchown = 16; pub const SYS_break = 17; pub const SYS_oldstat = 18; pub const SYS_lseek = 19; pub const SYS_getpid = 20; pub const SYS_mount = 21; pub const SYS_umount = 22; pub const SYS_setuid = 23; pub const SYS_getuid = 24; pub const SYS_stime = 25; pub const SYS_ptrace = 26; pub const SYS_alarm = 27; pub const SYS_oldfstat = 28; pub const SYS_pause = 29; pub const SYS_utime = 30; pub const SYS_stty = 31; pub const SYS_gtty = 32; pub const SYS_access = 33; pub const SYS_nice = 34; pub const SYS_ftime = 35; pub const SYS_sync = 36; pub const SYS_kill = 37; pub const SYS_rename = 38; pub const SYS_mkdir = 39; pub const SYS_rmdir = 40; pub const SYS_dup = 41; pub const SYS_pipe = 42; pub const SYS_times = 43; pub const SYS_prof = 44; pub const SYS_brk = 45; pub const SYS_setgid = 46; pub const SYS_getgid = 47; pub const SYS_signal = 48; pub const SYS_geteuid = 49; pub const SYS_getegid = 50; pub const SYS_acct = 51; pub const SYS_umount2 = 52; pub const SYS_lock = 53; pub const SYS_ioctl = 54; pub const SYS_fcntl = 55; pub const SYS_mpx = 56; pub const SYS_setpgid = 57; pub const SYS_ulimit = 58; pub const SYS_oldolduname = 59; pub const SYS_umask = 60; pub const SYS_chroot = 61; pub const SYS_ustat = 62; pub const SYS_dup2 = 63; pub const SYS_getppid = 64; pub const SYS_getpgrp = 65; pub const SYS_setsid = 66; pub const SYS_sigaction = 67; pub const SYS_sgetmask = 68; pub const SYS_ssetmask = 69; pub const SYS_setreuid = 70; pub const SYS_setregid = 71; pub const SYS_sigsuspend = 72; pub const SYS_sigpending = 73; pub const SYS_sethostname = 74; pub const SYS_setrlimit = 75; pub const SYS_getrlimit = 76; pub const SYS_getrusage = 77; pub const SYS_gettimeofday = 78; pub const SYS_settimeofday = 79; pub const SYS_getgroups = 80; pub const SYS_setgroups = 81; pub const SYS_select = 82; pub const SYS_symlink = 83; pub const SYS_oldlstat = 84; pub const SYS_readlink = 85; pub const SYS_uselib = 86; pub const SYS_swapon = 87; pub const SYS_reboot = 88; pub const SYS_readdir = 89; pub const SYS_mmap = 90; pub const SYS_munmap = 91; pub const SYS_truncate = 92; pub const SYS_ftruncate = 93; pub const SYS_fchmod = 94; pub const SYS_fchown = 95; pub const SYS_getpriority = 96; pub const SYS_setpriority = 97; pub const SYS_profil = 98; pub const SYS_statfs = 99; pub const SYS_fstatfs = 100; pub const SYS_ioperm = 101; pub const SYS_socketcall = 102; pub const SYS_syslog = 103; pub const SYS_setitimer = 104; pub const SYS_getitimer = 105; pub const SYS_stat = 106; pub const SYS_lstat = 107; pub const SYS_fstat = 108; pub const SYS_olduname = 109; pub const SYS_iopl = 110; pub const SYS_vhangup = 111; pub const SYS_idle = 112; pub const SYS_vm86old = 113; pub const SYS_wait4 = 114; pub const SYS_swapoff = 115; pub const SYS_sysinfo = 116; pub const SYS_ipc = 117; pub const SYS_fsync = 118; pub const SYS_sigreturn = 119; pub const SYS_clone = 120; pub const SYS_setdomainname = 121; pub const SYS_uname = 122; pub const SYS_modify_ldt = 123; pub const SYS_adjtimex = 124; pub const SYS_mprotect = 125; pub const SYS_sigprocmask = 126; pub const SYS_create_module = 127; pub const SYS_init_module = 128; pub const SYS_delete_module = 129; pub const SYS_get_kernel_syms = 130; pub const SYS_quotactl = 131; pub const SYS_getpgid = 132; pub const SYS_fchdir = 133; pub const SYS_bdflush = 134; pub const SYS_sysfs = 135; pub const SYS_personality = 136; pub const SYS_afs_syscall = 137; pub const SYS_setfsuid = 138; pub const SYS_setfsgid = 139; pub const SYS__llseek = 140; pub const SYS_getdents = 141; pub const SYS__newselect = 142; pub const SYS_flock = 143; pub const SYS_msync = 144; pub const SYS_readv = 145; pub const SYS_writev = 146; pub const SYS_getsid = 147; pub const SYS_fdatasync = 148; pub const SYS__sysctl = 149; pub const SYS_mlock = 150; pub const SYS_munlock = 151; pub const SYS_mlockall = 152; pub const SYS_munlockall = 153; pub const SYS_sched_setparam = 154; pub const SYS_sched_getparam = 155; pub const SYS_sched_setscheduler = 156; pub const SYS_sched_getscheduler = 157; pub const SYS_sched_yield = 158; pub const SYS_sched_get_priority_max = 159; pub const SYS_sched_get_priority_min = 160; pub const SYS_sched_rr_get_interval = 161; pub const SYS_nanosleep = 162; pub const SYS_mremap = 163; pub const SYS_setresuid = 164; pub const SYS_getresuid = 165; pub const SYS_vm86 = 166; pub const SYS_query_module = 167; pub const SYS_poll = 168; pub const SYS_nfsservctl = 169; pub const SYS_setresgid = 170; pub const SYS_getresgid = 171; pub const SYS_prctl = 172; pub const SYS_rt_sigreturn = 173; pub const SYS_rt_sigaction = 174; pub const SYS_rt_sigprocmask = 175; pub const SYS_rt_sigpending = 176; pub const SYS_rt_sigtimedwait = 177; pub const SYS_rt_sigqueueinfo = 178; pub const SYS_rt_sigsuspend = 179; pub const SYS_pread64 = 180; pub const SYS_pwrite64 = 181; pub const SYS_chown = 182; pub const SYS_getcwd = 183; pub const SYS_capget = 184; pub const SYS_capset = 185; pub const SYS_sigaltstack = 186; pub const SYS_sendfile = 187; pub const SYS_getpmsg = 188; pub const SYS_putpmsg = 189; pub const SYS_vfork = 190; pub const SYS_ugetrlimit = 191; pub const SYS_mmap2 = 192; pub const SYS_truncate64 = 193; pub const SYS_ftruncate64 = 194; pub const SYS_stat64 = 195; pub const SYS_lstat64 = 196; pub const SYS_fstat64 = 197; pub const SYS_lchown32 = 198; pub const SYS_getuid32 = 199; pub const SYS_getgid32 = 200; pub const SYS_geteuid32 = 201; pub const SYS_getegid32 = 202; pub const SYS_setreuid32 = 203; pub const SYS_setregid32 = 204; pub const SYS_getgroups32 = 205; pub const SYS_setgroups32 = 206; pub const SYS_fchown32 = 207; pub const SYS_setresuid32 = 208; pub const SYS_getresuid32 = 209; pub const SYS_setresgid32 = 210; pub const SYS_getresgid32 = 211; pub const SYS_chown32 = 212; pub const SYS_setuid32 = 213; pub const SYS_setgid32 = 214; pub const SYS_setfsuid32 = 215; pub const SYS_setfsgid32 = 216; pub const SYS_pivot_root = 217; pub const SYS_mincore = 218; pub const SYS_madvise = 219; pub const SYS_madvise1 = 219; pub const SYS_getdents64 = 220; pub const SYS_fcntl64 = 221; pub const SYS_gettid = 224; pub const SYS_readahead = 225; pub const SYS_setxattr = 226; pub const SYS_lsetxattr = 227; pub const SYS_fsetxattr = 228; pub const SYS_getxattr = 229; pub const SYS_lgetxattr = 230; pub const SYS_fgetxattr = 231; pub const SYS_listxattr = 232; pub const SYS_llistxattr = 233; pub const SYS_flistxattr = 234; pub const SYS_removexattr = 235; pub const SYS_lremovexattr = 236; pub const SYS_fremovexattr = 237; pub const SYS_tkill = 238; pub const SYS_sendfile64 = 239; pub const SYS_futex = 240; pub const SYS_sched_setaffinity = 241; pub const SYS_sched_getaffinity = 242; pub const SYS_set_thread_area = 243; pub const SYS_get_thread_area = 244; pub const SYS_io_setup = 245; pub const SYS_io_destroy = 246; pub const SYS_io_getevents = 247; pub const SYS_io_submit = 248; pub const SYS_io_cancel = 249; pub const SYS_fadvise64 = 250; pub const SYS_exit_group = 252; pub const SYS_lookup_dcookie = 253; pub const SYS_epoll_create = 254; pub const SYS_epoll_ctl = 255; pub const SYS_epoll_wait = 256; pub const SYS_remap_file_pages = 257; pub const SYS_set_tid_address = 258; pub const SYS_timer_create = 259; pub const SYS_timer_settime = SYS_timer_create+1; pub const SYS_timer_gettime = SYS_timer_create+2; pub const SYS_timer_getoverrun = SYS_timer_create+3; pub const SYS_timer_delete = SYS_timer_create+4; pub const SYS_clock_settime = SYS_timer_create+5; pub const SYS_clock_gettime = SYS_timer_create+6; pub const SYS_clock_getres = SYS_timer_create+7; pub const SYS_clock_nanosleep = SYS_timer_create+8; pub const SYS_statfs64 = 268; pub const SYS_fstatfs64 = 269; pub const SYS_tgkill = 270; pub const SYS_utimes = 271; pub const SYS_fadvise64_64 = 272; pub const SYS_vserver = 273; pub const SYS_mbind = 274; pub const SYS_get_mempolicy = 275; pub const SYS_set_mempolicy = 276; pub const SYS_mq_open = 277; pub const SYS_mq_unlink = SYS_mq_open+1; pub const SYS_mq_timedsend = SYS_mq_open+2; pub const SYS_mq_timedreceive = SYS_mq_open+3; pub const SYS_mq_notify = SYS_mq_open+4; pub const SYS_mq_getsetattr = SYS_mq_open+5; pub const SYS_kexec_load = 283; pub const SYS_waitid = 284; pub const SYS_add_key = 286; pub const SYS_request_key = 287; pub const SYS_keyctl = 288; pub const SYS_ioprio_set = 289; pub const SYS_ioprio_get = 290; pub const SYS_inotify_init = 291; pub const SYS_inotify_add_watch = 292; pub const SYS_inotify_rm_watch = 293; pub const SYS_migrate_pages = 294; pub const SYS_openat = 295; pub const SYS_mkdirat = 296; pub const SYS_mknodat = 297; pub const SYS_fchownat = 298; pub const SYS_futimesat = 299; pub const SYS_fstatat64 = 300; pub const SYS_unlinkat = 301; pub const SYS_renameat = 302; pub const SYS_linkat = 303; pub const SYS_symlinkat = 304; pub const SYS_readlinkat = 305; pub const SYS_fchmodat = 306; pub const SYS_faccessat = 307; pub const SYS_pselect6 = 308; pub const SYS_ppoll = 309; pub const SYS_unshare = 310; pub const SYS_set_robust_list = 311; pub const SYS_get_robust_list = 312; pub const SYS_splice = 313; pub const SYS_sync_file_range = 314; pub const SYS_tee = 315; pub const SYS_vmsplice = 316; pub const SYS_move_pages = 317; pub const SYS_getcpu = 318; pub const SYS_epoll_pwait = 319; pub const SYS_utimensat = 320; pub const SYS_signalfd = 321; pub const SYS_timerfd_create = 322; pub const SYS_eventfd = 323; pub const SYS_fallocate = 324; pub const SYS_timerfd_settime = 325; pub const SYS_timerfd_gettime = 326; pub const SYS_signalfd4 = 327; pub const SYS_eventfd2 = 328; pub const SYS_epoll_create1 = 329; pub const SYS_dup3 = 330; pub const SYS_pipe2 = 331; pub const SYS_inotify_init1 = 332; pub const SYS_preadv = 333; pub const SYS_pwritev = 334; pub const SYS_rt_tgsigqueueinfo = 335; pub const SYS_perf_event_open = 336; pub const SYS_recvmmsg = 337; pub const SYS_fanotify_init = 338; pub const SYS_fanotify_mark = 339; pub const SYS_prlimit64 = 340; pub const SYS_name_to_handle_at = 341; pub const SYS_open_by_handle_at = 342; pub const SYS_clock_adjtime = 343; pub const SYS_syncfs = 344; pub const SYS_sendmmsg = 345; pub const SYS_setns = 346; pub const SYS_process_vm_readv = 347; pub const SYS_process_vm_writev = 348; pub const SYS_kcmp = 349; pub const SYS_finit_module = 350; pub const SYS_sched_setattr = 351; pub const SYS_sched_getattr = 352; pub const SYS_renameat2 = 353; pub const SYS_seccomp = 354; pub const SYS_getrandom = 355; pub const SYS_memfd_create = 356; pub const SYS_bpf = 357; pub const SYS_execveat = 358; pub const SYS_socket = 359; pub const SYS_socketpair = 360; pub const SYS_bind = 361; pub const SYS_connect = 362; pub const SYS_listen = 363; pub const SYS_accept4 = 364; pub const SYS_getsockopt = 365; pub const SYS_setsockopt = 366; pub const SYS_getsockname = 367; pub const SYS_getpeername = 368; pub const SYS_sendto = 369; pub const SYS_sendmsg = 370; pub const SYS_recvfrom = 371; pub const SYS_recvmsg = 372; pub const SYS_shutdown = 373; pub const SYS_userfaultfd = 374; pub const SYS_membarrier = 375; pub const SYS_mlock2 = 376; pub const O_CREAT = 0o100; pub const O_EXCL = 0o200; pub const O_NOCTTY = 0o400; pub const O_TRUNC = 0o1000; pub const O_APPEND = 0o2000; pub const O_NONBLOCK = 0o4000; pub const O_DSYNC = 0o10000; pub const O_SYNC = 0o4010000; pub const O_RSYNC = 0o4010000; pub const O_DIRECTORY = 0o200000; pub const O_NOFOLLOW = 0o400000; pub const O_CLOEXEC = 0o2000000; pub const O_ASYNC = 0o20000; pub const O_DIRECT = 0o40000; pub const O_LARGEFILE = 0o100000; pub const O_NOATIME = 0o1000000; pub const O_PATH = 0o10000000; pub const O_TMPFILE = 0o20200000; pub const O_NDELAY = O_NONBLOCK; pub const F_DUPFD = 0; pub const F_GETFD = 1; pub const F_SETFD = 2; pub const F_GETFL = 3; pub const F_SETFL = 4; pub const F_SETOWN = 8; pub const F_GETOWN = 9; pub const F_SETSIG = 10; pub const F_GETSIG = 11; pub const F_GETLK = 12; pub const F_SETLK = 13; pub const F_SETLKW = 14; pub const F_SETOWN_EX = 15; pub const F_GETOWN_EX = 16; pub const F_GETOWNER_UIDS = 17; pub inline fn syscall0(number: usize) -> usize { asm volatile ("int $0x80" : [ret] "={eax}" (-> usize) : [number] "{eax}" (number)) } pub inline fn syscall1(number: usize, arg1: usize) -> usize { asm volatile ("int $0x80" : [ret] "={eax}" (-> usize) : [number] "{eax}" (number), [arg1] "{ebx}" (arg1)) } pub inline fn syscall2(number: usize, arg1: usize, arg2: usize) -> usize { asm volatile ("int $0x80" : [ret] "={eax}" (-> usize) : [number] "{eax}" (number), [arg1] "{ebx}" (arg1), [arg2] "{ecx}" (arg2)) } pub inline fn syscall3(number: usize, arg1: usize, arg2: usize, arg3: usize) -> usize { asm volatile ("int $0x80" : [ret] "={eax}" (-> usize) : [number] "{eax}" (number), [arg1] "{ebx}" (arg1), [arg2] "{ecx}" (arg2), [arg3] "{edx}" (arg3)) } pub inline fn syscall4(number: usize, arg1: usize, arg2: usize, arg3: usize, arg4: usize) -> usize { asm volatile ("int $0x80" : [ret] "={eax}" (-> usize) : [number] "{eax}" (number), [arg1] "{ebx}" (arg1), [arg2] "{ecx}" (arg2), [arg3] "{edx}" (arg3), [arg4] "{esi}" (arg4)) } pub inline fn syscall5(number: usize, arg1: usize, arg2: usize, arg3: usize, arg4: usize, arg5: usize) -> usize { asm volatile ("int $0x80" : [ret] "={eax}" (-> usize) : [number] "{eax}" (number), [arg1] "{ebx}" (arg1), [arg2] "{ecx}" (arg2), [arg3] "{edx}" (arg3), [arg4] "{esi}" (arg4), [arg5] "{edi}" (arg5)) } pub inline fn syscall6(number: usize, arg1: usize, arg2: usize, arg3: usize, arg4: usize, arg5: usize, arg6: usize) -> usize { asm volatile ("int $0x80" : [ret] "={eax}" (-> usize) : [number] "{eax}" (number), [arg1] "{ebx}" (arg1), [arg2] "{ecx}" (arg2), [arg3] "{edx}" (arg3), [arg4] "{esi}" (arg4), [arg5] "{edi}" (arg5), [arg6] "{ebp}" (arg6)) } pub nakedcc fn restore() { asm volatile ( \\popl %%eax \\movl $119, %%eax \\int $0x80 : : : "rcx", "r11") } pub nakedcc fn restore_rt() { asm volatile ("int $0x80" : : [number] "{eax}" (usize(SYS_rt_sigreturn)) : "rcx", "r11") } export struct msghdr { msg_name: &u8, msg_namelen: socklen_t, msg_iov: &iovec, msg_iovlen: i32, msg_control: &u8, msg_controllen: socklen_t, msg_flags: i32, }