syscalls_linux.odin 59 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854
  1. package unix
  2. import "core:intrinsics"
  3. // Linux has inconsistent system call numbering across architectures,
  4. // for largely historical reasons. This attempts to provide a unified
  5. // Odin-side interface for system calls that are required for the core
  6. // library to work.
  7. // For authorative system call numbers, the following files in the kernel
  8. // source can be used:
  9. //
  10. // amd64: arch/x86/entry/syscalls/syscall_64.tbl
  11. // arm64: include/uapi/asm-generic/unistd.h
  12. // 386: arch/x86/entry/syscalls/sycall_32.tbl
  13. // arm: arch/arm/tools/syscall.tbl
  14. when ODIN_ARCH == .amd64 {
  15. SYS_read : uintptr : 0
  16. SYS_write : uintptr : 1
  17. SYS_open : uintptr : 2
  18. SYS_close : uintptr : 3
  19. SYS_stat : uintptr : 4
  20. SYS_fstat : uintptr : 5
  21. SYS_lstat : uintptr : 6
  22. SYS_poll : uintptr : 7
  23. SYS_lseek : uintptr : 8
  24. SYS_mmap : uintptr : 9
  25. SYS_mprotect : uintptr : 10
  26. SYS_munmap : uintptr : 11
  27. SYS_brk : uintptr : 12
  28. SYS_rt_sigaction : uintptr : 13
  29. SYS_rt_sigprocmask : uintptr : 14
  30. SYS_rt_sigreturn : uintptr : 15
  31. SYS_ioctl : uintptr : 16
  32. SYS_pread64 : uintptr : 17
  33. SYS_pwrite64 : uintptr : 18
  34. SYS_readv : uintptr : 19
  35. SYS_writev : uintptr : 20
  36. SYS_access : uintptr : 21
  37. SYS_pipe : uintptr : 22
  38. SYS_select : uintptr : 23
  39. SYS_sched_yield : uintptr : 24
  40. SYS_mremap : uintptr : 25
  41. SYS_msync : uintptr : 26
  42. SYS_mincore : uintptr : 27
  43. SYS_madvise : uintptr : 28
  44. SYS_shmget : uintptr : 29
  45. SYS_shmat : uintptr : 30
  46. SYS_shmctl : uintptr : 31
  47. SYS_dup : uintptr : 32
  48. SYS_dup2 : uintptr : 33
  49. SYS_pause : uintptr : 34
  50. SYS_nanosleep : uintptr : 35
  51. SYS_getitimer : uintptr : 36
  52. SYS_alarm : uintptr : 37
  53. SYS_setitimer : uintptr : 38
  54. SYS_getpid : uintptr : 39
  55. SYS_sendfile : uintptr : 40
  56. SYS_socket : uintptr : 41
  57. SYS_connect : uintptr : 42
  58. SYS_accept : uintptr : 43
  59. SYS_sendto : uintptr : 44
  60. SYS_recvfrom : uintptr : 45
  61. SYS_sendmsg : uintptr : 46
  62. SYS_recvmsg : uintptr : 47
  63. SYS_shutdown : uintptr : 48
  64. SYS_bind : uintptr : 49
  65. SYS_listen : uintptr : 50
  66. SYS_getsockname : uintptr : 51
  67. SYS_getpeername : uintptr : 52
  68. SYS_socketpair : uintptr : 53
  69. SYS_setsockopt : uintptr : 54
  70. SYS_getsockopt : uintptr : 55
  71. SYS_clone : uintptr : 56
  72. SYS_fork : uintptr : 57
  73. SYS_vfork : uintptr : 58
  74. SYS_execve : uintptr : 59
  75. SYS_exit : uintptr : 60
  76. SYS_wait4 : uintptr : 61
  77. SYS_kill : uintptr : 62
  78. SYS_uname : uintptr : 63
  79. SYS_semget : uintptr : 64
  80. SYS_semop : uintptr : 65
  81. SYS_semctl : uintptr : 66
  82. SYS_shmdt : uintptr : 67
  83. SYS_msgget : uintptr : 68
  84. SYS_msgsnd : uintptr : 69
  85. SYS_msgrcv : uintptr : 70
  86. SYS_msgctl : uintptr : 71
  87. SYS_fcntl : uintptr : 72
  88. SYS_flock : uintptr : 73
  89. SYS_fsync : uintptr : 74
  90. SYS_fdatasync : uintptr : 75
  91. SYS_truncate : uintptr : 76
  92. SYS_ftruncate : uintptr : 77
  93. SYS_getdents : uintptr : 78
  94. SYS_getcwd : uintptr : 79
  95. SYS_chdir : uintptr : 80
  96. SYS_fchdir : uintptr : 81
  97. SYS_rename : uintptr : 82
  98. SYS_mkdir : uintptr : 83
  99. SYS_rmdir : uintptr : 84
  100. SYS_creat : uintptr : 85
  101. SYS_link : uintptr : 86
  102. SYS_unlink : uintptr : 87
  103. SYS_symlink : uintptr : 88
  104. SYS_readlink : uintptr : 89
  105. SYS_chmod : uintptr : 90
  106. SYS_fchmod : uintptr : 91
  107. SYS_chown : uintptr : 92
  108. SYS_fchown : uintptr : 93
  109. SYS_lchown : uintptr : 94
  110. SYS_umask : uintptr : 95
  111. SYS_gettimeofday : uintptr : 96
  112. SYS_getrlimit : uintptr : 97
  113. SYS_getrusage : uintptr : 98
  114. SYS_sysinfo : uintptr : 99
  115. SYS_times : uintptr : 100
  116. SYS_ptrace : uintptr : 101
  117. SYS_getuid : uintptr : 102
  118. SYS_syslog : uintptr : 103
  119. SYS_getgid : uintptr : 104
  120. SYS_setuid : uintptr : 105
  121. SYS_setgid : uintptr : 106
  122. SYS_geteuid : uintptr : 107
  123. SYS_getegid : uintptr : 108
  124. SYS_setpgid : uintptr : 109
  125. SYS_getppid : uintptr : 110
  126. SYS_getpgrp : uintptr : 111
  127. SYS_setsid : uintptr : 112
  128. SYS_setreuid : uintptr : 113
  129. SYS_setregid : uintptr : 114
  130. SYS_getgroups : uintptr : 115
  131. SYS_setgroups : uintptr : 116
  132. SYS_setresuid : uintptr : 117
  133. SYS_getresuid : uintptr : 118
  134. SYS_setresgid : uintptr : 119
  135. SYS_getresgid : uintptr : 120
  136. SYS_getpgid : uintptr : 121
  137. SYS_setfsuid : uintptr : 122
  138. SYS_setfsgid : uintptr : 123
  139. SYS_getsid : uintptr : 124
  140. SYS_capget : uintptr : 125
  141. SYS_capset : uintptr : 126
  142. SYS_rt_sigpending : uintptr : 127
  143. SYS_rt_sigtimedwait : uintptr : 128
  144. SYS_rt_sigqueueinfo : uintptr : 129
  145. SYS_rt_sigsuspend : uintptr : 130
  146. SYS_sigaltstack : uintptr : 131
  147. SYS_utime : uintptr : 132
  148. SYS_mknod : uintptr : 133
  149. SYS_uselib : uintptr : 134
  150. SYS_personality : uintptr : 135
  151. SYS_ustat : uintptr : 136
  152. SYS_statfs : uintptr : 137
  153. SYS_fstatfs : uintptr : 138
  154. SYS_sysfs : uintptr : 139
  155. SYS_getpriority : uintptr : 140
  156. SYS_setpriority : uintptr : 141
  157. SYS_sched_setparam : uintptr : 142
  158. SYS_sched_getparam : uintptr : 143
  159. SYS_sched_setscheduler : uintptr : 144
  160. SYS_sched_getscheduler : uintptr : 145
  161. SYS_sched_get_priority_max : uintptr : 146
  162. SYS_sched_get_priority_min : uintptr : 147
  163. SYS_sched_rr_get_interval : uintptr : 148
  164. SYS_mlock : uintptr : 149
  165. SYS_munlock : uintptr : 150
  166. SYS_mlockall : uintptr : 151
  167. SYS_munlockall : uintptr : 152
  168. SYS_vhangup : uintptr : 153
  169. SYS_modify_ldt : uintptr : 154
  170. SYS_pivot_root : uintptr : 155
  171. SYS__sysctl : uintptr : 156
  172. SYS_prctl : uintptr : 157
  173. SYS_arch_prctl : uintptr : 158
  174. SYS_adjtimex : uintptr : 159
  175. SYS_setrlimit : uintptr : 160
  176. SYS_chroot : uintptr : 161
  177. SYS_sync : uintptr : 162
  178. SYS_acct : uintptr : 163
  179. SYS_settimeofday : uintptr : 164
  180. SYS_mount : uintptr : 165
  181. SYS_umount2 : uintptr : 166
  182. SYS_swapon : uintptr : 167
  183. SYS_swapoff : uintptr : 168
  184. SYS_reboot : uintptr : 169
  185. SYS_sethostname : uintptr : 170
  186. SYS_setdomainname : uintptr : 171
  187. SYS_iopl : uintptr : 172
  188. SYS_ioperm : uintptr : 173
  189. SYS_create_module : uintptr : 174
  190. SYS_init_module : uintptr : 175
  191. SYS_delete_module : uintptr : 176
  192. SYS_get_kernel_syms : uintptr : 177
  193. SYS_query_module : uintptr : 178
  194. SYS_quotactl : uintptr : 179
  195. SYS_nfsservctl : uintptr : 180
  196. SYS_getpmsg : uintptr : 181
  197. SYS_putpmsg : uintptr : 182
  198. SYS_afs_syscall : uintptr : 183
  199. SYS_tuxcall : uintptr : 184
  200. SYS_security : uintptr : 185
  201. SYS_gettid : uintptr : 186
  202. SYS_readahead : uintptr : 187
  203. SYS_setxattr : uintptr : 188
  204. SYS_lsetxattr : uintptr : 189
  205. SYS_fsetxattr : uintptr : 190
  206. SYS_getxattr : uintptr : 191
  207. SYS_lgetxattr : uintptr : 192
  208. SYS_fgetxattr : uintptr : 193
  209. SYS_listxattr : uintptr : 194
  210. SYS_llistxattr : uintptr : 195
  211. SYS_flistxattr : uintptr : 196
  212. SYS_removexattr : uintptr : 197
  213. SYS_lremovexattr : uintptr : 198
  214. SYS_fremovexattr : uintptr : 199
  215. SYS_tkill : uintptr : 200
  216. SYS_time : uintptr : 201
  217. SYS_futex : uintptr : 202
  218. SYS_sched_setaffinity : uintptr : 203
  219. SYS_sched_getaffinity : uintptr : 204
  220. SYS_set_thread_area : uintptr : 205
  221. SYS_io_setup : uintptr : 206
  222. SYS_io_destroy : uintptr : 207
  223. SYS_io_getevents : uintptr : 208
  224. SYS_io_submit : uintptr : 209
  225. SYS_io_cancel : uintptr : 210
  226. SYS_get_thread_area : uintptr : 211
  227. SYS_lookup_dcookie : uintptr : 212
  228. SYS_epoll_create : uintptr : 213
  229. SYS_epoll_ctl_old : uintptr : 214
  230. SYS_epoll_wait_old : uintptr : 215
  231. SYS_remap_file_pages : uintptr : 216
  232. SYS_getdents64 : uintptr : 217
  233. SYS_set_tid_address : uintptr : 218
  234. SYS_restart_syscall : uintptr : 219
  235. SYS_semtimedop : uintptr : 220
  236. SYS_fadvise64 : uintptr : 221
  237. SYS_timer_create : uintptr : 222
  238. SYS_timer_settime : uintptr : 223
  239. SYS_timer_gettime : uintptr : 224
  240. SYS_timer_getoverrun : uintptr : 225
  241. SYS_timer_delete : uintptr : 226
  242. SYS_clock_settime : uintptr : 227
  243. SYS_clock_gettime : uintptr : 228
  244. SYS_clock_getres : uintptr : 229
  245. SYS_clock_nanosleep : uintptr : 230
  246. SYS_exit_group : uintptr : 231
  247. SYS_epoll_wait : uintptr : 232
  248. SYS_epoll_ctl : uintptr : 233
  249. SYS_tgkill : uintptr : 234
  250. SYS_utimes : uintptr : 235
  251. SYS_vserver : uintptr : 236
  252. SYS_mbind : uintptr : 237
  253. SYS_set_mempolicy : uintptr : 238
  254. SYS_get_mempolicy : uintptr : 239
  255. SYS_mq_open : uintptr : 240
  256. SYS_mq_unlink : uintptr : 241
  257. SYS_mq_timedsend : uintptr : 242
  258. SYS_mq_timedreceive : uintptr : 243
  259. SYS_mq_notify : uintptr : 244
  260. SYS_mq_getsetattr : uintptr : 245
  261. SYS_kexec_load : uintptr : 246
  262. SYS_waitid : uintptr : 247
  263. SYS_add_key : uintptr : 248
  264. SYS_request_key : uintptr : 249
  265. SYS_keyctl : uintptr : 250
  266. SYS_ioprio_set : uintptr : 251
  267. SYS_ioprio_get : uintptr : 252
  268. SYS_inotify_init : uintptr : 253
  269. SYS_inotify_add_watch : uintptr : 254
  270. SYS_inotify_rm_watch : uintptr : 255
  271. SYS_migrate_pages : uintptr : 256
  272. SYS_openat : uintptr : 257
  273. SYS_mkdirat : uintptr : 258
  274. SYS_mknodat : uintptr : 259
  275. SYS_fchownat : uintptr : 260
  276. SYS_futimesat : uintptr : 261
  277. SYS_fstatat : uintptr : 262
  278. SYS_unlinkat : uintptr : 263
  279. SYS_renameat : uintptr : 264
  280. SYS_linkat : uintptr : 265
  281. SYS_symlinkat : uintptr : 266
  282. SYS_readlinkat : uintptr : 267
  283. SYS_fchmodat : uintptr : 268
  284. SYS_faccessat : uintptr : 269
  285. SYS_pselect6 : uintptr : 270
  286. SYS_ppoll : uintptr : 271
  287. SYS_unshare : uintptr : 272
  288. SYS_set_robust_list : uintptr : 273
  289. SYS_get_robust_list : uintptr : 274
  290. SYS_splice : uintptr : 275
  291. SYS_tee : uintptr : 276
  292. SYS_sync_file_range : uintptr : 277
  293. SYS_vmsplice : uintptr : 278
  294. SYS_move_pages : uintptr : 279
  295. SYS_utimensat : uintptr : 280
  296. SYS_epoll_pwait : uintptr : 281
  297. SYS_signalfd : uintptr : 282
  298. SYS_timerfd_create : uintptr : 283
  299. SYS_eventfd : uintptr : 284
  300. SYS_fallocate : uintptr : 285
  301. SYS_timerfd_settime : uintptr : 286
  302. SYS_timerfd_gettime : uintptr : 287
  303. SYS_accept4 : uintptr : 288
  304. SYS_signalfd4 : uintptr : 289
  305. SYS_eventfd2 : uintptr : 290
  306. SYS_epoll_create1 : uintptr : 291
  307. SYS_dup3 : uintptr : 292
  308. SYS_pipe2 : uintptr : 293
  309. SYS_inotify_init1 : uintptr : 294
  310. SYS_preadv : uintptr : 295
  311. SYS_pwritev : uintptr : 296
  312. SYS_rt_tgsigqueueinfo : uintptr : 297
  313. SYS_perf_event_open : uintptr : 298
  314. SYS_recvmmsg : uintptr : 299
  315. SYS_fanotify_init : uintptr : 300
  316. SYS_fanotify_mark : uintptr : 301
  317. SYS_prlimit64 : uintptr : 302
  318. SYS_name_to_handle_at : uintptr : 303
  319. SYS_open_by_handle_at : uintptr : 304
  320. SYS_clock_adjtime : uintptr : 305
  321. SYS_syncfs : uintptr : 306
  322. SYS_sendmmsg : uintptr : 307
  323. SYS_setns : uintptr : 308
  324. SYS_getcpu : uintptr : 309
  325. SYS_process_vm_readv : uintptr : 310
  326. SYS_process_vm_writev : uintptr : 311
  327. SYS_kcmp : uintptr : 312
  328. SYS_finit_module : uintptr : 313
  329. SYS_sched_setattr : uintptr : 314
  330. SYS_sched_getattr : uintptr : 315
  331. SYS_renameat2 : uintptr : 316
  332. SYS_seccomp : uintptr : 317
  333. SYS_getrandom : uintptr : 318
  334. SYS_memfd_create : uintptr : 319
  335. SYS_kexec_file_load : uintptr : 320
  336. SYS_bpf : uintptr : 321
  337. SYS_execveat : uintptr : 322
  338. SYS_userfaultfd : uintptr : 323
  339. SYS_membarrier : uintptr : 324
  340. SYS_mlock2 : uintptr : 325
  341. SYS_copy_file_range : uintptr : 326
  342. SYS_preadv2 : uintptr : 327
  343. SYS_pwritev2 : uintptr : 328
  344. SYS_pkey_mprotect : uintptr : 329
  345. SYS_pkey_alloc : uintptr : 330
  346. SYS_pkey_free : uintptr : 331
  347. SYS_statx : uintptr : 332
  348. SYS_io_pgetevents : uintptr : 333
  349. SYS_rseq : uintptr : 334
  350. SYS_pidfd_send_signal : uintptr : 424
  351. SYS_io_uring_setup : uintptr : 425
  352. SYS_io_uring_enter : uintptr : 426
  353. SYS_io_uring_register : uintptr : 427
  354. SYS_open_tree : uintptr : 428
  355. SYS_move_mount : uintptr : 429
  356. SYS_fsopen : uintptr : 430
  357. SYS_fsconfig : uintptr : 431
  358. SYS_fsmount : uintptr : 432
  359. SYS_fspick : uintptr : 433
  360. SYS_pidfd_open : uintptr : 434
  361. SYS_clone3 : uintptr : 435
  362. SYS_close_range : uintptr : 436
  363. SYS_openat2 : uintptr : 437
  364. SYS_pidfd_getfd : uintptr : 438
  365. SYS_faccessat2 : uintptr : 439
  366. SYS_process_madvise : uintptr : 440
  367. SYS_epoll_pwait2 : uintptr : 441
  368. SYS_mount_setattr : uintptr : 442
  369. SYS_landlock_create_ruleset : uintptr : 444
  370. SYS_landlock_add_rule : uintptr : 445
  371. SYS_landlock_restrict_self : uintptr : 446
  372. SYS_memfd_secret : uintptr : 447
  373. } else when ODIN_ARCH == .arm64 {
  374. SYS_io_setup : uintptr : 0
  375. SYS_io_destroy : uintptr : 1
  376. SYS_io_submit : uintptr : 2
  377. SYS_io_cancel : uintptr : 3
  378. SYS_io_getevents : uintptr : 4
  379. SYS_setxattr : uintptr : 5
  380. SYS_lsetxattr : uintptr : 6
  381. SYS_fsetxattr : uintptr : 7
  382. SYS_getxattr : uintptr : 8
  383. SYS_lgetxattr : uintptr : 9
  384. SYS_fgetxattr : uintptr : 10
  385. SYS_listxattr : uintptr : 11
  386. SYS_llistxattr : uintptr : 12
  387. SYS_flistxattr : uintptr : 13
  388. SYS_removexattr : uintptr : 14
  389. SYS_lremovexattr : uintptr : 15
  390. SYS_fremovexattr : uintptr : 16
  391. SYS_getcwd : uintptr : 17
  392. SYS_lookup_dcookie : uintptr : 18
  393. SYS_eventfd2 : uintptr : 19
  394. SYS_epoll_create1 : uintptr : 20
  395. SYS_epoll_ctl : uintptr : 21
  396. SYS_epoll_pwait : uintptr : 22
  397. SYS_dup : uintptr : 23
  398. SYS_dup3 : uintptr : 24
  399. SYS_fcntl : uintptr : 25
  400. SYS_inotify_init1 : uintptr : 26
  401. SYS_inotify_add_watch : uintptr : 27
  402. SYS_inotify_rm_watch : uintptr : 28
  403. SYS_ioctl : uintptr : 29
  404. SYS_ioprio_set : uintptr : 30
  405. SYS_ioprio_get : uintptr : 31
  406. SYS_flock : uintptr : 32
  407. SYS_mknodat : uintptr : 33
  408. SYS_mkdirat : uintptr : 34
  409. SYS_unlinkat : uintptr : 35
  410. SYS_symlinkat : uintptr : 36
  411. SYS_linkat : uintptr : 37
  412. SYS_renameat : uintptr : 38
  413. SYS_umount2 : uintptr : 39
  414. SYS_mount : uintptr : 40
  415. SYS_pivot_root : uintptr : 41
  416. SYS_nfsservctl : uintptr : 42
  417. SYS_statfs : uintptr : 43
  418. SYS_fstatfs : uintptr : 44
  419. SYS_truncate : uintptr : 45
  420. SYS_ftruncate : uintptr : 46
  421. SYS_fallocate : uintptr : 47
  422. SYS_faccessat : uintptr : 48
  423. SYS_chdir : uintptr : 49
  424. SYS_fchdir : uintptr : 50
  425. SYS_chroot : uintptr : 51
  426. SYS_fchmod : uintptr : 52
  427. SYS_fchmodat : uintptr : 53
  428. SYS_fchownat : uintptr : 54
  429. SYS_fchown : uintptr : 55
  430. SYS_openat : uintptr : 56
  431. SYS_close : uintptr : 57
  432. SYS_vhangup : uintptr : 58
  433. SYS_pipe2 : uintptr : 59
  434. SYS_quotactl : uintptr : 60
  435. SYS_getdents64 : uintptr : 61
  436. SYS_lseek : uintptr : 62
  437. SYS_read : uintptr : 63
  438. SYS_write : uintptr : 64
  439. SYS_readv : uintptr : 65
  440. SYS_writev : uintptr : 66
  441. SYS_pread64 : uintptr : 67
  442. SYS_pwrite64 : uintptr : 68
  443. SYS_preadv : uintptr : 69
  444. SYS_pwritev : uintptr : 70
  445. SYS_sendfile : uintptr : 71
  446. SYS_pselect6 : uintptr : 72
  447. SYS_ppoll : uintptr : 73
  448. SYS_signalfd4 : uintptr : 74
  449. SYS_vmsplice : uintptr : 75
  450. SYS_splice : uintptr : 76
  451. SYS_tee : uintptr : 77
  452. SYS_readlinkat : uintptr : 78
  453. SYS_fstatat : uintptr : 79
  454. SYS_fstat : uintptr : 80
  455. SYS_sync : uintptr : 81
  456. SYS_fsync : uintptr : 82
  457. SYS_fdatasync : uintptr : 83
  458. SYS_sync_file_range : uintptr : 84
  459. SYS_timerfd_create : uintptr : 85
  460. SYS_timerfd_settime : uintptr : 86
  461. SYS_timerfd_gettime : uintptr : 87
  462. SYS_utimensat : uintptr : 88
  463. SYS_acct : uintptr : 89
  464. SYS_capget : uintptr : 90
  465. SYS_capset : uintptr : 91
  466. SYS_personality : uintptr : 92
  467. SYS_exit : uintptr : 93
  468. SYS_exit_group : uintptr : 94
  469. SYS_waitid : uintptr : 95
  470. SYS_set_tid_address : uintptr : 96
  471. SYS_unshare : uintptr : 97
  472. SYS_futex : uintptr : 98
  473. SYS_set_robust_list : uintptr : 99
  474. SYS_get_robust_list : uintptr : 100
  475. SYS_nanosleep : uintptr : 101
  476. SYS_getitimer : uintptr : 102
  477. SYS_setitimer : uintptr : 103
  478. SYS_kexec_load : uintptr : 104
  479. SYS_init_module : uintptr : 105
  480. SYS_delete_module : uintptr : 106
  481. SYS_timer_create : uintptr : 107
  482. SYS_timer_gettime : uintptr : 108
  483. SYS_timer_getoverrun : uintptr : 109
  484. SYS_timer_settime : uintptr : 110
  485. SYS_timer_delete : uintptr : 111
  486. SYS_clock_settime : uintptr : 112
  487. SYS_clock_gettime : uintptr : 113
  488. SYS_clock_getres : uintptr : 114
  489. SYS_clock_nanosleep : uintptr : 115
  490. SYS_syslog : uintptr : 116
  491. SYS_ptrace : uintptr : 117
  492. SYS_sched_setparam : uintptr : 118
  493. SYS_sched_setscheduler : uintptr : 119
  494. SYS_sched_getscheduler : uintptr : 120
  495. SYS_sched_getparam : uintptr : 121
  496. SYS_sched_setaffinity : uintptr : 122
  497. SYS_sched_getaffinity : uintptr : 123
  498. SYS_sched_yield : uintptr : 124
  499. SYS_sched_get_priority_max : uintptr : 125
  500. SYS_sched_get_priority_min : uintptr : 126
  501. SYS_sched_rr_get_interval : uintptr : 127
  502. SYS_restart_syscall : uintptr : 128
  503. SYS_kill : uintptr : 129
  504. SYS_tkill : uintptr : 130
  505. SYS_tgkill : uintptr : 131
  506. SYS_sigaltstack : uintptr : 132
  507. SYS_rt_sigsuspend : uintptr : 133
  508. SYS_rt_sigaction : uintptr : 134
  509. SYS_rt_sigprocmask : uintptr : 135
  510. SYS_rt_sigpending : uintptr : 136
  511. SYS_rt_sigtimedwait : uintptr : 137
  512. SYS_rt_sigqueueinfo : uintptr : 138
  513. SYS_rt_sigreturn : uintptr : 139
  514. SYS_setpriority : uintptr : 140
  515. SYS_getpriority : uintptr : 141
  516. SYS_reboot : uintptr : 142
  517. SYS_setregid : uintptr : 143
  518. SYS_setgid : uintptr : 144
  519. SYS_setreuid : uintptr : 145
  520. SYS_setuid : uintptr : 146
  521. SYS_setresuid : uintptr : 147
  522. SYS_getresuid : uintptr : 148
  523. SYS_setresgid : uintptr : 149
  524. SYS_getresgid : uintptr : 150
  525. SYS_setfsuid : uintptr : 151
  526. SYS_setfsgid : uintptr : 152
  527. SYS_times : uintptr : 153
  528. SYS_setpgid : uintptr : 154
  529. SYS_getpgid : uintptr : 155
  530. SYS_getsid : uintptr : 156
  531. SYS_setsid : uintptr : 157
  532. SYS_getgroups : uintptr : 158
  533. SYS_setgroups : uintptr : 159
  534. SYS_uname : uintptr : 160
  535. SYS_sethostname : uintptr : 161
  536. SYS_setdomainname : uintptr : 162
  537. SYS_getrlimit : uintptr : 163
  538. SYS_setrlimit : uintptr : 164
  539. SYS_getrusage : uintptr : 165
  540. SYS_umask : uintptr : 166
  541. SYS_prctl : uintptr : 167
  542. SYS_getcpu : uintptr : 168
  543. SYS_gettimeofday : uintptr : 169
  544. SYS_settimeofday : uintptr : 170
  545. SYS_adjtimex : uintptr : 171
  546. SYS_getpid : uintptr : 172
  547. SYS_getppid : uintptr : 173
  548. SYS_getuid : uintptr : 174
  549. SYS_geteuid : uintptr : 175
  550. SYS_getgid : uintptr : 176
  551. SYS_getegid : uintptr : 177
  552. SYS_gettid : uintptr : 178
  553. SYS_sysinfo : uintptr : 179
  554. SYS_mq_open : uintptr : 180
  555. SYS_mq_unlink : uintptr : 181
  556. SYS_mq_timedsend : uintptr : 182
  557. SYS_mq_timedreceive : uintptr : 183
  558. SYS_mq_notify : uintptr : 184
  559. SYS_mq_getsetattr : uintptr : 185
  560. SYS_msgget : uintptr : 186
  561. SYS_msgctl : uintptr : 187
  562. SYS_msgrcv : uintptr : 188
  563. SYS_msgsnd : uintptr : 189
  564. SYS_semget : uintptr : 190
  565. SYS_semctl : uintptr : 191
  566. SYS_semtimedop : uintptr : 192
  567. SYS_semop : uintptr : 193
  568. SYS_shmget : uintptr : 194
  569. SYS_shmctl : uintptr : 195
  570. SYS_shmat : uintptr : 196
  571. SYS_shmdt : uintptr : 197
  572. SYS_socket : uintptr : 198
  573. SYS_socketpair : uintptr : 199
  574. SYS_bind : uintptr : 200
  575. SYS_listen : uintptr : 201
  576. SYS_accept : uintptr : 202
  577. SYS_connect : uintptr : 203
  578. SYS_getsockname : uintptr : 204
  579. SYS_getpeername : uintptr : 205
  580. SYS_sendto : uintptr : 206
  581. SYS_recvfrom : uintptr : 207
  582. SYS_setsockopt : uintptr : 208
  583. SYS_getsockopt : uintptr : 209
  584. SYS_shutdown : uintptr : 210
  585. SYS_sendmsg : uintptr : 211
  586. SYS_recvmsg : uintptr : 212
  587. SYS_readahead : uintptr : 213
  588. SYS_brk : uintptr : 214
  589. SYS_munmap : uintptr : 215
  590. SYS_mremap : uintptr : 216
  591. SYS_add_key : uintptr : 217
  592. SYS_request_key : uintptr : 218
  593. SYS_keyctl : uintptr : 219
  594. SYS_clone : uintptr : 220
  595. SYS_execve : uintptr : 221
  596. SYS_mmap : uintptr : 222
  597. SYS_fadvise64 : uintptr : 223
  598. SYS_swapon : uintptr : 224
  599. SYS_swapoff : uintptr : 225
  600. SYS_mprotect : uintptr : 226
  601. SYS_msync : uintptr : 227
  602. SYS_mlock : uintptr : 228
  603. SYS_munlock : uintptr : 229
  604. SYS_mlockall : uintptr : 230
  605. SYS_munlockall : uintptr : 231
  606. SYS_mincore : uintptr : 232
  607. SYS_madvise : uintptr : 233
  608. SYS_remap_file_pages : uintptr : 234
  609. SYS_mbind : uintptr : 235
  610. SYS_get_mempolicy : uintptr : 236
  611. SYS_set_mempolicy : uintptr : 237
  612. SYS_migrate_pages : uintptr : 238
  613. SYS_move_pages : uintptr : 239
  614. SYS_rt_tgsigqueueinfo : uintptr : 240
  615. SYS_perf_event_open : uintptr : 241
  616. SYS_accept4 : uintptr : 242
  617. SYS_recvmmsg : uintptr : 243
  618. SYS_arch_specific_syscall : uintptr : 244
  619. SYS_wait4 : uintptr : 260
  620. SYS_prlimit64 : uintptr : 261
  621. SYS_fanotify_init : uintptr : 262
  622. SYS_fanotify_mark : uintptr : 263
  623. SYS_clock_adjtime : uintptr : 266
  624. SYS_syncfs : uintptr : 267
  625. SYS_setns : uintptr : 268
  626. SYS_sendmmsg : uintptr : 269
  627. SYS_process_vm_readv : uintptr : 270
  628. SYS_process_vm_writev : uintptr : 271
  629. SYS_kcmp : uintptr : 272
  630. SYS_finit_module : uintptr : 273
  631. SYS_sched_setattr : uintptr : 274
  632. SYS_sched_getattr : uintptr : 275
  633. SYS_renameat2 : uintptr : 276
  634. SYS_seccomp : uintptr : 277
  635. SYS_getrandom : uintptr : 278
  636. SYS_memfd_create : uintptr : 279
  637. SYS_bpf : uintptr : 280
  638. SYS_execveat : uintptr : 281
  639. SYS_userfaultfd : uintptr : 282
  640. SYS_membarrier : uintptr : 283
  641. SYS_mlock2 : uintptr : 284
  642. SYS_copy_file_range : uintptr : 285
  643. SYS_preadv2 : uintptr : 286
  644. SYS_pwritev2 : uintptr : 287
  645. SYS_pkey_mprotect : uintptr : 288
  646. SYS_pkey_alloc : uintptr : 289
  647. SYS_pkey_free : uintptr : 290
  648. SYS_statx : uintptr : 291
  649. SYS_io_pgetevents : uintptr : 292
  650. SYS_rseq : uintptr : 293
  651. SYS_kexec_file_load : uintptr : 294
  652. SYS_pidfd_send_signal : uintptr : 424
  653. SYS_io_uring_setup : uintptr : 425
  654. SYS_io_uring_enter : uintptr : 426
  655. SYS_io_uring_register : uintptr : 427
  656. SYS_open_tree : uintptr : 428
  657. SYS_move_mount : uintptr : 429
  658. SYS_fsopen : uintptr : 430
  659. SYS_fsconfig : uintptr : 431
  660. SYS_fsmount : uintptr : 432
  661. SYS_fspick : uintptr : 433
  662. SYS_pidfd_open : uintptr : 434
  663. SYS_clone3 : uintptr : 435
  664. SYS_close_range : uintptr : 436
  665. SYS_openat2 : uintptr : 437
  666. SYS_pidfd_getfd : uintptr : 438
  667. SYS_faccessat2 : uintptr : 439
  668. SYS_process_madvise : uintptr : 440
  669. SYS_epoll_pwait2 : uintptr : 441
  670. SYS_mount_setattr : uintptr : 442
  671. SYS_landlock_create_ruleset : uintptr : 444
  672. SYS_landlock_add_rule : uintptr : 445
  673. SYS_landlock_restrict_self : uintptr : 446
  674. SIGCHLD :: 17
  675. } else when ODIN_ARCH == .i386 {
  676. SYS_restart_syscall : uintptr : 0
  677. SYS_exit : uintptr : 1
  678. SYS_fork : uintptr : 2
  679. SYS_read : uintptr : 3
  680. SYS_write : uintptr : 4
  681. SYS_open : uintptr : 5
  682. SYS_close : uintptr : 6
  683. SYS_waitpid : uintptr : 7
  684. SYS_creat : uintptr : 8
  685. SYS_link : uintptr : 9
  686. SYS_unlink : uintptr : 10
  687. SYS_execve : uintptr : 11
  688. SYS_chdir : uintptr : 12
  689. SYS_time : uintptr : 13
  690. SYS_mknod : uintptr : 14
  691. SYS_chmod : uintptr : 15
  692. SYS_lchown : uintptr : 16
  693. SYS_break : uintptr : 17
  694. SYS_oldstat : uintptr : 18
  695. SYS_lseek : uintptr : 19
  696. SYS_getpid : uintptr : 20
  697. SYS_mount : uintptr : 21
  698. SYS_umount : uintptr : 22
  699. SYS_setuid : uintptr : 23
  700. SYS_getuid : uintptr : 24
  701. SYS_stime : uintptr : 25
  702. SYS_ptrace : uintptr : 26
  703. SYS_alarm : uintptr : 27
  704. SYS_oldfstat : uintptr : 28
  705. SYS_pause : uintptr : 29
  706. SYS_utime : uintptr : 30
  707. SYS_stty : uintptr : 31
  708. SYS_gtty : uintptr : 32
  709. SYS_access : uintptr : 33
  710. SYS_nice : uintptr : 34
  711. SYS_ftime : uintptr : 35
  712. SYS_sync : uintptr : 36
  713. SYS_kill : uintptr : 37
  714. SYS_rename : uintptr : 38
  715. SYS_mkdir : uintptr : 39
  716. SYS_rmdir : uintptr : 40
  717. SYS_dup : uintptr : 41
  718. SYS_pipe : uintptr : 42
  719. SYS_times : uintptr : 43
  720. SYS_prof : uintptr : 44
  721. SYS_brk : uintptr : 45
  722. SYS_setgid : uintptr : 46
  723. SYS_getgid : uintptr : 47
  724. SYS_signal : uintptr : 48
  725. SYS_geteuid : uintptr : 49
  726. SYS_getegid : uintptr : 50
  727. SYS_acct : uintptr : 51
  728. SYS_umount2 : uintptr : 52
  729. SYS_lock : uintptr : 53
  730. SYS_ioctl : uintptr : 54
  731. SYS_fcntl : uintptr : 55
  732. SYS_mpx : uintptr : 56
  733. SYS_setpgid : uintptr : 57
  734. SYS_ulimit : uintptr : 58
  735. SYS_oldolduname : uintptr : 59
  736. SYS_umask : uintptr : 60
  737. SYS_chroot : uintptr : 61
  738. SYS_ustat : uintptr : 62
  739. SYS_dup2 : uintptr : 63
  740. SYS_getppid : uintptr : 64
  741. SYS_getpgrp : uintptr : 65
  742. SYS_setsid : uintptr : 66
  743. SYS_sigaction : uintptr : 67
  744. SYS_sgetmask : uintptr : 68
  745. SYS_ssetmask : uintptr : 69
  746. SYS_setreuid : uintptr : 70
  747. SYS_setregid : uintptr : 71
  748. SYS_sigsuspend : uintptr : 72
  749. SYS_sigpending : uintptr : 73
  750. SYS_sethostname : uintptr : 74
  751. SYS_setrlimit : uintptr : 75
  752. SYS_getrlimit : uintptr : 76
  753. SYS_getrusage : uintptr : 77
  754. SYS_gettimeofday : uintptr : 78
  755. SYS_settimeofday : uintptr : 79
  756. SYS_getgroups : uintptr : 80
  757. SYS_setgroups : uintptr : 81
  758. SYS_select : uintptr : 82
  759. SYS_symlink : uintptr : 83
  760. SYS_oldlstat : uintptr : 84
  761. SYS_readlink : uintptr : 85
  762. SYS_uselib : uintptr : 86
  763. SYS_swapon : uintptr : 87
  764. SYS_reboot : uintptr : 88
  765. SYS_readdir : uintptr : 89
  766. SYS_old_mmap : uintptr : 90 // 90 is "sys_old_mmap", we want mmap2
  767. SYS_munmap : uintptr : 91
  768. SYS_truncate : uintptr : 92
  769. SYS_ftruncate : uintptr : 93
  770. SYS_fchmod : uintptr : 94
  771. SYS_fchown : uintptr : 95
  772. SYS_getpriority : uintptr : 96
  773. SYS_setpriority : uintptr : 97
  774. SYS_profil : uintptr : 98
  775. SYS_statfs : uintptr : 99
  776. SYS_fstatfs : uintptr : 100
  777. SYS_ioperm : uintptr : 101
  778. SYS_socketcall : uintptr : 102
  779. SYS_syslog : uintptr : 103
  780. SYS_setitimer : uintptr : 104
  781. SYS_getitimer : uintptr : 105
  782. SYS_stat : uintptr : 106
  783. SYS_lstat : uintptr : 107
  784. SYS_fstat : uintptr : 108
  785. SYS_olduname : uintptr : 109
  786. SYS_iopl : uintptr : 110
  787. SYS_vhangup : uintptr : 111
  788. SYS_idle : uintptr : 112
  789. SYS_vm86old : uintptr : 113
  790. SYS_wait4 : uintptr : 114
  791. SYS_swapoff : uintptr : 115
  792. SYS_sysinfo : uintptr : 116
  793. SYS_ipc : uintptr : 117
  794. SYS_fsync : uintptr : 118
  795. SYS_sigreturn : uintptr : 119
  796. SYS_clone : uintptr : 120
  797. SYS_setdomainname : uintptr : 121
  798. SYS_uname : uintptr : 122
  799. SYS_modify_ldt : uintptr : 123
  800. SYS_adjtimex : uintptr : 124
  801. SYS_mprotect : uintptr : 125
  802. SYS_sigprocmask : uintptr : 126
  803. SYS_create_module : uintptr : 127
  804. SYS_init_module : uintptr : 128
  805. SYS_delete_module : uintptr : 129
  806. SYS_get_kernel_syms : uintptr : 130
  807. SYS_quotactl : uintptr : 131
  808. SYS_getpgid : uintptr : 132
  809. SYS_fchdir : uintptr : 133
  810. SYS_bdflush : uintptr : 134
  811. SYS_sysfs : uintptr : 135
  812. SYS_personality : uintptr : 136
  813. SYS_afs_syscall : uintptr : 137
  814. SYS_setfsuid : uintptr : 138
  815. SYS_setfsgid : uintptr : 139
  816. SYS__llseek : uintptr : 140
  817. SYS_getdents : uintptr : 141
  818. SYS__newselect : uintptr : 142
  819. SYS_flock : uintptr : 143
  820. SYS_msync : uintptr : 144
  821. SYS_readv : uintptr : 145
  822. SYS_writev : uintptr : 146
  823. SYS_getsid : uintptr : 147
  824. SYS_fdatasync : uintptr : 148
  825. SYS__sysctl : uintptr : 149
  826. SYS_mlock : uintptr : 150
  827. SYS_munlock : uintptr : 151
  828. SYS_mlockall : uintptr : 152
  829. SYS_munlockall : uintptr : 153
  830. SYS_sched_setparam : uintptr : 154
  831. SYS_sched_getparam : uintptr : 155
  832. SYS_sched_setscheduler : uintptr : 156
  833. SYS_sched_getscheduler : uintptr : 157
  834. SYS_sched_yield : uintptr : 158
  835. SYS_sched_get_priority_max : uintptr : 159
  836. SYS_sched_get_priority_min : uintptr : 160
  837. SYS_sched_rr_get_interval : uintptr : 161
  838. SYS_nanosleep : uintptr : 162
  839. SYS_mremap : uintptr : 163
  840. SYS_setresuid : uintptr : 164
  841. SYS_getresuid : uintptr : 165
  842. SYS_vm86 : uintptr : 166
  843. SYS_query_module : uintptr : 167
  844. SYS_poll : uintptr : 168
  845. SYS_nfsservctl : uintptr : 169
  846. SYS_setresgid : uintptr : 170
  847. SYS_getresgid : uintptr : 171
  848. SYS_prctl : uintptr : 172
  849. SYS_rt_sigreturn : uintptr : 173
  850. SYS_rt_sigaction : uintptr : 174
  851. SYS_rt_sigprocmask : uintptr : 175
  852. SYS_rt_sigpending : uintptr : 176
  853. SYS_rt_sigtimedwait : uintptr : 177
  854. SYS_rt_sigqueueinfo : uintptr : 178
  855. SYS_rt_sigsuspend : uintptr : 179
  856. SYS_pread64 : uintptr : 180
  857. SYS_pwrite64 : uintptr : 181
  858. SYS_chown : uintptr : 182
  859. SYS_getcwd : uintptr : 183
  860. SYS_capget : uintptr : 184
  861. SYS_capset : uintptr : 185
  862. SYS_sigaltstack : uintptr : 186
  863. SYS_sendfile : uintptr : 187
  864. SYS_getpmsg : uintptr : 188
  865. SYS_putpmsg : uintptr : 189
  866. SYS_vfork : uintptr : 190
  867. SYS_ugetrlimit : uintptr : 191
  868. SYS_mmap : uintptr : 192 // actually mmap2
  869. SYS_truncate64 : uintptr : 193
  870. SYS_ftruncate64 : uintptr : 194
  871. SYS_stat64 : uintptr : 195
  872. SYS_lstat64 : uintptr : 196
  873. SYS_fstat64 : uintptr : 197
  874. SYS_lchown32 : uintptr : 198
  875. SYS_getuid32 : uintptr : 199
  876. SYS_getgid32 : uintptr : 200
  877. SYS_geteuid32 : uintptr : 201
  878. SYS_getegid32 : uintptr : 202
  879. SYS_setreuid32 : uintptr : 203
  880. SYS_setregid32 : uintptr : 204
  881. SYS_getgroups32 : uintptr : 205
  882. SYS_setgroups32 : uintptr : 206
  883. SYS_fchown32 : uintptr : 207
  884. SYS_setresuid32 : uintptr : 208
  885. SYS_getresuid32 : uintptr : 209
  886. SYS_setresgid32 : uintptr : 210
  887. SYS_getresgid32 : uintptr : 211
  888. SYS_chown32 : uintptr : 212
  889. SYS_setuid32 : uintptr : 213
  890. SYS_setgid32 : uintptr : 214
  891. SYS_setfsuid32 : uintptr : 215
  892. SYS_setfsgid32 : uintptr : 216
  893. SYS_pivot_root : uintptr : 217
  894. SYS_mincore : uintptr : 218
  895. SYS_madvise : uintptr : 219
  896. SYS_getdents64 : uintptr : 220
  897. SYS_fcntl64 : uintptr : 221
  898. SYS_gettid : uintptr : 224
  899. SYS_readahead : uintptr : 225
  900. SYS_setxattr : uintptr : 226
  901. SYS_lsetxattr : uintptr : 227
  902. SYS_fsetxattr : uintptr : 228
  903. SYS_getxattr : uintptr : 229
  904. SYS_lgetxattr : uintptr : 230
  905. SYS_fgetxattr : uintptr : 231
  906. SYS_listxattr : uintptr : 232
  907. SYS_llistxattr : uintptr : 233
  908. SYS_flistxattr : uintptr : 234
  909. SYS_removexattr : uintptr : 235
  910. SYS_lremovexattr : uintptr : 236
  911. SYS_fremovexattr : uintptr : 237
  912. SYS_tkill : uintptr : 238
  913. SYS_sendfile64 : uintptr : 239
  914. SYS_futex : uintptr : 240
  915. SYS_sched_setaffinity : uintptr : 241
  916. SYS_sched_getaffinity : uintptr : 242
  917. SYS_set_thread_area : uintptr : 243
  918. SYS_get_thread_area : uintptr : 244
  919. SYS_io_setup : uintptr : 245
  920. SYS_io_destroy : uintptr : 246
  921. SYS_io_getevents : uintptr : 247
  922. SYS_io_submit : uintptr : 248
  923. SYS_io_cancel : uintptr : 249
  924. SYS_fadvise64 : uintptr : 250
  925. SYS_exit_group : uintptr : 252
  926. SYS_lookup_dcookie : uintptr : 253
  927. SYS_epoll_create : uintptr : 254
  928. SYS_epoll_ctl : uintptr : 255
  929. SYS_epoll_wait : uintptr : 256
  930. SYS_remap_file_pages : uintptr : 257
  931. SYS_set_tid_address : uintptr : 258
  932. SYS_timer_create : uintptr : 259
  933. SYS_timer_settime : uintptr : 260
  934. SYS_timer_gettime : uintptr : 261
  935. SYS_timer_getoverrun : uintptr : 262
  936. SYS_timer_delete : uintptr : 263
  937. SYS_clock_settime : uintptr : 264
  938. SYS_clock_gettime : uintptr : 265
  939. SYS_clock_getres : uintptr : 266
  940. SYS_clock_nanosleep : uintptr : 267
  941. SYS_statfs64 : uintptr : 268
  942. SYS_fstatfs64 : uintptr : 269
  943. SYS_tgkill : uintptr : 270
  944. SYS_utimes : uintptr : 271
  945. SYS_fadvise64_64 : uintptr : 272
  946. SYS_vserver : uintptr : 273
  947. SYS_mbind : uintptr : 274
  948. SYS_get_mempolicy : uintptr : 275
  949. SYS_set_mempolicy : uintptr : 276
  950. SYS_mq_open : uintptr : 277
  951. SYS_mq_unlink : uintptr : 278
  952. SYS_mq_timedsend : uintptr : 279
  953. SYS_mq_timedreceive : uintptr : 280
  954. SYS_mq_notify : uintptr : 281
  955. SYS_mq_getsetattr : uintptr : 282
  956. SYS_kexec_load : uintptr : 283
  957. SYS_waitid : uintptr : 284
  958. SYS_add_key : uintptr : 286
  959. SYS_request_key : uintptr : 287
  960. SYS_keyctl : uintptr : 288
  961. SYS_ioprio_set : uintptr : 289
  962. SYS_ioprio_get : uintptr : 290
  963. SYS_inotify_init : uintptr : 291
  964. SYS_inotify_add_watch : uintptr : 292
  965. SYS_inotify_rm_watch : uintptr : 293
  966. SYS_migrate_pages : uintptr : 294
  967. SYS_openat : uintptr : 295
  968. SYS_mkdirat : uintptr : 296
  969. SYS_mknodat : uintptr : 297
  970. SYS_fchownat : uintptr : 298
  971. SYS_futimesat : uintptr : 299
  972. SYS_fstatat64 : uintptr : 300
  973. SYS_unlinkat : uintptr : 301
  974. SYS_renameat : uintptr : 302
  975. SYS_linkat : uintptr : 303
  976. SYS_symlinkat : uintptr : 304
  977. SYS_readlinkat : uintptr : 305
  978. SYS_fchmodat : uintptr : 306
  979. SYS_faccessat : uintptr : 307
  980. SYS_pselect6 : uintptr : 308
  981. SYS_ppoll : uintptr : 309
  982. SYS_unshare : uintptr : 310
  983. SYS_set_robust_list : uintptr : 311
  984. SYS_get_robust_list : uintptr : 312
  985. SYS_splice : uintptr : 313
  986. SYS_sync_file_range : uintptr : 314
  987. SYS_tee : uintptr : 315
  988. SYS_vmsplice : uintptr : 316
  989. SYS_move_pages : uintptr : 317
  990. SYS_getcpu : uintptr : 318
  991. SYS_epoll_pwait : uintptr : 319
  992. SYS_utimensat : uintptr : 320
  993. SYS_signalfd : uintptr : 321
  994. SYS_timerfd_create : uintptr : 322
  995. SYS_eventfd : uintptr : 323
  996. SYS_fallocate : uintptr : 324
  997. SYS_timerfd_settime : uintptr : 325
  998. SYS_timerfd_gettime : uintptr : 326
  999. SYS_signalfd4 : uintptr : 327
  1000. SYS_eventfd2 : uintptr : 328
  1001. SYS_epoll_create1 : uintptr : 329
  1002. SYS_dup3 : uintptr : 330
  1003. SYS_pipe2 : uintptr : 331
  1004. SYS_inotify_init1 : uintptr : 332
  1005. SYS_preadv : uintptr : 333
  1006. SYS_pwritev : uintptr : 334
  1007. SYS_rt_tgsigqueueinfo : uintptr : 335
  1008. SYS_perf_event_open : uintptr : 336
  1009. SYS_recvmmsg : uintptr : 337
  1010. SYS_fanotify_init : uintptr : 338
  1011. SYS_fanotify_mark : uintptr : 339
  1012. SYS_prlimit64 : uintptr : 340
  1013. SYS_name_to_handle_at : uintptr : 341
  1014. SYS_open_by_handle_at : uintptr : 342
  1015. SYS_clock_adjtime : uintptr : 343
  1016. SYS_syncfs : uintptr : 344
  1017. SYS_sendmmsg : uintptr : 345
  1018. SYS_setns : uintptr : 346
  1019. SYS_process_vm_readv : uintptr : 347
  1020. SYS_process_vm_writev : uintptr : 348
  1021. SYS_kcmp : uintptr : 349
  1022. SYS_finit_module : uintptr : 350
  1023. SYS_sched_setattr : uintptr : 351
  1024. SYS_sched_getattr : uintptr : 352
  1025. SYS_renameat2 : uintptr : 353
  1026. SYS_seccomp : uintptr : 354
  1027. SYS_getrandom : uintptr : 355
  1028. SYS_memfd_create : uintptr : 356
  1029. SYS_bpf : uintptr : 357
  1030. SYS_execveat : uintptr : 358
  1031. SYS_socket : uintptr : 359
  1032. SYS_socketpair : uintptr : 360
  1033. SYS_bind : uintptr : 361
  1034. SYS_connect : uintptr : 362
  1035. SYS_listen : uintptr : 363
  1036. SYS_accept4 : uintptr : 364
  1037. SYS_getsockopt : uintptr : 365
  1038. SYS_setsockopt : uintptr : 366
  1039. SYS_getsockname : uintptr : 367
  1040. SYS_getpeername : uintptr : 368
  1041. SYS_sendto : uintptr : 369
  1042. SYS_sendmsg : uintptr : 370
  1043. SYS_recvfrom : uintptr : 371
  1044. SYS_recvmsg : uintptr : 372
  1045. SYS_shutdown : uintptr : 373
  1046. SYS_userfaultfd : uintptr : 374
  1047. SYS_membarrier : uintptr : 375
  1048. SYS_mlock2 : uintptr : 376
  1049. SYS_copy_file_range : uintptr : 377
  1050. SYS_preadv2 : uintptr : 378
  1051. SYS_pwritev2 : uintptr : 379
  1052. SYS_pkey_mprotect : uintptr : 380
  1053. SYS_pkey_alloc : uintptr : 381
  1054. SYS_pkey_free : uintptr : 382
  1055. SYS_statx : uintptr : 383
  1056. SYS_arch_prctl : uintptr : 384
  1057. SYS_io_pgetevents : uintptr : 385
  1058. SYS_rseq : uintptr : 386
  1059. SYS_semget : uintptr : 393
  1060. SYS_semctl : uintptr : 394
  1061. SYS_shmget : uintptr : 395
  1062. SYS_shmctl : uintptr : 396
  1063. SYS_shmat : uintptr : 397
  1064. SYS_shmdt : uintptr : 398
  1065. SYS_msgget : uintptr : 399
  1066. SYS_msgsnd : uintptr : 400
  1067. SYS_msgrcv : uintptr : 401
  1068. SYS_msgctl : uintptr : 402
  1069. SYS_clock_gettime64 : uintptr : 403
  1070. SYS_clock_settime64 : uintptr : 404
  1071. SYS_clock_adjtime64 : uintptr : 405
  1072. SYS_clock_getres_time64 : uintptr : 406
  1073. SYS_clock_nanosleep_time64 : uintptr : 407
  1074. SYS_timer_gettime64 : uintptr : 408
  1075. SYS_timer_settime64 : uintptr : 409
  1076. SYS_timerfd_gettime64 : uintptr : 410
  1077. SYS_timerfd_settime64 : uintptr : 411
  1078. SYS_utimensat_time64 : uintptr : 412
  1079. SYS_pselect6_time64 : uintptr : 413
  1080. SYS_ppoll_time64 : uintptr : 414
  1081. SYS_io_pgetevents_time64 : uintptr : 416
  1082. SYS_recvmmsg_time64 : uintptr : 417
  1083. SYS_mq_timedsend_time64 : uintptr : 418
  1084. SYS_mq_timedreceive_time64 : uintptr : 419
  1085. SYS_semtimedop_time64 : uintptr : 420
  1086. SYS_rt_sigtimedwait_time64 : uintptr : 421
  1087. SYS_futex_time64 : uintptr : 422
  1088. SYS_sched_rr_get_interval_time64 : uintptr : 423
  1089. SYS_pidfd_send_signal : uintptr : 424
  1090. SYS_io_uring_setup : uintptr : 425
  1091. SYS_io_uring_enter : uintptr : 426
  1092. SYS_io_uring_register : uintptr : 427
  1093. SYS_open_tree : uintptr : 428
  1094. SYS_move_mount : uintptr : 429
  1095. SYS_fsopen : uintptr : 430
  1096. SYS_fsconfig : uintptr : 431
  1097. SYS_fsmount : uintptr : 432
  1098. SYS_fspick : uintptr : 433
  1099. SYS_pidfd_open : uintptr : 434
  1100. SYS_clone3 : uintptr : 435
  1101. SYS_close_range : uintptr : 436
  1102. SYS_openat2 : uintptr : 437
  1103. SYS_pidfd_getfd : uintptr : 438
  1104. SYS_faccessat2 : uintptr : 439
  1105. SYS_process_madvise : uintptr : 440
  1106. SYS_epoll_pwait2 : uintptr : 441
  1107. SYS_mount_setattr : uintptr : 442
  1108. SYS_landlock_create_ruleset : uintptr : 444
  1109. SYS_landlock_add_rule : uintptr : 445
  1110. SYS_landlock_restrict_self : uintptr : 446
  1111. SYS_memfd_secret : uintptr : 447
  1112. } else when ODIN_ARCH == .arm32 { // TODO
  1113. SYS_restart_syscall : uintptr : 0
  1114. SYS_exit : uintptr : 1
  1115. SYS_fork : uintptr : 2
  1116. SYS_read : uintptr : 3
  1117. SYS_write : uintptr : 4
  1118. SYS_open : uintptr : 5
  1119. SYS_close : uintptr : 6
  1120. SYS_creat : uintptr : 8
  1121. SYS_link : uintptr : 9
  1122. SYS_unlink : uintptr : 10
  1123. SYS_execve : uintptr : 11
  1124. SYS_chdir : uintptr : 12
  1125. SYS_mknod : uintptr : 14
  1126. SYS_chmod : uintptr : 15
  1127. SYS_lchown : uintptr : 16
  1128. SYS_lseek : uintptr : 19
  1129. SYS_getpid : uintptr : 20
  1130. SYS_mount : uintptr : 21
  1131. SYS_setuid : uintptr : 23
  1132. SYS_getuid : uintptr : 24
  1133. SYS_ptrace : uintptr : 26
  1134. SYS_pause : uintptr : 29
  1135. SYS_access : uintptr : 33
  1136. SYS_nice : uintptr : 34
  1137. SYS_sync : uintptr : 36
  1138. SYS_kill : uintptr : 37
  1139. SYS_rename : uintptr : 38
  1140. SYS_mkdir : uintptr : 39
  1141. SYS_rmdir : uintptr : 40
  1142. SYS_dup : uintptr : 41
  1143. SYS_pipe : uintptr : 42
  1144. SYS_times : uintptr : 43
  1145. SYS_brk : uintptr : 45
  1146. SYS_setgid : uintptr : 46
  1147. SYS_getgid : uintptr : 47
  1148. SYS_geteuid : uintptr : 49
  1149. SYS_getegid : uintptr : 50
  1150. SYS_acct : uintptr : 51
  1151. SYS_umount2 : uintptr : 52
  1152. SYS_ioctl : uintptr : 54
  1153. SYS_fcntl : uintptr : 55
  1154. SYS_setpgid : uintptr : 57
  1155. SYS_umask : uintptr : 60
  1156. SYS_chroot : uintptr : 61
  1157. SYS_ustat : uintptr : 62
  1158. SYS_dup2 : uintptr : 63
  1159. SYS_getppid : uintptr : 64
  1160. SYS_getpgrp : uintptr : 65
  1161. SYS_setsid : uintptr : 66
  1162. SYS_sigaction : uintptr : 67
  1163. SYS_setreuid : uintptr : 70
  1164. SYS_setregid : uintptr : 71
  1165. SYS_sigsuspend : uintptr : 72
  1166. SYS_sigpending : uintptr : 73
  1167. SYS_sethostname : uintptr : 74
  1168. SYS_setrlimit : uintptr : 75
  1169. SYS_getrusage : uintptr : 77
  1170. SYS_gettimeofday : uintptr : 78
  1171. SYS_settimeofday : uintptr : 79
  1172. SYS_getgroups : uintptr : 80
  1173. SYS_setgroups : uintptr : 81
  1174. SYS_symlink : uintptr : 83
  1175. SYS_readlink : uintptr : 85
  1176. SYS_uselib : uintptr : 86
  1177. SYS_swapon : uintptr : 87
  1178. SYS_reboot : uintptr : 88
  1179. SYS_munmap : uintptr : 91
  1180. SYS_truncate : uintptr : 92
  1181. SYS_ftruncate : uintptr : 93
  1182. SYS_fchmod : uintptr : 94
  1183. SYS_fchown : uintptr : 95
  1184. SYS_getpriority : uintptr : 96
  1185. SYS_setpriority : uintptr : 97
  1186. SYS_statfs : uintptr : 99
  1187. SYS_fstatfs : uintptr : 100
  1188. SYS_syslog : uintptr : 103
  1189. SYS_setitimer : uintptr : 104
  1190. SYS_getitimer : uintptr : 105
  1191. SYS_stat : uintptr : 106
  1192. SYS_lstat : uintptr : 107
  1193. SYS_fstat : uintptr : 108
  1194. SYS_vhangup : uintptr : 111
  1195. SYS_wait4 : uintptr : 114
  1196. SYS_swapoff : uintptr : 115
  1197. SYS_sysinfo : uintptr : 116
  1198. SYS_fsync : uintptr : 118
  1199. SYS_sigreturn : uintptr : 119
  1200. SYS_clone : uintptr : 120
  1201. SYS_setdomainname : uintptr : 121
  1202. SYS_uname : uintptr : 122
  1203. SYS_adjtimex : uintptr : 124
  1204. SYS_mprotect : uintptr : 125
  1205. SYS_sigprocmask : uintptr : 126
  1206. SYS_init_module : uintptr : 128
  1207. SYS_delete_module : uintptr : 129
  1208. SYS_quotactl : uintptr : 131
  1209. SYS_getpgid : uintptr : 132
  1210. SYS_fchdir : uintptr : 133
  1211. SYS_bdflush : uintptr : 134
  1212. SYS_sysfs : uintptr : 135
  1213. SYS_personality : uintptr : 136
  1214. SYS_setfsuid : uintptr : 138
  1215. SYS_setfsgid : uintptr : 139
  1216. SYS__llseek : uintptr : 140
  1217. SYS_getdents : uintptr : 141
  1218. SYS__newselect : uintptr : 142
  1219. SYS_flock : uintptr : 143
  1220. SYS_msync : uintptr : 144
  1221. SYS_readv : uintptr : 145
  1222. SYS_writev : uintptr : 146
  1223. SYS_getsid : uintptr : 147
  1224. SYS_fdatasync : uintptr : 148
  1225. SYS__sysctl : uintptr : 149
  1226. SYS_mlock : uintptr : 150
  1227. SYS_munlock : uintptr : 151
  1228. SYS_mlockall : uintptr : 152
  1229. SYS_munlockall : uintptr : 153
  1230. SYS_sched_setparam : uintptr : 154
  1231. SYS_sched_getparam : uintptr : 155
  1232. SYS_sched_setscheduler : uintptr : 156
  1233. SYS_sched_getscheduler : uintptr : 157
  1234. SYS_sched_yield : uintptr : 158
  1235. SYS_sched_get_priority_max : uintptr : 159
  1236. SYS_sched_get_priority_min : uintptr : 160
  1237. SYS_sched_rr_get_interval : uintptr : 161
  1238. SYS_nanosleep : uintptr : 162
  1239. SYS_mremap : uintptr : 163
  1240. SYS_setresuid : uintptr : 164
  1241. SYS_getresuid : uintptr : 165
  1242. SYS_poll : uintptr : 168
  1243. SYS_nfsservctl : uintptr : 169
  1244. SYS_setresgid : uintptr : 170
  1245. SYS_getresgid : uintptr : 171
  1246. SYS_prctl : uintptr : 172
  1247. SYS_rt_sigreturn : uintptr : 173
  1248. SYS_rt_sigaction : uintptr : 174
  1249. SYS_rt_sigprocmask : uintptr : 175
  1250. SYS_rt_sigpending : uintptr : 176
  1251. SYS_rt_sigtimedwait : uintptr : 177
  1252. SYS_rt_sigqueueinfo : uintptr : 178
  1253. SYS_rt_sigsuspend : uintptr : 179
  1254. SYS_pread64 : uintptr : 180
  1255. SYS_pwrite64 : uintptr : 181
  1256. SYS_chown : uintptr : 182
  1257. SYS_getcwd : uintptr : 183
  1258. SYS_capget : uintptr : 184
  1259. SYS_capset : uintptr : 185
  1260. SYS_sigaltstack : uintptr : 186
  1261. SYS_sendfile : uintptr : 187
  1262. SYS_vfork : uintptr : 190
  1263. SYS_ugetrlimit : uintptr : 191
  1264. SYS_mmap : uintptr : 192 // actually mmap2
  1265. SYS_truncate64 : uintptr : 193
  1266. SYS_ftruncate64 : uintptr : 194
  1267. SYS_stat64 : uintptr : 195
  1268. SYS_lstat64 : uintptr : 196
  1269. SYS_fstat64 : uintptr : 197
  1270. SYS_lchown32 : uintptr : 198
  1271. SYS_getuid32 : uintptr : 199
  1272. SYS_getgid32 : uintptr : 200
  1273. SYS_geteuid32 : uintptr : 201
  1274. SYS_getegid32 : uintptr : 202
  1275. SYS_setreuid32 : uintptr : 203
  1276. SYS_setregid32 : uintptr : 204
  1277. SYS_getgroups32 : uintptr : 205
  1278. SYS_setgroups32 : uintptr : 206
  1279. SYS_fchown32 : uintptr : 207
  1280. SYS_setresuid32 : uintptr : 208
  1281. SYS_getresuid32 : uintptr : 209
  1282. SYS_setresgid32 : uintptr : 210
  1283. SYS_getresgid32 : uintptr : 211
  1284. SYS_chown32 : uintptr : 212
  1285. SYS_setuid32 : uintptr : 213
  1286. SYS_setgid32 : uintptr : 214
  1287. SYS_setfsuid32 : uintptr : 215
  1288. SYS_setfsgid32 : uintptr : 216
  1289. SYS_getdents64 : uintptr : 217
  1290. SYS_pivot_root : uintptr : 218
  1291. SYS_mincore : uintptr : 219
  1292. SYS_madvise : uintptr : 220
  1293. SYS_fcntl64 : uintptr : 221
  1294. SYS_gettid : uintptr : 224
  1295. SYS_readahead : uintptr : 225
  1296. SYS_setxattr : uintptr : 226
  1297. SYS_lsetxattr : uintptr : 227
  1298. SYS_fsetxattr : uintptr : 228
  1299. SYS_getxattr : uintptr : 229
  1300. SYS_lgetxattr : uintptr : 230
  1301. SYS_fgetxattr : uintptr : 231
  1302. SYS_listxattr : uintptr : 232
  1303. SYS_llistxattr : uintptr : 233
  1304. SYS_flistxattr : uintptr : 234
  1305. SYS_removexattr : uintptr : 235
  1306. SYS_lremovexattr : uintptr : 236
  1307. SYS_fremovexattr : uintptr : 237
  1308. SYS_tkill : uintptr : 238
  1309. SYS_sendfile64 : uintptr : 239
  1310. SYS_futex : uintptr : 240
  1311. SYS_sched_setaffinity : uintptr : 241
  1312. SYS_sched_getaffinity : uintptr : 242
  1313. SYS_io_setup : uintptr : 243
  1314. SYS_io_destroy : uintptr : 244
  1315. SYS_io_getevents : uintptr : 245
  1316. SYS_io_submit : uintptr : 246
  1317. SYS_io_cancel : uintptr : 247
  1318. SYS_exit_group : uintptr : 248
  1319. SYS_lookup_dcookie : uintptr : 249
  1320. SYS_epoll_create : uintptr : 250
  1321. SYS_epoll_ctl : uintptr : 251
  1322. SYS_epoll_wait : uintptr : 252
  1323. SYS_remap_file_pages : uintptr : 253
  1324. SYS_set_tid_address : uintptr : 256
  1325. SYS_timer_create : uintptr : 257
  1326. SYS_timer_settime : uintptr : 258
  1327. SYS_timer_gettime : uintptr : 259
  1328. SYS_timer_getoverrun : uintptr : 260
  1329. SYS_timer_delete : uintptr : 261
  1330. SYS_clock_settime : uintptr : 262
  1331. SYS_clock_gettime : uintptr : 263
  1332. SYS_clock_getres : uintptr : 264
  1333. SYS_clock_nanosleep : uintptr : 265
  1334. SYS_statfs64 : uintptr : 266
  1335. SYS_fstatfs64 : uintptr : 267
  1336. SYS_tgkill : uintptr : 268
  1337. SYS_utimes : uintptr : 269
  1338. SYS_fadvise64_64 : uintptr : 270
  1339. SYS_pciconfig_iobase : uintptr : 271
  1340. SYS_pciconfig_read : uintptr : 272
  1341. SYS_pciconfig_write : uintptr : 273
  1342. SYS_mq_open : uintptr : 274
  1343. SYS_mq_unlink : uintptr : 275
  1344. SYS_mq_timedsend : uintptr : 276
  1345. SYS_mq_timedreceive : uintptr : 277
  1346. SYS_mq_notify : uintptr : 278
  1347. SYS_mq_getsetattr : uintptr : 279
  1348. SYS_waitid : uintptr : 280
  1349. SYS_socket : uintptr : 281
  1350. SYS_bind : uintptr : 282
  1351. SYS_connect : uintptr : 283
  1352. SYS_listen : uintptr : 284
  1353. SYS_accept : uintptr : 285
  1354. SYS_getsockname : uintptr : 286
  1355. SYS_getpeername : uintptr : 287
  1356. SYS_socketpair : uintptr : 288
  1357. SYS_send : uintptr : 289
  1358. SYS_sendto : uintptr : 290
  1359. SYS_recv : uintptr : 291
  1360. SYS_recvfrom : uintptr : 292
  1361. SYS_shutdown : uintptr : 293
  1362. SYS_setsockopt : uintptr : 294
  1363. SYS_getsockopt : uintptr : 295
  1364. SYS_sendmsg : uintptr : 296
  1365. SYS_recvmsg : uintptr : 297
  1366. SYS_semop : uintptr : 298
  1367. SYS_semget : uintptr : 299
  1368. SYS_semctl : uintptr : 300
  1369. SYS_msgsnd : uintptr : 301
  1370. SYS_msgrcv : uintptr : 302
  1371. SYS_msgget : uintptr : 303
  1372. SYS_msgctl : uintptr : 304
  1373. SYS_shmat : uintptr : 305
  1374. SYS_shmdt : uintptr : 306
  1375. SYS_shmget : uintptr : 307
  1376. SYS_shmctl : uintptr : 308
  1377. SYS_add_key : uintptr : 309
  1378. SYS_request_key : uintptr : 310
  1379. SYS_keyctl : uintptr : 311
  1380. SYS_semtimedop : uintptr : 312
  1381. SYS_vserver : uintptr : 313
  1382. SYS_ioprio_set : uintptr : 314
  1383. SYS_ioprio_get : uintptr : 315
  1384. SYS_inotify_init : uintptr : 316
  1385. SYS_inotify_add_watch : uintptr : 317
  1386. SYS_inotify_rm_watch : uintptr : 318
  1387. SYS_mbind : uintptr : 319
  1388. SYS_get_mempolicy : uintptr : 320
  1389. SYS_set_mempolicy : uintptr : 321
  1390. SYS_openat : uintptr : 322
  1391. SYS_mkdirat : uintptr : 323
  1392. SYS_mknodat : uintptr : 324
  1393. SYS_fchownat : uintptr : 325
  1394. SYS_futimesat : uintptr : 326
  1395. SYS_fstatat64 : uintptr : 327
  1396. SYS_unlinkat : uintptr : 328
  1397. SYS_renameat : uintptr : 329
  1398. SYS_linkat : uintptr : 330
  1399. SYS_symlinkat : uintptr : 331
  1400. SYS_readlinkat : uintptr : 332
  1401. SYS_fchmodat : uintptr : 333
  1402. SYS_faccessat : uintptr : 334
  1403. SYS_pselect6 : uintptr : 335
  1404. SYS_ppoll : uintptr : 336
  1405. SYS_unshare : uintptr : 337
  1406. SYS_set_robust_list : uintptr : 338
  1407. SYS_get_robust_list : uintptr : 339
  1408. SYS_splice : uintptr : 340
  1409. SYS_sync_file_range : uintptr : 341
  1410. SYS_tee : uintptr : 342
  1411. SYS_vmsplice : uintptr : 343
  1412. SYS_move_pages : uintptr : 344
  1413. SYS_getcpu : uintptr : 345
  1414. SYS_epoll_pwait : uintptr : 346
  1415. SYS_kexec_load : uintptr : 347
  1416. SYS_utimensat : uintptr : 348
  1417. SYS_signalfd : uintptr : 349
  1418. SYS_timerfd_create : uintptr : 350
  1419. SYS_eventfd : uintptr : 351
  1420. SYS_fallocate : uintptr : 352
  1421. SYS_timerfd_settime : uintptr : 353
  1422. SYS_timerfd_gettime : uintptr : 354
  1423. SYS_signalfd4 : uintptr : 355
  1424. SYS_eventfd2 : uintptr : 356
  1425. SYS_epoll_create1 : uintptr : 357
  1426. SYS_dup3 : uintptr : 358
  1427. SYS_pipe2 : uintptr : 359
  1428. SYS_inotify_init1 : uintptr : 360
  1429. SYS_preadv : uintptr : 361
  1430. SYS_pwritev : uintptr : 362
  1431. SYS_rt_tgsigqueueinfo : uintptr : 363
  1432. SYS_perf_event_open : uintptr : 364
  1433. SYS_recvmmsg : uintptr : 365
  1434. SYS_accept4 : uintptr : 366
  1435. SYS_fanotify_init : uintptr : 367
  1436. SYS_fanotify_mark : uintptr : 368
  1437. SYS_prlimit64 : uintptr : 369
  1438. SYS_name_to_handle_at : uintptr : 370
  1439. SYS_open_by_handle_at : uintptr : 371
  1440. SYS_clock_adjtime : uintptr : 372
  1441. SYS_syncfs : uintptr : 373
  1442. SYS_sendmmsg : uintptr : 374
  1443. SYS_setns : uintptr : 375
  1444. SYS_process_vm_readv : uintptr : 376
  1445. SYS_process_vm_writev : uintptr : 377
  1446. SYS_kcmp : uintptr : 378
  1447. SYS_finit_module : uintptr : 379
  1448. SYS_sched_setattr : uintptr : 380
  1449. SYS_sched_getattr : uintptr : 381
  1450. SYS_renameat2 : uintptr : 382
  1451. SYS_seccomp : uintptr : 383
  1452. SYS_getrandom : uintptr : 384
  1453. SYS_memfd_create : uintptr : 385
  1454. SYS_bpf : uintptr : 386
  1455. SYS_execveat : uintptr : 387
  1456. SYS_userfaultfd : uintptr : 388
  1457. SYS_membarrier : uintptr : 389
  1458. SYS_mlock2 : uintptr : 390
  1459. SYS_copy_file_range : uintptr : 391
  1460. SYS_preadv2 : uintptr : 392
  1461. SYS_pwritev2 : uintptr : 393
  1462. SYS_pkey_mprotect : uintptr : 394
  1463. SYS_pkey_alloc : uintptr : 395
  1464. SYS_pkey_free : uintptr : 396
  1465. SYS_statx : uintptr : 397
  1466. SYS_rseq : uintptr : 398
  1467. SYS_io_pgetevents : uintptr : 399
  1468. SYS_migrate_pages : uintptr : 400
  1469. SYS_kexec_file_load : uintptr : 401
  1470. SYS_clock_gettime64 : uintptr : 403
  1471. SYS_clock_settime64 : uintptr : 404
  1472. SYS_clock_adjtime64 : uintptr : 405
  1473. SYS_clock_getres_time64 : uintptr : 406
  1474. SYS_clock_nanosleep_time64 : uintptr : 407
  1475. SYS_timer_gettime64 : uintptr : 408
  1476. SYS_timer_settime64 : uintptr : 409
  1477. SYS_timerfd_gettime64 : uintptr : 410
  1478. SYS_timerfd_settime64 : uintptr : 411
  1479. SYS_utimensat_time64 : uintptr : 412
  1480. SYS_pselect6_time64 : uintptr : 413
  1481. SYS_ppoll_time64 : uintptr : 414
  1482. SYS_io_pgetevents_time64 : uintptr : 416
  1483. SYS_recvmmsg_time64 : uintptr : 417
  1484. SYS_mq_timedsend_time64 : uintptr : 418
  1485. SYS_mq_timedreceive_time64 : uintptr : 419
  1486. SYS_semtimedop_time64 : uintptr : 420
  1487. SYS_rt_sigtimedwait_time64 : uintptr : 421
  1488. SYS_futex_time64 : uintptr : 422
  1489. SYS_sched_rr_get_interval_time64 : uintptr : 423
  1490. SYS_pidfd_send_signal : uintptr : 424
  1491. SYS_io_uring_setup : uintptr : 425
  1492. SYS_io_uring_enter : uintptr : 426
  1493. SYS_io_uring_register : uintptr : 427
  1494. SYS_open_tree : uintptr : 428
  1495. SYS_move_mount : uintptr : 429
  1496. SYS_fsopen : uintptr : 430
  1497. SYS_fsconfig : uintptr : 431
  1498. SYS_fsmount : uintptr : 432
  1499. SYS_fspick : uintptr : 433
  1500. SYS_pidfd_open : uintptr : 434
  1501. SYS_clone3 : uintptr : 435
  1502. SYS_close_range : uintptr : 436
  1503. SYS_openat2 : uintptr : 437
  1504. SYS_pidfd_getfd : uintptr : 438
  1505. SYS_faccessat2 : uintptr : 439
  1506. SYS_process_madvise : uintptr : 440
  1507. SYS_epoll_pwait2 : uintptr : 441
  1508. SYS_mount_setattr : uintptr : 442
  1509. SYS_landlock_create_ruleset : uintptr : 444
  1510. SYS_landlock_add_rule : uintptr : 445
  1511. SYS_landlock_restrict_self : uintptr : 446
  1512. } else {
  1513. #panic("Unsupported architecture")
  1514. }
  1515. // syscall related constants
  1516. AT_FDCWD :: ~uintptr(99)
  1517. AT_REMOVEDIR :: uintptr(0x200)
  1518. AT_SYMLINK_FOLLOW :: uintptr(0x400)
  1519. AT_SYMLINK_NOFOLLOW :: uintptr(0x100)
  1520. // mmap flags
  1521. PROT_NONE :: 0x0
  1522. PROT_READ :: 0x1
  1523. PROT_WRITE :: 0x2
  1524. PROT_EXEC :: 0x4
  1525. PROT_GROWSDOWN :: 0x01000000
  1526. PROT_GROWSUP :: 0x02000000
  1527. MAP_FIXED :: 0x10
  1528. MAP_SHARED :: 0x1
  1529. MAP_PRIVATE :: 0x2
  1530. MAP_SHARED_VALIDATE :: 0x3
  1531. MAP_ANONYMOUS :: 0x20
  1532. // mremap flags
  1533. MREMAP_MAYMOVE :: 1
  1534. MREMAP_FIXED :: 2
  1535. MREMAP_DONTUNMAP :: 4
  1536. // madvise flags
  1537. MADV_NORMAL :: 0
  1538. MADV_RANDOM :: 1
  1539. MADV_SEQUENTIAL :: 2
  1540. MADV_WILLNEED :: 3
  1541. MADV_DONTNEED :: 4
  1542. MADV_FREE :: 8
  1543. MADV_REMOVE :: 9
  1544. MADV_DONTFORK :: 10
  1545. MADV_DOFORK :: 11
  1546. MADV_MERGEABLE :: 12
  1547. MADV_UNMERGEABLE :: 13
  1548. MADV_HUGEPAGE :: 14
  1549. MADV_NOHUGEPAGE :: 15
  1550. MADV_DONTDUMP :: 16
  1551. MADV_DODUMP :: 17
  1552. MADV_WIPEONFORK :: 18
  1553. MADV_KEEPONFORK :: 19
  1554. MADV_HWPOISON :: 100
  1555. sys_gettid :: proc "contextless" () -> int {
  1556. return cast(int)intrinsics.syscall(SYS_gettid)
  1557. }
  1558. sys_getrandom :: proc "contextless" (buf: [^]byte, buflen: int, flags: uint) -> int {
  1559. return cast(int)intrinsics.syscall(SYS_getrandom, uintptr(buf), uintptr(buflen), uintptr(flags))
  1560. }
  1561. sys_open :: proc "contextless" (path: cstring, flags: int, mode: int = 0o000) -> int {
  1562. when ODIN_ARCH != .arm64 {
  1563. return int(intrinsics.syscall(SYS_open, uintptr(rawptr(path)), uintptr(flags), uintptr(mode)))
  1564. } else { // NOTE: arm64 does not have open
  1565. return int(intrinsics.syscall(SYS_openat, AT_FDCWD, uintptr(rawptr(path)), uintptr(flags), uintptr(mode)))
  1566. }
  1567. }
  1568. sys_openat :: proc "contextless" (dfd: int, path: cstring, flags: int, mode: int = 0o000) -> int {
  1569. return int(intrinsics.syscall(SYS_openat, uintptr(dfd), uintptr(rawptr(path)), uintptr(flags), uintptr(mode)))
  1570. }
  1571. sys_close :: proc "contextless" (fd: int) -> int {
  1572. return int(intrinsics.syscall(SYS_close, uintptr(fd)))
  1573. }
  1574. sys_read :: proc "contextless" (fd: int, buf: rawptr, size: uint) -> int {
  1575. return int(intrinsics.syscall(SYS_read, uintptr(fd), uintptr(buf), uintptr(size)))
  1576. }
  1577. sys_pread :: proc "contextless" (fd: int, buf: rawptr, size: uint, offset: i64) -> int {
  1578. when ODIN_ARCH == .amd64 || ODIN_ARCH == .arm64 {
  1579. return int(intrinsics.syscall(SYS_pread64, uintptr(fd), uintptr(buf), uintptr(size), uintptr(offset)))
  1580. } else {
  1581. low := uintptr(offset & 0xFFFFFFFF)
  1582. high := uintptr(offset >> 32)
  1583. return int(intrinsics.syscall(SYS_pread64, uintptr(fd), uintptr(buf), uintptr(size), high, low))
  1584. }
  1585. }
  1586. sys_write :: proc "contextless" (fd: int, buf: rawptr, size: uint) -> int {
  1587. return int(intrinsics.syscall(SYS_write, uintptr(fd), uintptr(buf), uintptr(size)))
  1588. }
  1589. sys_pwrite :: proc "contextless" (fd: int, buf: rawptr, size: uint, offset: i64) -> int {
  1590. when ODIN_ARCH == .amd64 || ODIN_ARCH == .arm64 {
  1591. return int(intrinsics.syscall(SYS_pwrite64, uintptr(fd), uintptr(buf), uintptr(size), uintptr(offset)))
  1592. } else {
  1593. low := uintptr(offset & 0xFFFFFFFF)
  1594. high := uintptr(offset >> 32)
  1595. return int(intrinsics.syscall(SYS_pwrite64, uintptr(fd), uintptr(buf), uintptr(size), high, low))
  1596. }
  1597. }
  1598. sys_lseek :: proc "contextless" (fd: int, offset: i64, whence: int) -> i64 {
  1599. when ODIN_ARCH == .amd64 || ODIN_ARCH == .arm64 {
  1600. return i64(intrinsics.syscall(SYS_lseek, uintptr(fd), uintptr(offset), uintptr(whence)))
  1601. } else {
  1602. low := uintptr(offset & 0xFFFFFFFF)
  1603. high := uintptr(offset >> 32)
  1604. result: i64
  1605. res := i64(intrinsics.syscall(SYS__llseek, uintptr(fd), high, low, uintptr(&result), uintptr(whence)))
  1606. return res if res < 0 else result
  1607. }
  1608. }
  1609. sys_stat :: proc "contextless" (path: cstring, stat: rawptr) -> int {
  1610. when ODIN_ARCH == .amd64 {
  1611. return int(intrinsics.syscall(SYS_stat, uintptr(rawptr(path)), uintptr(stat)))
  1612. } else when ODIN_ARCH != .arm64 {
  1613. return int(intrinsics.syscall(SYS_stat64, uintptr(rawptr(path)), uintptr(stat)))
  1614. } else { // NOTE: arm64 does not have stat
  1615. return int(intrinsics.syscall(SYS_fstatat, AT_FDCWD, uintptr(rawptr(path)), uintptr(stat), 0))
  1616. }
  1617. }
  1618. sys_fstat :: proc "contextless" (fd: int, stat: rawptr) -> int {
  1619. when ODIN_ARCH == .amd64 || ODIN_ARCH == .arm64 {
  1620. return int(intrinsics.syscall(SYS_fstat, uintptr(fd), uintptr(stat)))
  1621. } else {
  1622. return int(intrinsics.syscall(SYS_fstat64, uintptr(fd), uintptr(stat)))
  1623. }
  1624. }
  1625. sys_lstat :: proc "contextless" (path: cstring, stat: rawptr) -> int {
  1626. when ODIN_ARCH == .amd64 {
  1627. return int(intrinsics.syscall(SYS_lstat, uintptr(rawptr(path)), uintptr(stat)))
  1628. } else when ODIN_ARCH != .arm64 {
  1629. return int(intrinsics.syscall(SYS_lstat64, uintptr(rawptr(path)), uintptr(stat)))
  1630. } else { // NOTE: arm64 does not have any lstat
  1631. return int(intrinsics.syscall(SYS_fstatat, AT_FDCWD, uintptr(rawptr(path)), uintptr(stat), AT_SYMLINK_NOFOLLOW))
  1632. }
  1633. }
  1634. sys_readlink :: proc "contextless" (path: cstring, buf: rawptr, bufsiz: uint) -> int {
  1635. when ODIN_ARCH != .arm64 {
  1636. return int(intrinsics.syscall(SYS_readlink, uintptr(rawptr(path)), uintptr(buf), uintptr(bufsiz)))
  1637. } else { // NOTE: arm64 does not have readlink
  1638. return int(intrinsics.syscall(SYS_readlinkat, AT_FDCWD, uintptr(rawptr(path)), uintptr(buf), uintptr(bufsiz)))
  1639. }
  1640. }
  1641. sys_symlink :: proc "contextless" (old_name: cstring, new_name: cstring) -> int {
  1642. when ODIN_ARCH != .arm64 {
  1643. return int(intrinsics.syscall(SYS_symlink, uintptr(rawptr(old_name)), uintptr(rawptr(new_name))))
  1644. } else { // NOTE: arm64 does not have symlink
  1645. return int(intrinsics.syscall(SYS_symlinkat, uintptr(rawptr(old_name)), AT_FDCWD, uintptr(rawptr(new_name))))
  1646. }
  1647. }
  1648. sys_access :: proc "contextless" (path: cstring, mask: int) -> int {
  1649. when ODIN_ARCH != .arm64 {
  1650. return int(intrinsics.syscall(SYS_access, uintptr(rawptr(path)), uintptr(mask)))
  1651. } else { // NOTE: arm64 does not have access
  1652. return int(intrinsics.syscall(SYS_faccessat, AT_FDCWD, uintptr(rawptr(path)), uintptr(mask)))
  1653. }
  1654. }
  1655. sys_getcwd :: proc "contextless" (buf: rawptr, size: uint) -> int {
  1656. return int(intrinsics.syscall(SYS_getcwd, uintptr(buf), uintptr(size)))
  1657. }
  1658. sys_chdir :: proc "contextless" (path: cstring) -> int {
  1659. return int(intrinsics.syscall(SYS_chdir, uintptr(rawptr(path))))
  1660. }
  1661. sys_fchdir :: proc "contextless" (fd: int) -> int {
  1662. return int(intrinsics.syscall(SYS_fchdir, uintptr(fd)))
  1663. }
  1664. sys_chmod :: proc "contextless" (path: cstring, mode: int) -> int {
  1665. when ODIN_ARCH != .arm64 {
  1666. return int(intrinsics.syscall(SYS_chmod, uintptr(rawptr(path)), uintptr(mode)))
  1667. } else { // NOTE: arm64 does not have chmod
  1668. return int(intrinsics.syscall(SYS_fchmodat, AT_FDCWD, uintptr(rawptr(path)), uintptr(mode)))
  1669. }
  1670. }
  1671. sys_fchmod :: proc "contextless" (fd: int, mode: int) -> int {
  1672. return int(intrinsics.syscall(SYS_fchmod, uintptr(fd), uintptr(mode)))
  1673. }
  1674. sys_chown :: proc "contextless" (path: cstring, user: int, group: int) -> int {
  1675. when ODIN_ARCH != .arm64 {
  1676. return int(intrinsics.syscall(SYS_chown, uintptr(rawptr(path)), uintptr(user), uintptr(group)))
  1677. } else { // NOTE: arm64 does not have chown
  1678. return int(intrinsics.syscall(SYS_fchownat, AT_FDCWD, uintptr(rawptr(path)), uintptr(user), uintptr(group), 0))
  1679. }
  1680. }
  1681. sys_fchown :: proc "contextless" (fd: int, user: int, group: int) -> int {
  1682. return int(intrinsics.syscall(SYS_fchown, uintptr(fd), uintptr(user), uintptr(group)))
  1683. }
  1684. sys_lchown :: proc "contextless" (path: cstring, user: int, group: int) -> int {
  1685. when ODIN_ARCH != .arm64 {
  1686. return int(intrinsics.syscall(SYS_lchown, uintptr(rawptr(path)), uintptr(user), uintptr(group)))
  1687. } else { // NOTE: arm64 does not have lchown
  1688. return int(intrinsics.syscall(SYS_fchownat, AT_FDCWD, uintptr(rawptr(path)), uintptr(user), uintptr(group), AT_SYMLINK_NOFOLLOW))
  1689. }
  1690. }
  1691. sys_rename :: proc "contextless" (old, new: cstring) -> int {
  1692. when ODIN_ARCH != .arm64 {
  1693. return int(intrinsics.syscall(SYS_rename, uintptr(rawptr(old)), uintptr(rawptr(new))))
  1694. } else { // NOTE: arm64 does not have rename
  1695. return int(intrinsics.syscall(SYS_renameat, AT_FDCWD, uintptr(rawptr(old)), uintptr(rawptr(new))))
  1696. }
  1697. }
  1698. sys_link :: proc "contextless" (old_name: cstring, new_name: cstring) -> int {
  1699. when ODIN_ARCH != .arm64 {
  1700. return int(intrinsics.syscall(SYS_link, uintptr(rawptr(old_name)), uintptr(rawptr(new_name))))
  1701. } else { // NOTE: arm64 does not have link
  1702. return int(intrinsics.syscall(SYS_linkat, AT_FDCWD, uintptr(rawptr(old_name)), AT_FDCWD, uintptr(rawptr(new_name)), AT_SYMLINK_FOLLOW))
  1703. }
  1704. }
  1705. sys_unlink :: proc "contextless" (path: cstring) -> int {
  1706. when ODIN_ARCH != .arm64 {
  1707. return int(intrinsics.syscall(SYS_unlink, uintptr(rawptr(path))))
  1708. } else { // NOTE: arm64 does not have unlink
  1709. return int(intrinsics.syscall(SYS_unlinkat, AT_FDCWD, uintptr(rawptr(path)), 0))
  1710. }
  1711. }
  1712. sys_unlinkat :: proc "contextless" (dfd: int, path: cstring, flag: int = 0) -> int {
  1713. return int(intrinsics.syscall(SYS_unlinkat, uintptr(dfd), uintptr(rawptr(path)), uintptr(flag)))
  1714. }
  1715. sys_rmdir :: proc "contextless" (path: cstring) -> int {
  1716. when ODIN_ARCH != .arm64 {
  1717. return int(intrinsics.syscall(SYS_rmdir, uintptr(rawptr(path))))
  1718. } else { // NOTE: arm64 does not have rmdir
  1719. return int(intrinsics.syscall(SYS_unlinkat, AT_FDCWD, uintptr(rawptr(path)), AT_REMOVEDIR))
  1720. }
  1721. }
  1722. sys_mkdir :: proc "contextless" (path: cstring, mode: int) -> int {
  1723. when ODIN_ARCH != .arm64 {
  1724. return int(intrinsics.syscall(SYS_mkdir, uintptr(rawptr(path)), uintptr(mode)))
  1725. } else { // NOTE: arm64 does not have mkdir
  1726. return int(intrinsics.syscall(SYS_mkdirat, AT_FDCWD, uintptr(rawptr(path)), uintptr(mode)))
  1727. }
  1728. }
  1729. sys_mkdirat :: proc "contextless" (dfd: int, path: cstring, mode: int) -> int {
  1730. return int(intrinsics.syscall(SYS_mkdirat, uintptr(dfd), uintptr(rawptr(path)), uintptr(mode)))
  1731. }
  1732. sys_mknod :: proc "contextless" (path: cstring, mode: int, dev: int) -> int {
  1733. when ODIN_ARCH != .arm64 {
  1734. return int(intrinsics.syscall(SYS_mknod, uintptr(rawptr(path)), uintptr(mode), uintptr(dev)))
  1735. } else { // NOTE: arm64 does not have mknod
  1736. return int(intrinsics.syscall(SYS_mknodat, AT_FDCWD, uintptr(rawptr(path)), uintptr(mode), uintptr(dev)))
  1737. }
  1738. }
  1739. sys_mknodat :: proc "contextless" (dfd: int, path: cstring, mode: int, dev: int) -> int {
  1740. return int(intrinsics.syscall(SYS_mknodat, uintptr(dfd), uintptr(rawptr(path)), uintptr(mode), uintptr(dev)))
  1741. }
  1742. sys_truncate :: proc "contextless" (path: cstring, length: i64) -> int {
  1743. when ODIN_ARCH == .amd64 || ODIN_ARCH == .arm64 {
  1744. return int(intrinsics.syscall(SYS_truncate, uintptr(rawptr(path)), uintptr(length)))
  1745. } else {
  1746. low := uintptr(length & 0xFFFFFFFF)
  1747. high := uintptr(length >> 32)
  1748. return int(intrinsics.syscall(SYS_truncate64, uintptr(rawptr(path)), high, low))
  1749. }
  1750. }
  1751. sys_ftruncate :: proc "contextless" (fd: int, length: i64) -> int {
  1752. when ODIN_ARCH == .amd64 || ODIN_ARCH == .arm64 {
  1753. return int(intrinsics.syscall(SYS_ftruncate, uintptr(fd), uintptr(length)))
  1754. } else {
  1755. low := uintptr(length & 0xFFFFFFFF)
  1756. high := uintptr(length >> 32)
  1757. return int(intrinsics.syscall(SYS_ftruncate64, uintptr(fd), high, low))
  1758. }
  1759. }
  1760. sys_fsync :: proc "contextless" (fd: int) -> int {
  1761. return int(intrinsics.syscall(SYS_fsync, uintptr(fd)))
  1762. }
  1763. sys_getdents64 :: proc "contextless" (fd: int, dirent: rawptr, count: int) -> int {
  1764. return int(intrinsics.syscall(SYS_getdents64, uintptr(fd), uintptr(dirent), uintptr(count)))
  1765. }
  1766. sys_fork :: proc "contextless" () -> int {
  1767. when ODIN_ARCH != .arm64 {
  1768. return int(intrinsics.syscall(SYS_fork))
  1769. } else {
  1770. return int(intrinsics.syscall(SYS_clone, SIGCHLD))
  1771. }
  1772. }
  1773. sys_mmap :: proc "contextless" (addr: rawptr, length: uint, prot, flags, fd: int, offset: uintptr) -> int {
  1774. return int(intrinsics.syscall(SYS_mmap, uintptr(addr), uintptr(length), uintptr(prot), uintptr(flags), uintptr(fd), offset))
  1775. }
  1776. sys_mremap :: proc "contextless" (addr: rawptr, old_length, new_length: uint, flags: int, new_addr: rawptr = nil) -> int {
  1777. return int(intrinsics.syscall(SYS_mremap, uintptr(addr), uintptr(old_length), uintptr(new_length), uintptr(flags), uintptr(new_addr)))
  1778. }
  1779. sys_munmap :: proc "contextless" (addr: rawptr, length: uint) -> int {
  1780. return int(intrinsics.syscall(SYS_munmap, uintptr(addr), uintptr(length)))
  1781. }
  1782. sys_mprotect :: proc "contextless" (addr: rawptr, length: uint, prot: int) -> int {
  1783. return int(intrinsics.syscall(SYS_mprotect, uintptr(addr), uintptr(length), uintptr(prot)))
  1784. }
  1785. sys_madvise :: proc "contextless" (addr: rawptr, length: uint, advice: int) -> int {
  1786. return int(intrinsics.syscall(SYS_madvise, uintptr(addr), uintptr(length), uintptr(advice)))
  1787. }
  1788. // NOTE: Unsure about if this works directly on 32 bit archs. It may need 32 bit version of the time struct.
  1789. // As of Linux 5.1, there is a utimensat_time64 function. Maybe use this in the future?
  1790. sys_utimensat :: proc "contextless" (dfd: int, path: cstring, times: rawptr, flags: int) -> int {
  1791. return int(intrinsics.syscall(SYS_utimensat, uintptr(dfd), uintptr(rawptr(path)), uintptr(times), uintptr(flags)))
  1792. }
  1793. get_errno :: proc "contextless" (res: int) -> i32 {
  1794. if res < 0 && res > -4096 {
  1795. return i32(-res)
  1796. }
  1797. return 0
  1798. }