| #include "sandboxed_api/sandbox2/syscall_defs.h" |
| |
| #include <cstdint> |
| #include <type_traits> |
| |
| #include <glog/logging.h> |
| #include "absl/strings/escaping.h" |
| #include "absl/strings/str_cat.h" |
| #include "absl/strings/str_format.h" |
| #include "sandboxed_api/sandbox2/util.h" |
| |
| namespace sandbox2 { |
| |
| // Type of a given syscall argument. Used with argument conversion routines. |
| enum ArgType { |
| kGen = 1, |
| kInt, |
| kPath, |
| kHex, |
| kOct, |
| kSocketCall, |
| kSocketCallPtr, |
| kSignal, |
| kString, |
| kAddressFamily, |
| kSockaddr, |
| kSockmsghdr, |
| kCloneFlag, |
| }; |
| |
| // Single syscall definition |
| struct SyscallTable::Entry { |
| // Returns the number of arguments which given syscall takes. |
| int GetNumArgs() const { |
| if (num_args < 0 || num_args > syscalls::kMaxArgs) { |
| return syscalls::kMaxArgs; |
| } |
| return num_args; |
| } |
| |
| static std::string GetArgumentDescription(uint64_t value, ArgType type, |
| pid_t pid); |
| |
| std::vector<std::string> GetArgumentsDescription( |
| const uint64_t values[syscalls::kMaxArgs], pid_t pid) const; |
| |
| const absl::string_view name; |
| const int num_args; |
| const std::array<ArgType, syscalls::kMaxArgs> arg_types; |
| }; |
| |
| std::string SyscallTable::Entry::GetArgumentDescription(uint64_t value, |
| ArgType type, |
| pid_t pid) { |
| std::string ret = absl::StrFormat("%#x", value); |
| switch (type) { |
| case kOct: |
| absl::StrAppendFormat(&ret, " [\\0%o]", value); |
| break; |
| case kPath: |
| if (auto path_or = util::ReadCPathFromPid(pid, value); path_or.ok()) { |
| absl::StrAppendFormat(&ret, " ['%s']", |
| absl::CHexEscape(path_or.value())); |
| } else { |
| absl::StrAppend(&ret, " [unreadable path]"); |
| } |
| break; |
| case kInt: |
| absl::StrAppendFormat(&ret, " [%d]", value); |
| break; |
| default: |
| break; |
| } |
| return ret; |
| } |
| |
| template <typename... ArgTypes> |
| constexpr SyscallTable::Entry MakeEntry(absl::string_view name, |
| ArgTypes... arg_types) { |
| static_assert(sizeof...(arg_types) <= syscalls::kMaxArgs, |
| "Too many arguments for syscall"); |
| return {name, sizeof...(arg_types), {arg_types...}}; |
| } |
| |
| struct UnknownArguments {}; |
| constexpr SyscallTable::Entry MakeEntry(absl::string_view name, |
| UnknownArguments) { |
| return {name, -1, {kGen, kGen, kGen, kGen, kGen, kGen}}; |
| } |
| |
| absl::string_view SyscallTable::GetName(int syscall) const { |
| return syscall < data_.size() ? data_[syscall].name : ""; |
| } |
| |
| std::vector<std::string> SyscallTable::GetArgumentsDescription( |
| int syscall, const uint64_t values[], pid_t pid) const { |
| static auto kInvalidEntry = MakeEntry("", kGen, kGen, kGen, kGen, kGen, kGen); |
| const auto& entry = syscall < data_.size() ? data_[syscall] : kInvalidEntry; |
| |
| int num_args = entry.GetNumArgs(); |
| std::vector<std::string> rv; |
| rv.reserve(num_args); |
| for (int i = 0; i < num_args; ++i) { |
| rv.push_back(SyscallTable::Entry::GetArgumentDescription( |
| values[i], entry.arg_types[i], pid)); |
| } |
| return rv; |
| } |
| |
| #define SYSCALLS_UNUSED(name) \ |
| MakeEntry(name, kHex, kHex, kHex, kHex, kHex, kHex) |
| |
| #define SYSCALLS_UNUSED0_9(prefix) \ |
| SYSCALLS_UNUSED(prefix "0"), SYSCALLS_UNUSED(prefix "1"), \ |
| SYSCALLS_UNUSED(prefix "2"), SYSCALLS_UNUSED(prefix "3"), \ |
| SYSCALLS_UNUSED(prefix "4"), SYSCALLS_UNUSED(prefix "5"), \ |
| SYSCALLS_UNUSED(prefix "6"), SYSCALLS_UNUSED(prefix "7"), \ |
| SYSCALLS_UNUSED(prefix "8"), SYSCALLS_UNUSED(prefix "9") |
| |
| #define SYSCALLS_UNUSED00_49(prefix) \ |
| SYSCALLS_UNUSED0_9(prefix "0"), SYSCALLS_UNUSED0_9(prefix "1"), \ |
| SYSCALLS_UNUSED0_9(prefix "2"), SYSCALLS_UNUSED0_9(prefix "3"), \ |
| SYSCALLS_UNUSED0_9(prefix "4") |
| #define SYSCALLS_UNUSED50_99(prefix) \ |
| SYSCALLS_UNUSED0_9(prefix "5"), SYSCALLS_UNUSED0_9(prefix "6"), \ |
| SYSCALLS_UNUSED0_9(prefix "7"), SYSCALLS_UNUSED0_9(prefix "8"), \ |
| SYSCALLS_UNUSED0_9(prefix "9") |
| #define SYSCALLS_UNUSED00_99(prefix) \ |
| SYSCALLS_UNUSED00_49(prefix), SYSCALLS_UNUSED50_99(prefix) |
| |
| #if defined(__x86_64__) |
| // Syscall description table for Linux x86_64 |
| constexpr SyscallTable::Entry kSyscallDataX8664[] = { |
| MakeEntry("read", kInt, kHex, kInt), // 0 |
| MakeEntry("write", kInt, kHex, kInt), // 1 |
| MakeEntry("open", kPath, kHex, kOct), // 2 |
| MakeEntry("close", kInt), // 3 |
| MakeEntry("stat", kPath, kGen), // 4 |
| MakeEntry("fstat", kInt, kHex), // 5 |
| MakeEntry("lstat", kPath, kGen), // 6 |
| MakeEntry("poll", UnknownArguments()), // 7 |
| MakeEntry("lseek", UnknownArguments()), // 8 |
| MakeEntry("mmap", kHex, kInt, kHex, kHex, kInt, kInt), // 9 |
| MakeEntry("mprotect", kHex, kHex, kHex), // 10 |
| MakeEntry("munmap", kHex, kHex), // 11 |
| MakeEntry("brk", kHex), // 12 |
| MakeEntry("rt_sigaction", kSignal, kHex, kHex, kInt), // 13 |
| MakeEntry("rt_sigprocmask", UnknownArguments()), // 14 |
| MakeEntry("rt_sigreturn"), // 15 |
| MakeEntry("ioctl", UnknownArguments()), // 16 |
| MakeEntry("pread64", UnknownArguments()), // 17 |
| MakeEntry("pwrite64", UnknownArguments()), // 18 |
| MakeEntry("readv", UnknownArguments()), // 19 |
| MakeEntry("writev", UnknownArguments()), // 20 |
| MakeEntry("access", kPath, kHex), // 21 |
| MakeEntry("pipe", UnknownArguments()), // 22 |
| MakeEntry("select", UnknownArguments()), // 23 |
| MakeEntry("sched_yield", UnknownArguments()), // 24 |
| MakeEntry("mremap", UnknownArguments()), // 25 |
| MakeEntry("msync", UnknownArguments()), // 26 |
| MakeEntry("mincore", UnknownArguments()), // 27 |
| MakeEntry("madvise", UnknownArguments()), // 28 |
| MakeEntry("shmget", UnknownArguments()), // 29 |
| MakeEntry("shmat", UnknownArguments()), // 30 |
| MakeEntry("shmctl", UnknownArguments()), // 31 |
| MakeEntry("dup", UnknownArguments()), // 32 |
| MakeEntry("dup2", kGen, kGen), // 33 |
| MakeEntry("pause"), // 34 |
| MakeEntry("nanosleep", kHex, kHex), // 35 |
| MakeEntry("getitimer", UnknownArguments()), // 36 |
| MakeEntry("alarm", kInt), // 37 |
| MakeEntry("setitimer", UnknownArguments()), // 38 |
| MakeEntry("getpid"), // 39 |
| MakeEntry("sendfile", UnknownArguments()), // 40 |
| MakeEntry("socket", kAddressFamily, kInt, kInt), // 41 |
| MakeEntry("connect", kInt, kSockaddr, kInt), // 42 |
| MakeEntry("accept", UnknownArguments()), // 43 |
| MakeEntry("sendto", kInt, kGen, kInt, kHex, kSockaddr, kInt), // 44 |
| MakeEntry("recvfrom", UnknownArguments()), // 45 |
| MakeEntry("sendmsg", kInt, kSockmsghdr, kHex), // 46 |
| MakeEntry("recvmsg", UnknownArguments()), // 47 |
| MakeEntry("shutdown", UnknownArguments()), // 48 |
| MakeEntry("bind", UnknownArguments()), // 49 |
| MakeEntry("listen", UnknownArguments()), // 50 |
| MakeEntry("getsockname", UnknownArguments()), // 51 |
| MakeEntry("getpeername", UnknownArguments()), // 52 |
| MakeEntry("socketpair", UnknownArguments()), // 53 |
| MakeEntry("setsockopt", UnknownArguments()), // 54 |
| MakeEntry("getsockopt", UnknownArguments()), // 55 |
| MakeEntry("clone", kCloneFlag, kHex, kHex, kHex, kHex), // 56 |
| MakeEntry("fork"), // 57 |
| MakeEntry("vfork"), // 58 |
| MakeEntry("execve", kPath, kHex, kHex), // 59 |
| MakeEntry("exit", kInt), // 60 |
| MakeEntry("wait4", kInt, kHex, kHex, kHex), // 61 |
| MakeEntry("kill", kInt, kSignal), // 62 |
| MakeEntry("uname", UnknownArguments()), // 63 |
| MakeEntry("semget", UnknownArguments()), // 64 |
| MakeEntry("semop", UnknownArguments()), // 65 |
| MakeEntry("semctl", UnknownArguments()), // 66 |
| MakeEntry("shmdt", UnknownArguments()), // 67 |
| MakeEntry("msgget", UnknownArguments()), // 68 |
| MakeEntry("msgsnd", UnknownArguments()), // 69 |
| MakeEntry("msgrcv", UnknownArguments()), // 70 |
| MakeEntry("msgctl", UnknownArguments()), // 71 |
| MakeEntry("fcntl", UnknownArguments()), // 72 |
| MakeEntry("flock", UnknownArguments()), // 73 |
| MakeEntry("fsync", UnknownArguments()), // 74 |
| MakeEntry("fdatasync", UnknownArguments()), // 75 |
| MakeEntry("truncate", kPath, kInt), // 76 |
| MakeEntry("ftruncate", UnknownArguments()), // 77 |
| MakeEntry("getdents", UnknownArguments()), // 78 |
| MakeEntry("getcwd", UnknownArguments()), // 79 |
| MakeEntry("chdir", kPath), // 80 |
| MakeEntry("fchdir", UnknownArguments()), // 81 |
| MakeEntry("rename", kPath, kPath), // 82 |
| MakeEntry("mkdir", kPath, kOct), // 83 |
| MakeEntry("rmdir", kPath), // 84 |
| MakeEntry("creat", kPath, kOct), // 85 |
| MakeEntry("link", kPath, kPath), // 86 |
| MakeEntry("unlink", kPath), // 87 |
| MakeEntry("symlink", kPath, kPath), // 88 |
| MakeEntry("readlink", kPath, kGen, kInt), // 89 |
| MakeEntry("chmod", kPath, kOct), // 90 |
| MakeEntry("fchmod", UnknownArguments()), // 91 |
| MakeEntry("chown", kPath, kInt, kInt), // 92 |
| MakeEntry("fchown", UnknownArguments()), // 93 |
| MakeEntry("lchown", kPath, kInt, kInt), // 94 |
| MakeEntry("umask", kHex), // 95 |
| MakeEntry("gettimeofday", kHex, kHex), // 96 |
| MakeEntry("getrlimit", UnknownArguments()), // 97 |
| MakeEntry("getrusage", UnknownArguments()), // 98 |
| MakeEntry("sysinfo", UnknownArguments()), // 99 |
| MakeEntry("times", UnknownArguments()), // 100 |
| MakeEntry("ptrace", kGen, kGen, kGen), // 101 |
| MakeEntry("getuid", UnknownArguments()), // 102 |
| MakeEntry("syslog", UnknownArguments()), // 103 |
| MakeEntry("getgid", UnknownArguments()), // 104 |
| MakeEntry("setuid", UnknownArguments()), // 105 |
| MakeEntry("setgid", UnknownArguments()), // 106 |
| MakeEntry("geteuid", UnknownArguments()), // 107 |
| MakeEntry("getegid", UnknownArguments()), // 108 |
| MakeEntry("setpgid", UnknownArguments()), // 109 |
| MakeEntry("getppid", UnknownArguments()), // 110 |
| MakeEntry("getpgrp", UnknownArguments()), // 111 |
| MakeEntry("setsid", UnknownArguments()), // 112 |
| MakeEntry("setreuid", UnknownArguments()), // 113 |
| MakeEntry("setregid", UnknownArguments()), // 114 |
| MakeEntry("getgroups", UnknownArguments()), // 115 |
| MakeEntry("setgroups", UnknownArguments()), // 116 |
| MakeEntry("setresuid", UnknownArguments()), // 117 |
| MakeEntry("getresuid", UnknownArguments()), // 118 |
| MakeEntry("setresgid", UnknownArguments()), // 119 |
| MakeEntry("getresgid", UnknownArguments()), // 120 |
| MakeEntry("getpgid", UnknownArguments()), // 121 |
| MakeEntry("setfsuid", UnknownArguments()), // 122 |
| MakeEntry("setfsgid", UnknownArguments()), // 123 |
| MakeEntry("getsid", UnknownArguments()), // 124 |
| MakeEntry("capget", UnknownArguments()), // 125 |
| MakeEntry("capset", UnknownArguments()), // 126 |
| MakeEntry("rt_sigpending", UnknownArguments()), // 127 |
| MakeEntry("rt_sigtimedwait", UnknownArguments()), // 128 |
| MakeEntry("rt_sigqueueinfo", UnknownArguments()), // 129 |
| MakeEntry("rt_sigsuspend", UnknownArguments()), // 130 |
| MakeEntry("sigaltstack", UnknownArguments()), // 131 |
| MakeEntry("utime", UnknownArguments()), // 132 |
| MakeEntry("mknod", kPath, kOct, kHex), // 133 |
| MakeEntry("uselib", kPath), // 134 |
| MakeEntry("personality", UnknownArguments()), // 135 |
| MakeEntry("ustat", UnknownArguments()), // 136 |
| MakeEntry("statfs", UnknownArguments()), // 137 |
| MakeEntry("fstatfs", UnknownArguments()), // 138 |
| MakeEntry("sysfs", UnknownArguments()), // 139 |
| MakeEntry("getpriority", UnknownArguments()), // 140 |
| MakeEntry("setpriority", UnknownArguments()), // 141 |
| MakeEntry("sched_setparam", UnknownArguments()), // 142 |
| MakeEntry("sched_getparam", UnknownArguments()), // 143 |
| MakeEntry("sched_setscheduler", UnknownArguments()), // 144 |
| MakeEntry("sched_getscheduler", UnknownArguments()), // 145 |
| MakeEntry("sched_get_priority_max", UnknownArguments()), // 146 |
| MakeEntry("sched_get_priority_min", UnknownArguments()), // 147 |
| MakeEntry("sched_rr_get_interval", UnknownArguments()), // 148 |
| MakeEntry("mlock", UnknownArguments()), // 149 |
| MakeEntry("munlock", UnknownArguments()), // 150 |
| MakeEntry("mlockall", UnknownArguments()), // 151 |
| MakeEntry("munlockall", UnknownArguments()), // 152 |
| MakeEntry("vhangup", UnknownArguments()), // 153 |
| MakeEntry("modify_ldt", UnknownArguments()), // 154 |
| MakeEntry("pivot_root", kPath, kPath), // 155 |
| MakeEntry("_sysctl", UnknownArguments()), // 156 |
| MakeEntry("prctl", kInt, kHex, kHex, kHex, kHex), // 157 |
| MakeEntry("arch_prctl", kInt, kHex), // 158 |
| MakeEntry("adjtimex", UnknownArguments()), // 159 |
| MakeEntry("setrlimit", UnknownArguments()), // 160 |
| MakeEntry("chroot", kPath), // 161 |
| MakeEntry("sync", UnknownArguments()), // 162 |
| MakeEntry("acct", kPath), // 163 |
| MakeEntry("settimeofday", kHex, kHex), // 164 |
| MakeEntry("mount", kPath, kPath, kString, kHex, kGen), // 165 |
| MakeEntry("umount2", kPath, kHex), // 166 |
| MakeEntry("swapon", kPath, kHex), // 167 |
| MakeEntry("swapoff", kPath), // 168 |
| MakeEntry("reboot", UnknownArguments()), // 169 |
| MakeEntry("sethostname", UnknownArguments()), // 170 |
| MakeEntry("setdomainname", UnknownArguments()), // 171 |
| MakeEntry("iopl", UnknownArguments()), // 172 |
| MakeEntry("ioperm", UnknownArguments()), // 173 |
| MakeEntry("create_module", UnknownArguments()), // 174 |
| MakeEntry("init_module", UnknownArguments()), // 175 |
| MakeEntry("delete_module", UnknownArguments()), // 176 |
| MakeEntry("get_kernel_syms", UnknownArguments()), // 177 |
| MakeEntry("query_module", UnknownArguments()), // 178 |
| MakeEntry("quotactl", kInt, kPath, kInt), // 179 |
| MakeEntry("nfsservctl", UnknownArguments()), // 180 |
| MakeEntry("getpmsg", UnknownArguments()), // 181 |
| MakeEntry("putpmsg", UnknownArguments()), // 182 |
| MakeEntry("afs_syscall", UnknownArguments()), // 183 |
| MakeEntry("tuxcall", UnknownArguments()), // 184 |
| MakeEntry("security", UnknownArguments()), // 185 |
| MakeEntry("gettid"), // 186 |
| MakeEntry("readahead", UnknownArguments()), // 187 |
| MakeEntry("setxattr", kPath, kString, kGen, kInt, kHex), // 188 |
| MakeEntry("lsetxattr", kPath, kString, kGen, kInt, kHex), // 189 |
| MakeEntry("fsetxattr", UnknownArguments()), // 190 |
| MakeEntry("getxattr", kPath, kString, kGen, kInt), // 191 |
| MakeEntry("lgetxattr", kPath, kString, kGen, kInt), // 192 |
| MakeEntry("fgetxattr", UnknownArguments()), // 193 |
| MakeEntry("listxattr", kPath, kGen, kInt), // 194 |
| MakeEntry("llistxattr", kPath, kGen, kInt), // 195 |
| MakeEntry("flistxattr", UnknownArguments()), // 196 |
| MakeEntry("removexattr", kPath, kString), // 197 |
| MakeEntry("lremovexattr", UnknownArguments()), // 198 |
| MakeEntry("fremovexattr", UnknownArguments()), // 199 |
| MakeEntry("tkill", kInt, kSignal), // 200 |
| MakeEntry("time", kHex), // 201 |
| MakeEntry("futex", kGen, kInt, kInt, kGen, kGen, kInt), // 202 |
| MakeEntry("sched_setaffinity", UnknownArguments()), // 203 |
| MakeEntry("sched_getaffinity", UnknownArguments()), // 204 |
| MakeEntry("set_thread_area", kHex), // 205 |
| MakeEntry("io_setup", UnknownArguments()), // 206 |
| MakeEntry("io_destroy", UnknownArguments()), // 207 |
| MakeEntry("io_getevents", UnknownArguments()), // 208 |
| MakeEntry("io_submit", UnknownArguments()), // 209 |
| MakeEntry("io_cancel", UnknownArguments()), // 210 |
| MakeEntry("get_thread_area", kHex), // 211 |
| MakeEntry("lookup_dcookie", UnknownArguments()), // 212 |
| MakeEntry("epoll_create", UnknownArguments()), // 213 |
| MakeEntry("epoll_ctl_old", UnknownArguments()), // 214 |
| MakeEntry("epoll_wait_old", UnknownArguments()), // 215 |
| MakeEntry("remap_file_pages", UnknownArguments()), // 216 |
| MakeEntry("getdents64", UnknownArguments()), // 217 |
| MakeEntry("set_tid_address", kHex), // 218 |
| MakeEntry("restart_syscall", UnknownArguments()), // 219 |
| MakeEntry("semtimedop", UnknownArguments()), // 220 |
| MakeEntry("fadvise64", UnknownArguments()), // 221 |
| MakeEntry("timer_create", UnknownArguments()), // 222 |
| MakeEntry("timer_settime", UnknownArguments()), // 223 |
| MakeEntry("timer_gettime", UnknownArguments()), // 224 |
| MakeEntry("timer_getoverrun", UnknownArguments()), // 225 |
| MakeEntry("timer_delete", UnknownArguments()), // 226 |
| MakeEntry("clock_settime", UnknownArguments()), // 227 |
| MakeEntry("clock_gettime", UnknownArguments()), // 228 |
| MakeEntry("clock_getres", UnknownArguments()), // 229 |
| MakeEntry("clock_nanosleep", UnknownArguments()), // 230 |
| MakeEntry("exit_group", kInt), // 231 |
| MakeEntry("epoll_wait", UnknownArguments()), // 232 |
| MakeEntry("epoll_ctl", UnknownArguments()), // 233 |
| MakeEntry("tgkill", kInt, kInt, kSignal), // 234 |
| MakeEntry("utimes", UnknownArguments()), // 235 |
| MakeEntry("vserver", UnknownArguments()), // 236 |
| MakeEntry("mbind", UnknownArguments()), // 237 |
| MakeEntry("set_mempolicy", UnknownArguments()), // 238 |
| MakeEntry("get_mempolicy", UnknownArguments()), // 239 |
| MakeEntry("mq_open", UnknownArguments()), // 240 |
| MakeEntry("mq_unlink", UnknownArguments()), // 241 |
| MakeEntry("mq_timedsend", UnknownArguments()), // 242 |
| MakeEntry("mq_timedreceive", UnknownArguments()), // 243 |
| MakeEntry("mq_notify", UnknownArguments()), // 244 |
| MakeEntry("mq_getsetattr", UnknownArguments()), // 245 |
| MakeEntry("kexec_load", UnknownArguments()), // 246 |
| MakeEntry("waitid", UnknownArguments()), // 247 |
| MakeEntry("add_key", UnknownArguments()), // 248 |
| MakeEntry("request_key", UnknownArguments()), // 249 |
| MakeEntry("keyctl", UnknownArguments()), // 250 |
| MakeEntry("ioprio_set", UnknownArguments()), // 251 |
| MakeEntry("ioprio_get", UnknownArguments()), // 252 |
| MakeEntry("inotify_init", UnknownArguments()), // 253 |
| MakeEntry("inotify_add_watch", UnknownArguments()), // 254 |
| MakeEntry("inotify_rm_watch", UnknownArguments()), // 255 |
| MakeEntry("migrate_pages", UnknownArguments()), // 256 |
| MakeEntry("openat", kGen, kPath, kOct, kHex), // 257 |
| MakeEntry("mkdirat", kGen, kPath), // 258 |
| MakeEntry("mknodat", kGen, kPath), // 259 |
| MakeEntry("fchownat", kGen, kPath), // 260 |
| MakeEntry("futimesat", kGen, kPath), // 261 |
| MakeEntry("newfstatat", kGen, kPath), // 262 |
| MakeEntry("unlinkat", kGen, kPath), // 263 |
| MakeEntry("renameat", kGen, kPath, kGen, kPath), // 264 |
| MakeEntry("linkat", kGen, kPath, kGen, kPath), // 265 |
| MakeEntry("symlinkat", kPath, kGen, kPath), // 266 |
| MakeEntry("readlinkat", kGen, kPath), // 267 |
| MakeEntry("fchmodat", kGen, kPath), // 268 |
| MakeEntry("faccessat", kGen, kPath), // 269 |
| MakeEntry("pselect6", UnknownArguments()), // 270 |
| MakeEntry("ppoll", UnknownArguments()), // 271 |
| MakeEntry("unshare", UnknownArguments()), // 272 |
| MakeEntry("set_robust_list", kGen, kGen), // 273 |
| MakeEntry("get_robust_list", UnknownArguments()), // 274 |
| MakeEntry("splice", UnknownArguments()), // 275 |
| MakeEntry("tee", UnknownArguments()), // 276 |
| MakeEntry("sync_file_range", UnknownArguments()), // 277 |
| MakeEntry("vmsplice", UnknownArguments()), // 278 |
| MakeEntry("move_pages", UnknownArguments()), // 279 |
| MakeEntry("utimensat", UnknownArguments()), // 280 |
| MakeEntry("epoll_pwait", UnknownArguments()), // 281 |
| MakeEntry("signalfd", UnknownArguments()), // 282 |
| MakeEntry("timerfd_create", UnknownArguments()), // 283 |
| MakeEntry("eventfd", UnknownArguments()), // 284 |
| MakeEntry("fallocate", UnknownArguments()), // 285 |
| MakeEntry("timerfd_settime", UnknownArguments()), // 286 |
| MakeEntry("timerfd_gettime", UnknownArguments()), // 287 |
| MakeEntry("accept4", UnknownArguments()), // 288 |
| MakeEntry("signalfd4", UnknownArguments()), // 289 |
| MakeEntry("eventfd2", UnknownArguments()), // 290 |
| MakeEntry("epoll_create1", UnknownArguments()), // 291 |
| MakeEntry("dup3", kGen, kGen, kGen), // 292 |
| MakeEntry("pipe2", UnknownArguments()), // 293 |
| MakeEntry("inotify_init1", UnknownArguments()), // 294 |
| MakeEntry("preadv", UnknownArguments()), // 295 |
| MakeEntry("pwritev", UnknownArguments()), // 296 |
| MakeEntry("rt_tgsigqueueinfo", UnknownArguments()), // 297 |
| MakeEntry("perf_event_open", UnknownArguments()), // 298 |
| MakeEntry("recvmmsg", kInt, kHex, kHex, kHex), // 299 |
| MakeEntry("fanotify_init", kHex, kHex, kInt), // 300 |
| MakeEntry("fanotify_mark", kInt, kHex, kInt, kPath), // 301 |
| MakeEntry("prlimit64", kInt, kInt, kHex, kHex), // 302 |
| MakeEntry("name_to_handle_at", kInt, kGen, kHex, kHex, kHex), // 303 |
| MakeEntry("open_by_handle_at", kInt, kHex, kHex), // 304 |
| MakeEntry("clock_adjtime", kInt, kHex), // 305 |
| MakeEntry("syncfs", kInt), // 306 |
| MakeEntry("sendmmsg", kInt, kHex, kInt, kHex), // 307 |
| MakeEntry("setns", kInt, kHex), // 308 |
| MakeEntry("getcpu", kHex, kHex, kHex), // 309 |
| MakeEntry("process_vm_readv", kInt, kHex, kInt, kHex, kInt, kInt), // 310 |
| MakeEntry("process_vm_writev", kInt, kHex, kInt, kHex, kInt, kInt), // 311 |
| MakeEntry("kcmp", kInt, kInt, kInt, kHex, kHex), // 312 |
| MakeEntry("finit_module", kInt, kPath, kHex), // 313 |
| MakeEntry("sched_setattr", kGen, kGen, kGen, kGen, kGen, kGen), // 314 |
| MakeEntry("sched_getattr", kGen, kGen, kGen, kGen, kGen, kGen), // 315 |
| MakeEntry("renameat2", kGen, kPath, kGen, kPath, kGen, kGen), // 316 |
| MakeEntry("seccomp", kGen, kGen, kGen, kGen, kGen, kGen), // 317 |
| MakeEntry("getrandom", kGen, kGen, kGen, kGen, kGen, kGen), // 318 |
| MakeEntry("memfd_create", kGen, kGen, kGen, kGen, kGen, kGen), // 319 |
| MakeEntry("kexec_file_load", kGen, kGen, kGen, kGen, kGen, kGen), // 320 |
| MakeEntry("bpf", kHex, kHex, kHex, kHex, kHex, kHex), // 321 |
| MakeEntry("execveat", kHex, kPath, kHex, kHex, kHex), // 322 |
| MakeEntry("userfaultfd", kHex), // 323 |
| MakeEntry("membarrier", kHex, kHex), // 324 |
| }; |
| |
| constexpr SyscallTable::Entry kSyscallDataX8632[] = { |
| MakeEntry("restart_syscall", kHex, kHex, kHex, kHex, kHex, kHex), // 0 |
| MakeEntry("exit", kHex, kHex, kHex, kHex, kHex, kHex), // 1 |
| MakeEntry("fork", kHex, kHex, kHex, kHex, kHex, kHex), // 2 |
| MakeEntry("read", kHex, kHex, kHex, kHex, kHex, kHex), // 3 |
| MakeEntry("write", kHex, kHex, kHex, kHex, kHex, kHex), // 4 |
| MakeEntry("open", kPath, kHex, kOct, kHex, kHex, kHex), // 5 |
| MakeEntry("close", kHex, kHex, kHex, kHex, kHex, kHex), // 6 |
| MakeEntry("waitpid", kHex, kHex, kHex, kHex, kHex, kHex), // 7 |
| MakeEntry("creat", kPath, kHex, kHex, kHex, kHex, kHex), // 8 |
| MakeEntry("link", kPath, kPath, kHex, kHex, kHex, kHex), // 9 |
| MakeEntry("unlink", kPath, kHex, kHex, kHex, kHex, kHex), // 10 |
| MakeEntry("execve", kPath, kHex, kHex, kHex, kHex, kHex), // 11 |
| MakeEntry("chdir", kPath, kHex, kHex, kHex, kHex, kHex), // 12 |
| MakeEntry("time", kHex, kHex, kHex, kHex, kHex, kHex), // 13 |
| MakeEntry("mknod", kPath, kOct, kHex, kHex, kHex, kHex), // 14 |
| MakeEntry("chmod", kPath, kOct, kHex, kHex, kHex, kHex), // 15 |
| MakeEntry("lchown", kPath, kInt, kInt, kHex, kHex, kHex), // 16 |
| MakeEntry("break", kHex, kHex, kHex, kHex, kHex, kHex), // 17 |
| MakeEntry("oldstat", kHex, kHex, kHex, kHex, kHex, kHex), // 18 |
| MakeEntry("lseek", kHex, kHex, kHex, kHex, kHex, kHex), // 19 |
| MakeEntry("getpid", kHex, kHex, kHex, kHex, kHex, kHex), // 20 |
| MakeEntry("mount", kHex, kHex, kHex, kHex, kHex, kHex), // 21 |
| MakeEntry("umount", kHex, kHex, kHex, kHex, kHex, kHex), // 22 |
| MakeEntry("setuid", kHex, kHex, kHex, kHex, kHex, kHex), // 23 |
| MakeEntry("getuid", kHex, kHex, kHex, kHex, kHex, kHex), // 24 |
| MakeEntry("stime", kHex, kHex, kHex, kHex, kHex, kHex), // 25 |
| MakeEntry("ptrace", kHex, kHex, kHex, kHex), // 26 |
| MakeEntry("alarm", kHex, kHex, kHex, kHex, kHex, kHex), // 27 |
| MakeEntry("oldfstat", kHex, kHex, kHex, kHex, kHex, kHex), // 28 |
| MakeEntry("pause", kHex, kHex, kHex, kHex, kHex, kHex), // 29 |
| MakeEntry("utime", kHex, kHex, kHex, kHex, kHex, kHex), // 30 |
| MakeEntry("stty", kHex, kHex, kHex, kHex, kHex, kHex), // 31 |
| MakeEntry("gtty", kHex, kHex, kHex, kHex, kHex, kHex), // 32 |
| MakeEntry("access", kPath, kHex, kHex, kHex, kHex, kHex), // 33 |
| MakeEntry("nice", kHex, kHex, kHex, kHex, kHex, kHex), // 34 |
| MakeEntry("ftime", kHex, kHex, kHex, kHex, kHex, kHex), // 35 |
| MakeEntry("sync", kHex, kHex, kHex, kHex, kHex, kHex), // 36 |
| MakeEntry("kill", kHex, kHex, kHex, kHex, kHex, kHex), // 37 |
| MakeEntry("rename", kPath, kPath, kHex, kHex, kHex, kHex), // 38 |
| MakeEntry("mkdir", kPath, kHex, kHex, kHex, kHex, kHex), // 39 |
| MakeEntry("rmdir", kHex, kHex, kHex, kHex, kHex, kHex), // 40 |
| MakeEntry("dup", kHex, kHex, kHex, kHex, kHex, kHex), // 41 |
| MakeEntry("pipe", kHex, kHex, kHex, kHex, kHex, kHex), // 42 |
| MakeEntry("times", kHex, kHex, kHex, kHex, kHex, kHex), // 43 |
| MakeEntry("prof", kHex, kHex, kHex, kHex, kHex, kHex), // 44 |
| MakeEntry("brk", kHex, kHex, kHex, kHex, kHex, kHex), // 45 |
| MakeEntry("setgid", kHex, kHex, kHex, kHex, kHex, kHex), // 46 |
| MakeEntry("getgid", kHex, kHex, kHex, kHex, kHex, kHex), // 47 |
| MakeEntry("signal", kHex, kHex, kHex, kHex, kHex, kHex), // 48 |
| MakeEntry("geteuid", kHex, kHex, kHex, kHex, kHex, kHex), // 49 |
| MakeEntry("getegid", kHex, kHex, kHex, kHex, kHex, kHex), // 50 |
| MakeEntry("acct", kHex, kHex, kHex, kHex, kHex, kHex), // 51 |
| MakeEntry("umount2", kHex, kHex, kHex, kHex, kHex, kHex), // 52 |
| MakeEntry("lock", kHex, kHex, kHex, kHex, kHex, kHex), // 53 |
| MakeEntry("ioctl", kHex, kHex, kHex, kHex, kHex, kHex), // 54 |
| MakeEntry("fcntl", kHex, kHex, kHex, kHex, kHex, kHex), // 55 |
| MakeEntry("mpx", kHex, kHex, kHex, kHex, kHex, kHex), // 56 |
| MakeEntry("setpgid", kHex, kHex, kHex, kHex, kHex, kHex), // 57 |
| MakeEntry("ulimit", kHex, kHex, kHex, kHex, kHex, kHex), // 58 |
| MakeEntry("oldolduname", kHex, kHex, kHex, kHex, kHex, kHex), // 59 |
| MakeEntry("umask", kHex, kHex, kHex, kHex, kHex, kHex), // 60 |
| MakeEntry("chroot", kHex, kHex, kHex, kHex, kHex, kHex), // 61 |
| MakeEntry("ustat", kHex, kHex, kHex, kHex, kHex, kHex), // 62 |
| MakeEntry("dup2", kHex, kHex, kHex, kHex, kHex, kHex), // 63 |
| MakeEntry("getppid", kHex, kHex, kHex, kHex, kHex, kHex), // 64 |
| MakeEntry("getpgrp", kHex, kHex, kHex, kHex, kHex, kHex), // 65 |
| MakeEntry("setsid", kHex, kHex, kHex, kHex, kHex, kHex), // 66 |
| MakeEntry("sigaction", kHex, kHex, kHex, kHex, kHex, kHex), // 67 |
| MakeEntry("sgetmask", kHex, kHex, kHex, kHex, kHex, kHex), // 68 |
| MakeEntry("ssetmask", kHex, kHex, kHex, kHex, kHex, kHex), // 69 |
| MakeEntry("setreuid", kHex, kHex, kHex, kHex, kHex, kHex), // 70 |
| MakeEntry("setregid", kHex, kHex, kHex, kHex, kHex, kHex), // 71 |
| MakeEntry("sigsuspend", kHex, kHex, kHex, kHex, kHex, kHex), // 72 |
| MakeEntry("sigpending", kHex, kHex, kHex, kHex, kHex, kHex), // 73 |
| MakeEntry("sethostname", kHex, kHex, kHex, kHex, kHex, kHex), // 74 |
| MakeEntry("setrlimit", kHex, kHex, kHex, kHex, kHex, kHex), // 75 |
| MakeEntry("getrlimit", kHex, kHex, kHex, kHex, kHex, kHex), // 76 |
| MakeEntry("getrusage", kHex, kHex, kHex, kHex, kHex, kHex), // 77 |
| MakeEntry("gettimeofday", kHex, kHex, kHex, kHex, kHex, kHex), // 78 |
| MakeEntry("settimeofday", kHex, kHex, kHex, kHex, kHex, kHex), // 79 |
| MakeEntry("getgroups", kHex, kHex, kHex, kHex, kHex, kHex), // 80 |
| MakeEntry("setgroups", kHex, kHex, kHex, kHex, kHex, kHex), // 81 |
| MakeEntry("select", kHex, kHex, kHex, kHex, kHex, kHex), // 82 |
| MakeEntry("symlink", kPath, kPath, kHex, kHex, kHex, kHex), // 83 |
| MakeEntry("oldlstat", kHex, kHex, kHex, kHex, kHex, kHex), // 84 |
| MakeEntry("readlink", kPath, kHex, kInt, kHex, kHex, kHex), // 85 |
| MakeEntry("uselib", kPath, kHex, kHex, kHex, kHex, kHex), // 86 |
| MakeEntry("swapon", kHex, kHex, kHex, kHex, kHex, kHex), // 87 |
| MakeEntry("reboot", kHex, kHex, kHex, kHex, kHex, kHex), // 88 |
| MakeEntry("readdir", kHex, kHex, kHex, kHex, kHex, kHex), // 89 |
| MakeEntry("mmap", kHex, kHex, kHex, kHex, kHex, kHex), // 90 |
| MakeEntry("munmap", kHex, kHex, kHex, kHex, kHex, kHex), // 91 |
| MakeEntry("truncate", kPath, kHex, kHex, kHex, kHex, kHex), // 92 |
| MakeEntry("ftruncate", kHex, kHex, kHex, kHex, kHex, kHex), // 93 |
| MakeEntry("fchmod", kHex, kHex, kHex, kHex, kHex, kHex), // 94 |
| MakeEntry("fchown", kHex, kHex, kHex, kHex, kHex, kHex), // 95 |
| MakeEntry("getpriority", kHex, kHex, kHex, kHex, kHex, kHex), // 96 |
| MakeEntry("setpriority", kHex, kHex, kHex, kHex, kHex, kHex), // 97 |
| MakeEntry("profil", kHex, kHex, kHex, kHex, kHex, kHex), // 98 |
| MakeEntry("statfs", kPath, kHex, kHex, kHex, kHex, kHex), // 99 |
| MakeEntry("fstatfs", kHex, kHex, kHex, kHex, kHex, kHex), // 100 |
| MakeEntry("ioperm", kHex, kHex, kHex, kHex, kHex, kHex), // 101 |
| MakeEntry("socketcall", kHex, kHex, kHex, kHex, kHex, kHex), // 102 |
| MakeEntry("syslog", kHex, kHex, kHex, kHex, kHex, kHex), // 103 |
| MakeEntry("setitimer", kHex, kHex, kHex, kHex, kHex, kHex), // 104 |
| MakeEntry("getitimer", kHex, kHex, kHex, kHex, kHex, kHex), // 105 |
| MakeEntry("stat", kPath, kHex, kHex, kHex, kHex, kHex), // 106 |
| MakeEntry("lstat", kPath, kHex, kHex, kHex, kHex, kHex), // 107 |
| MakeEntry("fstat", kHex, kHex, kHex, kHex, kHex, kHex), // 108 |
| MakeEntry("olduname", kHex, kHex, kHex, kHex, kHex, kHex), // 109 |
| MakeEntry("iopl", kHex, kHex, kHex, kHex, kHex, kHex), // 110 |
| MakeEntry("vhangup", kHex, kHex, kHex, kHex, kHex, kHex), // 111 |
| MakeEntry("idle", kHex, kHex, kHex, kHex, kHex, kHex), // 112 |
| MakeEntry("vm86old", kHex, kHex, kHex, kHex, kHex, kHex), // 113 |
| MakeEntry("wait4", kHex, kHex, kHex, kHex, kHex, kHex), // 114 |
| MakeEntry("swapoff", kHex, kHex, kHex, kHex, kHex, kHex), // 115 |
| MakeEntry("sysinfo", kHex, kHex, kHex, kHex, kHex, kHex), // 116 |
| MakeEntry("ipc", kHex, kHex, kHex, kHex, kHex, kHex), // 117 |
| MakeEntry("fsync", kHex, kHex, kHex, kHex, kHex, kHex), // 118 |
| MakeEntry("sigreturn", kHex, kHex, kHex, kHex, kHex, kHex), // 119 |
| MakeEntry("clone", kHex, kHex, kHex, kHex, kHex, kHex), // 120 |
| MakeEntry("setdomainname", kHex, kHex, kHex, kHex, kHex, kHex), // 121 |
| MakeEntry("uname", kHex, kHex, kHex, kHex, kHex, kHex), // 122 |
| MakeEntry("modify_ldt", kHex, kHex, kHex, kHex, kHex, kHex), // 123 |
| MakeEntry("adjtimex", kHex, kHex, kHex, kHex, kHex, kHex), // 124 |
| MakeEntry("mprotect", kHex, kHex, kHex, kHex, kHex, kHex), // 125 |
| MakeEntry("sigprocmask", kHex, kHex, kHex, kHex, kHex, kHex), // 126 |
| MakeEntry("create_module", kHex, kHex, kHex, kHex, kHex, kHex), // 127 |
| MakeEntry("init_module", kHex, kHex, kHex, kHex, kHex, kHex), // 128 |
| MakeEntry("delete_module", kHex, kHex, kHex, kHex, kHex, kHex), // 129 |
| MakeEntry("get_kernel_syms", kHex, kHex, kHex, kHex, kHex, kHex), // 130 |
| MakeEntry("quotactl", kHex, kHex, kHex, kHex, kHex, kHex), // 131 |
| MakeEntry("getpgid", kHex, kHex, kHex, kHex, kHex, kHex), // 132 |
| MakeEntry("fchdir", kHex, kHex, kHex, kHex, kHex, kHex), // 133 |
| MakeEntry("bdflush", kHex, kHex, kHex, kHex, kHex, kHex), // 134 |
| MakeEntry("sysfs", kHex, kHex, kHex, kHex, kHex, kHex), // 135 |
| MakeEntry("personality", kHex, kHex, kHex, kHex, kHex, kHex), // 136 |
| MakeEntry("afs_syscall", kHex, kHex, kHex, kHex, kHex, kHex), // 137 |
| MakeEntry("setfsuid", kHex, kHex, kHex, kHex, kHex, kHex), // 138 |
| MakeEntry("setfsgid", kHex, kHex, kHex, kHex, kHex, kHex), // 139 |
| MakeEntry("_llseek", kHex, kHex, kHex, kHex, kHex, kHex), // 140 |
| MakeEntry("getdents", kHex, kHex, kHex, kHex, kHex, kHex), // 141 |
| MakeEntry("_newselect", kHex, kHex, kHex, kHex, kHex, kHex), // 142 |
| MakeEntry("flock", kHex, kHex, kHex, kHex, kHex, kHex), // 143 |
| MakeEntry("msync", kHex, kHex, kHex, kHex, kHex, kHex), // 144 |
| MakeEntry("readv", kHex, kHex, kHex, kHex, kHex, kHex), // 145 |
| MakeEntry("writev", kHex, kHex, kHex, kHex, kHex, kHex), // 146 |
| MakeEntry("getsid", kHex, kHex, kHex, kHex, kHex, kHex), // 147 |
| MakeEntry("fdatasync", kHex, kHex, kHex, kHex, kHex, kHex), // 148 |
| MakeEntry("_sysctl", kHex, kHex, kHex, kHex, kHex, kHex), // 149 |
| MakeEntry("mlock", kHex, kHex, kHex, kHex, kHex, kHex), // 150 |
| MakeEntry("munlock", kHex, kHex, kHex, kHex, kHex, kHex), // 151 |
| MakeEntry("mlockall", kHex, kHex, kHex, kHex, kHex, kHex), // 152 |
| MakeEntry("munlockall", kHex, kHex, kHex, kHex, kHex, kHex), // 153 |
| MakeEntry("sched_setparam", kHex, kHex, kHex, kHex, kHex, kHex), // 154 |
| MakeEntry("sched_getparam", kHex, kHex, kHex, kHex, kHex, kHex), // 155 |
| MakeEntry("sched_setscheduler", kHex, kHex, kHex, kHex, kHex, kHex), // 156 |
| MakeEntry("sched_getscheduler", kHex, kHex, kHex, kHex, kHex, kHex), // 157 |
| MakeEntry("sched_yield", kHex, kHex, kHex, kHex, kHex, kHex), // 158 |
| MakeEntry("sched_get_priority_max", kHex, kHex, kHex, kHex, kHex, |
| kHex), // 159 |
| MakeEntry("sched_get_priority_min", kHex, kHex, kHex, kHex, kHex, |
| kHex), // 160 |
| MakeEntry("sched_rr_get_interval", kHex, kHex, kHex, kHex, kHex, |
| kHex), // 161 |
| MakeEntry("nanosleep", kHex, kHex, kHex, kHex, kHex, kHex), // 162 |
| MakeEntry("mremap", kHex, kHex, kHex, kHex, kHex, kHex), // 163 |
| MakeEntry("setresuid", kHex, kHex, kHex, kHex, kHex, kHex), // 164 |
| MakeEntry("getresuid", kHex, kHex, kHex, kHex, kHex, kHex), // 165 |
| MakeEntry("vm86", kHex, kHex, kHex, kHex, kHex, kHex), // 166 |
| MakeEntry("query_module", kHex, kHex, kHex, kHex, kHex, kHex), // 167 |
| MakeEntry("poll", kHex, kHex, kHex, kHex, kHex, kHex), // 168 |
| MakeEntry("nfsservctl", kHex, kHex, kHex, kHex, kHex, kHex), // 169 |
| MakeEntry("setresgid", kHex, kHex, kHex, kHex, kHex, kHex), // 170 |
| MakeEntry("getresgid", kHex, kHex, kHex, kHex, kHex, kHex), // 171 |
| MakeEntry("prctl", kHex, kHex, kHex, kHex, kHex, kHex), // 172 |
| MakeEntry("rt_sigreturn", kHex, kHex, kHex, kHex, kHex, kHex), // 173 |
| MakeEntry("rt_sigaction", kHex, kHex, kHex, kHex, kHex, kHex), // 174 |
| MakeEntry("rt_sigprocmask", kHex, kHex, kHex, kHex, kHex, kHex), // 175 |
| MakeEntry("rt_sigpending", kHex, kHex, kHex, kHex, kHex, kHex), // 176 |
| MakeEntry("rt_sigtimedwait", kHex, kHex, kHex, kHex, kHex, kHex), // 177 |
| MakeEntry("rt_sigqueueinfo", kHex, kHex, kHex, kHex, kHex, kHex), // 178 |
| MakeEntry("rt_sigsuspend", kHex, kHex, kHex, kHex, kHex, kHex), // 179 |
| MakeEntry("pread64", kHex, kHex, kHex, kHex, kHex, kHex), // 180 |
| MakeEntry("pwrite64", kHex, kHex, kHex, kHex, kHex, kHex), // 181 |
| MakeEntry("chown", kHex, kHex, kHex, kHex, kHex, kHex), // 182 |
| MakeEntry("getcwd", kHex, kHex, kHex, kHex, kHex, kHex), // 183 |
| MakeEntry("capget", kHex, kHex, kHex, kHex, kHex, kHex), // 184 |
| MakeEntry("capset", kHex, kHex, kHex, kHex, kHex, kHex), // 185 |
| MakeEntry("sigaltstack", kHex, kHex, kHex, kHex, kHex, kHex), // 186 |
| MakeEntry("sendfile", kHex, kHex, kHex, kHex, kHex, kHex), // 187 |
| MakeEntry("getpmsg", kHex, kHex, kHex, kHex, kHex, kHex), // 188 |
| MakeEntry("putpmsg", kHex, kHex, kHex, kHex, kHex, kHex), // 189 |
| MakeEntry("vfork", kHex, kHex, kHex, kHex, kHex, kHex), // 190 |
| MakeEntry("ugetrlimit", kHex, kHex, kHex, kHex, kHex, kHex), // 191 |
| MakeEntry("mmap2", kHex, kHex, kHex, kHex, kHex, kHex), // 192 |
| MakeEntry("truncate64", kPath, kHex, kHex, kHex, kHex, kHex), // 193 |
| MakeEntry("ftruncate64", kHex, kHex, kHex, kHex, kHex, kHex), // 194 |
| MakeEntry("stat64", kHex, kHex, kHex, kHex, kHex, kHex), // 195 |
| MakeEntry("lstat64", kPath, kHex, kHex, kHex, kHex, kHex), // 196 |
| MakeEntry("fstat64", kHex, kHex, kHex, kHex, kHex, kHex), // 197 |
| MakeEntry("lchown32", kHex, kHex, kHex, kHex, kHex, kHex), // 198 |
| MakeEntry("getuid32", kHex, kHex, kHex, kHex, kHex, kHex), // 199 |
| MakeEntry("getgid32", kHex, kHex, kHex, kHex, kHex, kHex), // 200 |
| MakeEntry("geteuid32", kHex, kHex, kHex, kHex, kHex, kHex), // 201 |
| MakeEntry("getegid32", kHex, kHex, kHex, kHex, kHex, kHex), // 202 |
| MakeEntry("setreuid32", kHex, kHex, kHex, kHex, kHex, kHex), // 203 |
| MakeEntry("setregid32", kHex, kHex, kHex, kHex, kHex, kHex), // 204 |
| MakeEntry("getgroups32", kHex, kHex, kHex, kHex, kHex, kHex), // 205 |
| MakeEntry("setgroups32", kHex, kHex, kHex, kHex, kHex, kHex), // 206 |
| MakeEntry("fchown32", kHex, kHex, kHex, kHex, kHex, kHex), // 207 |
| MakeEntry("setresuid32", kHex, kHex, kHex, kHex, kHex, kHex), // 208 |
| MakeEntry("getresuid32", kHex, kHex, kHex, kHex, kHex, kHex), // 209 |
| MakeEntry("setresgid32", kHex, kHex, kHex, kHex, kHex, kHex), // 210 |
| MakeEntry("getresgid32", kHex, kHex, kHex, kHex, kHex, kHex), // 211 |
| MakeEntry("chown32", kHex, kHex, kHex, kHex, kHex, kHex), // 212 |
| MakeEntry("setuid32", kHex, kHex, kHex, kHex, kHex, kHex), // 213 |
| MakeEntry("setgid32", kHex, kHex, kHex, kHex, kHex, kHex), // 214 |
| MakeEntry("setfsuid32", kHex, kHex, kHex, kHex, kHex, kHex), // 215 |
| MakeEntry("setfsgid32", kHex, kHex, kHex, kHex, kHex, kHex), // 216 |
| MakeEntry("pivot_root", kHex, kHex, kHex, kHex, kHex, kHex), // 217 |
| MakeEntry("mincore", kHex, kHex, kHex, kHex, kHex, kHex), // 218 |
| MakeEntry("madvise", kHex, kHex, kHex, kHex, kHex, kHex), // 219 |
| MakeEntry("getdents64", kHex, kHex, kHex, kHex, kHex, kHex), // 220 |
| MakeEntry("fcntl64", kHex, kHex, kHex, kHex, kHex, kHex), // 221 |
| MakeEntry("unused1-222", kHex, kHex, kHex, kHex, kHex, kHex), // 222 |
| MakeEntry("unused2-223", kHex, kHex, kHex, kHex, kHex, kHex), // 223 |
| MakeEntry("gettid", kHex, kHex, kHex, kHex, kHex, kHex), // 224 |
| MakeEntry("readahead", kHex, kHex, kHex, kHex, kHex, kHex), // 225 |
| MakeEntry("setxattr", kHex, kHex, kHex, kHex, kHex, kHex), // 226 |
| MakeEntry("lsetxattr", kHex, kHex, kHex, kHex, kHex, kHex), // 227 |
| MakeEntry("fsetxattr", kHex, kHex, kHex, kHex, kHex, kHex), // 228 |
| MakeEntry("getxattr", kHex, kHex, kHex, kHex, kHex, kHex), // 229 |
| MakeEntry("lgetxattr", kHex, kHex, kHex, kHex, kHex, kHex), // 230 |
| MakeEntry("fgetxattr", kHex, kHex, kHex, kHex, kHex, kHex), // 231 |
| MakeEntry("listxattr", kHex, kHex, kHex, kHex, kHex, kHex), // 232 |
| MakeEntry("llistxattr", kHex, kHex, kHex, kHex, kHex, kHex), // 233 |
| MakeEntry("flistxattr", kHex, kHex, kHex, kHex, kHex, kHex), // 234 |
| MakeEntry("removexattr", kHex, kHex, kHex, kHex, kHex, kHex), // 235 |
| MakeEntry("lremovexattr", kHex, kHex, kHex, kHex, kHex, kHex), // 236 |
| MakeEntry("fremovexattr", kHex, kHex, kHex, kHex, kHex, kHex), // 237 |
| MakeEntry("tkill", kHex, kHex, kHex, kHex, kHex, kHex), // 238 |
| MakeEntry("sendfile64", kHex, kHex, kHex, kHex, kHex, kHex), // 239 |
| MakeEntry("futex", kHex, kHex, kHex, kHex, kHex, kHex), // 240 |
| MakeEntry("sched_setaffinity", kHex, kHex, kHex, kHex, kHex, kHex), // 241 |
| MakeEntry("sched_getaffinity", kHex, kHex, kHex, kHex, kHex, kHex), // 242 |
| MakeEntry("set_thread_area", kHex, kHex, kHex, kHex, kHex, kHex), // 243 |
| MakeEntry("get_thread_area", kHex, kHex, kHex, kHex, kHex, kHex), // 244 |
| MakeEntry("io_setup", kHex, kHex, kHex, kHex, kHex, kHex), // 245 |
| MakeEntry("io_destroy", kHex, kHex, kHex, kHex, kHex, kHex), // 246 |
| MakeEntry("io_getevents", kHex, kHex, kHex, kHex, kHex, kHex), // 247 |
| MakeEntry("io_submit", kHex, kHex, kHex, kHex, kHex, kHex), // 248 |
| MakeEntry("io_cancel", kHex, kHex, kHex, kHex, kHex, kHex), // 249 |
| MakeEntry("fadvise64", kHex, kHex, kHex, kHex, kHex, kHex), // 250 |
| MakeEntry("251-old_sys_set_zone_reclaim", kHex, kHex, kHex, kHex, kHex, |
| kHex), // 251 |
| MakeEntry("exit_group", kHex, kHex, kHex, kHex, kHex, kHex), // 252 |
| MakeEntry("lookup_dcookie", kHex, kHex, kHex, kHex, kHex, kHex), // 253 |
| MakeEntry("epoll_create", kHex, kHex, kHex, kHex, kHex, kHex), // 254 |
| MakeEntry("epoll_ctl", kHex, kHex, kHex, kHex, kHex, kHex), // 255 |
| MakeEntry("epoll_wait", kHex, kHex, kHex, kHex, kHex, kHex), // 256 |
| MakeEntry("remap_file_pages", kHex, kHex, kHex, kHex, kHex, kHex), // 257 |
| MakeEntry("set_tid_address", kHex, kHex, kHex, kHex, kHex, kHex), // 258 |
| MakeEntry("timer_create", kHex, kHex, kHex, kHex, kHex, kHex), // 259 |
| MakeEntry("timer_settime", kHex, kHex, kHex, kHex, kHex, kHex), // 260 |
| MakeEntry("timer_gettime", kHex, kHex, kHex, kHex, kHex, kHex), // 261 |
| MakeEntry("timer_getoverrun", kHex, kHex, kHex, kHex, kHex, kHex), // 262 |
| MakeEntry("timer_delete", kHex, kHex, kHex, kHex, kHex, kHex), // 263 |
| MakeEntry("clock_settime", kHex, kHex, kHex, kHex, kHex, kHex), // 264 |
| MakeEntry("clock_gettime", kHex, kHex, kHex, kHex, kHex, kHex), // 265 |
| MakeEntry("clock_getres", kHex, kHex, kHex, kHex, kHex, kHex), // 266 |
| MakeEntry("clock_nanosleep", kHex, kHex, kHex, kHex, kHex, kHex), // 267 |
| MakeEntry("statfs64", kHex, kHex, kHex, kHex, kHex, kHex), // 268 |
| MakeEntry("fstatfs64", kHex, kHex, kHex, kHex, kHex, kHex), // 269 |
| MakeEntry("tgkill", kHex, kHex, kHex, kHex, kHex, kHex), // 270 |
| MakeEntry("utimes", kHex, kHex, kHex, kHex, kHex, kHex), // 271 |
| MakeEntry("fadvise64_64", kHex, kHex, kHex, kHex, kHex, kHex), // 272 |
| MakeEntry("vserver", kHex, kHex, kHex, kHex, kHex, kHex), // 273 |
| MakeEntry("mbind", kHex, kHex, kHex, kHex, kHex, kHex), // 274 |
| MakeEntry("get_mempolicy", kHex, kHex, kHex, kHex, kHex, kHex), // 275 |
| MakeEntry("set_mempolicy", kHex, kHex, kHex, kHex, kHex, kHex), // 276 |
| MakeEntry("mq_open", kHex, kHex, kHex, kHex, kHex, kHex), // 277 |
| MakeEntry("mq_unlink", kHex, kHex, kHex, kHex, kHex, kHex), // 278 |
| MakeEntry("mq_timedsend", kHex, kHex, kHex, kHex, kHex, kHex), // 279 |
| MakeEntry("mq_timedreceive", kHex, kHex, kHex, kHex, kHex, kHex), // 280 |
| MakeEntry("mq_notify", kHex, kHex, kHex, kHex, kHex, kHex), // 281 |
| MakeEntry("mq_getsetattr", kHex, kHex, kHex, kHex, kHex, kHex), // 282 |
| MakeEntry("kexec_load", kHex, kHex, kHex, kHex, kHex, kHex), // 283 |
| MakeEntry("waitid", kHex, kHex, kHex, kHex, kHex, kHex), // 284 |
| MakeEntry("285-old_sys_setaltroot", kHex, kHex, kHex, kHex, kHex, |
| kHex), // 285 |
| MakeEntry("add_key", kHex, kHex, kHex, kHex, kHex, kHex), // 286 |
| MakeEntry("request_key", kHex, kHex, kHex, kHex, kHex, kHex), // 287 |
| MakeEntry("keyctl", kHex, kHex, kHex, kHex, kHex, kHex), // 288 |
| MakeEntry("ioprio_set", kHex, kHex, kHex, kHex, kHex, kHex), // 289 |
| MakeEntry("ioprio_get", kHex, kHex, kHex, kHex, kHex, kHex), // 290 |
| MakeEntry("inotify_init", kHex, kHex, kHex, kHex, kHex, kHex), // 291 |
| MakeEntry("inotify_add_watch", kHex, kHex, kHex, kHex, kHex, kHex), // 292 |
| MakeEntry("inotify_rm_watch", kHex, kHex, kHex, kHex, kHex, kHex), // 293 |
| MakeEntry("migrate_pages", kHex, kHex, kHex, kHex, kHex, kHex), // 294 |
| MakeEntry("openat", kHex, kPath, kOct, kHex, kHex, kHex), // 295 |
| MakeEntry("mkdirat", kHex, kHex, kHex, kHex, kHex, kHex), // 296 |
| MakeEntry("mknodat", kHex, kHex, kHex, kHex, kHex, kHex), // 297 |
| MakeEntry("fchownat", kHex, kPath, kHex, kHex, kHex, kHex), // 298 |
| MakeEntry("futimesat", kHex, kPath, kHex, kHex, kHex, kHex), // 299 |
| MakeEntry("fstatat64", kHex, kHex, kHex, kHex, kHex, kHex), // 300 |
| MakeEntry("unlinkat", kHex, kPath, kHex, kHex, kHex, kHex), // 301 |
| MakeEntry("renameat", kHex, kPath, kHex, kPath, kHex, kHex), // 302 |
| MakeEntry("linkat", kHex, kPath, kHex, kPath, kHex, kHex), // 303 |
| MakeEntry("symlinkat", kPath, kHex, kPath, kHex, kHex, kHex), // 304 |
| MakeEntry("readlinkat", kHex, kPath, kHex, kHex, kHex, kHex), // 305 |
| MakeEntry("fchmodat", kHex, kPath, kHex, kHex, kHex, kHex), // 306 |
| MakeEntry("faccessat", kHex, kPath, kHex, kHex, kHex, kHex), // 307 |
| MakeEntry("pselect6", kHex, kHex, kHex, kHex, kHex, kHex), // 308 |
| MakeEntry("ppoll", kHex, kHex, kHex, kHex, kHex, kHex), // 309 |
| MakeEntry("unshare", kHex, kHex, kHex, kHex, kHex, kHex), // 310 |
| MakeEntry("set_robust_list", kHex, kHex, kHex, kHex, kHex, kHex), // 311 |
| MakeEntry("get_robust_list", kHex, kHex, kHex, kHex, kHex, kHex), // 312 |
| MakeEntry("splice", kHex, kHex, kHex, kHex, kHex, kHex), // 313 |
| MakeEntry("sync_file_range", kHex, kHex, kHex, kHex, kHex, kHex), // 314 |
| MakeEntry("tee", kHex, kHex, kHex, kHex, kHex, kHex), // 315 |
| MakeEntry("vmsplice", kHex, kHex, kHex, kHex, kHex, kHex), // 316 |
| MakeEntry("move_pages", kHex, kHex, kHex, kHex, kHex, kHex), // 317 |
| MakeEntry("getcpu", kHex, kHex, kHex, kHex, kHex, kHex), // 318 |
| MakeEntry("epoll_pwait", kHex, kHex, kHex, kHex, kHex, kHex), // 319 |
| MakeEntry("utimensat", kHex, kHex, kHex, kHex, kHex, kHex), // 320 |
| MakeEntry("signalfd", kHex, kHex, kHex, kHex, kHex, kHex), // 321 |
| MakeEntry("timerfd_create", kHex, kHex, kHex, kHex, kHex, kHex), // 322 |
| MakeEntry("eventfd", kHex, kHex, kHex, kHex, kHex, kHex), // 323 |
| MakeEntry("fallocate", kHex, kHex, kHex, kHex, kHex, kHex), // 324 |
| MakeEntry("timerfd_settime", kHex, kHex, kHex, kHex, kHex, kHex), // 325 |
| MakeEntry("timerfd_gettime", kHex, kHex, kHex, kHex, kHex, kHex), // 326 |
| MakeEntry("signalfd4", kHex, kHex, kHex, kHex, kHex, kHex), // 327 |
| MakeEntry("eventfd2", kHex, kHex, kHex, kHex, kHex, kHex), // 328 |
| MakeEntry("epoll_create1", kHex, kHex, kHex, kHex, kHex, kHex), // 329 |
| MakeEntry("dup3", kHex, kHex, kHex, kHex, kHex, kHex), // 330 |
| MakeEntry("pipe2", kHex, kHex, kHex, kHex, kHex, kHex), // 331 |
| MakeEntry("inotify_init1", kHex, kHex, kHex, kHex, kHex, kHex), // 332 |
| MakeEntry("preadv", kHex, kHex, kHex, kHex, kHex, kHex), // 333 |
| MakeEntry("pwritev", kHex, kHex, kHex, kHex, kHex, kHex), // 334 |
| MakeEntry("rt_tgsigqueueinfo", kHex, kHex, kHex, kHex, kHex, kHex), // 335 |
| MakeEntry("perf_event_open", kHex, kHex, kHex, kHex, kHex, kHex), // 336 |
| MakeEntry("recvmmsg", kHex, kHex, kHex, kHex, kHex, kHex), // 337 |
| MakeEntry("fanotify_init", kHex, kHex, kHex, kHex, kHex, kHex), // 338 |
| MakeEntry("fanotify_mark", kHex, kHex, kHex, kHex, kHex, kHex), // 339 |
| MakeEntry("prlimit64", kHex, kHex, kHex, kHex, kHex, kHex), // 340 |
| MakeEntry("name_to_handle_at", kHex, kHex, kHex, kHex, kHex, kHex), // 341 |
| MakeEntry("open_by_handle_at", kHex, kHex, kHex, kHex, kHex, kHex), // 342 |
| MakeEntry("clock_adjtime", kHex, kHex, kHex, kHex, kHex, kHex), // 343 |
| MakeEntry("syncfs", kHex, kHex, kHex, kHex, kHex, kHex), // 344 |
| MakeEntry("sendmmsg", kHex, kHex, kHex, kHex, kHex, kHex), // 345 |
| MakeEntry("setns", kHex, kHex, kHex, kHex, kHex, kHex), // 346 |
| MakeEntry("process_vm_readv", kHex, kHex, kHex, kHex, kHex, kHex), // 347 |
| MakeEntry("process_vm_writev", kHex, kHex, kHex, kHex, kHex, kHex), // 348 |
| MakeEntry("kcmp", kHex, kHex, kHex, kHex, kHex, kHex), // 349 |
| MakeEntry("finit_module", kHex, kHex, kHex, kHex, kHex, kHex), // 350 |
| MakeEntry("sched_setattr", kHex, kHex, kHex, kHex, kHex, kHex), // 351 |
| MakeEntry("sched_getattr", kHex, kHex, kHex, kHex, kHex, kHex), // 352 |
| MakeEntry("renameat2", kHex, kPath, kHex, kPath, kHex, kHex), // 353 |
| MakeEntry("seccomp", kHex, kHex, kHex, kHex, kHex, kHex), // 354 |
| MakeEntry("getrandom", kHex, kHex, kHex, kHex, kHex, kHex), // 355 |
| MakeEntry("memfd_create", kHex, kHex, kHex, kHex, kHex, kHex), // 356 |
| MakeEntry("bpf", kHex, kHex, kHex, kHex, kHex, kHex), // 357 |
| }; |
| |
| #elif defined(__powerpc64__) |
| |
| // http://lxr.free-electrons.com/source/arch/powerpc/include/uapi/asm/unistd.h |
| // Note: PPC64 syscalls can have up to 7 register arguments, but nobody is |
| // using the 7th argument - probably for x64 compatibility reasons. |
| constexpr SyscallTable::Entry kSyscallDataPPC64[] = { |
| MakeEntry("restart_syscall", kGen, kGen, kGen, kGen, kGen, kGen), // 0 |
| MakeEntry("exit", kInt, kGen, kGen, kGen, kGen, kGen), // 1 |
| MakeEntry("fork", kGen, kGen, kGen, kGen, kGen, kGen), // 2 |
| MakeEntry("read", kInt, kHex, kInt), // 3 |
| MakeEntry("write", kInt, kHex, kInt, kGen, kGen, kGen), // 4 |
| MakeEntry("open", kPath, kHex, kOct, kGen, kGen, kGen), // 5 |
| MakeEntry("close", kInt, kGen, kGen, kGen, kGen, kGen), // 6 |
| MakeEntry("waitpid", kHex, kHex, kHex, kHex, kHex, kHex), // 7 |
| MakeEntry("creat", kPath, kOct, kGen, kGen, kGen, kGen), // 8 |
| MakeEntry("link", kPath, kPath, kGen, kGen, kGen, kGen), // 9 |
| MakeEntry("unlink", kPath, kGen, kGen, kGen, kGen, kGen), // 10 |
| MakeEntry("execve", kPath, kHex, kHex, kGen, kGen, kGen), // 11 |
| MakeEntry("chdir", kPath, kGen, kGen, kGen, kGen, kGen), // 12 |
| MakeEntry("time", kHex, kGen, kGen, kGen, kGen, kGen), // 13 |
| MakeEntry("mknod", kPath, kOct, kHex, kGen, kGen, kGen), // 14 |
| MakeEntry("chmod", kPath, kOct, kGen, kGen, kGen, kGen), // 15 |
| MakeEntry("lchown", kPath, kInt, kInt, kGen, kGen, kGen), // 16 |
| MakeEntry("break", kHex, kHex, kHex, kHex, kHex, kHex), // 17 |
| MakeEntry("oldstat", kHex, kHex, kHex, kHex, kHex, kHex), // 18 |
| MakeEntry("lseek", kGen, kGen, kGen, kGen, kGen, kGen), // 19 |
| MakeEntry("getpid", kGen, kGen, kGen, kGen, kGen, kGen), // 20 |
| MakeEntry("mount", kPath, kPath, kString, kHex, kGen, kGen), // 21 |
| MakeEntry("umount", kHex, kHex, kHex, kHex, kHex, kHex), // 22 |
| MakeEntry("setuid", kGen, kGen, kGen, kGen, kGen, kGen), // 23 |
| MakeEntry("getuid", kGen, kGen, kGen, kGen, kGen, kGen), // 24 |
| MakeEntry("stime", kHex, kHex, kHex, kHex, kHex, kHex), // 25 |
| MakeEntry("ptrace", kGen, kGen, kGen, kGen, kGen, kGen), // 26 |
| MakeEntry("alarm", kInt, kGen, kGen, kGen, kGen, kGen), // 27 |
| MakeEntry("oldfstat", kHex, kHex, kHex, kHex, kHex, kHex), // 28 |
| MakeEntry("pause", kGen, kGen, kGen, kGen, kGen, kGen), // 29 |
| MakeEntry("utime", kGen, kGen, kGen, kGen, kGen, kGen), // 30 |
| MakeEntry("stty", kHex, kHex, kHex, kHex, kHex, kHex), // 31 |
| MakeEntry("gtty", kHex, kHex, kHex, kHex, kHex, kHex), // 32 |
| MakeEntry("access", kPath, kHex, kGen, kGen, kGen, kGen), // 33 |
| MakeEntry("nice", kHex, kHex, kHex, kHex, kHex, kHex), // 34 |
| MakeEntry("ftime", kHex, kHex, kHex, kHex, kHex, kHex), // 35 |
| MakeEntry("sync", kGen, kGen, kGen, kGen, kGen, kGen), // 36 |
| MakeEntry("kill", kInt, kSignal, kGen, kGen, kGen, kGen), // 37 |
| MakeEntry("rename", kPath, kPath, kGen, kGen, kGen, kGen), // 38 |
| MakeEntry("mkdir", kPath, kOct, kGen, kGen, kGen, kGen), // 39 |
| MakeEntry("rmdir", kPath, kGen, kGen, kGen, kGen, kGen), // 40 |
| MakeEntry("dup", kGen, kGen, kGen, kGen, kGen, kGen), // 41 |
| MakeEntry("pipe", kGen, kGen, kGen, kGen, kGen, kGen), // 42 |
| MakeEntry("times", kGen, kGen, kGen, kGen, kGen, kGen), // 43 |
| MakeEntry("prof", kHex, kHex, kHex, kHex, kHex, kHex), // 44 |
| MakeEntry("brk", kHex, kGen, kGen, kGen, kGen, kGen), // 45 |
| MakeEntry("setgid", kGen, kGen, kGen, kGen, kGen, kGen), // 46 |
| MakeEntry("getgid", kGen, kGen, kGen, kGen, kGen, kGen), // 47 |
| MakeEntry("signal", kHex, kHex, kHex, kHex, kHex, kHex), // 48 |
| MakeEntry("geteuid", kGen, kGen, kGen, kGen, kGen, kGen), // 49 |
| MakeEntry("getegid", kGen, kGen, kGen, kGen, kGen, kGen), // 50 |
| MakeEntry("acct", kPath, kGen, kGen, kGen, kGen, kGen), // 51 |
| MakeEntry("umount2", kPath, kHex, kGen, kGen, kGen, kGen), // 52 |
| MakeEntry("lock", kHex, kHex, kHex, kHex, kHex, kHex), // 53 |
| MakeEntry("ioctl", kGen, kGen, kGen, kGen, kGen, kGen), // 54 |
| MakeEntry("fcntl", kGen, kGen, kGen, kGen, kGen, kGen), // 55 |
| MakeEntry("mpx", kHex, kHex, kHex, kHex, kHex, kHex), // 56 |
| MakeEntry("setpgid", kGen, kGen, kGen, kGen, kGen, kGen), // 57 |
| MakeEntry("ulimit", kHex, kHex, kHex, kHex, kHex, kHex), // 58 |
| MakeEntry("oldolduname", kHex, kHex, kHex, kHex, kHex, kHex), // 59 |
| MakeEntry("umask", kHex, kGen, kGen, kGen, kGen, kGen), // 60 |
| MakeEntry("chroot", kPath, kGen, kGen, kGen, kGen, kGen), // 61 |
| MakeEntry("ustat", kGen, kGen, kGen, kGen, kGen, kGen), // 62 |
| MakeEntry("dup2", kGen, kGen, kGen, kGen, kGen, kGen), // 63 |
| MakeEntry("getppid", kGen, kGen, kGen, kGen, kGen, kGen), // 64 |
| MakeEntry("getpgrp", kGen, kGen, kGen, kGen, kGen, kGen), // 65 |
| MakeEntry("setsid", kGen, kGen, kGen, kGen, kGen, kGen), // 66 |
| MakeEntry("sigaction", kHex, kHex, kHex, kHex, kHex, kHex), // 67 |
| MakeEntry("sgetmask", kHex, kHex, kHex, kHex, kHex, kHex), // 68 |
| MakeEntry("ssetmask", kHex, kHex, kHex, kHex, kHex, kHex), // 69 |
| MakeEntry("setreuid", kGen, kGen, kGen, kGen, kGen, kGen), // 70 |
| MakeEntry("setregid", kGen, kGen, kGen, kGen, kGen, kGen), // 71 |
| MakeEntry("sigsuspend", kHex, kHex, kHex, kHex, kHex, kHex), // 72 |
| MakeEntry("sigpending", kHex, kHex, kHex, kHex, kHex, kHex), // 73 |
| MakeEntry("sethostname", kGen, kGen, kGen, kGen, kGen, kGen), // 74 |
| MakeEntry("setrlimit", kGen, kGen, kGen, kGen, kGen, kGen), // 75 |
| MakeEntry("getrlimit", kGen, kGen, kGen, kGen, kGen, kGen), // 76 |
| MakeEntry("getrusage", kGen, kGen, kGen, kGen, kGen, kGen), // 77 |
| MakeEntry("gettimeofday", kHex, kHex, kGen, kGen, kGen, kGen), // 78 |
| MakeEntry("settimeofday", kHex, kHex, kGen, kGen, kGen, kGen), // 79 |
| MakeEntry("getgroups", kGen, kGen, kGen, kGen, kGen, kGen), // 80 |
| MakeEntry("setgroups", kGen, kGen, kGen, kGen, kGen, kGen), // 81 |
| MakeEntry("select", kGen, kGen, kGen, kGen, kGen, kGen), // 82 |
| MakeEntry("symlink", kPath, kPath, kGen, kGen, kGen, kGen), // 83 |
| MakeEntry("oldlstat", kHex, kHex, kHex, kHex, kHex, kHex), // 84 |
| MakeEntry("readlink", kPath, kGen, kInt, kGen, kGen, kGen), // 85 |
| MakeEntry("uselib", kPath, kGen, kGen, kGen, kGen, kGen), // 86 |
| MakeEntry("swapon", kPath, kHex, kGen, kGen, kGen, kGen), // 87 |
| MakeEntry("reboot", kGen, kGen, kGen, kGen, kGen, kGen), // 88 |
| MakeEntry("readdir", kHex, kHex, kHex, kHex, kHex, kHex), // 89 |
| MakeEntry("mmap", kHex, kInt, kHex, kHex, kInt, kInt), // 90 |
| MakeEntry("munmap", kHex, kHex, kGen, kGen, kGen, kGen), // 91 |
| MakeEntry("truncate", kPath, kInt, kGen, kGen, kGen, kGen), // 92 |
| MakeEntry("ftruncate", kGen, kGen, kGen, kGen, kGen, kGen), // 93 |
| MakeEntry("fchmod", kGen, kGen, kGen, kGen, kGen, kGen), // 94 |
| MakeEntry("fchown", kGen, kGen, kGen, kGen, kGen, kGen), // 95 |
| MakeEntry("getpriority", kGen, kGen, kGen, kGen, kGen, kGen), // 96 |
| MakeEntry("setpriority", kGen, kGen, kGen, kGen, kGen, kGen), // 97 |
| MakeEntry("profil", kHex, kHex, kHex, kHex, kHex, kHex), // 98 |
| MakeEntry("statfs", kPath, kGen, kGen, kGen, kGen, kGen), // 99 |
| MakeEntry("fstatfs", kGen, kGen, kGen, kGen, kGen, kGen), // 100 |
| MakeEntry("ioperm", kGen, kGen, kGen, kGen, kGen, kGen), // 101 |
| MakeEntry("socketcall", kHex, kHex, kHex, kHex, kHex, kHex), // 102 |
| MakeEntry("syslog", kGen, kGen, kGen, kGen, kGen, kGen), // 103 |
| MakeEntry("setitimer", kGen, kGen, kGen, kGen, kGen, kGen), // 104 |
| MakeEntry("getitimer", kGen, kGen, kGen, kGen, kGen, kGen), // 105 |
| MakeEntry("stat", kPath, kGen, kGen, kGen, kGen, kGen), // 106 |
| MakeEntry("lstat", kPath, kGen, kGen, kGen, kGen, kGen), // 107 |
| MakeEntry("fstat", kInt, kHex, kGen, kGen, kGen, kGen), // 108 |
| MakeEntry("olduname", kHex, kHex, kHex, kHex, kHex, kHex), // 109 |
| MakeEntry("iopl", kGen, kGen, kGen, kGen, kGen, kGen), // 110 |
| MakeEntry("vhangup", kGen, kGen, kGen, kGen, kGen, kGen), // 111 |
| MakeEntry("idle", kHex, kHex, kHex, kHex, kHex, kHex), // 112 |
| MakeEntry("vm86", kHex, kHex, kHex, kHex, kHex, kHex), // 113 |
| MakeEntry("wait4", kInt, kHex, kHex, kHex, kGen, kGen), // 114 |
| MakeEntry("swapoff", kPath, kGen, kGen, kGen, kGen, kGen), // 115 |
| MakeEntry("sysinfo", kGen, kGen, kGen, kGen, kGen, kGen), // 116 |
| MakeEntry("ipc", kHex, kHex, kHex, kHex, kHex, kHex), // 117 |
| MakeEntry("fsync", kGen, kGen, kGen, kGen, kGen, kGen), // 118 |
| MakeEntry("sigreturn", kHex, kHex, kHex, kHex, kHex, kHex), // 119 |
| MakeEntry("clone", kCloneFlag, kHex, kHex, kHex, kHex, kGen), // 120 |
| MakeEntry("setdomainname", kGen, kGen, kGen, kGen, kGen, kGen), // 121 |
| MakeEntry("uname", kGen, kGen, kGen, kGen, kGen, kGen), // 122 |
| MakeEntry("modify_ldt", kGen, kGen, kGen, kGen, kGen, kGen), // 123 |
| MakeEntry("adjtimex", kGen, kGen, kGen, kGen, kGen, kGen), // 124 |
| MakeEntry("mprotect", kHex, kHex, kHex, kGen, kGen, kGen), // 125 |
| MakeEntry("sigprocmask", kHex, kHex, kHex, kHex, kHex, kHex), // 126 |
| MakeEntry("create_module", kGen, kGen, kGen, kGen, kGen, kGen), // 127 |
| MakeEntry("init_module", kGen, kGen, kGen, kGen, kGen, kGen), // 128 |
| MakeEntry("delete_module", kGen, kGen, kGen, kGen, kGen, kGen), // 129 |
| MakeEntry("get_kernel_syms", kGen, kGen, kGen, kGen, kGen, kGen), // 130 |
| MakeEntry("quotactl", kInt, kPath, kInt, kGen, kGen, kGen), // 131 |
| MakeEntry("getpgid", kGen, kGen, kGen, kGen, kGen, kGen), // 132 |
| MakeEntry("fchdir", kGen, kGen, kGen, kGen, kGen, kGen), // 133 |
| MakeEntry("bdflush", kHex, kHex, kHex, kHex, kHex, kHex), // 134 |
| MakeEntry("sysfs", kGen, kGen, kGen, kGen, kGen, kGen), // 135 |
| MakeEntry("personality", kGen, kGen, kGen, kGen, kGen, kGen), // 136 |
| MakeEntry("afs_syscall", kGen, kGen, kGen, kGen, kGen, kGen), // 137 |
| MakeEntry("setfsuid", kGen, kGen, kGen, kGen, kGen, kGen), // 138 |
| MakeEntry("setfsgid", kGen, kGen, kGen, kGen, kGen, kGen), // 139 |
| MakeEntry("_llseek", kHex, kHex, kHex, kHex, kHex, kHex), // 140 |
| MakeEntry("getdents", kGen, kGen, kGen, kGen, kGen, kGen), // 141 |
| MakeEntry("_newselect", kHex, kHex, kHex, kHex, kHex, kHex), // 142 |
| MakeEntry("flock", kGen, kGen, kGen, kGen, kGen, kGen), // 143 |
| MakeEntry("msync", kGen, kGen, kGen, kGen, kGen, kGen), // 144 |
| MakeEntry("readv", kGen, kGen, kGen, kGen, kGen, kGen), // 145 |
| MakeEntry("writev", kGen, kGen, kGen, kGen, kGen, kGen), // 146 |
| MakeEntry("getsid", kGen, kGen, kGen, kGen, kGen, kGen), // 147 |
| MakeEntry("fdatasync", kGen, kGen, kGen, kGen, kGen, kGen), // 148 |
| MakeEntry("_sysctl", kGen, kGen, kGen, kGen, kGen, kGen), // 149 |
| MakeEntry("mlock", kGen, kGen, kGen, kGen, kGen, kGen), // 150 |
| MakeEntry("munlock", kGen, kGen, kGen, kGen, kGen, kGen), // 151 |
| MakeEntry("mlockall", kGen, kGen, kGen, kGen, kGen, kGen), // 152 |
| MakeEntry("munlockall", kGen, kGen, kGen, kGen, kGen, kGen), // 153 |
| MakeEntry("sched_setparam", kGen, kGen, kGen, kGen, kGen, kGen), // 154 |
| MakeEntry("sched_getparam", kGen, kGen, kGen, kGen, kGen, kGen), // 155 |
| MakeEntry("sched_setscheduler", kGen, kGen, kGen, kGen, kGen, kGen), // 156 |
| MakeEntry("sched_getscheduler", kGen, kGen, kGen, kGen, kGen, kGen), // 157 |
| MakeEntry("sched_yield", kGen, kGen, kGen, kGen, kGen, kGen), // 158 |
| MakeEntry("sched_get_priority_max", kGen, kGen, kGen, kGen, kGen, |
| kGen), // 159 |
| MakeEntry("sched_get_priority_min", kGen, kGen, kGen, kGen, kGen, |
| kGen), // 160 |
| MakeEntry("sched_rr_get_interval", kGen, kGen, kGen, kGen, kGen, |
| kGen), // 161 |
| MakeEntry("nanosleep", kHex, kHex, kGen, kGen, kGen, kGen), // 162 |
| MakeEntry("mremap", kGen, kGen, kGen, kGen, kGen, kGen), // 163 |
| MakeEntry("setresuid", kGen, kGen, kGen, kGen, kGen, kGen), // 164 |
| MakeEntry("getresuid", kGen, kGen, kGen, kGen, kGen, kGen), // 165 |
| MakeEntry("query_module", kGen, kGen, kGen, kGen, kGen, kGen), // 166 |
| MakeEntry("poll", kGen, kGen, kGen, kGen, kGen, kGen), // 167 |
| MakeEntry("nfsservctl", kGen, kGen, kGen, kGen, kGen, kGen), // 168 |
| MakeEntry("setresgid", kGen, kGen, kGen, kGen, kGen, kGen), // 169 |
| MakeEntry("getresgid", kGen, kGen, kGen, kGen, kGen, kGen), // 170 |
| MakeEntry("prctl", kInt, kHex, kHex, kHex, kHex, kGen), // 171 |
| MakeEntry("rt_sigreturn", kGen, kGen, kGen, kGen, kGen, kGen), // 172 |
| MakeEntry("rt_sigaction", kSignal, kHex, kHex, kInt, kGen, kGen), // 173 |
| MakeEntry("rt_sigprocmask", kGen, kGen, kGen, kGen, kGen, kGen), // 174 |
| MakeEntry("rt_sigpending", kGen, kGen, kGen, kGen, kGen, kGen), // 175 |
| MakeEntry("rt_sigtimedwait", kGen, kGen, kGen, kGen, kGen, kGen), // 176 |
| MakeEntry("rt_sigqueueinfo", kGen, kGen, kGen, kGen, kGen, kGen), // 177 |
| MakeEntry("rt_sigsuspend", kGen, kGen, kGen, kGen, kGen, kGen), // 178 |
| MakeEntry("pread64", kGen, kGen, kGen, kGen, kGen, kGen), // 179 |
| MakeEntry("pwrite64", kGen, kGen, kGen, kGen, kGen, kGen), // 180 |
| MakeEntry("chown", kPath, kInt, kInt, kGen, kGen, kGen), // 181 |
| MakeEntry("getcwd", kGen, kGen, kGen, kGen, kGen, kGen), // 182 |
| MakeEntry("capget", kGen, kGen, kGen, kGen, kGen, kGen), // 183 |
| MakeEntry("capset", kGen, kGen, kGen, kGen, kGen, kGen), // 184 |
| MakeEntry("sigaltstack", kGen, kGen, kGen, kGen, kGen, kGen), // 185 |
| MakeEntry("sendfile", kGen, kGen, kGen, kGen, kGen, kGen), // 186 |
| MakeEntry("getpmsg", kGen, kGen, kGen, kGen, kGen, kGen), // 187 |
| MakeEntry("putpmsg", kGen, kGen, kGen, kGen, kGen, kGen), // 188 |
| MakeEntry("vfork", kGen, kGen, kGen, kGen, kGen, kGen), // 189 |
| MakeEntry("ugetrlimit", kHex, kHex, kHex, kHex, kHex, kHex), // 190 |
| MakeEntry("readahead", kGen, kGen, kGen, kGen, kGen, kGen), // 191 |
| MakeEntry("mmap2", kHex, kHex, kHex, kHex, kHex, kHex), // 192 |
| MakeEntry("truncate64", kHex, kHex, kHex, kHex, kHex, kHex), // 193 |
| MakeEntry("ftruncate64", kHex, kHex, kHex, kHex, kHex, kHex), // 194 |
| MakeEntry("stat64", kHex, kHex, kHex, kHex, kHex, kHex), // 195 |
| MakeEntry("lstat64", kHex, kHex, kHex, kHex, kHex, kHex), // 196 |
| MakeEntry("fstat64", kHex, kHex, kHex, kHex, kHex, kHex), // 197 |
| MakeEntry("pciconfig_read", kHex, kHex, kHex, kHex, kHex, kHex), // 198 |
| MakeEntry("pciconfig_write", kHex, kHex, kHex, kHex, kHex, kHex), // 199 |
| MakeEntry("pciconfig_iobase", kHex, kHex, kHex, kHex, kHex, kHex), // 200 |
| MakeEntry("multiplexer", kHex, kHex, kHex, kHex, kHex, kHex), // 201 |
| MakeEntry("getdents64", kGen, kGen, kGen, kGen, kGen, kGen), // 202 |
| MakeEntry("pivot_root", kPath, kPath, kGen, kGen, kGen, kGen), // 203 |
| MakeEntry("fcntl64", kHex, kHex, kHex, kHex, kHex, kHex), // 204 |
| MakeEntry("madvise", kGen, kGen, kGen, kGen, kGen, kGen), // 205 |
| MakeEntry("mincore", kGen, kGen, kGen, kGen, kGen, kGen), // 206 |
| MakeEntry("gettid", kGen, kGen, kGen, kGen, kGen, kGen), // 207 |
| MakeEntry("tkill", kInt, kSignal, kGen, kGen, kGen, kGen), // 208 |
| MakeEntry("setxattr", kPath, kString, kGen, kInt, kHex, kGen), // 209 |
| MakeEntry("lsetxattr", kPath, kString, kGen, kInt, kHex, kGen), // 210 |
| MakeEntry("fsetxattr", kGen, kGen, kGen, kGen, kGen, kGen), // 211 |
| MakeEntry("getxattr", kPath, kString, kGen, kInt, kGen, kGen), // 212 |
| MakeEntry("lgetxattr", kPath, kString, kGen, kInt, kGen, kGen), // 213 |
| MakeEntry("fgetxattr", kGen, kGen, kGen, kGen, kGen, kGen), // 214 |
| MakeEntry("listxattr", kPath, kGen, kInt, kGen, kGen, kGen), // 215 |
| MakeEntry("llistxattr", kPath, kGen, kInt, kGen, kGen, kGen), // 216 |
| MakeEntry("flistxattr", kGen, kGen, kGen, kGen, kGen, kGen), // 217 |
| MakeEntry("removexattr", kPath, kString, kGen, kGen, kGen, kGen), // 218 |
| MakeEntry("lremovexattr", kGen, kGen, kGen, kGen, kGen, kGen), // 219 |
| MakeEntry("fremovexattr", kGen, kGen, kGen, kGen, kGen, kGen), // 220 |
| MakeEntry("futex", kGen, kGen, kGen, kGen, kGen, kGen), // 221 |
| MakeEntry("sched_setaffinity", kGen, kGen, kGen, kGen, kGen, kGen), // 222 |
| MakeEntry("sched_getaffinity", kGen, kGen, kGen, kGen, kGen, kGen), // 223 |
| SYSCALLS_UNUSED("UNUSED224"), // 224 |
| MakeEntry("tuxcall", kGen, kGen, kGen, kGen, kGen, kGen), // 225 |
| MakeEntry("sendfile64", kHex, kHex, kHex, kHex, kHex, kHex), // 226 |
| MakeEntry("io_setup", kGen, kGen, kGen, kGen, kGen, kGen), // 227 |
| MakeEntry("io_destroy", kGen, kGen, kGen, kGen, kGen, kGen), // 228 |
| MakeEntry("io_getevents", kGen, kGen, kGen, kGen, kGen, kGen), // 229 |
| MakeEntry("io_submit", kGen, kGen, kGen, kGen, kGen, kGen), // 230 |
| MakeEntry("io_cancel", kGen, kGen, kGen, kGen, kGen, kGen), // 231 |
| MakeEntry("set_tid_address", kHex, kGen, kGen, kGen, kGen, kGen), // 232 |
| MakeEntry("fadvise64", kGen, kGen, kGen, kGen, kGen, kGen), // 233 |
| MakeEntry("exit_group", kInt, kGen, kGen, kGen, kGen, kGen), // 234 |
| MakeEntry("lookup_dcookie", kGen, kGen, kGen, kGen, kGen, kGen), // 235 |
| MakeEntry("epoll_create", kGen, kGen, kGen, kGen, kGen, kGen), // 236 |
| MakeEntry("epoll_ctl", kGen, kGen, kGen, kGen, kGen, kGen), // 237 |
| MakeEntry("epoll_wait", kGen, kGen, kGen, kGen, kGen, kGen), // 238 |
| MakeEntry("remap_file_pages", kGen, kGen, kGen, kGen, kGen, kGen), // 239 |
| MakeEntry("timer_create", kGen, kGen, kGen, kGen, kGen, kGen), // 240 |
| MakeEntry("timer_settime", kGen, kGen, kGen, kGen, kGen, kGen), // 241 |
| MakeEntry("timer_gettime", kGen, kGen, kGen, kGen, kGen, kGen), // 242 |
| MakeEntry("timer_getoverrun", kGen, kGen, kGen, kGen, kGen, kGen), // 243 |
| MakeEntry("timer_delete", kGen, kGen, kGen, kGen, kGen, kGen), // 244 |
| MakeEntry("clock_settime", kGen, kGen, kGen, kGen, kGen, kGen), // 245 |
| MakeEntry("clock_gettime", kGen, kGen, kGen, kGen, kGen, kGen), // 246 |
| MakeEntry("clock_getres", kGen, kGen, kGen, kGen, kGen, kGen), // 247 |
| MakeEntry("clock_nanosleep", kGen, kGen, kGen, kGen, kGen, kGen), // 248 |
| MakeEntry("swapcontext", kHex, kHex, kHex, kHex, kHex, kHex), // 249 |
| MakeEntry("tgkill", kInt, kInt, kSignal, kGen, kGen, kGen), // 250 |
| MakeEntry("utimes", kGen, kGen, kGen, kGen, kGen, kGen), // 251 |
| MakeEntry("statfs64", kHex, kHex, kHex, kHex, kHex, kHex), // 252 |
| MakeEntry("fstatfs64", kHex, kHex, kHex, kHex, kHex, kHex), // 253 |
| MakeEntry("fadvise64_64", kHex, kHex, kHex, kHex, kHex, kHex), // 254 |
| MakeEntry("rtas", kHex, kHex, kHex, kHex, kHex, kHex), // 255 |
| MakeEntry("sys_debug_setcontext", kHex, kHex, kHex, kHex, kHex, |
| kHex), // 256 |
| SYSCALLS_UNUSED("UNUSED257"), // 257 |
| MakeEntry("migrate_pages", kGen, kGen, kGen, kGen, kGen, kGen), // 258 |
| MakeEntry("mbind", kGen, kGen, kGen, kGen, kGen, kGen), // 259 |
| MakeEntry("get_mempolicy", kGen, kGen, kGen, kGen, kGen, kGen), // 260 |
| MakeEntry("set_mempolicy", kGen, kGen, kGen, kGen, kGen, kGen), // 261 |
| MakeEntry("mq_open", kGen, kGen, kGen, kGen, kGen, kGen), // 262 |
| MakeEntry("mq_unlink", kGen, kGen, kGen, kGen, kGen, kGen), // 263 |
| MakeEntry("mq_timedsend", kGen, kGen, kGen, kGen, kGen, kGen), // 264 |
| MakeEntry("mq_timedreceive", kGen, kGen, kGen, kGen, kGen, kGen), // 265 |
| MakeEntry("mq_notify", kGen, kGen, kGen, kGen, kGen, kGen), // 266 |
| MakeEntry("mq_getsetattr", kGen, kGen, kGen, kGen, kGen, kGen), // 267 |
| MakeEntry("kexec_load", kGen, kGen, kGen, kGen, kGen, kGen), // 268 |
| MakeEntry("add_key", kGen, kGen, kGen, kGen, kGen, kGen), // 269 |
| MakeEntry("request_key", kGen, kGen, kGen, kGen, kGen, kGen), // 270 |
| MakeEntry("keyctl", kGen, kGen, kGen, kGen, kGen, kGen), // 271 |
| MakeEntry("waitid", kGen, kGen, kGen, kGen, kGen, kGen), // 272 |
| MakeEntry("ioprio_set", kGen, kGen, kGen, kGen, kGen, kGen), // 273 |
| MakeEntry("ioprio_get", kGen, kGen, kGen, kGen, kGen, kGen), // 274 |
| MakeEntry("inotify_init", kGen, kGen, kGen, kGen, kGen, kGen), // 275 |
| MakeEntry("inotify_add_watch", kGen, kGen, kGen, kGen, kGen, kGen), // 276 |
| MakeEntry("inotify_rm_watch", kGen, kGen, kGen, kGen, kGen, kGen), // 277 |
| MakeEntry("spu_run", kHex, kHex, kHex, kHex, kHex, kHex), // 278 |
| MakeEntry("spu_create", kHex, kHex, kHex, kHex, kHex, kHex), // 279 |
| MakeEntry("pselect6", kGen, kGen, kGen, kGen, kGen, kGen), // 280 |
| MakeEntry("ppoll", kGen, kGen, kGen, kGen, kGen, kGen), // 281 |
| MakeEntry("unshare", kGen, kGen, kGen, kGen, kGen, kGen), // 282 |
| MakeEntry("splice", kGen, kGen, kGen, kGen, kGen, kGen), // 283 |
| MakeEntry("tee", kGen, kGen, kGen, kGen, kGen, kGen), // 284 |
| MakeEntry("vmsplice", kGen, kGen, kGen, kGen, kGen, kGen), // 285 |
| MakeEntry("openat", kGen, kPath, kOct, kHex, kGen, kGen), // 286 |
| MakeEntry("mkdirat", kGen, kPath, kGen, kGen, kGen, kGen), // 287 |
| MakeEntry("mknodat", kGen, kPath, kGen, kGen, kGen, kGen), // 288 |
| MakeEntry("fchownat", kGen, kPath, kGen, kGen, kGen, kGen), // 289 |
| MakeEntry("futimesat", kGen, kPath, kGen, kGen, kGen, kGen), // 290 |
| MakeEntry("newfstatat", kGen, kPath, kGen, kGen, kGen, kGen), // 291 |
| MakeEntry("unlinkat", kGen, kPath, kGen, kGen, kGen, kGen), // 292 |
| MakeEntry("renameat", kGen, kPath, kGen, kPath, kGen, kGen), // 293 |
| MakeEntry("linkat", kGen, kPath, kGen, kPath, kGen, kGen), // 294 |
| MakeEntry("symlinkat", kPath, kGen, kPath, kGen, kGen, kGen), // 295 |
| MakeEntry("readlinkat", kGen, kPath, kGen, kGen, kGen, kGen), // 296 |
| MakeEntry("fchmodat", kGen, kPath, kGen, kGen, kGen, kGen), // 297 |
| MakeEntry("faccessat", kGen, kPath, kGen, kGen, kGen, kGen), // 298 |
| MakeEntry("get_robust_list", kGen, kGen, kGen, kGen, kGen, kGen), // 299 |
| MakeEntry("set_robust_list", kGen, kGen, kGen, kGen, kGen, kGen), // 300 |
| MakeEntry("move_pages", kGen, kGen, kGen, kGen, kGen, kGen), // 301 |
| MakeEntry("getcpu", kHex, kHex, kHex, kGen, kGen, kGen), // 302 |
| MakeEntry("epoll_pwait", kGen, kGen, kGen, kGen, kGen, kGen), // 303 |
| MakeEntry("utimensat", kGen, kGen, kGen, kGen, kGen, kGen), // 304 |
| MakeEntry("signalfd", kGen, kGen, kGen, kGen, kGen, kGen), // 305 |
| MakeEntry("timerfd_create", kGen, kGen, kGen, kGen, kGen, kGen), // 306 |
| MakeEntry("eventfd", kGen, kGen, kGen, kGen, kGen, kGen), // 307 |
| MakeEntry("sync_file_range2", kHex, kHex, kHex, kHex, kHex, kHex), // 308 |
| MakeEntry("fallocate", kGen, kGen, kGen, kGen, kGen, kGen), // 309 |
| MakeEntry("subpage_prot", kHex, kHex, kHex, kHex, kHex, kHex), // 310 |
| MakeEntry("timerfd_settime", kGen, kGen, kGen, kGen, kGen, kGen), // 311 |
| MakeEntry("timerfd_gettime", kGen, kGen, kGen, kGen, kGen, kGen), // 312 |
| MakeEntry("signalfd4", kGen, kGen, kGen, kGen, kGen, kGen), // 313 |
| MakeEntry("eventfd2", kGen, kGen, kGen, kGen, kGen, kGen), // 314 |
| MakeEntry("epoll_create1", kGen, kGen, kGen, kGen, kGen, kGen), // 315 |
| MakeEntry("dup3", kGen, kGen, kGen, kGen, kGen, kGen), // 316 |
| MakeEntry("pipe2", kGen, kGen, kGen, kGen, kGen, kGen), // 317 |
| MakeEntry("inotify_init1", kGen, kGen, kGen, kGen, kGen, kGen), // 318 |
| MakeEntry("perf_event_open", kGen, kGen, kGen, kGen, kGen, kGen), // 319 |
| MakeEntry("preadv", kGen, kGen, kGen, kGen, kGen, kGen), // 320 |
| MakeEntry("pwritev", kGen, kGen, kGen, kGen, kGen, kGen), // 321 |
| MakeEntry("rt_tgsigqueueinfo", kGen, kGen, kGen, kGen, kGen, kGen), // 322 |
| MakeEntry("fanotify_init", kHex, kHex, kInt, kGen, kGen, kGen), // 323 |
| MakeEntry("fanotify_mark", kInt, kHex, kInt, kPath, kGen, kGen), // 324 |
| MakeEntry("prlimit64", kInt, kInt, kHex, kHex, kGen, kGen), // 325 |
| MakeEntry("socket", kAddressFamily, kInt, kInt, kGen, kGen, kGen), // 326 |
| MakeEntry("bind", kGen, kGen, kGen, kGen, kGen, kGen), // 327 |
| MakeEntry("connect", kInt, kSockaddr, kInt, kGen, kGen, kGen), // 328 |
| MakeEntry("listen", kGen, kGen, kGen, kGen, kGen, kGen), // 329 |
| MakeEntry("accept", kGen, kGen, kGen, kGen, kGen, kGen), // 330 |
| MakeEntry("getsockname", kGen, kGen, kGen, kGen, kGen, kGen), // 331 |
| MakeEntry("getpeername", kGen, kGen, kGen, kGen, kGen, kGen), // 332 |
| MakeEntry("socketpair", kGen, kGen, kGen, kGen, kGen, kGen), // 333 |
| MakeEntry("send", kHex, kHex, kHex, kHex, kHex, kHex), // 334 |
| MakeEntry("sendto", kInt, kGen, kInt, kHex, kSockaddr, kInt), // 335 |
| MakeEntry("recv", kHex, kHex, kHex, kHex, kHex, kHex), // 336 |
| MakeEntry("recvfrom", kGen, kGen, kGen, kGen, kGen, kGen), // 337 |
| MakeEntry("shutdown", kGen, kGen, kGen, kGen, kGen, kGen), // 338 |
| MakeEntry("setsockopt", kGen, kGen, kGen, kGen, kGen, kGen), // 339 |
| MakeEntry("getsockopt", kGen, kGen, kGen, kGen, kGen, kGen), // 340 |
| MakeEntry("sendmsg", kInt, kSockmsghdr, kHex, kGen, kGen, kGen), // 341 |
| MakeEntry("recvmsg", kGen, kGen, kGen, kGen, kGen, kGen), // 342 |
| MakeEntry("recvmmsg", kInt, kHex, kHex, kHex, kGen, kGen), // 343 |
| MakeEntry("accept4", kGen, kGen, kGen, kGen, kGen, kGen), // 344 |
| MakeEntry("name_to_handle_at", kInt, kGen, kHex, kHex, kHex, kGen), // 345 |
| MakeEntry("open_by_handle_at", kInt, kHex, kHex, kGen, kGen, kGen), // 346 |
| MakeEntry("clock_adjtime", kInt, kHex, kGen, kGen, kGen, kGen), // 347 |
| MakeEntry("syncfs", kInt, kGen, kGen, kGen, kGen, kGen), // 348 |
| MakeEntry("sendmmsg", kInt, kHex, kInt, kHex, kGen, kGen), // 349 |
| MakeEntry("setns", kInt, kHex, kGen, kGen, kGen, kGen), // 350 |
| MakeEntry("process_vm_readv", kInt, kHex, kInt, kHex, kInt, kInt), // 351 |
| MakeEntry("process_vm_writev", kInt, kHex, kInt, kHex, kInt, kInt), // 352 |
| MakeEntry("finit_module", kInt, kPath, kHex, kGen, kGen, kGen), // 353 |
| MakeEntry("kcmp", kInt, kInt, kInt, kHex, kHex, kGen), // 354 |
| MakeEntry("sched_setattr", kGen, kGen, kGen, kGen, kGen, kGen), // 355 |
| MakeEntry("sched_getattr", kGen, kGen, kGen, kGen, kGen, kGen), // 356 |
| MakeEntry("renameat2", kGen, kPath, kGen, kPath, kGen, kGen), // 357 |
| MakeEntry("seccomp", kGen, kGen, kGen, kGen, kGen, kGen), // 358 |
| MakeEntry("getrandom", kGen, kGen, kGen, kGen, kGen, kGen), // 359 |
| MakeEntry("memfd_create", kGen, kGen, kGen, kGen, kGen, kGen), // 360 |
| MakeEntry("bpf", kHex, kHex, kHex, kHex, kHex, kHex), // 361 |
| MakeEntry("execveat", kHex, kHex, kHex, kHex, kHex, kHex), // 362 |
| MakeEntry("switch_endian", kHex, kHex, kHex, kHex, kHex, kHex), // 363 |
| MakeEntry("userfaultfd", kHex, kHex, kHex, kHex, kHex, kHex), // 364 |
| MakeEntry("membarrier", kHex, kHex, kHex, kHex, kHex, kHex), // 365 |
| SYSCALLS_UNUSED("UNUSED366"), // 366 |
| SYSCALLS_UNUSED("UNUSED367"), // 367 |
| SYSCALLS_UNUSED("UNUSED368"), // 368 |
| SYSCALLS_UNUSED("UNUSED369"), // 369 |
| SYSCALLS_UNUSED("UNUSED370"), // 370 |
| SYSCALLS_UNUSED("UNUSED371"), // 371 |
| SYSCALLS_UNUSED("UNUSED372"), // 372 |
| SYSCALLS_UNUSED("UNUSED373"), // 373 |
| SYSCALLS_UNUSED("UNUSED374"), // 374 |
| SYSCALLS_UNUSED("UNUSED375"), // 375 |
| SYSCALLS_UNUSED("UNUSED376"), // 376 |
| SYSCALLS_UNUSED("UNUSED377"), // 377 |
| MakeEntry("mlock2", kHex, kHex, kHex, kHex, kHex, kHex), // 378 |
| MakeEntry("copy_file_range", kHex, kHex, kHex, kHex, kHex, kHex), // 379 |
| MakeEntry("preadv2", kHex, kHex, kHex, kHex, kHex, kHex), // 380 |
| MakeEntry("pwritev2", kHex, kHex, kHex, kHex, kHex, kHex), // 381 |
| }; |
| |
| #endif |
| |
| #undef SYSCALLS_UNUSED00_99 |
| #undef SYSCALLS_UNUSED50_99 |
| #undef SYSCALLS_UNUSED00_49 |
| #undef SYSCALLS_UNUSED0_9 |
| #undef SYSCALLS_UNUSED |
| |
| SyscallTable SyscallTable::get(Syscall::CpuArch arch) { |
| switch (arch) { |
| #if defined(__x86_64__) |
| case Syscall::kX86_64: |
| return SyscallTable(kSyscallDataX8664); |
| case Syscall::kX86_32: |
| return SyscallTable(kSyscallDataX8632); |
| #elif defined(__powerpc64__) |
| case Syscall::kPPC_64: |
| return SyscallTable(kSyscallDataPPC64); |
| #endif |
| default: |
| return SyscallTable(); |
| } |
| } |
| |
| } // namespace sandbox2 |