@zigc/lib 0.16.0 → 0.17.0-dev.131

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (155) hide show
  1. package/c/fcntl.zig +6 -1
  2. package/c/inttypes.zig +0 -10
  3. package/c/math.zig +46 -122
  4. package/c/pthread.zig +57 -0
  5. package/c/search.zig +1 -27
  6. package/c/stdlib/drand48.zig +0 -57
  7. package/c/stdlib.zig +0 -100
  8. package/c/string.zig +20 -7
  9. package/c/strings.zig +0 -38
  10. package/c/unistd.zig +27 -26
  11. package/c/wchar.zig +10 -0
  12. package/c.zig +2 -2
  13. package/compiler/aro/aro/CodeGen.zig +5 -6
  14. package/compiler/aro/aro/Compilation.zig +17 -14
  15. package/compiler/aro/aro/Driver.zig +14 -13
  16. package/compiler/aro/aro/Parser.zig +20 -15
  17. package/compiler/aro/aro/Pragma.zig +3 -2
  18. package/compiler/aro/aro/Preprocessor.zig +9 -6
  19. package/compiler/aro/aro/pragmas/message.zig +3 -2
  20. package/compiler/aro/aro/text_literal.zig +3 -2
  21. package/compiler/aro/assembly_backend/x86_64.zig +4 -4
  22. package/compiler/build_runner.zig +0 -2
  23. package/compiler/reduce/Walk.zig +7 -7
  24. package/compiler/test_runner.zig +2 -2
  25. package/compiler/translate-c/Translator.zig +6 -2
  26. package/compiler/translate-c/main.zig +1 -1
  27. package/compiler_rt/cos.zig +0 -2
  28. package/compiler_rt/divmodei4.zig +40 -17
  29. package/compiler_rt/exp.zig +1 -6
  30. package/compiler_rt/exp2.zig +1 -6
  31. package/compiler_rt/exp_f128.zig +377 -0
  32. package/compiler_rt/fabs.zig +0 -2
  33. package/compiler_rt/fma.zig +0 -2
  34. package/compiler_rt/fmax.zig +0 -2
  35. package/compiler_rt/fmin.zig +0 -2
  36. package/compiler_rt/fmod.zig +0 -2
  37. package/compiler_rt/limb64.zig +876 -15
  38. package/compiler_rt/log.zig +0 -2
  39. package/compiler_rt/log10.zig +0 -2
  40. package/compiler_rt/log2.zig +0 -2
  41. package/compiler_rt/mulXi3.zig +1 -1
  42. package/compiler_rt/round.zig +0 -2
  43. package/compiler_rt/sin.zig +0 -2
  44. package/compiler_rt/sincos.zig +0 -2
  45. package/compiler_rt/sqrt.zig +0 -2
  46. package/compiler_rt/ssp.zig +1 -1
  47. package/compiler_rt/tan.zig +0 -2
  48. package/compiler_rt/trunc.zig +0 -2
  49. package/compiler_rt/udivmodei4.zig +28 -0
  50. package/fuzzer.zig +2 -0
  51. package/libc/musl/arch/mipsn32/syscall_arch.h +35 -32
  52. package/package.json +1 -1
  53. package/std/Build/Cache.zig +6 -6
  54. package/std/Build/Step/Compile.zig +0 -1
  55. package/std/Build/Step/Run.zig +2 -2
  56. package/std/Build/Step.zig +2 -4
  57. package/std/Build/WebServer.zig +2 -2
  58. package/std/Build.zig +0 -3
  59. package/std/Io/Dir.zig +7 -2
  60. package/std/Io/Dispatch.zig +3 -13
  61. package/std/Io/File/Writer.zig +8 -6
  62. package/std/Io/Reader.zig +8 -9
  63. package/std/Io/Semaphore.zig +112 -17
  64. package/std/Io/Terminal.zig +1 -1
  65. package/std/Io/Threaded.zig +171 -37
  66. package/std/Io/Uring.zig +13 -15
  67. package/std/Io/Writer.zig +46 -42
  68. package/std/Io/net.zig +11 -11
  69. package/std/Io.zig +90 -26
  70. package/std/SemanticVersion.zig +1 -1
  71. package/std/Target/Query.zig +2 -2
  72. package/std/Target.zig +50 -5
  73. package/std/array_hash_map.zig +9 -18
  74. package/std/builtin.zig +4 -0
  75. package/std/c/haiku.zig +3 -0
  76. package/std/c/serenity.zig +1 -6
  77. package/std/c.zig +89 -7
  78. package/std/compress/flate/Decompress.zig +2 -3
  79. package/std/compress/zstd/Decompress.zig +2 -4
  80. package/std/crypto/Certificate.zig +13 -1
  81. package/std/crypto/ascon.zig +75 -33
  82. package/std/crypto/codecs/asn1/Oid.zig +12 -1
  83. package/std/crypto/codecs/base64_hex_ct.zig +2 -4
  84. package/std/crypto/ml_kem.zig +2 -9
  85. package/std/crypto/tls/Client.zig +79 -4
  86. package/std/crypto/tls.zig +1 -1
  87. package/std/crypto.zig +1 -0
  88. package/std/debug/Pdb.zig +1 -1
  89. package/std/debug.zig +4 -3
  90. package/std/fmt.zig +8 -3
  91. package/std/fs/path.zig +6 -4
  92. package/std/heap/BufferFirstAllocator.zig +165 -0
  93. package/std/heap.zig +2 -126
  94. package/std/http/Client.zig +21 -24
  95. package/std/http.zig +3 -4
  96. package/std/json/Scanner.zig +2 -2
  97. package/std/os/emscripten.zig +1 -1
  98. package/std/os/linux/IoUring.zig +2 -0
  99. package/std/os/linux/aarch64.zig +41 -12
  100. package/std/os/linux/arc.zig +173 -0
  101. package/std/os/linux/arm.zig +41 -12
  102. package/std/os/linux/hexagon.zig +33 -11
  103. package/std/os/linux/loongarch32.zig +41 -13
  104. package/std/os/linux/loongarch64.zig +41 -12
  105. package/std/os/linux/m68k.zig +41 -13
  106. package/std/os/linux/mips.zig +67 -36
  107. package/std/os/linux/mips64.zig +60 -29
  108. package/std/os/linux/mipsn32.zig +60 -29
  109. package/std/os/linux/or1k.zig +41 -12
  110. package/std/os/linux/powerpc.zig +41 -12
  111. package/std/os/linux/powerpc64.zig +41 -12
  112. package/std/os/linux/riscv32.zig +41 -12
  113. package/std/os/linux/riscv64.zig +41 -12
  114. package/std/os/linux/s390x.zig +44 -7
  115. package/std/os/linux/sparc64.zig +83 -52
  116. package/std/os/linux/thumb.zig +52 -36
  117. package/std/os/linux/x32.zig +41 -12
  118. package/std/os/linux/x86.zig +42 -13
  119. package/std/os/linux/x86_64.zig +41 -12
  120. package/std/os/linux.zig +412 -436
  121. package/std/os/uefi/tables/boot_services.zig +9 -8
  122. package/std/os.zig +41 -0
  123. package/std/process.zig +1 -1
  124. package/std/sort.zig +3 -3
  125. package/std/zig/Ast/Render.zig +3 -3
  126. package/std/zig/AstGen.zig +44 -98
  127. package/std/zig/AstRlAnnotate.zig +0 -11
  128. package/std/zig/BuiltinFn.zig +0 -32
  129. package/std/zig/LibCInstallation.zig +4 -3
  130. package/std/zig/Parse.zig +7 -7
  131. package/std/zig/WindowsSdk.zig +13 -13
  132. package/std/zig/Zir.zig +50 -63
  133. package/std/zig/ZonGen.zig +6 -5
  134. package/std/zig/llvm/Builder.zig +12 -12
  135. package/std/zig.zig +1 -10
  136. package/std/zip.zig +5 -5
  137. package/zig.h +340 -1
  138. package/libc/mingw/math/fdiml.c +0 -24
  139. package/libc/mingw/winpthreads/spinlock.c +0 -82
  140. package/libc/musl/src/linux/tee.c +0 -8
  141. package/libc/musl/src/math/fdimf.c +0 -10
  142. package/libc/musl/src/math/fdiml.c +0 -18
  143. package/libc/musl/src/string/strdup.c +0 -10
  144. package/libc/musl/src/string/strndup.c +0 -12
  145. package/libc/musl/src/string/wcsdup.c +0 -10
  146. package/libc/musl/src/thread/pthread_spin_destroy.c +0 -6
  147. package/libc/musl/src/thread/pthread_spin_init.c +0 -6
  148. package/libc/musl/src/thread/pthread_spin_lock.c +0 -8
  149. package/libc/musl/src/thread/pthread_spin_trylock.c +0 -7
  150. package/libc/musl/src/thread/pthread_spin_unlock.c +0 -7
  151. package/libc/musl/src/unistd/dup2.c +0 -20
  152. package/libc/musl/src/unistd/dup3.c +0 -26
  153. package/libc/wasi/thread-stub/pthread_spin_lock.c +0 -8
  154. package/libc/wasi/thread-stub/pthread_spin_trylock.c +0 -8
  155. package/libc/wasi/thread-stub/pthread_spin_unlock.c +0 -7
