* include/bits/allocator.h (operator==, operator!=): Add exception
[official-gcc.git] / libsanitizer / sanitizer_common / sanitizer_syscall_linux_x86_64.inc
blob8810c7faa4bf07a70acb303751a0a3053917700b
1 //===-- sanitizer_syscall_linux_x86_64.inc ----------------------*- C++ -*-===//
2 //
3 // This file is distributed under the University of Illinois Open Source
4 // License. See LICENSE.TXT for details.
5 //
6 //===----------------------------------------------------------------------===//
7 //
8 // Implementations of internal_syscall and internal_iserror for Linux/x86_64.
9 //
10 //===----------------------------------------------------------------------===//
12 static uptr internal_syscall(u64 nr) {
13   u64 retval;
14   asm volatile("syscall" : "=a"(retval) : "a"(nr) : "rcx", "r11",
15                "memory", "cc");
16   return retval;
19 template <typename T1>
20 static uptr internal_syscall(u64 nr, T1 arg1) {
21   u64 retval;
22   asm volatile("syscall" : "=a"(retval) : "a"(nr), "D"((u64)arg1) :
23                "rcx", "r11", "memory", "cc");
24   return retval;
27 template <typename T1, typename T2>
28 static uptr internal_syscall(u64 nr, T1 arg1, T2 arg2) {
29   u64 retval;
30   asm volatile("syscall" : "=a"(retval) : "a"(nr), "D"((u64)arg1),
31                "S"((u64)arg2) : "rcx", "r11", "memory", "cc");
32   return retval;
35 template <typename T1, typename T2, typename T3>
36 static uptr internal_syscall(u64 nr, T1 arg1, T2 arg2, T3 arg3) {
37   u64 retval;
38   asm volatile("syscall" : "=a"(retval) : "a"(nr), "D"((u64)arg1),
39                "S"((u64)arg2), "d"((u64)arg3) : "rcx", "r11", "memory", "cc");
40   return retval;
43 template <typename T1, typename T2, typename T3, typename T4>
44 static uptr internal_syscall(u64 nr, T1 arg1, T2 arg2, T3 arg3, T4 arg4) {
45   u64 retval;
46   asm volatile("mov %5, %%r10;"
47                "syscall" : "=a"(retval) : "a"(nr), "D"((u64)arg1),
48                "S"((u64)arg2), "d"((u64)arg3), "r"((u64)arg4) :
49                "rcx", "r11", "r10", "memory", "cc");
50   return retval;
53 template <typename T1, typename T2, typename T3, typename T4, typename T5>
54 static uptr internal_syscall(u64 nr, T1 arg1, T2 arg2, T3 arg3, T4 arg4,
55                              T5 arg5) {
56   u64 retval;
57   asm volatile("mov %5, %%r10;"
58                "mov %6, %%r8;"
59                "syscall" : "=a"(retval) : "a"(nr), "D"((u64)arg1),
60                "S"((u64)arg2), "d"((u64)arg3), "r"((u64)arg4), "r"((u64)arg5) :
61                "rcx", "r11", "r10", "r8", "memory", "cc");
62   return retval;
65 template <typename T1, typename T2, typename T3, typename T4, typename T5,
66           typename T6>
67 static uptr internal_syscall(u64 nr, T1 arg1, T2 arg2, T3 arg3, T4 arg4,
68                              T5 arg5, T6 arg6) {
69   u64 retval;
70   asm volatile("mov %5, %%r10;"
71                "mov %6, %%r8;"
72                "mov %7, %%r9;"
73                "syscall" : "=a"(retval) : "a"(nr), "D"((u64)arg1),
74                "S"((u64)arg2), "d"((u64)arg3), "r"((u64)arg4), "r"((u64)arg5),
75                "r"((u64)arg6) : "rcx", "r11", "r10", "r8", "r9",
76                "memory", "cc");
77   return retval;
80 bool internal_iserror(uptr retval, int *rverrno) {
81   if (retval >= (uptr)-4095) {
82     if (rverrno)
83       *rverrno = -retval;
84     return true;
85   }
86   return false;