sanitizer_syscall_linux_x86_64.inc revision 0c8af33262be025def2108352f9a720d9559ffdb
1//===-- sanitizer_syscall_linux_x86_64.inc ----------------------*- C++ -*-===// 2// 3// The LLVM Compiler Infrastructure 4// 5// This file is distributed under the University of Illinois Open Source 6// License. See LICENSE.TXT for details. 7// 8//===----------------------------------------------------------------------===// 9// 10// Implementations of internal_syscall and internal_iserror for Linux/x86_64. 11// 12//===----------------------------------------------------------------------===// 13 14static uptr internal_syscall(u64 nr) { 15 u64 retval; 16 asm volatile("syscall" : "=a"(retval) : "a"(nr) : "rcx", "r11", 17 "memory", "cc"); 18 return retval; 19} 20 21template <typename T1> 22static uptr internal_syscall(u64 nr, T1 arg1) { 23 u64 retval; 24 asm volatile("syscall" : "=a"(retval) : "a"(nr), "D"((u64)arg1) : 25 "rcx", "r11", "memory", "cc"); 26 return retval; 27} 28 29template <typename T1, typename T2> 30static uptr internal_syscall(u64 nr, T1 arg1, T2 arg2) { 31 u64 retval; 32 asm volatile("syscall" : "=a"(retval) : "a"(nr), "D"((u64)arg1), 33 "S"((u64)arg2) : "rcx", "r11", "memory", "cc"); 34 return retval; 35} 36 37template <typename T1, typename T2, typename T3> 38static uptr internal_syscall(u64 nr, T1 arg1, T2 arg2, T3 arg3) { 39 u64 retval; 40 asm volatile("syscall" : "=a"(retval) : "a"(nr), "D"((u64)arg1), 41 "S"((u64)arg2), "d"((u64)arg3) : "rcx", "r11", "memory", "cc"); 42 return retval; 43} 44 45template <typename T1, typename T2, typename T3, typename T4> 46static uptr internal_syscall(u64 nr, T1 arg1, T2 arg2, T3 arg3, T4 arg4) { 47 u64 retval; 48 asm volatile("mov %5, %%r10;" 49 "syscall" : "=a"(retval) : "a"(nr), "D"((u64)arg1), 50 "S"((u64)arg2), "d"((u64)arg3), "r"((u64)arg4) : 51 "rcx", "r11", "r10", "memory", "cc"); 52 return retval; 53} 54 55template <typename T1, typename T2, typename T3, typename T4, typename T5> 56static uptr internal_syscall(u64 nr, T1 arg1, T2 arg2, T3 arg3, T4 arg4, 57 T5 arg5) { 58 u64 retval; 59 asm volatile("mov %5, %%r10;" 60 "mov %6, %%r8;" 61 "syscall" : "=a"(retval) : "a"(nr), "D"((u64)arg1), 62 "S"((u64)arg2), "d"((u64)arg3), "r"((u64)arg4), "r"((u64)arg5) : 63 "rcx", "r11", "r10", "r8", "memory", "cc"); 64 return retval; 65} 66 67template <typename T1, typename T2, typename T3, typename T4, typename T5, 68 typename T6> 69static uptr internal_syscall(u64 nr, T1 arg1, T2 arg2, T3 arg3, T4 arg4, 70 T5 arg5, T6 arg6) { 71 u64 retval; 72 asm volatile("mov %5, %%r10;" 73 "mov %6, %%r8;" 74 "mov %7, %%r9;" 75 "syscall" : "=a"(retval) : "a"(nr), "D"((u64)arg1), 76 "S"((u64)arg2), "d"((u64)arg3), "r"((u64)arg4), "r"((u64)arg5), 77 "r"((u64)arg6) : "rcx", "r11", "r10", "r8", "r9", 78 "memory", "cc"); 79 return retval; 80} 81 82bool internal_iserror(uptr retval, int *rverrno) { 83 if (retval >= (uptr)-4095) { 84 if (rverrno) 85 *rverrno = -retval; 86 return true; 87 } 88 return false; 89} 90