@@ -2,7 +2,11 @@ const builtin = @import("builtin");
2
2
  const std = @import("../../std.zig");
3
3
  const SYS = std.os.linux.SYS;
4
4
 
5
- pub fn syscall0(number: SYS) u32 {
5
+ pub const syscall_arg_t = u64;
6
+
7
+ pub fn syscall0(
8
+ number: SYS,
9
+ ) u32 {
6
10
  return asm volatile (
7
11
  \\ syscall
8
12
  \\ beq $a3, $zero, 1f
@@ -14,24 +18,10 @@ pub fn syscall0(number: SYS) u32 {
14
18
  : .{ .r1 = true, .r3 = true, .r4 = true, .r5 = true, .r6 = true, .r7 = true, .r8 = true, .r9 = true, .r10 = true, .r11 = true, .r12 = true, .r13 = true, .r14 = true, .r15 = true, .r24 = true, .r25 = true, .hi = true, .lo = true, .memory = true });
15
19
  }
16
20
 
17
- pub fn syscall_pipe(fd: *[2]i32) u32 {
18
- return asm volatile (
19
- \\ syscall
20
- \\ beq $a3, $zero, 1f
21
- \\ blez $v0, 2f
22
- \\ subu $v0, $zero, $v0
23
- \\ b 2f
24
- \\1:
25
- \\ sw $v0, 0($a0)
26
- \\ sw $v1, 4($a0)
27
- \\2:
28
- : [ret] "={$2}" (-> u32),
29
- : [number] "{$2}" (@intFromEnum(SYS.pipe)),
30
- [fd] "{$4}" (fd),
31
- : .{ .r1 = true, .r3 = true, .r5 = true, .r6 = true, .r7 = true, .r8 = true, .r9 = true, .r10 = true, .r11 = true, .r12 = true, .r13 = true, .r14 = true, .r15 = true, .r24 = true, .r25 = true, .hi = true, .lo = true, .memory = true });
32
- }
33
-
34
- pub fn syscall1(number: SYS, arg1: u32) u32 {
21
+ pub fn syscall1(
22
+ number: SYS,
23
+ arg1: syscall_arg_t,
24
+ ) u32 {
35
25
  return asm volatile (
36
26
  \\ syscall
37
27
  \\ beq $a3, $zero, 1f
@@ -44,7 +34,11 @@ pub fn syscall1(number: SYS, arg1: u32) u32 {
44
34
  : .{ .r1 = true, .r3 = true, .r5 = true, .r6 = true, .r7 = true, .r8 = true, .r9 = true, .r10 = true, .r11 = true, .r12 = true, .r13 = true, .r14 = true, .r15 = true, .r24 = true, .r25 = true, .hi = true, .lo = true, .memory = true });
45
35
  }
46
36
 
47
- pub fn syscall2(number: SYS, arg1: u32, arg2: u32) u32 {
37
+ pub fn syscall2(
38
+ number: SYS,
39
+ arg1: syscall_arg_t,
40
+ arg2: syscall_arg_t,
41
+ ) u32 {
48
42
  return asm volatile (
49
43
  \\ syscall
50
44
  \\ beq $a3, $zero, 1f
@@ -58,7 +52,12 @@ pub fn syscall2(number: SYS, arg1: u32, arg2: u32) u32 {
58
52
  : .{ .r1 = true, .r3 = true, .r6 = true, .r7 = true, .r8 = true, .r9 = true, .r10 = true, .r11 = true, .r12 = true, .r13 = true, .r14 = true, .r15 = true, .r24 = true, .r25 = true, .hi = true, .lo = true, .memory = true });
59
53
  }
60
54
 
61
- pub fn syscall3(number: SYS, arg1: u32, arg2: u32, arg3: u32) u32 {
55
+ pub fn syscall3(
56
+ number: SYS,
57
+ arg1: syscall_arg_t,
58
+ arg2: syscall_arg_t,
59
+ arg3: syscall_arg_t,
60
+ ) u32 {
62
61
  return asm volatile (
63
62
  \\ syscall
64
63
  \\ beq $a3, $zero, 1f
@@ -73,7 +72,13 @@ pub fn syscall3(number: SYS, arg1: u32, arg2: u32, arg3: u32) u32 {
73
72
  : .{ .r1 = true, .r3 = true, .r7 = true, .r8 = true, .r9 = true, .r10 = true, .r11 = true, .r12 = true, .r13 = true, .r14 = true, .r15 = true, .r24 = true, .r25 = true, .hi = true, .lo = true, .memory = true });
74
73
  }
75
74
 
76
- pub fn syscall4(number: SYS, arg1: u32, arg2: u32, arg3: u32, arg4: u32) u32 {
75
+ pub fn syscall4(
76
+ number: SYS,
77
+ arg1: syscall_arg_t,
78
+ arg2: syscall_arg_t,
79
+ arg3: syscall_arg_t,
80
+ arg4: syscall_arg_t,
81
+ ) u32 {
77
82
  return asm volatile (
78
83
  \\ syscall
79
84
  \\ beq $a3, $zero, 1f
@@ -89,7 +94,14 @@ pub fn syscall4(number: SYS, arg1: u32, arg2: u32, arg3: u32, arg4: u32) u32 {
89
94
  : .{ .r1 = true, .r3 = true, .r8 = true, .r9 = true, .r10 = true, .r11 = true, .r12 = true, .r13 = true, .r14 = true, .r15 = true, .r24 = true, .r25 = true, .hi = true, .lo = true, .memory = true });
90
95
  }
91
96
 
92
- pub fn syscall5(number: SYS, arg1: u32, arg2: u32, arg3: u32, arg4: u32, arg5: u32) u32 {
97
+ pub fn syscall5(
98
+ number: SYS,
99
+ arg1: syscall_arg_t,
100
+ arg2: syscall_arg_t,
101
+ arg3: syscall_arg_t,
102
+ arg4: syscall_arg_t,
103
+ arg5: syscall_arg_t,
104
+ ) u32 {
93
105
  return asm volatile (
94
106
  \\ syscall
95
107
  \\ beq $a3, $zero, 1f
@@ -108,12 +120,12 @@ pub fn syscall5(number: SYS, arg1: u32, arg2: u32, arg3: u32, arg4: u32, arg5: u
108
120
 
109
121
  pub fn syscall6(
110
122
  number: SYS,
111
- arg1: u32,
112
- arg2: u32,
113
- arg3: u32,
114
- arg4: u32,
115
- arg5: u32,
116
- arg6: u32,
123
+ arg1: syscall_arg_t,
124
+ arg2: syscall_arg_t,
125
+ arg3: syscall_arg_t,
126
+ arg4: syscall_arg_t,
127
+ arg5: syscall_arg_t,
128
+ arg6: syscall_arg_t,
117
129
  ) u32 {
118
130
  return asm volatile (
119
131
  \\ syscall
@@ -132,6 +144,25 @@ pub fn syscall6(
132
144
  : .{ .r1 = true, .r3 = true, .r8 = true, .r9 = true, .r10 = true, .r11 = true, .r12 = true, .r13 = true, .r14 = true, .r15 = true, .r24 = true, .r25 = true, .hi = true, .lo = true, .memory = true });
133
145
  }
134
146
 
147
+ pub fn syscall_pipe(
148
+ fd: *[2]std.os.linux.fd_t,
149
+ ) u32 {
150
+ return asm volatile (
151
+ \\ syscall
152
+ \\ beq $a3, $zero, 1f
153
+ \\ blez $v0, 2f
154
+ \\ subu $v0, $zero, $v0
155
+ \\ b 2f
156
+ \\1:
157
+ \\ sw $v0, 0($a0)
158
+ \\ sw $v1, 4($a0)
159
+ \\2:
160
+ : [ret] "={$2}" (-> u32),
161
+ : [number] "{$2}" (@intFromEnum(SYS.pipe)),
162
+ [fd] "{$4}" (fd),
163
+ : .{ .r1 = true, .r3 = true, .r5 = true, .r6 = true, .r7 = true, .r8 = true, .r9 = true, .r10 = true, .r11 = true, .r12 = true, .r13 = true, .r14 = true, .r15 = true, .r24 = true, .r25 = true, .hi = true, .lo = true, .memory = true });
164
+ }
165
+
135
166
  pub fn clone() callconv(.naked) u32 {
136
167
  // __clone(func, stack, flags, arg, ptid, tls, ctid)
137
168
  // a0, a1, a2, a3, a4, a5, a6
@@ -2,7 +2,11 @@ const builtin = @import("builtin");
2
2
  const std = @import("../../std.zig");
3
3
  const SYS = std.os.linux.SYS;
4
4
 
5
- pub fn syscall0(number: SYS) u32 {
5
+ pub const syscall_arg_t = u32;
6
+
7
+ pub fn syscall0(
8
+ number: SYS,
9
+ ) u32 {
6
10
  return asm volatile (
7
11
  \\ l.sys 1
8
12
  : [ret] "={r11}" (-> u32),
@@ -10,7 +14,10 @@ pub fn syscall0(number: SYS) u32 {
10
14
  : .{ .r3 = true, .r4 = true, .r5 = true, .r6 = true, .r7 = true, .r8 = true, .r12 = true, .r13 = true, .r15 = true, .r17 = true, .r19 = true, .r21 = true, .r23 = true, .r25 = true, .r27 = true, .r29 = true, .r31 = true, .memory = true });
11
15
  }
12
16
 
13
- pub fn syscall1(number: SYS, arg1: u32) u32 {
17
+ pub fn syscall1(
18
+ number: SYS,
19
+ arg1: syscall_arg_t,
20
+ ) u32 {
14
21
  return asm volatile (
15
22
  \\ l.sys 1
16
23
  : [ret] "={r11}" (-> u32),
@@ -19,7 +26,11 @@ pub fn syscall1(number: SYS, arg1: u32) u32 {
19
26
  : .{ .r4 = true, .r5 = true, .r6 = true, .r7 = true, .r8 = true, .r12 = true, .r13 = true, .r15 = true, .r17 = true, .r19 = true, .r21 = true, .r23 = true, .r25 = true, .r27 = true, .r29 = true, .r31 = true, .memory = true });
20
27
  }
21
28
 
22
- pub fn syscall2(number: SYS, arg1: u32, arg2: u32) u32 {
29
+ pub fn syscall2(
30
+ number: SYS,
31
+ arg1: syscall_arg_t,
32
+ arg2: syscall_arg_t,
33
+ ) u32 {
23
34
  return asm volatile (
24
35
  \\ l.sys 1
25
36
  : [ret] "={r11}" (-> u32),
@@ -29,7 +40,12 @@ pub fn syscall2(number: SYS, arg1: u32, arg2: u32) u32 {
29
40
  : .{ .r5 = true, .r6 = true, .r7 = true, .r8 = true, .r12 = true, .r13 = true, .r15 = true, .r17 = true, .r19 = true, .r21 = true, .r23 = true, .r25 = true, .r27 = true, .r29 = true, .r31 = true, .memory = true });
30
41
  }
31
42
 
32
- pub fn syscall3(number: SYS, arg1: u32, arg2: u32, arg3: u32) u32 {
43
+ pub fn syscall3(
44
+ number: SYS,
45
+ arg1: syscall_arg_t,
46
+ arg2: syscall_arg_t,
47
+ arg3: syscall_arg_t,
48
+ ) u32 {
33
49
  return asm volatile (
34
50
  \\ l.sys 1
35
51
  : [ret] "={r11}" (-> u32),
@@ -40,7 +56,13 @@ pub fn syscall3(number: SYS, arg1: u32, arg2: u32, arg3: u32) u32 {
40
56
  : .{ .r6 = true, .r7 = true, .r8 = true, .r12 = true, .r13 = true, .r15 = true, .r17 = true, .r19 = true, .r21 = true, .r23 = true, .r25 = true, .r27 = true, .r29 = true, .r31 = true, .memory = true });
41
57
  }
42
58
 
43
- pub fn syscall4(number: SYS, arg1: u32, arg2: u32, arg3: u32, arg4: u32) u32 {
59
+ pub fn syscall4(
60
+ number: SYS,
61
+ arg1: syscall_arg_t,
62
+ arg2: syscall_arg_t,
63
+ arg3: syscall_arg_t,
64
+ arg4: syscall_arg_t,
65
+ ) u32 {
44
66
  return asm volatile (
45
67
  \\ l.sys 1
46
68
  : [ret] "={r11}" (-> u32),
@@ -52,7 +74,14 @@ pub fn syscall4(number: SYS, arg1: u32, arg2: u32, arg3: u32, arg4: u32) u32 {
52
74
  : .{ .r7 = true, .r8 = true, .r12 = true, .r13 = true, .r15 = true, .r17 = true, .r19 = true, .r21 = true, .r23 = true, .r25 = true, .r27 = true, .r29 = true, .r31 = true, .memory = true });
53
75
  }
54
76
 
55
- pub fn syscall5(number: SYS, arg1: u32, arg2: u32, arg3: u32, arg4: u32, arg5: u32) u32 {
77
+ pub fn syscall5(
78
+ number: SYS,
79
+ arg1: syscall_arg_t,
80
+ arg2: syscall_arg_t,
81
+ arg3: syscall_arg_t,
82
+ arg4: syscall_arg_t,
83
+ arg5: syscall_arg_t,
84
+ ) u32 {
56
85
  return asm volatile (
57
86
  \\ l.sys 1
58
87
  : [ret] "={r11}" (-> u32),
@@ -67,12 +96,12 @@ pub fn syscall5(number: SYS, arg1: u32, arg2: u32, arg3: u32, arg4: u32, arg5: u
67
96
 
68
97
  pub fn syscall6(
69
98
  number: SYS,
70
- arg1: u32,
71
- arg2: u32,
72
- arg3: u32,
73
- arg4: u32,
74
- arg5: u32,
75
- arg6: u32,
99
+ arg1: syscall_arg_t,
100
+ arg2: syscall_arg_t,
101
+ arg3: syscall_arg_t,
102
+ arg4: syscall_arg_t,
103
+ arg5: syscall_arg_t,
104
+ arg6: syscall_arg_t,
76
105
  ) u32 {
77
106
  return asm volatile (
78
107
  \\ l.sys 1
@@ -2,7 +2,11 @@ const builtin = @import("builtin");
2
2
  const std = @import("../../std.zig");
3
3
  const SYS = std.os.linux.SYS;
4
4
 
5
- pub fn syscall0(number: SYS) u32 {
5
+ pub const syscall_arg_t = u32;
6
+
7
+ pub fn syscall0(
8
+ number: SYS,
9
+ ) u32 {
6
10
  // r0 is both an input register and a clobber. musl and glibc achieve this with
7
11
  // a "+" constraint, which isn't supported in Zig, so instead we separately list
8
12
  // r0 as both an input and an output. (Listing it as an input and a clobber would
@@ -19,7 +23,10 @@ pub fn syscall0(number: SYS) u32 {
19
23
  : .{ .memory = true, .cr0 = true, .r4 = true, .r5 = true, .r6 = true, .r7 = true, .r8 = true, .r9 = true, .r10 = true, .r11 = true, .r12 = true, .ctr = true, .xer = true });
20
24
  }
21
25
 
22
- pub fn syscall1(number: SYS, arg1: u32) u32 {
26
+ pub fn syscall1(
27
+ number: SYS,
28
+ arg1: syscall_arg_t,
29
+ ) u32 {
23
30
  // r0 is both an input and a clobber.
24
31
  var r0_out: u32 = undefined;
25
32
  return asm volatile (
@@ -34,7 +41,11 @@ pub fn syscall1(number: SYS, arg1: u32) u32 {
34
41
  : .{ .memory = true, .cr0 = true, .r4 = true, .r5 = true, .r6 = true, .r7 = true, .r8 = true, .r9 = true, .r10 = true, .r11 = true, .r12 = true, .ctr = true, .xer = true });
35
42
  }
36
43
 
37
- pub fn syscall2(number: SYS, arg1: u32, arg2: u32) u32 {
44
+ pub fn syscall2(
45
+ number: SYS,
46
+ arg1: syscall_arg_t,
47
+ arg2: syscall_arg_t,
48
+ ) u32 {
38
49
  // These registers are both inputs and clobbers.
39
50
  var r0_out: u32 = undefined;
40
51
  var r4_out: u32 = undefined;
@@ -52,7 +63,12 @@ pub fn syscall2(number: SYS, arg1: u32, arg2: u32) u32 {
52
63
  : .{ .memory = true, .cr0 = true, .r5 = true, .r6 = true, .r7 = true, .r8 = true, .r9 = true, .r10 = true, .r11 = true, .r12 = true, .ctr = true, .xer = true });
53
64
  }
54
65
 
55
- pub fn syscall3(number: SYS, arg1: u32, arg2: u32, arg3: u32) u32 {
66
+ pub fn syscall3(
67
+ number: SYS,
68
+ arg1: syscall_arg_t,
69
+ arg2: syscall_arg_t,
70
+ arg3: syscall_arg_t,
71
+ ) u32 {
56
72
  // These registers are both inputs and clobbers.
57
73
  var r0_out: u32 = undefined;
58
74
  var r4_out: u32 = undefined;
@@ -73,7 +89,13 @@ pub fn syscall3(number: SYS, arg1: u32, arg2: u32, arg3: u32) u32 {
73
89
  : .{ .memory = true, .cr0 = true, .r6 = true, .r7 = true, .r8 = true, .r9 = true, .r10 = true, .r11 = true, .r12 = true, .ctr = true, .xer = true });
74
90
  }
75
91
 
76
- pub fn syscall4(number: SYS, arg1: u32, arg2: u32, arg3: u32, arg4: u32) u32 {
92
+ pub fn syscall4(
93
+ number: SYS,
94
+ arg1: syscall_arg_t,
95
+ arg2: syscall_arg_t,
96
+ arg3: syscall_arg_t,
97
+ arg4: syscall_arg_t,
98
+ ) u32 {
77
99
  // These registers are both inputs and clobbers.
78
100
  var r0_out: u32 = undefined;
79
101
  var r4_out: u32 = undefined;
@@ -97,7 +119,14 @@ pub fn syscall4(number: SYS, arg1: u32, arg2: u32, arg3: u32, arg4: u32) u32 {
97
119
  : .{ .memory = true, .cr0 = true, .r7 = true, .r8 = true, .r9 = true, .r10 = true, .r11 = true, .r12 = true, .ctr = true, .xer = true });
98
120
  }
99
121
 
100
- pub fn syscall5(number: SYS, arg1: u32, arg2: u32, arg3: u32, arg4: u32, arg5: u32) u32 {
122
+ pub fn syscall5(
123
+ number: SYS,
124
+ arg1: syscall_arg_t,
125
+ arg2: syscall_arg_t,
126
+ arg3: syscall_arg_t,
127
+ arg4: syscall_arg_t,
128
+ arg5: syscall_arg_t,
129
+ ) u32 {
101
130
  // These registers are both inputs and clobbers.
102
131
  var r0_out: u32 = undefined;
103
132
  var r4_out: u32 = undefined;
@@ -126,12 +155,12 @@ pub fn syscall5(number: SYS, arg1: u32, arg2: u32, arg3: u32, arg4: u32, arg5: u
126
155
 
127
156
  pub fn syscall6(
128
157
  number: SYS,
129
- arg1: u32,
130
- arg2: u32,
131
- arg3: u32,
132
- arg4: u32,
133
- arg5: u32,
134
- arg6: u32,
158
+ arg1: syscall_arg_t,
159
+ arg2: syscall_arg_t,
160
+ arg3: syscall_arg_t,
161
+ arg4: syscall_arg_t,
162
+ arg5: syscall_arg_t,
163
+ arg6: syscall_arg_t,
135
164
  ) u32 {
136
165
  // These registers are both inputs and clobbers.
137
166
  var r0_out: u32 = undefined;
@@ -2,7 +2,11 @@ const builtin = @import("builtin");
2
2
  const std = @import("../../std.zig");
3
3
  const SYS = std.os.linux.SYS;
4
4
 
5
- pub fn syscall0(number: SYS) u64 {
5
+ pub const syscall_arg_t = u64;
6
+
7
+ pub fn syscall0(
8
+ number: SYS,
9
+ ) u64 {
6
10
  // r0 is both an input register and a clobber. musl and glibc achieve this with
7
11
  // a "+" constraint, which isn't supported in Zig, so instead we separately list
8
12
  // r0 as both an input and an output. (Listing it as an input and a clobber would
@@ -19,7 +23,10 @@ pub fn syscall0(number: SYS) u64 {
19
23
  : .{ .memory = true, .cr0 = true, .r4 = true, .r5 = true, .r6 = true, .r7 = true, .r8 = true, .r9 = true, .r10 = true, .r11 = true, .r12 = true, .ctr = true, .xer = true });
20
24
  }
21
25
 
22
- pub fn syscall1(number: SYS, arg1: u64) u64 {
26
+ pub fn syscall1(
27
+ number: SYS,
28
+ arg1: syscall_arg_t,
29
+ ) u64 {
23
30
  // r0 is both an input and a clobber.
24
31
  var r0_out: u64 = undefined;
25
32
  return asm volatile (
@@ -34,7 +41,11 @@ pub fn syscall1(number: SYS, arg1: u64) u64 {
34
41
  : .{ .memory = true, .cr0 = true, .r4 = true, .r5 = true, .r6 = true, .r7 = true, .r8 = true, .r9 = true, .r10 = true, .r11 = true, .r12 = true, .ctr = true, .xer = true });
35
42
  }
36
43
 
37
- pub fn syscall2(number: SYS, arg1: u64, arg2: u64) u64 {
44
+ pub fn syscall2(
45
+ number: SYS,
46
+ arg1: syscall_arg_t,
47
+ arg2: syscall_arg_t,
48
+ ) u64 {
38
49
  // These registers are both inputs and clobbers.
39
50
  var r0_out: u64 = undefined;
40
51
  var r4_out: u64 = undefined;
@@ -52,7 +63,12 @@ pub fn syscall2(number: SYS, arg1: u64, arg2: u64) u64 {
52
63
  : .{ .memory = true, .cr0 = true, .r5 = true, .r6 = true, .r7 = true, .r8 = true, .r9 = true, .r10 = true, .r11 = true, .r12 = true, .ctr = true, .xer = true });
53
64
  }
54
65
 
55
- pub fn syscall3(number: SYS, arg1: u64, arg2: u64, arg3: u64) u64 {
66
+ pub fn syscall3(
67
+ number: SYS,
68
+ arg1: syscall_arg_t,
69
+ arg2: syscall_arg_t,
70
+ arg3: syscall_arg_t,
71
+ ) u64 {
56
72
  // These registers are both inputs and clobbers.
57
73
  var r0_out: u64 = undefined;
58
74
  var r4_out: u64 = undefined;
@@ -73,7 +89,13 @@ pub fn syscall3(number: SYS, arg1: u64, arg2: u64, arg3: u64) u64 {
73
89
  : .{ .memory = true, .cr0 = true, .r6 = true, .r7 = true, .r8 = true, .r9 = true, .r10 = true, .r11 = true, .r12 = true, .ctr = true, .xer = true });
74
90
  }
75
91
 
76
- pub fn syscall4(number: SYS, arg1: u64, arg2: u64, arg3: u64, arg4: u64) u64 {
92
+ pub fn syscall4(
93
+ number: SYS,
94
+ arg1: syscall_arg_t,
95
+ arg2: syscall_arg_t,
96
+ arg3: syscall_arg_t,
97
+ arg4: syscall_arg_t,
98
+ ) u64 {
77
99
  // These registers are both inputs and clobbers.
78
100
  var r0_out: u64 = undefined;
79
101
  var r4_out: u64 = undefined;
@@ -97,7 +119,14 @@ pub fn syscall4(number: SYS, arg1: u64, arg2: u64, arg3: u64, arg4: u64) u64 {
97
119
  : .{ .memory = true, .cr0 = true, .r7 = true, .r8 = true, .r9 = true, .r10 = true, .r11 = true, .r12 = true, .ctr = true, .xer = true });
98
120
  }
99
121
 
100
- pub fn syscall5(number: SYS, arg1: u64, arg2: u64, arg3: u64, arg4: u64, arg5: u64) u64 {
122
+ pub fn syscall5(
123
+ number: SYS,
124
+ arg1: syscall_arg_t,
125
+ arg2: syscall_arg_t,
126
+ arg3: syscall_arg_t,
127
+ arg4: syscall_arg_t,
128
+ arg5: syscall_arg_t,
129
+ ) u64 {
101
130
  // These registers are both inputs and clobbers.
102
131
  var r0_out: u64 = undefined;
103
132
  var r4_out: u64 = undefined;
@@ -126,12 +155,12 @@ pub fn syscall5(number: SYS, arg1: u64, arg2: u64, arg3: u64, arg4: u64, arg5: u
126
155
 
127
156
  pub fn syscall6(
128
157
  number: SYS,
129
- arg1: u64,
130
- arg2: u64,
131
- arg3: u64,
132
- arg4: u64,
133
- arg5: u64,
134
- arg6: u64,
158
+ arg1: syscall_arg_t,
159
+ arg2: syscall_arg_t,
160
+ arg3: syscall_arg_t,
161
+ arg4: syscall_arg_t,
162
+ arg5: syscall_arg_t,
163
+ arg6: syscall_arg_t,
135
164
  ) u64 {
136
165
  // These registers are both inputs and clobbers.
137
166
  var r0_out: u64 = undefined;
@@ -2,14 +2,21 @@ const builtin = @import("builtin");
2
2
  const std = @import("../../std.zig");
3
3
  const SYS = std.os.linux.SYS;
4
4
 
5
- pub fn syscall0(number: SYS) u32 {
5
+ pub const syscall_arg_t = u32;
6
+
7
+ pub fn syscall0(
8
+ number: SYS,
9
+ ) u32 {
6
10
  return asm volatile ("ecall"
7
11
  : [ret] "={x10}" (-> u32),
8
12
  : [number] "{x17}" (@intFromEnum(number)),
9
13
  : .{ .memory = true });
10
14
  }
11
15
 
12
- pub fn syscall1(number: SYS, arg1: u32) u32 {
16
+ pub fn syscall1(
17
+ number: SYS,
18
+ arg1: syscall_arg_t,
19
+ ) u32 {
13
20
  return asm volatile ("ecall"
14
21
  : [ret] "={x10}" (-> u32),
15
22
  : [number] "{x17}" (@intFromEnum(number)),
@@ -17,7 +24,11 @@ pub fn syscall1(number: SYS, arg1: u32) u32 {
17
24
  : .{ .memory = true });
18
25
  }
19
26
 
20
- pub fn syscall2(number: SYS, arg1: u32, arg2: u32) u32 {
27
+ pub fn syscall2(
28
+ number: SYS,
29
+ arg1: syscall_arg_t,
30
+ arg2: syscall_arg_t,
31
+ ) u32 {
21
32
  return asm volatile ("ecall"
22
33
  : [ret] "={x10}" (-> u32),
23
34
  : [number] "{x17}" (@intFromEnum(number)),
@@ -26,7 +37,12 @@ pub fn syscall2(number: SYS, arg1: u32, arg2: u32) u32 {
26
37
  : .{ .memory = true });
27
38
  }
28
39
 
29
- pub fn syscall3(number: SYS, arg1: u32, arg2: u32, arg3: u32) u32 {
40
+ pub fn syscall3(
41
+ number: SYS,
42
+ arg1: syscall_arg_t,
43
+ arg2: syscall_arg_t,
44
+ arg3: syscall_arg_t,
45
+ ) u32 {
30
46
  return asm volatile ("ecall"
31
47
  : [ret] "={x10}" (-> u32),
32
48
  : [number] "{x17}" (@intFromEnum(number)),
@@ -36,7 +52,13 @@ pub fn syscall3(number: SYS, arg1: u32, arg2: u32, arg3: u32) u32 {
36
52
  : .{ .memory = true });
37
53
  }
38
54
 
39
- pub fn syscall4(number: SYS, arg1: u32, arg2: u32, arg3: u32, arg4: u32) u32 {
55
+ pub fn syscall4(
56
+ number: SYS,
57
+ arg1: syscall_arg_t,
58
+ arg2: syscall_arg_t,
59
+ arg3: syscall_arg_t,
60
+ arg4: syscall_arg_t,
61
+ ) u32 {
40
62
  return asm volatile ("ecall"
41
63
  : [ret] "={x10}" (-> u32),
42
64
  : [number] "{x17}" (@intFromEnum(number)),
@@ -47,7 +69,14 @@ pub fn syscall4(number: SYS, arg1: u32, arg2: u32, arg3: u32, arg4: u32) u32 {
47
69
  : .{ .memory = true });
48
70
  }
49
71
 
50
- pub fn syscall5(number: SYS, arg1: u32, arg2: u32, arg3: u32, arg4: u32, arg5: u32) u32 {
72
+ pub fn syscall5(
73
+ number: SYS,
74
+ arg1: syscall_arg_t,
75
+ arg2: syscall_arg_t,
76
+ arg3: syscall_arg_t,
77
+ arg4: syscall_arg_t,
78
+ arg5: syscall_arg_t,
79
+ ) u32 {
51
80
  return asm volatile ("ecall"
52
81
  : [ret] "={x10}" (-> u32),
53
82
  : [number] "{x17}" (@intFromEnum(number)),
@@ -61,12 +90,12 @@ pub fn syscall5(number: SYS, arg1: u32, arg2: u32, arg3: u32, arg4: u32, arg5: u
61
90
 
62
91
  pub fn syscall6(
63
92
  number: SYS,
64
- arg1: u32,
65
- arg2: u32,
66
- arg3: u32,
67
- arg4: u32,
68
- arg5: u32,
69
- arg6: u32,
93
+ arg1: syscall_arg_t,
94
+ arg2: syscall_arg_t,
95
+ arg3: syscall_arg_t,
96
+ arg4: syscall_arg_t,
97
+ arg5: syscall_arg_t,
98
+ arg6: syscall_arg_t,
70
99
  ) u32 {
71
100
  return asm volatile ("ecall"
72
101
  : [ret] "={x10}" (-> u32),
@@ -2,14 +2,21 @@ const builtin = @import("builtin");
2
2
  const std = @import("../../std.zig");
3
3
  const SYS = std.os.linux.SYS;
4
4
 
5
- pub fn syscall0(number: SYS) u64 {
5
+ pub const syscall_arg_t = u64;
6
+
7
+ pub fn syscall0(
8
+ number: SYS,
9
+ ) u64 {
6
10
  return asm volatile ("ecall"
7
11
  : [ret] "={x10}" (-> u64),
8
12
  : [number] "{x17}" (@intFromEnum(number)),
9
13
  : .{ .memory = true });
10
14
  }
11
15
 
12
- pub fn syscall1(number: SYS, arg1: u64) u64 {
16
+ pub fn syscall1(
17
+ number: SYS,
18
+ arg1: syscall_arg_t,
19
+ ) u64 {
13
20
  return asm volatile ("ecall"
14
21
  : [ret] "={x10}" (-> u64),
15
22
  : [number] "{x17}" (@intFromEnum(number)),
@@ -17,7 +24,11 @@ pub fn syscall1(number: SYS, arg1: u64) u64 {
17
24
  : .{ .memory = true });
18
25
  }
19
26
 
20
- pub fn syscall2(number: SYS, arg1: u64, arg2: u64) u64 {
27
+ pub fn syscall2(
28
+ number: SYS,
29
+ arg1: syscall_arg_t,
30
+ arg2: syscall_arg_t,
31
+ ) u64 {
21
32
  return asm volatile ("ecall"
22
33
  : [ret] "={x10}" (-> u64),
23
34
  : [number] "{x17}" (@intFromEnum(number)),
@@ -26,7 +37,12 @@ pub fn syscall2(number: SYS, arg1: u64, arg2: u64) u64 {
26
37
  : .{ .memory = true });
27
38
  }
28
39
 
29
- pub fn syscall3(number: SYS, arg1: u64, arg2: u64, arg3: u64) u64 {
40
+ pub fn syscall3(
41
+ number: SYS,
42
+ arg1: syscall_arg_t,
43
+ arg2: syscall_arg_t,
44
+ arg3: syscall_arg_t,
45
+ ) u64 {
30
46
  return asm volatile ("ecall"
31
47
  : [ret] "={x10}" (-> u64),
32
48
  : [number] "{x17}" (@intFromEnum(number)),
@@ -36,7 +52,13 @@ pub fn syscall3(number: SYS, arg1: u64, arg2: u64, arg3: u64) u64 {
36
52
  : .{ .memory = true });
37
53
  }
38
54
 
39
- pub fn syscall4(number: SYS, arg1: u64, arg2: u64, arg3: u64, arg4: u64) u64 {
55
+ pub fn syscall4(
56
+ number: SYS,
57
+ arg1: syscall_arg_t,
58
+ arg2: syscall_arg_t,
59
+ arg3: syscall_arg_t,
60
+ arg4: syscall_arg_t,
61
+ ) u64 {
40
62
  return asm volatile ("ecall"
41
63
  : [ret] "={x10}" (-> u64),
42
64
  : [number] "{x17}" (@intFromEnum(number)),
@@ -47,7 +69,14 @@ pub fn syscall4(number: SYS, arg1: u64, arg2: u64, arg3: u64, arg4: u64) u64 {
47
69
  : .{ .memory = true });
48
70
  }
49
71
 
50
- pub fn syscall5(number: SYS, arg1: u64, arg2: u64, arg3: u64, arg4: u64, arg5: u64) u64 {
72
+ pub fn syscall5(
73
+ number: SYS,
74
+ arg1: syscall_arg_t,
75
+ arg2: syscall_arg_t,
76
+ arg3: syscall_arg_t,
77
+ arg4: syscall_arg_t,
78
+ arg5: syscall_arg_t,
79
+ ) u64 {
51
80
  return asm volatile ("ecall"
52
81
  : [ret] "={x10}" (-> u64),
53
82
  : [number] "{x17}" (@intFromEnum(number)),
@@ -61,12 +90,12 @@ pub fn syscall5(number: SYS, arg1: u64, arg2: u64, arg3: u64, arg4: u64, arg5: u
61
90
 
62
91
  pub fn syscall6(
63
92
  number: SYS,
64
- arg1: u64,
65
- arg2: u64,
66
- arg3: u64,
67
- arg4: u64,
68
- arg5: u64,
69
- arg6: u64,
93
+ arg1: syscall_arg_t,
94
+ arg2: syscall_arg_t,
95
+ arg3: syscall_arg_t,
96
+ arg4: syscall_arg_t,
97
+ arg5: syscall_arg_t,
98
+ arg6: syscall_arg_t,
70
99
  ) u64 {
71
100
  return asm volatile ("ecall"
72
101
  : [ret] "={x10}" (-> u64),