1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
pub mod nr;
#[inline(always)]
pub unsafe fn syscall0(mut n: usize) -> usize {
llvm_asm!("syscall"
: "+{rax}"(n)
:
: "rcx", "r11", "memory"
: "volatile");
n
}
#[inline(always)]
pub unsafe fn syscall1(mut n: usize, a1: usize) -> usize {
llvm_asm!("syscall"
: "+{rax}"(n)
: "{rdi}"(a1)
: "rcx", "r11", "memory"
: "volatile");
n
}
#[inline(always)]
pub unsafe fn syscall2(mut n: usize, a1: usize, a2: usize) -> usize {
llvm_asm!("syscall"
: "+{rax}"(n)
: "{rdi}"(a1) "{rsi}"(a2)
: "rcx", "r11", "memory"
: "volatile");
n
}
#[inline(always)]
pub unsafe fn syscall3(mut n: usize, a1: usize, a2: usize, a3: usize) -> usize {
llvm_asm!("syscall"
: "+{rax}"(n)
: "{rdi}"(a1) "{rsi}"(a2) "{rdx}"(a3)
: "rcx", "r11", "memory"
: "volatile");
n
}
#[inline(always)]
pub unsafe fn syscall4(mut n: usize,
a1: usize,
a2: usize,
a3: usize,
a4: usize)
-> usize {
llvm_asm!("syscall"
: "+{rax}"(n)
: "{rdi}"(a1) "{rsi}"(a2) "{rdx}"(a3) "{r10}"(a4)
: "rcx", "r11", "memory"
: "volatile");
n
}
#[inline(always)]
pub unsafe fn syscall5(mut n: usize,
a1: usize,
a2: usize,
a3: usize,
a4: usize,
a5: usize)
-> usize {
llvm_asm!("syscall"
: "+{rax}"(n)
: "{rdi}"(a1) "{rsi}"(a2) "{rdx}"(a3) "{r10}"(a4) "{r8}"(a5)
: "rcx", "r11", "memory"
: "volatile");
n
}
#[inline(always)]
pub unsafe fn syscall6(mut n: usize,
a1: usize,
a2: usize,
a3: usize,
a4: usize,
a5: usize,
a6: usize)
-> usize {
llvm_asm!("syscall"
: "+{rax}"(n)
: "{rdi}"(a1) "{rsi}"(a2) "{rdx}"(a3) "{r10}"(a4) "{r8}"(a5)"{r9}"(a6)
: "rcx", "r11", "memory"
: "volatile");
n
}