/* * Raw syscalls. * * Copyright (c) 2018-2021 The strace developers. * All rights reserved. * * SPDX-License-Identifier: LGPL-2.1-or-later */ #ifndef STRACE_RAW_SYSCALL_H # define STRACE_RAW_SYSCALL_H # include "kernel_types.h" static inline kernel_ulong_t raw_syscall_0(const kernel_ulong_t nr, kernel_ulong_t *err) { *err = 0; register kernel_ulong_t r3 __asm__("%r3") = nr; register kernel_ulong_t r0 __asm__("%r0"); __asm__ __volatile__("trapa #0x10\n\t" "or r0,r0\n\t" "or r0,r0\n\t" "or r0,r0\n\t" "or r0,r0\n\t" "or r0,r0\n\t" : "=r"(r0) : "r"(r3) : "memory", "t"); return r0; } # define raw_syscall_0 raw_syscall_0 #endif /* !STRACE_RAW_SYSCALL_H */