syscall_arch.h 3.0 KB
Newer Older
R
Rich Felker 已提交
1 2 3 4 5
#define __SYSCALL_LL_E(x) \
((union { long long ll; long l[2]; }){ .ll = x }).l[0], \
((union { long long ll; long l[2]; }){ .ll = x }).l[1]
#define __SYSCALL_LL_O(x) 0, __SYSCALL_LL_E((x))

6 7 8 9 10 11 12 13 14 15 16 17 18 19
#ifdef __thumb__

/* Avoid use of r7 in asm constraints when producing thumb code,
 * since it's reserved as frame pointer and might not be supported. */
#define __ASM____R7__
#define __asm_syscall(...) do { \
	__asm__ __volatile__ ( "mov %1,r7 ; mov r7,%2 ; svc 0 ; mov r7,%1" \
	: "=r"(r0), "=&r"((int){0}) : __VA_ARGS__ : "memory"); \
	return r0; \
	} while (0)

#else

#define __ASM____R7__ __asm__("r7")
R
Rich Felker 已提交
20 21 22 23 24
#define __asm_syscall(...) do { \
	__asm__ __volatile__ ( "svc 0" \
	: "=r"(r0) : __VA_ARGS__ : "memory"); \
	return r0; \
	} while (0)
25 26 27 28 29 30 31 32 33 34 35
#endif

/* For thumb2, we can allow 8-bit immediate syscall numbers, saving a
 * register in the above dance around r7. Does not work for thumb1 where
 * only movs, not mov, supports immediates, and we can't use movs because
 * it doesn't support high regs. */
#ifdef __thumb2__
#define R7_OPERAND "rI"(r7)
#else
#define R7_OPERAND "r"(r7)
#endif
R
Rich Felker 已提交
36 37 38

static inline long __syscall0(long n)
{
39
	register long r7 __ASM____R7__ = n;
R
Rich Felker 已提交
40
	register long r0 __asm__("r0");
41
	__asm_syscall(R7_OPERAND);
R
Rich Felker 已提交
42 43 44 45
}

static inline long __syscall1(long n, long a)
{
46
	register long r7 __ASM____R7__ = n;
R
Rich Felker 已提交
47
	register long r0 __asm__("r0") = a;
48
	__asm_syscall(R7_OPERAND, "0"(r0));
R
Rich Felker 已提交
49 50 51 52
}

static inline long __syscall2(long n, long a, long b)
{
53
	register long r7 __ASM____R7__ = n;
R
Rich Felker 已提交
54 55
	register long r0 __asm__("r0") = a;
	register long r1 __asm__("r1") = b;
56
	__asm_syscall(R7_OPERAND, "0"(r0), "r"(r1));
R
Rich Felker 已提交
57 58 59 60
}

static inline long __syscall3(long n, long a, long b, long c)
{
61
	register long r7 __ASM____R7__ = n;
R
Rich Felker 已提交
62 63 64
	register long r0 __asm__("r0") = a;
	register long r1 __asm__("r1") = b;
	register long r2 __asm__("r2") = c;
65
	__asm_syscall(R7_OPERAND, "0"(r0), "r"(r1), "r"(r2));
R
Rich Felker 已提交
66 67 68 69
}

static inline long __syscall4(long n, long a, long b, long c, long d)
{
70
	register long r7 __ASM____R7__ = n;
R
Rich Felker 已提交
71 72 73 74
	register long r0 __asm__("r0") = a;
	register long r1 __asm__("r1") = b;
	register long r2 __asm__("r2") = c;
	register long r3 __asm__("r3") = d;
75
	__asm_syscall(R7_OPERAND, "0"(r0), "r"(r1), "r"(r2), "r"(r3));
R
Rich Felker 已提交
76 77
}

R
Rich Felker 已提交
78 79
static inline long __syscall5(long n, long a, long b, long c, long d, long e)
{
80
	register long r7 __ASM____R7__ = n;
81 82 83 84 85
	register long r0 __asm__("r0") = a;
	register long r1 __asm__("r1") = b;
	register long r2 __asm__("r2") = c;
	register long r3 __asm__("r3") = d;
	register long r4 __asm__("r4") = e;
86
	__asm_syscall(R7_OPERAND, "0"(r0), "r"(r1), "r"(r2), "r"(r3), "r"(r4));
R
Rich Felker 已提交
87 88 89 90
}

static inline long __syscall6(long n, long a, long b, long c, long d, long e, long f)
{
91
	register long r7 __ASM____R7__ = n;
92 93 94 95 96 97
	register long r0 __asm__("r0") = a;
	register long r1 __asm__("r1") = b;
	register long r2 __asm__("r2") = c;
	register long r3 __asm__("r3") = d;
	register long r4 __asm__("r4") = e;
	register long r5 __asm__("r5") = f;
98
	__asm_syscall(R7_OPERAND, "0"(r0), "r"(r1), "r"(r2), "r"(r3), "r"(r4), "r"(r5));
R
Rich Felker 已提交
99
}
S
Szabolcs Nagy 已提交
100

101
#define SYSCALL_FADVISE_6_ARG
102 103

#define SYSCALL_IPC_BROKEN_MODE