syscalls_linux.odin 65 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099
  1. package unix
  2. import "base: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. // pipe2 flags
  1556. O_CLOEXEC :: 0o2000000
  1557. // poll events
  1558. POLLIN :: 0x0001
  1559. POLLPRI :: 0x0002
  1560. POLLOUT :: 0x0004
  1561. POLLERR :: 0x0008
  1562. POLLHUP :: 0x0010
  1563. POLLNVAL :: 0x0020
  1564. POLLRDNORM :: 0x0040
  1565. POLLRDBAND :: 0x0080
  1566. POLLWRNORM :: 0x0100
  1567. POLLWRBAND :: 0x0200
  1568. POLLMSG :: 0x0400
  1569. POLLREMOVE :: 0x1000
  1570. POLLRDHUP :: 0x2000
  1571. POLLFREE :: 0x4000
  1572. POLL_BUSY_LOOP :: 0x8000
  1573. // perf event data
  1574. Perf_Sample :: struct #raw_union {
  1575. period: u64,
  1576. frequency: u64,
  1577. }
  1578. Perf_Wakeup :: struct #raw_union {
  1579. events: u32,
  1580. watermark: u32,
  1581. }
  1582. Perf_Field1 :: struct #raw_union {
  1583. breakpoint_addr: u64,
  1584. kprobe_func: u64,
  1585. uprobe_path: u64,
  1586. config1: u64,
  1587. }
  1588. Perf_Field2 :: struct #raw_union {
  1589. breakpoint_len: u64,
  1590. kprobe_addr: u64,
  1591. uprobe_offset: u64,
  1592. config2: u64,
  1593. }
  1594. Perf_Event_Attr :: struct #packed {
  1595. type: u32,
  1596. size: u32,
  1597. config: u64,
  1598. sample: Perf_Sample,
  1599. sample_type: u64,
  1600. read_format: u64,
  1601. flags: Perf_Flags,
  1602. wakeup: Perf_Wakeup,
  1603. breakpoint_type: u32,
  1604. field1: Perf_Field1,
  1605. field2: Perf_Field2,
  1606. branch_sample_type: u64,
  1607. sample_regs_user: u64,
  1608. sample_stack_user: u32,
  1609. clock_id: i32,
  1610. sample_regs_intr: u64,
  1611. aux_watermark: u32,
  1612. sample_max_stack: u16,
  1613. _padding: u16,
  1614. }
  1615. Perf_Event_Flags :: distinct bit_set[Perf_Event_Flag; u64]
  1616. Perf_Event_Flag :: enum u64 {
  1617. Bit0 = 0,
  1618. Bit0_Is_Deprecated = 1,
  1619. User_Rdpmc = 2,
  1620. User_Time = 3,
  1621. User_Time_Zero = 4,
  1622. User_Time_Short = 5,
  1623. }
  1624. Perf_Capabilities :: struct #raw_union {
  1625. capabilities: u64,
  1626. flags: Perf_Event_Flags,
  1627. }
  1628. Perf_Event_mmap_Page :: struct #packed {
  1629. version: u32,
  1630. compat_version: u32,
  1631. lock: u32,
  1632. index: u32,
  1633. offset: i64,
  1634. time_enabled: u64,
  1635. time_running: u64,
  1636. cap: Perf_Capabilities,
  1637. pmc_width: u16,
  1638. time_shift: u16,
  1639. time_mult: u32,
  1640. time_offset: u64,
  1641. time_zero: u64,
  1642. size: u32,
  1643. reserved1: u32,
  1644. time_cycles: u64,
  1645. time_mask: u64,
  1646. reserved2: [116*8]u8,
  1647. data_head: u64,
  1648. data_tail: u64,
  1649. data_offset: u64,
  1650. data_size: u64,
  1651. aux_head: u64,
  1652. aux_tail: u64,
  1653. aux_offset: u64,
  1654. aux_size: u64,
  1655. }
  1656. Perf_Type_Id :: enum u32 {
  1657. Hardware = 0,
  1658. Software = 1,
  1659. Tracepoint = 2,
  1660. HW_Cache = 3,
  1661. Raw = 4,
  1662. Breakpoint = 5,
  1663. }
  1664. Perf_Hardware_Id :: enum u64 {
  1665. CPU_Cycles = 0,
  1666. Instructions = 1,
  1667. Cache_References = 2,
  1668. Cache_Misses = 3,
  1669. Branch_Instructions = 4,
  1670. Branch_Misses = 5,
  1671. Bus_Cycles = 6,
  1672. Stalled_Cycles_Frontend = 7,
  1673. Stalled_Cycles_Backend = 8,
  1674. Ref_CPU_Cycles = 9,
  1675. }
  1676. Perf_Flags :: distinct bit_set[Perf_Flag; u64]
  1677. Perf_Flag :: enum u64 {
  1678. Disabled = 0,
  1679. Inherit = 1,
  1680. Pinned = 2,
  1681. Exclusive = 3,
  1682. Exclude_User = 4,
  1683. Exclude_Kernel = 5,
  1684. Exclude_HV = 6,
  1685. Exclude_Idle = 7,
  1686. mmap = 8,
  1687. Comm = 9,
  1688. Freq = 10,
  1689. Inherit_Stat = 11,
  1690. Enable_On_Exec = 12,
  1691. Task = 13,
  1692. Watermark = 14,
  1693. Precise_IP_0 = 15,
  1694. Precise_IP_1 = 16,
  1695. mmap_Data = 17,
  1696. Sample_Id_All = 18,
  1697. Exclude_Host = 19,
  1698. Exclude_Guest = 20,
  1699. Exclude_Callchain_Kernel = 21,
  1700. Exclude_Callchain_User = 22,
  1701. mmap2 = 23,
  1702. Comm_Exec = 24,
  1703. Use_Clockid = 25,
  1704. Context_Switch = 26,
  1705. Write_Backward = 27,
  1706. Namespaces = 28,
  1707. KSymbol = 29,
  1708. BPF_Event = 30,
  1709. Aux_Output = 31,
  1710. CGroup = 32,
  1711. Text_Poke = 33,
  1712. Build_Id = 34,
  1713. Inherit_Thread = 35,
  1714. Remove_On_Exec = 36,
  1715. Sigtrap = 37,
  1716. }
  1717. sys_gettid :: proc "contextless" () -> int {
  1718. return int(intrinsics.syscall(SYS_gettid))
  1719. }
  1720. sys_getrandom :: proc "contextless" (buf: [^]byte, buflen: uint, flags: int) -> int {
  1721. return int(intrinsics.syscall(SYS_getrandom, uintptr(buf), uintptr(buflen), uintptr(flags)))
  1722. }
  1723. sys_open :: proc "contextless" (path: cstring, flags: int, mode: uint = 0o000) -> int {
  1724. when ODIN_ARCH != .arm64 {
  1725. return int(intrinsics.syscall(SYS_open, uintptr(rawptr(path)), uintptr(flags), uintptr(mode)))
  1726. } else { // NOTE: arm64 does not have open
  1727. return int(intrinsics.syscall(SYS_openat, AT_FDCWD, uintptr(rawptr(path)), uintptr(flags), uintptr(mode)))
  1728. }
  1729. }
  1730. sys_openat :: proc "contextless" (dfd: int, path: cstring, flags: int, mode: uint = 0o000) -> int {
  1731. return int(intrinsics.syscall(SYS_openat, uintptr(dfd), uintptr(rawptr(path)), uintptr(flags), uintptr(mode)))
  1732. }
  1733. sys_close :: proc "contextless" (fd: int) -> int {
  1734. return int(intrinsics.syscall(SYS_close, uintptr(fd)))
  1735. }
  1736. sys_read :: proc "contextless" (fd: int, buf: rawptr, size: uint) -> int {
  1737. return int(intrinsics.syscall(SYS_read, uintptr(fd), uintptr(buf), uintptr(size)))
  1738. }
  1739. sys_pread :: proc "contextless" (fd: int, buf: rawptr, size: uint, offset: i64) -> int {
  1740. when ODIN_ARCH == .amd64 || ODIN_ARCH == .arm64 {
  1741. return int(intrinsics.syscall(SYS_pread64, uintptr(fd), uintptr(buf), uintptr(size), uintptr(offset)))
  1742. } else {
  1743. low := uintptr(offset & 0xFFFFFFFF)
  1744. high := uintptr(offset >> 32)
  1745. return int(intrinsics.syscall(SYS_pread64, uintptr(fd), uintptr(buf), uintptr(size), high, low))
  1746. }
  1747. }
  1748. sys_write :: proc "contextless" (fd: int, buf: rawptr, size: uint) -> int {
  1749. return int(intrinsics.syscall(SYS_write, uintptr(fd), uintptr(buf), uintptr(size)))
  1750. }
  1751. sys_pwrite :: proc "contextless" (fd: int, buf: rawptr, size: uint, offset: i64) -> int {
  1752. when ODIN_ARCH == .amd64 || ODIN_ARCH == .arm64 {
  1753. return int(intrinsics.syscall(SYS_pwrite64, uintptr(fd), uintptr(buf), uintptr(size), uintptr(offset)))
  1754. } else {
  1755. low := uintptr(offset & 0xFFFFFFFF)
  1756. high := uintptr(offset >> 32)
  1757. return int(intrinsics.syscall(SYS_pwrite64, uintptr(fd), uintptr(buf), uintptr(size), high, low))
  1758. }
  1759. }
  1760. sys_lseek :: proc "contextless" (fd: int, offset: i64, whence: int) -> i64 {
  1761. when ODIN_ARCH == .amd64 || ODIN_ARCH == .arm64 {
  1762. return i64(intrinsics.syscall(SYS_lseek, uintptr(fd), uintptr(offset), uintptr(whence)))
  1763. } else {
  1764. low := uintptr(offset & 0xFFFFFFFF)
  1765. high := uintptr(offset >> 32)
  1766. result: i64
  1767. res := i64(intrinsics.syscall(SYS__llseek, uintptr(fd), high, low, uintptr(&result), uintptr(whence)))
  1768. return res if res < 0 else result
  1769. }
  1770. }
  1771. sys_stat :: proc "contextless" (path: cstring, stat: rawptr) -> int {
  1772. when ODIN_ARCH == .amd64 {
  1773. return int(intrinsics.syscall(SYS_stat, uintptr(rawptr(path)), uintptr(stat)))
  1774. } else when ODIN_ARCH != .arm64 {
  1775. return int(intrinsics.syscall(SYS_stat64, uintptr(rawptr(path)), uintptr(stat)))
  1776. } else { // NOTE: arm64 does not have stat
  1777. return int(intrinsics.syscall(SYS_fstatat, AT_FDCWD, uintptr(rawptr(path)), uintptr(stat), 0))
  1778. }
  1779. }
  1780. sys_fstat :: proc "contextless" (fd: int, stat: rawptr) -> int {
  1781. when ODIN_ARCH == .amd64 || ODIN_ARCH == .arm64 {
  1782. return int(intrinsics.syscall(SYS_fstat, uintptr(fd), uintptr(stat)))
  1783. } else {
  1784. return int(intrinsics.syscall(SYS_fstat64, uintptr(fd), uintptr(stat)))
  1785. }
  1786. }
  1787. sys_lstat :: proc "contextless" (path: cstring, stat: rawptr) -> int {
  1788. when ODIN_ARCH == .amd64 {
  1789. return int(intrinsics.syscall(SYS_lstat, uintptr(rawptr(path)), uintptr(stat)))
  1790. } else when ODIN_ARCH != .arm64 {
  1791. return int(intrinsics.syscall(SYS_lstat64, uintptr(rawptr(path)), uintptr(stat)))
  1792. } else { // NOTE: arm64 does not have any lstat
  1793. return int(intrinsics.syscall(SYS_fstatat, AT_FDCWD, uintptr(rawptr(path)), uintptr(stat), AT_SYMLINK_NOFOLLOW))
  1794. }
  1795. }
  1796. sys_readlink :: proc "contextless" (path: cstring, buf: rawptr, bufsiz: uint) -> int {
  1797. when ODIN_ARCH != .arm64 {
  1798. return int(intrinsics.syscall(SYS_readlink, uintptr(rawptr(path)), uintptr(buf), uintptr(bufsiz)))
  1799. } else { // NOTE: arm64 does not have readlink
  1800. return int(intrinsics.syscall(SYS_readlinkat, AT_FDCWD, uintptr(rawptr(path)), uintptr(buf), uintptr(bufsiz)))
  1801. }
  1802. }
  1803. sys_symlink :: proc "contextless" (old_name: cstring, new_name: cstring) -> int {
  1804. when ODIN_ARCH != .arm64 {
  1805. return int(intrinsics.syscall(SYS_symlink, uintptr(rawptr(old_name)), uintptr(rawptr(new_name))))
  1806. } else { // NOTE: arm64 does not have symlink
  1807. return int(intrinsics.syscall(SYS_symlinkat, uintptr(rawptr(old_name)), AT_FDCWD, uintptr(rawptr(new_name))))
  1808. }
  1809. }
  1810. sys_access :: proc "contextless" (path: cstring, mask: int) -> int {
  1811. when ODIN_ARCH != .arm64 {
  1812. return int(intrinsics.syscall(SYS_access, uintptr(rawptr(path)), uintptr(mask)))
  1813. } else { // NOTE: arm64 does not have access
  1814. return int(intrinsics.syscall(SYS_faccessat, AT_FDCWD, uintptr(rawptr(path)), uintptr(mask)))
  1815. }
  1816. }
  1817. sys_getcwd :: proc "contextless" (buf: rawptr, size: uint) -> int {
  1818. return int(intrinsics.syscall(SYS_getcwd, uintptr(buf), uintptr(size)))
  1819. }
  1820. sys_chdir :: proc "contextless" (path: cstring) -> int {
  1821. return int(intrinsics.syscall(SYS_chdir, uintptr(rawptr(path))))
  1822. }
  1823. sys_fchdir :: proc "contextless" (fd: int) -> int {
  1824. return int(intrinsics.syscall(SYS_fchdir, uintptr(fd)))
  1825. }
  1826. sys_chmod :: proc "contextless" (path: cstring, mode: uint) -> int {
  1827. when ODIN_ARCH != .arm64 {
  1828. return int(intrinsics.syscall(SYS_chmod, uintptr(rawptr(path)), uintptr(mode)))
  1829. } else { // NOTE: arm64 does not have chmod
  1830. return int(intrinsics.syscall(SYS_fchmodat, AT_FDCWD, uintptr(rawptr(path)), uintptr(mode)))
  1831. }
  1832. }
  1833. sys_fchmod :: proc "contextless" (fd: int, mode: uint) -> int {
  1834. return int(intrinsics.syscall(SYS_fchmod, uintptr(fd), uintptr(mode)))
  1835. }
  1836. sys_chown :: proc "contextless" (path: cstring, user: int, group: int) -> int {
  1837. when ODIN_ARCH != .arm64 {
  1838. return int(intrinsics.syscall(SYS_chown, uintptr(rawptr(path)), uintptr(user), uintptr(group)))
  1839. } else { // NOTE: arm64 does not have chown
  1840. return int(intrinsics.syscall(SYS_fchownat, AT_FDCWD, uintptr(rawptr(path)), uintptr(user), uintptr(group), 0))
  1841. }
  1842. }
  1843. sys_fchown :: proc "contextless" (fd: int, user: int, group: int) -> int {
  1844. return int(intrinsics.syscall(SYS_fchown, uintptr(fd), uintptr(user), uintptr(group)))
  1845. }
  1846. sys_lchown :: proc "contextless" (path: cstring, user: int, group: int) -> int {
  1847. when ODIN_ARCH != .arm64 {
  1848. return int(intrinsics.syscall(SYS_lchown, uintptr(rawptr(path)), uintptr(user), uintptr(group)))
  1849. } else { // NOTE: arm64 does not have lchown
  1850. return int(intrinsics.syscall(SYS_fchownat, AT_FDCWD, uintptr(rawptr(path)), uintptr(user), uintptr(group), AT_SYMLINK_NOFOLLOW))
  1851. }
  1852. }
  1853. sys_rename :: proc "contextless" (old, new: cstring) -> int {
  1854. when ODIN_ARCH != .arm64 {
  1855. return int(intrinsics.syscall(SYS_rename, uintptr(rawptr(old)), uintptr(rawptr(new))))
  1856. } else { // NOTE: arm64 does not have rename
  1857. return int(intrinsics.syscall(SYS_renameat, AT_FDCWD, uintptr(rawptr(old)), uintptr(rawptr(new))))
  1858. }
  1859. }
  1860. sys_link :: proc "contextless" (old_name: cstring, new_name: cstring) -> int {
  1861. when ODIN_ARCH != .arm64 {
  1862. return int(intrinsics.syscall(SYS_link, uintptr(rawptr(old_name)), uintptr(rawptr(new_name))))
  1863. } else { // NOTE: arm64 does not have link
  1864. return int(intrinsics.syscall(SYS_linkat, AT_FDCWD, uintptr(rawptr(old_name)), AT_FDCWD, uintptr(rawptr(new_name)), AT_SYMLINK_FOLLOW))
  1865. }
  1866. }
  1867. sys_unlink :: proc "contextless" (path: cstring) -> int {
  1868. when ODIN_ARCH != .arm64 {
  1869. return int(intrinsics.syscall(SYS_unlink, uintptr(rawptr(path))))
  1870. } else { // NOTE: arm64 does not have unlink
  1871. return int(intrinsics.syscall(SYS_unlinkat, AT_FDCWD, uintptr(rawptr(path)), 0))
  1872. }
  1873. }
  1874. sys_unlinkat :: proc "contextless" (dfd: int, path: cstring, flag: int = 0) -> int {
  1875. return int(intrinsics.syscall(SYS_unlinkat, uintptr(dfd), uintptr(rawptr(path)), uintptr(flag)))
  1876. }
  1877. sys_rmdir :: proc "contextless" (path: cstring) -> int {
  1878. when ODIN_ARCH != .arm64 {
  1879. return int(intrinsics.syscall(SYS_rmdir, uintptr(rawptr(path))))
  1880. } else { // NOTE: arm64 does not have rmdir
  1881. return int(intrinsics.syscall(SYS_unlinkat, AT_FDCWD, uintptr(rawptr(path)), AT_REMOVEDIR))
  1882. }
  1883. }
  1884. sys_mkdir :: proc "contextless" (path: cstring, mode: uint) -> int {
  1885. when ODIN_ARCH != .arm64 {
  1886. return int(intrinsics.syscall(SYS_mkdir, uintptr(rawptr(path)), uintptr(mode)))
  1887. } else { // NOTE: arm64 does not have mkdir
  1888. return int(intrinsics.syscall(SYS_mkdirat, AT_FDCWD, uintptr(rawptr(path)), uintptr(mode)))
  1889. }
  1890. }
  1891. sys_mkdirat :: proc "contextless" (dfd: int, path: cstring, mode: uint) -> int {
  1892. return int(intrinsics.syscall(SYS_mkdirat, uintptr(dfd), uintptr(rawptr(path)), uintptr(mode)))
  1893. }
  1894. sys_mknod :: proc "contextless" (path: cstring, mode: uint, dev: int) -> int {
  1895. when ODIN_ARCH != .arm64 {
  1896. return int(intrinsics.syscall(SYS_mknod, uintptr(rawptr(path)), uintptr(mode), uintptr(dev)))
  1897. } else { // NOTE: arm64 does not have mknod
  1898. return int(intrinsics.syscall(SYS_mknodat, AT_FDCWD, uintptr(rawptr(path)), uintptr(mode), uintptr(dev)))
  1899. }
  1900. }
  1901. sys_mknodat :: proc "contextless" (dfd: int, path: cstring, mode: uint, dev: int) -> int {
  1902. return int(intrinsics.syscall(SYS_mknodat, uintptr(dfd), uintptr(rawptr(path)), uintptr(mode), uintptr(dev)))
  1903. }
  1904. sys_truncate :: proc "contextless" (path: cstring, length: i64) -> int {
  1905. when ODIN_ARCH == .amd64 || ODIN_ARCH == .arm64 {
  1906. return int(intrinsics.syscall(SYS_truncate, uintptr(rawptr(path)), uintptr(length)))
  1907. } else {
  1908. low := uintptr(length & 0xFFFFFFFF)
  1909. high := uintptr(length >> 32)
  1910. return int(intrinsics.syscall(SYS_truncate64, uintptr(rawptr(path)), high, low))
  1911. }
  1912. }
  1913. sys_ftruncate :: proc "contextless" (fd: int, length: i64) -> int {
  1914. when ODIN_ARCH == .amd64 || ODIN_ARCH == .arm64 {
  1915. return int(intrinsics.syscall(SYS_ftruncate, uintptr(fd), uintptr(length)))
  1916. } else {
  1917. low := uintptr(length & 0xFFFFFFFF)
  1918. high := uintptr(length >> 32)
  1919. return int(intrinsics.syscall(SYS_ftruncate64, uintptr(fd), high, low))
  1920. }
  1921. }
  1922. sys_fsync :: proc "contextless" (fd: int) -> int {
  1923. return int(intrinsics.syscall(SYS_fsync, uintptr(fd)))
  1924. }
  1925. sys_getdents64 :: proc "contextless" (fd: int, dirent: rawptr, count: int) -> int {
  1926. return int(intrinsics.syscall(SYS_getdents64, uintptr(fd), uintptr(dirent), uintptr(count)))
  1927. }
  1928. sys_fork :: proc "contextless" () -> int {
  1929. when ODIN_ARCH != .arm64 {
  1930. return int(intrinsics.syscall(SYS_fork))
  1931. } else {
  1932. return int(intrinsics.syscall(SYS_clone, SIGCHLD))
  1933. }
  1934. }
  1935. sys_pipe2 :: proc "contextless" (fds: rawptr, flags: int) -> int {
  1936. return int(intrinsics.syscall(SYS_pipe2, uintptr(fds), uintptr(flags)))
  1937. }
  1938. sys_dup2 :: proc "contextless" (oldfd: int, newfd: int) -> int {
  1939. when ODIN_ARCH != .arm64 {
  1940. return int(intrinsics.syscall(SYS_dup2, uintptr(oldfd), uintptr(newfd)))
  1941. } else {
  1942. return int(intrinsics.syscall(SYS_dup3, uintptr(oldfd), uintptr(newfd), 0))
  1943. }
  1944. }
  1945. sys_mmap :: proc "contextless" (addr: rawptr, length: uint, prot, flags, fd: int, offset: uintptr) -> int {
  1946. return int(intrinsics.syscall(SYS_mmap, uintptr(addr), uintptr(length), uintptr(prot), uintptr(flags), uintptr(fd), offset))
  1947. }
  1948. sys_mremap :: proc "contextless" (addr: rawptr, old_length, new_length: uint, flags: int, new_addr: rawptr = nil) -> int {
  1949. return int(intrinsics.syscall(SYS_mremap, uintptr(addr), uintptr(old_length), uintptr(new_length), uintptr(flags), uintptr(new_addr)))
  1950. }
  1951. sys_munmap :: proc "contextless" (addr: rawptr, length: uint) -> int {
  1952. return int(intrinsics.syscall(SYS_munmap, uintptr(addr), uintptr(length)))
  1953. }
  1954. sys_mprotect :: proc "contextless" (addr: rawptr, length: uint, prot: int) -> int {
  1955. return int(intrinsics.syscall(SYS_mprotect, uintptr(addr), uintptr(length), uintptr(prot)))
  1956. }
  1957. sys_madvise :: proc "contextless" (addr: rawptr, length: uint, advice: int) -> int {
  1958. return int(intrinsics.syscall(SYS_madvise, uintptr(addr), uintptr(length), uintptr(advice)))
  1959. }
  1960. // NOTE: Unsure about if this works directly on 32 bit archs. It may need 32 bit version of the time struct.
  1961. // As of Linux 5.1, there is a utimensat_time64 function. Maybe use this in the future?
  1962. sys_utimensat :: proc "contextless" (dfd: int, path: cstring, times: rawptr, flags: int) -> int {
  1963. return int(intrinsics.syscall(SYS_utimensat, uintptr(dfd), uintptr(rawptr(path)), uintptr(times), uintptr(flags)))
  1964. }
  1965. sys_socket :: proc "contextless" (domain: int, type: int, protocol: int) -> int {
  1966. return int(intrinsics.syscall(SYS_socket, uintptr(domain), uintptr(type), uintptr(protocol)))
  1967. }
  1968. sys_connect :: proc "contextless" (sd: int, addr: rawptr, len: i32) -> int {
  1969. return int(intrinsics.syscall(SYS_connect, uintptr(sd), uintptr(addr), uintptr(len)))
  1970. }
  1971. sys_accept :: proc "contextless" (sd: int, addr: rawptr, len: rawptr) -> int {
  1972. return int(intrinsics.syscall(SYS_accept4, uintptr(sd), uintptr(addr), uintptr(len), uintptr(0)))
  1973. }
  1974. sys_listen :: proc "contextless" (sd: int, backlog: int) -> int {
  1975. return int(intrinsics.syscall(SYS_listen, uintptr(sd), uintptr(backlog)))
  1976. }
  1977. sys_bind :: proc "contextless" (sd: int, addr: rawptr, len: i32) -> int {
  1978. return int(intrinsics.syscall(SYS_bind, uintptr(sd), uintptr(addr), uintptr(len)))
  1979. }
  1980. sys_setsockopt :: proc "contextless" (sd: int, level: int, optname: int, optval: rawptr, optlen: i32) -> int {
  1981. return int(intrinsics.syscall(SYS_setsockopt, uintptr(sd), uintptr(level), uintptr(optname), uintptr(optval), uintptr(optlen)))
  1982. }
  1983. sys_recvfrom :: proc "contextless" (sd: int, buf: rawptr, len: uint, flags: int, addr: rawptr, alen: uintptr) -> i64 {
  1984. return i64(intrinsics.syscall(SYS_recvfrom, uintptr(sd), uintptr(buf), uintptr(len), uintptr(flags), uintptr(addr), uintptr(alen)))
  1985. }
  1986. sys_sendto :: proc "contextless" (sd: int, buf: rawptr, len: uint, flags: int, addr: rawptr, alen: i32) -> i64 {
  1987. return i64(intrinsics.syscall(SYS_sendto, uintptr(sd), uintptr(buf), uintptr(len), uintptr(flags), uintptr(addr), uintptr(alen)))
  1988. }
  1989. sys_shutdown :: proc "contextless" (sd: int, how: int) -> int {
  1990. return int(intrinsics.syscall(SYS_shutdown, uintptr(sd), uintptr(how)))
  1991. }
  1992. sys_perf_event_open :: proc "contextless" (event_attr: rawptr, pid: i32, cpu: i32, group_fd: i32, flags: u32) -> int {
  1993. return int(intrinsics.syscall(SYS_perf_event_open, uintptr(event_attr), uintptr(pid), uintptr(cpu), uintptr(group_fd), uintptr(flags)))
  1994. }
  1995. sys_personality :: proc(persona: u64) -> int {
  1996. return int(intrinsics.syscall(SYS_personality, uintptr(persona)))
  1997. }
  1998. sys_fcntl :: proc "contextless" (fd: int, cmd: int, arg: int) -> int {
  1999. return int(intrinsics.syscall(SYS_fcntl, uintptr(fd), uintptr(cmd), uintptr(arg)))
  2000. }
  2001. sys_poll :: proc "contextless" (fds: rawptr, nfds: uint, timeout: int) -> int {
  2002. // NOTE: specialcased here because `arm64` does not have `poll`
  2003. when ODIN_ARCH == .arm64 {
  2004. seconds := i64(timeout / 1_000)
  2005. nanoseconds := i64((timeout % 1000) * 1_000_000)
  2006. timeout_spec := timespec{seconds, nanoseconds}
  2007. return int(intrinsics.syscall(SYS_ppoll, uintptr(fds), uintptr(nfds), uintptr(&timeout_spec), uintptr(0), uintptr(8)))
  2008. } else {
  2009. return int(intrinsics.syscall(SYS_poll, uintptr(fds), uintptr(nfds), uintptr(timeout)))
  2010. }
  2011. }
  2012. sys_ppoll :: proc "contextless" (fds: rawptr, nfds: uint, timeout: rawptr, sigmask: rawptr, sigsetsize: uint) -> int {
  2013. return int(intrinsics.syscall(SYS_ppoll, uintptr(fds), uintptr(nfds), uintptr(timeout), uintptr(sigmask), uintptr(sigsetsize)))
  2014. }
  2015. get_errno :: proc "contextless" (res: int) -> i32 {
  2016. if res < 0 && res > -4096 {
  2017. return i32(-res)
  2018. }
  2019. return 0
  2020. }