use core::arch::asm;
pub type SyscallWord = u64;
#[inline(always)]
pub unsafe fn syscall0(n: SyscallWord) -> SyscallWord {
let mut ret: SyscallWord;
unsafe {
asm!(
"svc 0",
out("r2") ret,
in("r1") n,
);
}
ret
}
#[inline(always)]
pub unsafe fn syscall1(n: SyscallWord, arg1: SyscallWord) -> SyscallWord {
let mut ret: SyscallWord;
unsafe {
asm!(
"svc 0",
lateout("r2") ret,
in("r1") n,
in("r2") arg1,
);
}
ret
}
#[inline(always)]
pub unsafe fn syscall2(
n: SyscallWord,
arg1: SyscallWord,
arg2: SyscallWord,
) -> SyscallWord {
let mut ret: SyscallWord;
unsafe {
asm!(
"svc 0",
lateout("r2") ret,
in("r1") n,
in("r2") arg1,
in("r3") arg2,
);
}
ret
}
#[inline(always)]
pub unsafe fn syscall3(
n: SyscallWord,
arg1: SyscallWord,
arg2: SyscallWord,
arg3: SyscallWord,
) -> SyscallWord {
let mut ret: SyscallWord;
unsafe {
asm!(
"svc 0",
lateout("r2") ret,
in("r1") n,
in("r2") arg1,
in("r3") arg2,
in("r4") arg3,
);
}
ret
}
#[inline(always)]
pub unsafe fn syscall4(
n: SyscallWord,
arg1: SyscallWord,
arg2: SyscallWord,
arg3: SyscallWord,
arg4: SyscallWord,
) -> SyscallWord {
let mut ret: SyscallWord;
unsafe {
asm!(
"svc 0",
lateout("r2") ret,
in("r1") n,
in("r2") arg1,
in("r3") arg2,
in("r4") arg3,
in("r5") arg4,
);
}
ret
}
#[inline(always)]
pub unsafe fn syscall5(
n: SyscallWord,
arg1: SyscallWord,
arg2: SyscallWord,
arg3: SyscallWord,
arg4: SyscallWord,
arg5: SyscallWord,
) -> SyscallWord {
let mut ret: SyscallWord;
unsafe {
asm!(
"svc 0",
lateout("r2") ret,
in("r1") n,
in("r2") arg1,
in("r3") arg2,
in("r4") arg3,
in("r5") arg4,
in("r6") arg5,
);
}
ret
}
#[inline(always)]
pub unsafe fn syscall6(
n: SyscallWord,
arg1: SyscallWord,
arg2: SyscallWord,
arg3: SyscallWord,
arg4: SyscallWord,
arg5: SyscallWord,
arg6: SyscallWord,
) -> SyscallWord {
let mut ret: SyscallWord;
unsafe {
asm!(
"svc 0",
lateout("r2") ret,
in("r1") n,
in("r2") arg1,
in("r3") arg2,
in("r4") arg3,
in("r5") arg4,
in("r6") arg5,
in("r7") arg6,
);
}
ret
}