usingnamespace @import("../bits.zig"); pub fn syscall0(number: usize) usize { return asm volatile ("svc #0" : [ret] "={r0}" (-> usize) : [number] "{r7}" (number) : "memory" ); } pub fn syscall1(number: usize, arg1: usize) usize { return asm volatile ("svc #0" : [ret] "={r0}" (-> usize) : [number] "{r7}" (number), [arg1] "{r0}" (arg1) : "memory" ); } pub fn syscall2(number: usize, arg1: usize, arg2: usize) usize { return asm volatile ("svc #0" : [ret] "={r0}" (-> usize) : [number] "{r7}" (number), [arg1] "{r0}" (arg1), [arg2] "{r1}" (arg2) : "memory" ); } pub fn syscall3(number: usize, arg1: usize, arg2: usize, arg3: usize) usize { return asm volatile ("svc #0" : [ret] "={r0}" (-> usize) : [number] "{r7}" (number), [arg1] "{r0}" (arg1), [arg2] "{r1}" (arg2), [arg3] "{r2}" (arg3) : "memory" ); } pub fn syscall4(number: usize, arg1: usize, arg2: usize, arg3: usize, arg4: usize) usize { return asm volatile ("svc #0" : [ret] "={r0}" (-> usize) : [number] "{r7}" (number), [arg1] "{r0}" (arg1), [arg2] "{r1}" (arg2), [arg3] "{r2}" (arg3), [arg4] "{r3}" (arg4) : "memory" ); } pub fn syscall5(number: usize, arg1: usize, arg2: usize, arg3: usize, arg4: usize, arg5: usize) usize { return asm volatile ("svc #0" : [ret] "={r0}" (-> usize) : [number] "{r7}" (number), [arg1] "{r0}" (arg1), [arg2] "{r1}" (arg2), [arg3] "{r2}" (arg3), [arg4] "{r3}" (arg4), [arg5] "{r4}" (arg5) : "memory" ); } pub fn syscall6( number: usize, arg1: usize, arg2: usize, arg3: usize, arg4: usize, arg5: usize, arg6: usize, ) usize { return asm volatile ("svc #0" : [ret] "={r0}" (-> usize) : [number] "{r7}" (number), [arg1] "{r0}" (arg1), [arg2] "{r1}" (arg2), [arg3] "{r2}" (arg3), [arg4] "{r3}" (arg4), [arg5] "{r4}" (arg5), [arg6] "{r5}" (arg6) : "memory" ); } /// This matches the libc clone function. pub extern fn clone(func: extern fn (arg: usize) u8, stack: usize, flags: u32, arg: usize, ptid: *i32, tls: usize, ctid: *i32) usize; // LLVM calls this when the read-tp-hard feature is set to false. Currently, there is no way to pass // that to llvm via zig, see https://github.com/ziglang/zig/issues/2883. // LLVM expects libc to provide this function as __aeabi_read_tp, so it is exported if needed from special/c.zig. pub extern fn getThreadPointer() usize { return asm volatile ("mrc p15, 0, %[ret], c13, c0, 3" : [ret] "=r" (-> usize) ); } pub nakedcc fn restore() void { return asm volatile ("svc #0" : : [number] "{r7}" (usize(SYS_sigreturn)) : "memory" ); } pub nakedcc fn restore_rt() void { return asm volatile ("svc #0" : : [number] "{r7}" (usize(SYS_rt_sigreturn)) : "memory" ); }