source: asp3_tinet_ecnl_rx/trunk/musl-1.1.18/arch/rx/syscall_arch.h@ 342

Last change on this file since 342 was 342, checked in by coas-nagasima, 6 years ago

syscallが関数呼びになるよう変更
他更新

  • Property svn:eol-style set to native
  • Property svn:mime-type set to text/x-chdr;charset=UTF-8
File size: 3.0 KB
Line 
1#define __SYSCALL_LL_E(x) \
2((union { long long ll; long l[2]; }){ .ll = x }).l[0], \
3((union { long long ll; long l[2]; }){ .ll = x }).l[1]
4#define __SYSCALL_LL_O(x) __SYSCALL_LL_E((x))
5#define __SYSCALL_LL_PRW(x) 0, __SYSCALL_LL_E((x))
6
7#if 0
8#define __asm_syscall(...) do { \
9 __asm__ __volatile__ ( \
10 "int #08\n" \
11 : "=r"(r0) : __VA_ARGS__ : "memory"); \
12 return r0; \
13 } while (0)
14
15static inline long __syscall0(long n)
16{
17 register long r3 __asm__("r3") = n;
18 register long r0 __asm__("r0");
19 __asm_syscall("r"(r3));
20}
21
22static inline long __syscall1(long n, long a)
23{
24 register long r3 __asm__("r3") = n;
25 register long r4 __asm__("r4") = a;
26 register long r0 __asm__("r0");
27 __asm_syscall("r"(r3), "r"(r4));
28}
29
30static inline long __syscall2(long n, long a, long b)
31{
32 register long r3 __asm__("r3") = n;
33 register long r4 __asm__("r4") = a;
34 register long r5 __asm__("r5") = b;
35 register long r0 __asm__("r0");
36 __asm_syscall("r"(r3), "r"(r4), "r"(r5));
37}
38
39static inline long __syscall3(long n, long a, long b, long c)
40{
41 register long r3 __asm__("r3") = n;
42 register long r4 __asm__("r4") = a;
43 register long r5 __asm__("r5") = b;
44 register long r6 __asm__("r6") = c;
45 register long r0 __asm__("r0");
46 __asm_syscall("r"(r3), "r"(r4), "r"(r5), "r"(r6));
47}
48
49static inline long __syscall4(long n, long a, long b, long c, long d)
50{
51 register long r3 __asm__("r3") = n;
52 register long r4 __asm__("r4") = a;
53 register long r5 __asm__("r5") = b;
54 register long r6 __asm__("r6") = c;
55 register long r7 __asm__("r7") = d;
56 register long r0 __asm__("r0");
57 __asm_syscall("r"(r3), "r"(r4), "r"(r5), "r"(r6), "r"(r7));
58}
59
60static inline long __syscall5(long n, long a, long b, long c, long d, long e)
61{
62 register long r3 __asm__("r3") = n;
63 register long r4 __asm__("r4") = a;
64 register long r5 __asm__("r5") = b;
65 register long r6 __asm__("r6") = c;
66 register long r7 __asm__("r7") = d;
67 register long r0 __asm__("r0") = e;
68 __asm_syscall("r"(r3), "r"(r4), "r"(r5), "r"(r6), "r"(r7), "0"(r0));
69}
70
71static inline long __syscall6(long n, long a, long b, long c, long d, long e, long f)
72{
73 register long r3 __asm__("r3") = n;
74 register long r4 __asm__("r4") = a;
75 register long r5 __asm__("r5") = b;
76 register long r6 __asm__("r6") = c;
77 register long r7 __asm__("r7") = d;
78 register long r0 __asm__("r0") = e;
79 register long r1 __asm__("r1") = f;
80 __asm_syscall("r"(r3), "r"(r4), "r"(r5), "r"(r6), "r"(r7), "0"(r0), "r"(r1));
81}
82#else
83#define __scc(X) ((long) (X))
84typedef long syscall_arg_t;
85
86__attribute__((visibility("hidden")))
87long __syscall_ret(unsigned long), __syscall_nr(long nr, ...);
88
89#define __syscall(n, ...) n(__VA_ARGS__)
90#define __syscall_cp(n, ...) n(__VA_ARGS__)
91#define syscall(n, ...) __syscall_ret(__syscall(n, __VA_ARGS__))
92#define syscall_cp(n, ...) __syscall_ret(__syscall_cp(n, __VA_ARGS__))
93
94#define __syscall2(n, ...) n(__VA_ARGS__)
95#define __syscall3(n, ...) n(__VA_ARGS__)
96#define __syscall_cp2(n, ...) n(__VA_ARGS__)
97#define __syscall_cp3(n, ...) n(__VA_ARGS__)
98#endif
Note: See TracBrowser for help on using the repository browser.