@zigc/lib 0.16.0 → 0.17.0-dev.39
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.
- package/c/fcntl.zig +1 -1
- package/c/math.zig +20 -7
- package/compiler/build_runner.zig +0 -2
- package/compiler/test_runner.zig +1 -1
- package/compiler_rt/divmodei4.zig +40 -17
- package/compiler_rt/exp.zig +1 -4
- package/compiler_rt/exp2.zig +1 -4
- package/compiler_rt/exp_f128.zig +377 -0
- package/compiler_rt/limb64.zig +875 -15
- package/compiler_rt/mulXi3.zig +1 -1
- package/compiler_rt/ssp.zig +1 -1
- package/compiler_rt/udivmodei4.zig +28 -0
- package/libc/musl/arch/mipsn32/syscall_arch.h +35 -32
- package/package.json +1 -1
- package/std/Build/Step/Compile.zig +0 -1
- package/std/Build.zig +0 -3
- package/std/Io/Threaded.zig +8 -8
- package/std/Io/Writer.zig +46 -42
- package/std/os/emscripten.zig +1 -1
- package/std/os/linux/aarch64.zig +41 -12
- package/std/os/linux/arc.zig +173 -0
- package/std/os/linux/arm.zig +41 -12
- package/std/os/linux/hexagon.zig +33 -11
- package/std/os/linux/loongarch32.zig +41 -13
- package/std/os/linux/loongarch64.zig +41 -12
- package/std/os/linux/m68k.zig +41 -13
- package/std/os/linux/mips.zig +67 -36
- package/std/os/linux/mips64.zig +60 -29
- package/std/os/linux/mipsn32.zig +60 -29
- package/std/os/linux/or1k.zig +41 -12
- package/std/os/linux/powerpc.zig +41 -12
- package/std/os/linux/powerpc64.zig +41 -12
- package/std/os/linux/riscv32.zig +41 -12
- package/std/os/linux/riscv64.zig +41 -12
- package/std/os/linux/s390x.zig +44 -7
- package/std/os/linux/sparc64.zig +83 -52
- package/std/os/linux/thumb.zig +52 -36
- package/std/os/linux/x32.zig +41 -12
- package/std/os/linux/x86.zig +42 -13
- package/std/os/linux/x86_64.zig +41 -12
- package/std/os/linux.zig +400 -434
- package/std/zig/AstGen.zig +1 -74
- package/std/zig/AstRlAnnotate.zig +0 -11
- package/std/zig/BuiltinFn.zig +0 -32
- package/std/zig/Zir.zig +50 -63
- package/std/zig.zig +0 -10
- package/libc/mingw/math/fdiml.c +0 -24
- package/libc/musl/src/math/fdimf.c +0 -10
- package/libc/musl/src/math/fdiml.c +0 -18
|
@@ -0,0 +1,173 @@
|
|
|
1
|
+
const builtin = @import("builtin");
|
|
2
|
+
const std = @import("../../std.zig");
|
|
3
|
+
const SYS = std.os.linux.SYS;
|
|
4
|
+
|
|
5
|
+
pub const syscall_arg_t = u32;
|
|
6
|
+
|
|
7
|
+
pub fn syscall0(
|
|
8
|
+
number: SYS,
|
|
9
|
+
) u32 {
|
|
10
|
+
return asm volatile ("trap_s 0"
|
|
11
|
+
: [ret] "={r0}" (-> u32),
|
|
12
|
+
: [number] "{r8}" (@intFromEnum(number)),
|
|
13
|
+
: .{ .memory = true });
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
pub fn syscall1(
|
|
17
|
+
number: SYS,
|
|
18
|
+
arg1: syscall_arg_t,
|
|
19
|
+
) u32 {
|
|
20
|
+
return asm volatile ("trap_s 0"
|
|
21
|
+
: [ret] "={r0}" (-> u32),
|
|
22
|
+
: [number] "{r8}" (@intFromEnum(number)),
|
|
23
|
+
[arg1] "{r0}" (arg1),
|
|
24
|
+
: .{ .memory = true });
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
pub fn syscall2(
|
|
28
|
+
number: SYS,
|
|
29
|
+
arg1: syscall_arg_t,
|
|
30
|
+
arg2: syscall_arg_t,
|
|
31
|
+
) u32 {
|
|
32
|
+
return asm volatile ("trap_s 0"
|
|
33
|
+
: [ret] "={r0}" (-> u32),
|
|
34
|
+
: [number] "{r8}" (@intFromEnum(number)),
|
|
35
|
+
[arg1] "{r0}" (arg1),
|
|
36
|
+
[arg2] "{r1}" (arg2),
|
|
37
|
+
: .{ .memory = true });
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
pub fn syscall3(
|
|
41
|
+
number: SYS,
|
|
42
|
+
arg1: syscall_arg_t,
|
|
43
|
+
arg2: syscall_arg_t,
|
|
44
|
+
arg3: syscall_arg_t,
|
|
45
|
+
) u32 {
|
|
46
|
+
return asm volatile ("trap_s 0"
|
|
47
|
+
: [ret] "={r0}" (-> u32),
|
|
48
|
+
: [number] "{r8}" (@intFromEnum(number)),
|
|
49
|
+
[arg1] "{r0}" (arg1),
|
|
50
|
+
[arg2] "{r1}" (arg2),
|
|
51
|
+
[arg3] "{r2}" (arg3),
|
|
52
|
+
: .{ .memory = true });
|
|
53
|
+
}
|
|
54
|
+
|
|
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 {
|
|
62
|
+
return asm volatile ("trap_s 0"
|
|
63
|
+
: [ret] "={r0}" (-> u32),
|
|
64
|
+
: [number] "{r8}" (@intFromEnum(number)),
|
|
65
|
+
[arg1] "{r0}" (arg1),
|
|
66
|
+
[arg2] "{r1}" (arg2),
|
|
67
|
+
[arg3] "{r2}" (arg3),
|
|
68
|
+
[arg4] "{r3}" (arg4),
|
|
69
|
+
: .{ .memory = true });
|
|
70
|
+
}
|
|
71
|
+
|
|
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 {
|
|
80
|
+
return asm volatile ("trap_s 0"
|
|
81
|
+
: [ret] "={r0}" (-> u32),
|
|
82
|
+
: [number] "{r8}" (@intFromEnum(number)),
|
|
83
|
+
[arg1] "{r0}" (arg1),
|
|
84
|
+
[arg2] "{r1}" (arg2),
|
|
85
|
+
[arg3] "{r2}" (arg3),
|
|
86
|
+
[arg4] "{r3}" (arg4),
|
|
87
|
+
[arg5] "{r4}" (arg5),
|
|
88
|
+
: .{ .memory = true });
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
pub fn syscall6(
|
|
92
|
+
number: SYS,
|
|
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,
|
|
99
|
+
) u32 {
|
|
100
|
+
return asm volatile ("trap_s 0"
|
|
101
|
+
: [ret] "={r0}" (-> u32),
|
|
102
|
+
: [number] "{r8}" (@intFromEnum(number)),
|
|
103
|
+
[arg1] "{r0}" (arg1),
|
|
104
|
+
[arg2] "{r1}" (arg2),
|
|
105
|
+
[arg3] "{r2}" (arg3),
|
|
106
|
+
[arg4] "{r3}" (arg4),
|
|
107
|
+
[arg5] "{r4}" (arg5),
|
|
108
|
+
[arg6] "{r5}" (arg6),
|
|
109
|
+
: .{ .memory = true });
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
pub fn clone() callconv(.naked) u32 {
|
|
113
|
+
// __clone(func, stack, flags, arg, ptid, tls, ctid)
|
|
114
|
+
// r0, r1, r2, r3, r4, r5, r6
|
|
115
|
+
//
|
|
116
|
+
// syscall(SYS_clone, flags, stack, ptid, tls, ctid)
|
|
117
|
+
// r8 r0, r1, r2, r3, r4
|
|
118
|
+
asm volatile (
|
|
119
|
+
\\ // Align stack pointer
|
|
120
|
+
\\ and r1, r1, -16
|
|
121
|
+
\\ mov r10, r0
|
|
122
|
+
\\ mov r11, r3
|
|
123
|
+
\\ // Setup the arguments
|
|
124
|
+
\\ mov r0, r2
|
|
125
|
+
\\ mov r2, r4
|
|
126
|
+
\\ mov r3, r5
|
|
127
|
+
\\ mov r4, r6
|
|
128
|
+
\\ mov r8, 220 // SYS_clone
|
|
129
|
+
\\ trap_s 0
|
|
130
|
+
\\ cmp r0, 0
|
|
131
|
+
\\ beq 1f
|
|
132
|
+
\\ j [blink]
|
|
133
|
+
\\ // Child
|
|
134
|
+
\\ 1:
|
|
135
|
+
);
|
|
136
|
+
if (builtin.unwind_tables != .none or !builtin.strip_debug_info) asm volatile (
|
|
137
|
+
\\ .cfi_undefined blink
|
|
138
|
+
);
|
|
139
|
+
|
|
140
|
+
asm volatile (
|
|
141
|
+
\\ mov fp, 0
|
|
142
|
+
\\ mov blink, 0
|
|
143
|
+
\\
|
|
144
|
+
\\ mov r0, r11
|
|
145
|
+
\\ jl [r10]
|
|
146
|
+
\\
|
|
147
|
+
\\ // Exit
|
|
148
|
+
\\ mov r8, 93 // SYS_exit
|
|
149
|
+
\\ trap_s 0
|
|
150
|
+
);
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
pub const restore = restore_rt;
|
|
154
|
+
|
|
155
|
+
pub fn restore_rt() callconv(.naked) noreturn {
|
|
156
|
+
switch (builtin.zig_backend) {
|
|
157
|
+
.stage2_c => asm volatile (
|
|
158
|
+
\\ mov r8, %[number]
|
|
159
|
+
\\ trap_s 0
|
|
160
|
+
:
|
|
161
|
+
: [number] "I" (@intFromEnum(SYS.rt_sigreturn)),
|
|
162
|
+
),
|
|
163
|
+
else => asm volatile (
|
|
164
|
+
\\ trap_s 0
|
|
165
|
+
:
|
|
166
|
+
: [number] "{r8}" (@intFromEnum(SYS.rt_sigreturn)),
|
|
167
|
+
),
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
pub const time_t = i64;
|
|
172
|
+
|
|
173
|
+
pub const VDSO = void;
|
package/std/os/linux/arm.zig
CHANGED
|
@@ -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
|
|
5
|
+
pub const syscall_arg_t = u32;
|
|
6
|
+
|
|
7
|
+
pub fn syscall0(
|
|
8
|
+
number: SYS,
|
|
9
|
+
) u32 {
|
|
6
10
|
return asm volatile ("svc #0"
|
|
7
11
|
: [ret] "={r0}" (-> u32),
|
|
8
12
|
: [number] "{r7}" (@intFromEnum(number)),
|
|
9
13
|
: .{ .memory = true });
|
|
10
14
|
}
|
|
11
15
|
|
|
12
|
-
pub fn syscall1(
|
|
16
|
+
pub fn syscall1(
|
|
17
|
+
number: SYS,
|
|
18
|
+
arg1: syscall_arg_t,
|
|
19
|
+
) u32 {
|
|
13
20
|
return asm volatile ("svc #0"
|
|
14
21
|
: [ret] "={r0}" (-> u32),
|
|
15
22
|
: [number] "{r7}" (@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(
|
|
27
|
+
pub fn syscall2(
|
|
28
|
+
number: SYS,
|
|
29
|
+
arg1: syscall_arg_t,
|
|
30
|
+
arg2: syscall_arg_t,
|
|
31
|
+
) u32 {
|
|
21
32
|
return asm volatile ("svc #0"
|
|
22
33
|
: [ret] "={r0}" (-> u32),
|
|
23
34
|
: [number] "{r7}" (@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(
|
|
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 ("svc #0"
|
|
31
47
|
: [ret] "={r0}" (-> u32),
|
|
32
48
|
: [number] "{r7}" (@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(
|
|
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 ("svc #0"
|
|
41
63
|
: [ret] "={r0}" (-> u32),
|
|
42
64
|
: [number] "{r7}" (@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(
|
|
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 ("svc #0"
|
|
52
81
|
: [ret] "={r0}" (-> u32),
|
|
53
82
|
: [number] "{r7}" (@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:
|
|
65
|
-
arg2:
|
|
66
|
-
arg3:
|
|
67
|
-
arg4:
|
|
68
|
-
arg5:
|
|
69
|
-
arg6:
|
|
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 ("svc #0"
|
|
72
101
|
: [ret] "={r0}" (-> u32),
|
package/std/os/linux/hexagon.zig
CHANGED
|
@@ -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
|
|
5
|
+
pub const syscall_arg_t = u32;
|
|
6
|
+
|
|
7
|
+
pub fn syscall0(
|
|
8
|
+
number: SYS,
|
|
9
|
+
) u32 {
|
|
6
10
|
return asm volatile ("trap0(#1)"
|
|
7
11
|
: [ret] "={r0}" (-> u32),
|
|
8
12
|
: [number] "{r6}" (@intFromEnum(number)),
|
|
9
13
|
: .{ .memory = true });
|
|
10
14
|
}
|
|
11
15
|
|
|
12
|
-
pub fn syscall1(
|
|
16
|
+
pub fn syscall1(
|
|
17
|
+
number: SYS,
|
|
18
|
+
arg1: syscall_arg_t,
|
|
19
|
+
) u32 {
|
|
13
20
|
return asm volatile ("trap0(#1)"
|
|
14
21
|
: [ret] "={r0}" (-> u32),
|
|
15
22
|
: [number] "{r6}" (@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(
|
|
27
|
+
pub fn syscall2(
|
|
28
|
+
number: SYS,
|
|
29
|
+
arg1: syscall_arg_t,
|
|
30
|
+
arg2: syscall_arg_t,
|
|
31
|
+
) u32 {
|
|
21
32
|
return asm volatile ("trap0(#1)"
|
|
22
33
|
: [ret] "={r0}" (-> u32),
|
|
23
34
|
: [number] "{r6}" (@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(
|
|
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 ("trap0(#1)"
|
|
31
47
|
: [ret] "={r0}" (-> u32),
|
|
32
48
|
: [number] "{r6}" (@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(
|
|
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 ("trap0(#1)"
|
|
41
63
|
: [ret] "={r0}" (-> u32),
|
|
42
64
|
: [number] "{r6}" (@intFromEnum(number)),
|
|
@@ -61,12 +83,12 @@ pub fn syscall5(number: SYS, arg1: u32, arg2: u32, arg3: u32, arg4: u32, arg5: u
|
|
|
61
83
|
|
|
62
84
|
pub fn syscall6(
|
|
63
85
|
number: SYS,
|
|
64
|
-
arg1:
|
|
65
|
-
arg2:
|
|
66
|
-
arg3:
|
|
67
|
-
arg4:
|
|
68
|
-
arg5:
|
|
69
|
-
arg6:
|
|
86
|
+
arg1: syscall_arg_t,
|
|
87
|
+
arg2: syscall_arg_t,
|
|
88
|
+
arg3: syscall_arg_t,
|
|
89
|
+
arg4: syscall_arg_t,
|
|
90
|
+
arg5: syscall_arg_t,
|
|
91
|
+
arg6: syscall_arg_t,
|
|
70
92
|
) u32 {
|
|
71
93
|
return asm volatile ("trap0(#1)"
|
|
72
94
|
: [ret] "={r0}" (-> u32),
|
|
@@ -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
|
|
5
|
+
pub const syscall_arg_t = u32;
|
|
6
|
+
|
|
7
|
+
pub fn syscall0(
|
|
8
|
+
number: SYS,
|
|
9
|
+
) u32 {
|
|
6
10
|
return asm volatile (
|
|
7
11
|
\\ syscall 0
|
|
8
12
|
: [ret] "={$r4}" (-> u32),
|
|
@@ -10,7 +14,10 @@ pub fn syscall0(number: SYS) u32 {
|
|
|
10
14
|
: .{ .r12 = true, .r13 = true, .r14 = true, .r15 = true, .r16 = true, .r17 = true, .r18 = true, .r19 = true, .r20 = true, .memory = true });
|
|
11
15
|
}
|
|
12
16
|
|
|
13
|
-
pub fn syscall1(
|
|
17
|
+
pub fn syscall1(
|
|
18
|
+
number: SYS,
|
|
19
|
+
arg1: syscall_arg_t,
|
|
20
|
+
) u32 {
|
|
14
21
|
return asm volatile (
|
|
15
22
|
\\ syscall 0
|
|
16
23
|
: [ret] "={$r4}" (-> u32),
|
|
@@ -19,7 +26,11 @@ pub fn syscall1(number: SYS, arg1: u32) u32 {
|
|
|
19
26
|
: .{ .r12 = true, .r13 = true, .r14 = true, .r15 = true, .r16 = true, .r17 = true, .r18 = true, .r19 = true, .r20 = true, .memory = true });
|
|
20
27
|
}
|
|
21
28
|
|
|
22
|
-
pub fn syscall2(
|
|
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
|
\\ syscall 0
|
|
25
36
|
: [ret] "={$r4}" (-> u32),
|
|
@@ -29,7 +40,12 @@ pub fn syscall2(number: SYS, arg1: u32, arg2: u32) u32 {
|
|
|
29
40
|
: .{ .r12 = true, .r13 = true, .r14 = true, .r15 = true, .r16 = true, .r17 = true, .r18 = true, .r19 = true, .r20 = true, .memory = true });
|
|
30
41
|
}
|
|
31
42
|
|
|
32
|
-
pub fn syscall3(
|
|
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
|
\\ syscall 0
|
|
35
51
|
: [ret] "={$r4}" (-> u32),
|
|
@@ -40,7 +56,13 @@ pub fn syscall3(number: SYS, arg1: u32, arg2: u32, arg3: u32) u32 {
|
|
|
40
56
|
: .{ .r12 = true, .r13 = true, .r14 = true, .r15 = true, .r16 = true, .r17 = true, .r18 = true, .r19 = true, .r20 = true, .memory = true });
|
|
41
57
|
}
|
|
42
58
|
|
|
43
|
-
pub fn syscall4(
|
|
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
|
\\ syscall 0
|
|
46
68
|
: [ret] "={$r4}" (-> u32),
|
|
@@ -52,7 +74,14 @@ pub fn syscall4(number: SYS, arg1: u32, arg2: u32, arg3: u32, arg4: u32) u32 {
|
|
|
52
74
|
: .{ .r12 = true, .r13 = true, .r14 = true, .r15 = true, .r16 = true, .r17 = true, .r18 = true, .r19 = true, .r20 = true, .memory = true });
|
|
53
75
|
}
|
|
54
76
|
|
|
55
|
-
pub fn syscall5(
|
|
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
|
\\ syscall 0
|
|
58
87
|
: [ret] "={$r4}" (-> 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:
|
|
71
|
-
arg2:
|
|
72
|
-
arg3:
|
|
73
|
-
arg4:
|
|
74
|
-
arg5:
|
|
75
|
-
arg6:
|
|
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
|
\\ syscall 0
|
|
@@ -87,7 +116,6 @@ pub fn syscall6(
|
|
|
87
116
|
: .{ .r12 = true, .r13 = true, .r14 = true, .r15 = true, .r16 = true, .r17 = true, .r18 = true, .r19 = true, .r20 = true, .memory = true });
|
|
88
117
|
}
|
|
89
118
|
|
|
90
|
-
// FIXME
|
|
91
119
|
pub fn clone() callconv(.naked) u32 {
|
|
92
120
|
// __clone(func, stack, flags, arg, ptid, tls, ctid)
|
|
93
121
|
// 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
|
|
5
|
+
pub const syscall_arg_t = u64;
|
|
6
|
+
|
|
7
|
+
pub fn syscall0(
|
|
8
|
+
number: SYS,
|
|
9
|
+
) u64 {
|
|
6
10
|
return asm volatile (
|
|
7
11
|
\\ syscall 0
|
|
8
12
|
: [ret] "={$r4}" (-> u64),
|
|
@@ -10,7 +14,10 @@ pub fn syscall0(number: SYS) u64 {
|
|
|
10
14
|
: .{ .r12 = true, .r13 = true, .r14 = true, .r15 = true, .r16 = true, .r17 = true, .r18 = true, .r19 = true, .r20 = true, .memory = true });
|
|
11
15
|
}
|
|
12
16
|
|
|
13
|
-
pub fn syscall1(
|
|
17
|
+
pub fn syscall1(
|
|
18
|
+
number: SYS,
|
|
19
|
+
arg1: syscall_arg_t,
|
|
20
|
+
) u64 {
|
|
14
21
|
return asm volatile (
|
|
15
22
|
\\ syscall 0
|
|
16
23
|
: [ret] "={$r4}" (-> u64),
|
|
@@ -19,7 +26,11 @@ pub fn syscall1(number: SYS, arg1: u64) u64 {
|
|
|
19
26
|
: .{ .r12 = true, .r13 = true, .r14 = true, .r15 = true, .r16 = true, .r17 = true, .r18 = true, .r19 = true, .r20 = true, .memory = true });
|
|
20
27
|
}
|
|
21
28
|
|
|
22
|
-
pub fn syscall2(
|
|
29
|
+
pub fn syscall2(
|
|
30
|
+
number: SYS,
|
|
31
|
+
arg1: syscall_arg_t,
|
|
32
|
+
arg2: syscall_arg_t,
|
|
33
|
+
) u64 {
|
|
23
34
|
return asm volatile (
|
|
24
35
|
\\ syscall 0
|
|
25
36
|
: [ret] "={$r4}" (-> u64),
|
|
@@ -29,7 +40,12 @@ pub fn syscall2(number: SYS, arg1: u64, arg2: u64) u64 {
|
|
|
29
40
|
: .{ .r12 = true, .r13 = true, .r14 = true, .r15 = true, .r16 = true, .r17 = true, .r18 = true, .r19 = true, .r20 = true, .memory = true });
|
|
30
41
|
}
|
|
31
42
|
|
|
32
|
-
pub fn syscall3(
|
|
43
|
+
pub fn syscall3(
|
|
44
|
+
number: SYS,
|
|
45
|
+
arg1: syscall_arg_t,
|
|
46
|
+
arg2: syscall_arg_t,
|
|
47
|
+
arg3: syscall_arg_t,
|
|
48
|
+
) u64 {
|
|
33
49
|
return asm volatile (
|
|
34
50
|
\\ syscall 0
|
|
35
51
|
: [ret] "={$r4}" (-> u64),
|
|
@@ -40,7 +56,13 @@ pub fn syscall3(number: SYS, arg1: u64, arg2: u64, arg3: u64) u64 {
|
|
|
40
56
|
: .{ .r12 = true, .r13 = true, .r14 = true, .r15 = true, .r16 = true, .r17 = true, .r18 = true, .r19 = true, .r20 = true, .memory = true });
|
|
41
57
|
}
|
|
42
58
|
|
|
43
|
-
pub fn syscall4(
|
|
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
|
+
) u64 {
|
|
44
66
|
return asm volatile (
|
|
45
67
|
\\ syscall 0
|
|
46
68
|
: [ret] "={$r4}" (-> u64),
|
|
@@ -52,7 +74,14 @@ pub fn syscall4(number: SYS, arg1: u64, arg2: u64, arg3: u64, arg4: u64) u64 {
|
|
|
52
74
|
: .{ .r12 = true, .r13 = true, .r14 = true, .r15 = true, .r16 = true, .r17 = true, .r18 = true, .r19 = true, .r20 = true, .memory = true });
|
|
53
75
|
}
|
|
54
76
|
|
|
55
|
-
pub fn syscall5(
|
|
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
|
+
) u64 {
|
|
56
85
|
return asm volatile (
|
|
57
86
|
\\ syscall 0
|
|
58
87
|
: [ret] "={$r4}" (-> u64),
|
|
@@ -67,12 +96,12 @@ pub fn syscall5(number: SYS, arg1: u64, arg2: u64, arg3: u64, arg4: u64, arg5: u
|
|
|
67
96
|
|
|
68
97
|
pub fn syscall6(
|
|
69
98
|
number: SYS,
|
|
70
|
-
arg1:
|
|
71
|
-
arg2:
|
|
72
|
-
arg3:
|
|
73
|
-
arg4:
|
|
74
|
-
arg5:
|
|
75
|
-
arg6:
|
|
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
|
) u64 {
|
|
77
106
|
return asm volatile (
|
|
78
107
|
\\ syscall 0
|
package/std/os/linux/m68k.zig
CHANGED
|
@@ -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
|
|
5
|
+
pub const syscall_arg_t = u32;
|
|
6
|
+
|
|
7
|
+
pub fn syscall0(
|
|
8
|
+
number: SYS,
|
|
9
|
+
) u32 {
|
|
6
10
|
return asm volatile ("trap #0"
|
|
7
11
|
: [ret] "={d0}" (-> u32),
|
|
8
12
|
: [number] "{d0}" (@intFromEnum(number)),
|
|
9
13
|
: .{ .memory = true });
|
|
10
14
|
}
|
|
11
15
|
|
|
12
|
-
pub fn syscall1(
|
|
16
|
+
pub fn syscall1(
|
|
17
|
+
number: SYS,
|
|
18
|
+
arg1: syscall_arg_t,
|
|
19
|
+
) u32 {
|
|
13
20
|
return asm volatile ("trap #0"
|
|
14
21
|
: [ret] "={d0}" (-> u32),
|
|
15
22
|
: [number] "{d0}" (@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(
|
|
27
|
+
pub fn syscall2(
|
|
28
|
+
number: SYS,
|
|
29
|
+
arg1: syscall_arg_t,
|
|
30
|
+
arg2: syscall_arg_t,
|
|
31
|
+
) u32 {
|
|
21
32
|
return asm volatile ("trap #0"
|
|
22
33
|
: [ret] "={d0}" (-> u32),
|
|
23
34
|
: [number] "{d0}" (@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(
|
|
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 ("trap #0"
|
|
31
47
|
: [ret] "={d0}" (-> u32),
|
|
32
48
|
: [number] "{d0}" (@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(
|
|
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 ("trap #0"
|
|
41
63
|
: [ret] "={d0}" (-> u32),
|
|
42
64
|
: [number] "{d0}" (@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(
|
|
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 ("trap #0"
|
|
52
81
|
: [ret] "={d0}" (-> u32),
|
|
53
82
|
: [number] "{d0}" (@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:
|
|
65
|
-
arg2:
|
|
66
|
-
arg3:
|
|
67
|
-
arg4:
|
|
68
|
-
arg5:
|
|
69
|
-
arg6:
|
|
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 ("trap #0"
|
|
72
101
|
: [ret] "={d0}" (-> u32),
|
|
@@ -144,5 +173,4 @@ pub fn restore_rt() callconv(.naked) noreturn {
|
|
|
144
173
|
|
|
145
174
|
pub const time_t = i32;
|
|
146
175
|
|
|
147
|
-
// No VDSO used as of glibc 112a0ae18b831bf31f44d81b82666980312511d6.
|
|
148
176
|
pub const VDSO = void;
|