make oldconfig will rebuild these...
[linux-2.4.21-pre4.git] / include / asm-mips64 / unistd.h
1 /*
2  * This file is subject to the terms and conditions of the GNU General Public
3  * License.  See the file "COPYING" in the main directory of this archive
4  * for more details.
5  *
6  * Copyright (C) 1995, 96, 97, 98, 99, 2000 by Ralf Baechle
7  * Copyright (C) 1999, 2000 Silicon Graphics, Inc.
8  *
9  * Changed system calls macros _syscall5 - _syscall7 to push args 5 to 7 onto
10  * the stack. Robin Farine for ACN S.A, Copyright (C) 1996 by ACN S.A
11  */
12 #ifndef _ASM_UNISTD_H
13 #define _ASM_UNISTD_H
14
15 /*
16  * Linux o32 style syscalls are in the range from 4000 to 4999.
17  */
18 #define __NR_Linux32                    4000
19 #define __NR_Linux32_syscall            (__NR_Linux32 +   0)
20 #define __NR_Linux32_exit               (__NR_Linux32 +   1)
21 #define __NR_Linux32_fork               (__NR_Linux32 +   2)
22 #define __NR_Linux32_read               (__NR_Linux32 +   3)
23 #define __NR_Linux32_write              (__NR_Linux32 +   4)
24 #define __NR_Linux32_open               (__NR_Linux32 +   5)
25 #define __NR_Linux32_close              (__NR_Linux32 +   6)
26 #define __NR_Linux32_waitpid            (__NR_Linux32 +   7)
27 #define __NR_Linux32_creat              (__NR_Linux32 +   8)
28 #define __NR_Linux32_link               (__NR_Linux32 +   9)
29 #define __NR_Linux32_unlink             (__NR_Linux32 +  10)
30 #define __NR_Linux32_execve             (__NR_Linux32 +  11)
31 #define __NR_Linux32_chdir              (__NR_Linux32 +  12)
32 #define __NR_Linux32_time               (__NR_Linux32 +  13)
33 #define __NR_Linux32_mknod              (__NR_Linux32 +  14)
34 #define __NR_Linux32_chmod              (__NR_Linux32 +  15)
35 #define __NR_Linux32_lchown             (__NR_Linux32 +  16)
36 #define __NR_Linux32_break              (__NR_Linux32 +  17)
37 #define __NR_Linux32_oldstat            (__NR_Linux32 +  18)
38 #define __NR_Linux32_lseek              (__NR_Linux32 +  19)
39 #define __NR_Linux32_getpid             (__NR_Linux32 +  20)
40 #define __NR_Linux32_mount              (__NR_Linux32 +  21)
41 #define __NR_Linux32_umount             (__NR_Linux32 +  22)
42 #define __NR_Linux32_setuid             (__NR_Linux32 +  23)
43 #define __NR_Linux32_getuid             (__NR_Linux32 +  24)
44 #define __NR_Linux32_stime              (__NR_Linux32 +  25)
45 #define __NR_Linux32_ptrace             (__NR_Linux32 +  26)
46 #define __NR_Linux32_alarm              (__NR_Linux32 +  27)
47 #define __NR_Linux32_oldfstat           (__NR_Linux32 +  28)
48 #define __NR_Linux32_pause              (__NR_Linux32 +  29)
49 #define __NR_Linux32_utime              (__NR_Linux32 +  30)
50 #define __NR_Linux32_stty               (__NR_Linux32 +  31)
51 #define __NR_Linux32_gtty               (__NR_Linux32 +  32)
52 #define __NR_Linux32_access             (__NR_Linux32 +  33)
53 #define __NR_Linux32_nice               (__NR_Linux32 +  34)
54 #define __NR_Linux32_ftime              (__NR_Linux32 +  35)
55 #define __NR_Linux32_sync               (__NR_Linux32 +  36)
56 #define __NR_Linux32_kill               (__NR_Linux32 +  37)
57 #define __NR_Linux32_rename             (__NR_Linux32 +  38)
58 #define __NR_Linux32_mkdir              (__NR_Linux32 +  39)
59 #define __NR_Linux32_rmdir              (__NR_Linux32 +  40)
60 #define __NR_Linux32_dup                (__NR_Linux32 +  41)
61 #define __NR_Linux32_pipe               (__NR_Linux32 +  42)
62 #define __NR_Linux32_times              (__NR_Linux32 +  43)
63 #define __NR_Linux32_prof               (__NR_Linux32 +  44)
64 #define __NR_Linux32_brk                (__NR_Linux32 +  45)
65 #define __NR_Linux32_setgid             (__NR_Linux32 +  46)
66 #define __NR_Linux32_getgid             (__NR_Linux32 +  47)
67 #define __NR_Linux32_signal             (__NR_Linux32 +  48)
68 #define __NR_Linux32_geteuid            (__NR_Linux32 +  49)
69 #define __NR_Linux32_getegid            (__NR_Linux32 +  50)
70 #define __NR_Linux32_acct               (__NR_Linux32 +  51)
71 #define __NR_Linux32_umount2            (__NR_Linux32 +  52)
72 #define __NR_Linux32_lock               (__NR_Linux32 +  53)
73 #define __NR_Linux32_ioctl              (__NR_Linux32 +  54)
74 #define __NR_Linux32_fcntl              (__NR_Linux32 +  55)
75 #define __NR_Linux32_mpx                (__NR_Linux32 +  56)
76 #define __NR_Linux32_setpgid            (__NR_Linux32 +  57)
77 #define __NR_Linux32_ulimit             (__NR_Linux32 +  58)
78 #define __NR_Linux32_unused59           (__NR_Linux32 +  59)
79 #define __NR_Linux32_umask              (__NR_Linux32 +  60)
80 #define __NR_Linux32_chroot             (__NR_Linux32 +  61)
81 #define __NR_Linux32_ustat              (__NR_Linux32 +  62)
82 #define __NR_Linux32_dup2               (__NR_Linux32 +  63)
83 #define __NR_Linux32_getppid            (__NR_Linux32 +  64)
84 #define __NR_Linux32_getpgrp            (__NR_Linux32 +  65)
85 #define __NR_Linux32_setsid             (__NR_Linux32 +  66)
86 #define __NR_Linux32_sigaction          (__NR_Linux32 +  67)
87 #define __NR_Linux32_sgetmask           (__NR_Linux32 +  68)
88 #define __NR_Linux32_ssetmask           (__NR_Linux32 +  69)
89 #define __NR_Linux32_setreuid           (__NR_Linux32 +  70)
90 #define __NR_Linux32_setregid           (__NR_Linux32 +  71)
91 #define __NR_Linux32_sigsuspend         (__NR_Linux32 +  72)
92 #define __NR_Linux32_sigpending         (__NR_Linux32 +  73)
93 #define __NR_Linux32_sethostname        (__NR_Linux32 +  74)
94 #define __NR_Linux32_setrlimit          (__NR_Linux32 +  75)
95 #define __NR_Linux32_getrlimit          (__NR_Linux32 +  76)
96 #define __NR_Linux32_getrusage          (__NR_Linux32 +  77)
97 #define __NR_Linux32_gettimeofday       (__NR_Linux32 +  78)
98 #define __NR_Linux32_settimeofday       (__NR_Linux32 +  79)
99 #define __NR_Linux32_getgroups          (__NR_Linux32 +  80)
100 #define __NR_Linux32_setgroups          (__NR_Linux32 +  81)
101 #define __NR_Linux32_reserved82         (__NR_Linux32 +  82)
102 #define __NR_Linux32_symlink            (__NR_Linux32 +  83)
103 #define __NR_Linux32_oldlstat           (__NR_Linux32 +  84)
104 #define __NR_Linux32_readlink           (__NR_Linux32 +  85)
105 #define __NR_Linux32_uselib             (__NR_Linux32 +  86)
106 #define __NR_Linux32_swapon             (__NR_Linux32 +  87)
107 #define __NR_Linux32_reboot             (__NR_Linux32 +  88)
108 #define __NR_Linux32_readdir            (__NR_Linux32 +  89)
109 #define __NR_Linux32_mmap               (__NR_Linux32 +  90)
110 #define __NR_Linux32_munmap             (__NR_Linux32 +  91)
111 #define __NR_Linux32_truncate           (__NR_Linux32 +  92)
112 #define __NR_Linux32_ftruncate          (__NR_Linux32 +  93)
113 #define __NR_Linux32_fchmod             (__NR_Linux32 +  94)
114 #define __NR_Linux32_fchown             (__NR_Linux32 +  95)
115 #define __NR_Linux32_getpriority        (__NR_Linux32 +  96)
116 #define __NR_Linux32_setpriority        (__NR_Linux32 +  97)
117 #define __NR_Linux32_profil             (__NR_Linux32 +  98)
118 #define __NR_Linux32_statfs             (__NR_Linux32 +  99)
119 #define __NR_Linux32_fstatfs            (__NR_Linux32 + 100)
120 #define __NR_Linux32_ioperm             (__NR_Linux32 + 101)
121 #define __NR_Linux32_socketcall         (__NR_Linux32 + 102)
122 #define __NR_Linux32_syslog             (__NR_Linux32 + 103)
123 #define __NR_Linux32_setitimer          (__NR_Linux32 + 104)
124 #define __NR_Linux32_getitimer          (__NR_Linux32 + 105)
125 #define __NR_Linux32_stat               (__NR_Linux32 + 106)
126 #define __NR_Linux32_lstat              (__NR_Linux32 + 107)
127 #define __NR_Linux32_fstat              (__NR_Linux32 + 108)
128 #define __NR_Linux32_unused109          (__NR_Linux32 + 109)
129 #define __NR_Linux32_iopl               (__NR_Linux32 + 110)
130 #define __NR_Linux32_vhangup            (__NR_Linux32 + 111)
131 #define __NR_Linux32_idle               (__NR_Linux32 + 112)
132 #define __NR_Linux32_vm86               (__NR_Linux32 + 113)
133 #define __NR_Linux32_wait4              (__NR_Linux32 + 114)
134 #define __NR_Linux32_swapoff            (__NR_Linux32 + 115)
135 #define __NR_Linux32_sysinfo            (__NR_Linux32 + 116)
136 #define __NR_Linux32_ipc                (__NR_Linux32 + 117)
137 #define __NR_Linux32_fsync              (__NR_Linux32 + 118)
138 #define __NR_Linux32_sigreturn          (__NR_Linux32 + 119)
139 #define __NR_Linux32_clone              (__NR_Linux32 + 120)
140 #define __NR_Linux32_setdomainname      (__NR_Linux32 + 121)
141 #define __NR_Linux32_uname              (__NR_Linux32 + 122)
142 #define __NR_Linux32_modify_ldt         (__NR_Linux32 + 123)
143 #define __NR_Linux32_adjtimex           (__NR_Linux32 + 124)
144 #define __NR_Linux32_mprotect           (__NR_Linux32 + 125)
145 #define __NR_Linux32_sigprocmask        (__NR_Linux32 + 126)
146 #define __NR_Linux32_create_module      (__NR_Linux32 + 127)
147 #define __NR_Linux32_init_module        (__NR_Linux32 + 128)
148 #define __NR_Linux32_delete_module      (__NR_Linux32 + 129)
149 #define __NR_Linux32_get_kernel_syms    (__NR_Linux32 + 130)
150 #define __NR_Linux32_quotactl           (__NR_Linux32 + 131)
151 #define __NR_Linux32_getpgid            (__NR_Linux32 + 132)
152 #define __NR_Linux32_fchdir             (__NR_Linux32 + 133)
153 #define __NR_Linux32_bdflush            (__NR_Linux32 + 134)
154 #define __NR_Linux32_sysfs              (__NR_Linux32 + 135)
155 #define __NR_Linux32_personality        (__NR_Linux32 + 136)
156 #define __NR_Linux32_afs_syscall        (__NR_Linux32 + 137) /* Syscall for Andrew File System */
157 #define __NR_Linux32_setfsuid           (__NR_Linux32 + 138)
158 #define __NR_Linux32_setfsgid           (__NR_Linux32 + 139)
159 #define __NR_Linux32__llseek            (__NR_Linux32 + 140)
160 #define __NR_Linux32_getdents           (__NR_Linux32 + 141)
161 #define __NR_Linux32__newselect         (__NR_Linux32 + 142)
162 #define __NR_Linux32_flock              (__NR_Linux32 + 143)
163 #define __NR_Linux32_msync              (__NR_Linux32 + 144)
164 #define __NR_Linux32_readv              (__NR_Linux32 + 145)
165 #define __NR_Linux32_writev             (__NR_Linux32 + 146)
166 #define __NR_Linux32_cacheflush         (__NR_Linux32 + 147)
167 #define __NR_Linux32_cachectl           (__NR_Linux32 + 148)
168 #define __NR_Linux32_sysmips            (__NR_Linux32 + 149)
169 #define __NR_Linux32_unused150          (__NR_Linux32 + 150)
170 #define __NR_Linux32_getsid             (__NR_Linux32 + 151)
171 #define __NR_Linux32_fdatasync          (__NR_Linux32 + 152)
172 #define __NR_Linux32__sysctl            (__NR_Linux32 + 153)
173 #define __NR_Linux32_mlock              (__NR_Linux32 + 154)
174 #define __NR_Linux32_munlock            (__NR_Linux32 + 155)
175 #define __NR_Linux32_mlockall           (__NR_Linux32 + 156)
176 #define __NR_Linux32_munlockall         (__NR_Linux32 + 157)
177 #define __NR_Linux32_sched_setparam     (__NR_Linux32 + 158)
178 #define __NR_Linux32_sched_getparam     (__NR_Linux32 + 159)
179 #define __NR_Linux32_sched_setscheduler (__NR_Linux32 + 160)
180 #define __NR_Linux32_sched_getscheduler (__NR_Linux32 + 161)
181 #define __NR_Linux32_sched_yield        (__NR_Linux32 + 162)
182 #define __NR_Linux32_sched_get_priority_max     (__NR_Linux32 + 163)
183 #define __NR_Linux32_sched_get_priority_min     (__NR_Linux32 + 164)
184 #define __NR_Linux32_sched_rr_get_interval      (__NR_Linux32 + 165)
185 #define __NR_Linux32_nanosleep          (__NR_Linux32 + 166)
186 #define __NR_Linux32_mremap             (__NR_Linux32 + 167)
187 #define __NR_Linux32_accept             (__NR_Linux32 + 168)
188 #define __NR_Linux32_bind               (__NR_Linux32 + 169)
189 #define __NR_Linux32_connect            (__NR_Linux32 + 170)
190 #define __NR_Linux32_getpeername        (__NR_Linux32 + 171)
191 #define __NR_Linux32_getsockname        (__NR_Linux32 + 172)
192 #define __NR_Linux32_getsockopt         (__NR_Linux32 + 173)
193 #define __NR_Linux32_listen             (__NR_Linux32 + 174)
194 #define __NR_Linux32_recv               (__NR_Linux32 + 175)
195 #define __NR_Linux32_recvfrom           (__NR_Linux32 + 176)
196 #define __NR_Linux32_recvmsg            (__NR_Linux32 + 177)
197 #define __NR_Linux32_send               (__NR_Linux32 + 178)
198 #define __NR_Linux32_sendmsg            (__NR_Linux32 + 179)
199 #define __NR_Linux32_sendto             (__NR_Linux32 + 180)
200 #define __NR_Linux32_setsockopt         (__NR_Linux32 + 181)
201 #define __NR_Linux32_shutdown           (__NR_Linux32 + 182)
202 #define __NR_Linux32_socket             (__NR_Linux32 + 183)
203 #define __NR_Linux32_socketpair         (__NR_Linux32 + 184)
204 #define __NR_Linux32_setresuid          (__NR_Linux32 + 185)
205 #define __NR_Linux32_getresuid          (__NR_Linux32 + 186)
206 #define __NR_Linux32_query_module       (__NR_Linux32 + 187)
207 #define __NR_Linux32_poll               (__NR_Linux32 + 188)
208 #define __NR_Linux32_nfsservctl         (__NR_Linux32 + 189)
209 #define __NR_Linux32_setresgid          (__NR_Linux32 + 190)
210 #define __NR_Linux32_getresgid          (__NR_Linux32 + 191)
211 #define __NR_Linux32_prctl              (__NR_Linux32 + 192)
212 #define __NR_Linux32_rt_sigreturn       (__NR_Linux32 + 193)
213 #define __NR_Linux32_rt_sigaction       (__NR_Linux32 + 194)
214 #define __NR_Linux32_rt_sigprocmask     (__NR_Linux32 + 195)
215 #define __NR_Linux32_rt_sigpending      (__NR_Linux32 + 196)
216 #define __NR_Linux32_rt_sigtimedwait    (__NR_Linux32 + 197)
217 #define __NR_Linux32_rt_sigqueueinfo    (__NR_Linux32 + 198)
218 #define __NR_Linux32_rt_sigsuspend      (__NR_Linux32 + 199)
219 #define __NR_Linux32_pread              (__NR_Linux32 + 200)
220 #define __NR_Linux32_pwrite             (__NR_Linux32 + 201)
221 #define __NR_Linux32_chown              (__NR_Linux32 + 202)
222 #define __NR_Linux32_getcwd             (__NR_Linux32 + 203)
223 #define __NR_Linux32_capget             (__NR_Linux32 + 204)
224 #define __NR_Linux32_capset             (__NR_Linux32 + 205)
225 #define __NR_Linux32_sigaltstack        (__NR_Linux32 + 206)
226 #define __NR_Linux32_sendfile           (__NR_Linux32 + 207)
227 #define __NR_Linux32_getpmsg            (__NR_Linux32 + 208)
228 #define __NR_Linux32_putpmsg            (__NR_Linux32 + 209)
229 #define __NR_Linux32_mmap2              (__NR_Linux32 + 210)
230 #define __NR_Linux32_truncate64         (__NR_Linux32 + 211)
231 #define __NR_Linux32_ftruncate64        (__NR_Linux32 + 212)
232 #define __NR_Linux32_stat64             (__NR_Linux32 + 213)
233 #define __NR_Linux32_lstat64            (__NR_Linux32 + 214)
234 #define __NR_Linux32_fstat64            (__NR_Linux32 + 215)
235 #define __NR_Linux32_root_pivot         (__NR_Linux32 + 216)
236 #define __NR_Linux32_mincore            (__NR_Linux32 + 217)
237 #define __NR_Linux32_madvise            (__NR_Linux32 + 218)
238 #define __NR_Linux32_getdents64         (__NR_Linux32 + 219)
239 #define __NR_Linux32_fcntl64            (__NR_Linux32 + 220)
240 #define __NR_Linux32_security           (__NR_Linux32 + 221)
241 #define __NR_Linux32_gettid             (__NR_Linux32 + 222)
242 #define __NR_Linux32_readahead          (__NR_Linux32 + 223)
243 #define __NR_Linux32_setxattr           (__NR_Linux32 + 224)
244 #define __NR_Linux32_lsetxattr          (__NR_Linux32 + 225)
245 #define __NR_Linux32_fsetxattr          (__NR_Linux32 + 226)
246 #define __NR_Linux32_getxattr           (__NR_Linux32 + 227)
247 #define __NR_Linux32_lgetxattr          (__NR_Linux32 + 228)
248 #define __NR_Linux32_fgetxattr          (__NR_Linux32 + 229)
249 #define __NR_Linux32_listxattr          (__NR_Linux32 + 230)
250 #define __NR_Linux32_llistxattr         (__NR_Linux32 + 231)
251 #define __NR_Linux32_flistxattr         (__NR_Linux32 + 232)
252 #define __NR_Linux32_removexattr        (__NR_Linux32 + 233)
253 #define __NR_Linux32_lremovexattr       (__NR_Linux32 + 234)
254 #define __NR_Linux32_fremovexattr       (__NR_Linux32 + 235)
255 #define __NR_Linux32_tkill              (__NR_Linux32 + 236)
256 #define __NR_Linux32_sendfile64         (__NR_Linux32 + 237)
257 #define __NR_Linux32_futex              (__NR_Linux32 + 238)
258 #define __NR_Linux32_sched_setaffinity  (__NR_Linux32 + 239)
259 #define __NR_Linux32_sched_getaffinity  (__NR_Linux32 + 240)
260
261 /*
262  * Offset of the last Linux o32 flavoured syscall
263  */
264 #define __NR_Linux32_syscalls           240
265
266 /*
267  * Linux 64-bit syscalls are in the range from 5000 to 5999.
268  */
269 #define __NR_Linux                      5000
270 #define __NR_syscall                    (__NR_Linux +   0)
271 #define __NR_exit                       (__NR_Linux +   1)
272 #define __NR_fork                       (__NR_Linux +   2)
273 #define __NR_read                       (__NR_Linux +   3)
274 #define __NR_write                      (__NR_Linux +   4)
275 #define __NR_open                       (__NR_Linux +   5)
276 #define __NR_close                      (__NR_Linux +   6)
277 #define __NR_waitpid                    (__NR_Linux +   7)
278 #define __NR_creat                      (__NR_Linux +   8)
279 #define __NR_link                       (__NR_Linux +   9)
280 #define __NR_unlink                     (__NR_Linux +  10)
281 #define __NR_execve                     (__NR_Linux +  11)
282 #define __NR_chdir                      (__NR_Linux +  12)
283 #define __NR_time                       (__NR_Linux +  13)
284 #define __NR_mknod                      (__NR_Linux +  14)
285 #define __NR_chmod                      (__NR_Linux +  15)
286 #define __NR_lchown                     (__NR_Linux +  16)
287 #define __NR_break                      (__NR_Linux +  17)
288 #define __NR_oldstat                    (__NR_Linux +  18)
289 #define __NR_lseek                      (__NR_Linux +  19)
290 #define __NR_getpid                     (__NR_Linux +  20)
291 #define __NR_mount                      (__NR_Linux +  21)
292 #define __NR_umount                     (__NR_Linux +  22)
293 #define __NR_setuid                     (__NR_Linux +  23)
294 #define __NR_getuid                     (__NR_Linux +  24)
295 #define __NR_stime                      (__NR_Linux +  25)
296 #define __NR_ptrace                     (__NR_Linux +  26)
297 #define __NR_alarm                      (__NR_Linux +  27)
298 #define __NR_oldfstat                   (__NR_Linux +  28)
299 #define __NR_pause                      (__NR_Linux +  29)
300 #define __NR_utime                      (__NR_Linux +  30)
301 #define __NR_stty                       (__NR_Linux +  31)
302 #define __NR_gtty                       (__NR_Linux +  32)
303 #define __NR_access                     (__NR_Linux +  33)
304 #define __NR_nice                       (__NR_Linux +  34)
305 #define __NR_ftime                      (__NR_Linux +  35)
306 #define __NR_sync                       (__NR_Linux +  36)
307 #define __NR_kill                       (__NR_Linux +  37)
308 #define __NR_rename                     (__NR_Linux +  38)
309 #define __NR_mkdir                      (__NR_Linux +  39)
310 #define __NR_rmdir                      (__NR_Linux +  40)
311 #define __NR_dup                        (__NR_Linux +  41)
312 #define __NR_pipe                       (__NR_Linux +  42)
313 #define __NR_times                      (__NR_Linux +  43)
314 #define __NR_prof                       (__NR_Linux +  44)
315 #define __NR_brk                        (__NR_Linux +  45)
316 #define __NR_setgid                     (__NR_Linux +  46)
317 #define __NR_getgid                     (__NR_Linux +  47)
318 #define __NR_signal                     (__NR_Linux +  48)
319 #define __NR_geteuid                    (__NR_Linux +  49)
320 #define __NR_getegid                    (__NR_Linux +  50)
321 #define __NR_acct                       (__NR_Linux +  51)
322 #define __NR_umount2                    (__NR_Linux +  52)
323 #define __NR_lock                       (__NR_Linux +  53)
324 #define __NR_ioctl                      (__NR_Linux +  54)
325 #define __NR_fcntl                      (__NR_Linux +  55)
326 #define __NR_mpx                        (__NR_Linux +  56)
327 #define __NR_setpgid                    (__NR_Linux +  57)
328 #define __NR_ulimit                     (__NR_Linux +  58)
329 #define __NR_unused59                   (__NR_Linux +  59)
330 #define __NR_umask                      (__NR_Linux +  60)
331 #define __NR_chroot                     (__NR_Linux +  61)
332 #define __NR_ustat                      (__NR_Linux +  62)
333 #define __NR_dup2                       (__NR_Linux +  63)
334 #define __NR_getppid                    (__NR_Linux +  64)
335 #define __NR_getpgrp                    (__NR_Linux +  65)
336 #define __NR_setsid                     (__NR_Linux +  66)
337 #define __NR_sigaction                  (__NR_Linux +  67)
338 #define __NR_sgetmask                   (__NR_Linux +  68)
339 #define __NR_ssetmask                   (__NR_Linux +  69)
340 #define __NR_setreuid                   (__NR_Linux +  70)
341 #define __NR_setregid                   (__NR_Linux +  71)
342 #define __NR_sigsuspend                 (__NR_Linux +  72)
343 #define __NR_sigpending                 (__NR_Linux +  73)
344 #define __NR_sethostname                (__NR_Linux +  74)
345 #define __NR_setrlimit                  (__NR_Linux +  75)
346 #define __NR_getrlimit                  (__NR_Linux +  76)
347 #define __NR_getrusage                  (__NR_Linux +  77)
348 #define __NR_gettimeofday               (__NR_Linux +  78)
349 #define __NR_settimeofday               (__NR_Linux +  79)
350 #define __NR_getgroups                  (__NR_Linux +  80)
351 #define __NR_setgroups                  (__NR_Linux +  81)
352 #define __NR_reserved82                 (__NR_Linux +  82)
353 #define __NR_symlink                    (__NR_Linux +  83)
354 #define __NR_oldlstat                   (__NR_Linux +  84)
355 #define __NR_readlink                   (__NR_Linux +  85)
356 #define __NR_uselib                     (__NR_Linux +  86)
357 #define __NR_swapon                     (__NR_Linux +  87)
358 #define __NR_reboot                     (__NR_Linux +  88)
359 #define __NR_readdir                    (__NR_Linux +  89)
360 #define __NR_mmap                       (__NR_Linux +  90)
361 #define __NR_munmap                     (__NR_Linux +  91)
362 #define __NR_truncate                   (__NR_Linux +  92)
363 #define __NR_ftruncate                  (__NR_Linux +  93)
364 #define __NR_fchmod                     (__NR_Linux +  94)
365 #define __NR_fchown                     (__NR_Linux +  95)
366 #define __NR_getpriority                (__NR_Linux +  96)
367 #define __NR_setpriority                (__NR_Linux +  97)
368 #define __NR_profil                     (__NR_Linux +  98)
369 #define __NR_statfs                     (__NR_Linux +  99)
370 #define __NR_fstatfs                    (__NR_Linux + 100)
371 #define __NR_ioperm                     (__NR_Linux + 101)
372 #define __NR_socketcall                 (__NR_Linux + 102)
373 #define __NR_syslog                     (__NR_Linux + 103)
374 #define __NR_setitimer                  (__NR_Linux + 104)
375 #define __NR_getitimer                  (__NR_Linux + 105)
376 #define __NR_stat                       (__NR_Linux + 106)
377 #define __NR_lstat                      (__NR_Linux + 107)
378 #define __NR_fstat                      (__NR_Linux + 108)
379 #define __NR_unused109                  (__NR_Linux + 109)
380 #define __NR_iopl                       (__NR_Linux + 110)
381 #define __NR_vhangup                    (__NR_Linux + 111)
382 #define __NR_idle                       (__NR_Linux + 112)
383 #define __NR_vm86                       (__NR_Linux + 113)
384 #define __NR_wait4                      (__NR_Linux + 114)
385 #define __NR_swapoff                    (__NR_Linux + 115)
386 #define __NR_sysinfo                    (__NR_Linux + 116)
387 #define __NR_ipc                        (__NR_Linux + 117)
388 #define __NR_fsync                      (__NR_Linux + 118)
389 #define __NR_sigreturn                  (__NR_Linux + 119)
390 #define __NR_clone                      (__NR_Linux + 120)
391 #define __NR_setdomainname              (__NR_Linux + 121)
392 #define __NR_uname                      (__NR_Linux + 122)
393 #define __NR_modify_ldt                 (__NR_Linux + 123)
394 #define __NR_adjtimex                   (__NR_Linux + 124)
395 #define __NR_mprotect                   (__NR_Linux + 125)
396 #define __NR_sigprocmask                (__NR_Linux + 126)
397 #define __NR_create_module              (__NR_Linux + 127)
398 #define __NR_init_module                (__NR_Linux + 128)
399 #define __NR_delete_module              (__NR_Linux + 129)
400 #define __NR_get_kernel_syms            (__NR_Linux + 130)
401 #define __NR_quotactl                   (__NR_Linux + 131)
402 #define __NR_getpgid                    (__NR_Linux + 132)
403 #define __NR_fchdir                     (__NR_Linux + 133)
404 #define __NR_bdflush                    (__NR_Linux + 134)
405 #define __NR_sysfs                      (__NR_Linux + 135)
406 #define __NR_personality                (__NR_Linux + 136)
407 #define __NR_afs_syscall                (__NR_Linux + 137) /* Syscall for Andrew File System */
408 #define __NR_setfsuid                   (__NR_Linux + 138)
409 #define __NR_setfsgid                   (__NR_Linux + 139)
410 #define __NR__llseek                    (__NR_Linux + 140)
411 #define __NR_getdents                   (__NR_Linux + 141)
412 #define __NR__newselect                 (__NR_Linux + 142)
413 #define __NR_flock                      (__NR_Linux + 143)
414 #define __NR_msync                      (__NR_Linux + 144)
415 #define __NR_readv                      (__NR_Linux + 145)
416 #define __NR_writev                     (__NR_Linux + 146)
417 #define __NR_cacheflush                 (__NR_Linux + 147)
418 #define __NR_cachectl                   (__NR_Linux + 148)
419 #define __NR_sysmips                    (__NR_Linux + 149)
420 #define __NR_unused150                  (__NR_Linux + 150)
421 #define __NR_getsid                     (__NR_Linux + 151)
422 #define __NR_fdatasync                  (__NR_Linux + 152)
423 #define __NR__sysctl                    (__NR_Linux + 153)
424 #define __NR_mlock                      (__NR_Linux + 154)
425 #define __NR_munlock                    (__NR_Linux + 155)
426 #define __NR_mlockall                   (__NR_Linux + 156)
427 #define __NR_munlockall                 (__NR_Linux + 157)
428 #define __NR_sched_setparam             (__NR_Linux + 158)
429 #define __NR_sched_getparam             (__NR_Linux + 159)
430 #define __NR_sched_setscheduler         (__NR_Linux + 160)
431 #define __NR_sched_getscheduler         (__NR_Linux + 161)
432 #define __NR_sched_yield                (__NR_Linux + 162)
433 #define __NR_sched_get_priority_max     (__NR_Linux + 163)
434 #define __NR_sched_get_priority_min     (__NR_Linux + 164)
435 #define __NR_sched_rr_get_interval      (__NR_Linux + 165)
436 #define __NR_nanosleep                  (__NR_Linux + 166)
437 #define __NR_mremap                     (__NR_Linux + 167)
438 #define __NR_accept                     (__NR_Linux + 168)
439 #define __NR_bind                       (__NR_Linux + 169)
440 #define __NR_connect                    (__NR_Linux + 170)
441 #define __NR_getpeername                (__NR_Linux + 171)
442 #define __NR_getsockname                (__NR_Linux + 172)
443 #define __NR_getsockopt                 (__NR_Linux + 173)
444 #define __NR_listen                     (__NR_Linux + 174)
445 #define __NR_recv                       (__NR_Linux + 175)
446 #define __NR_recvfrom                   (__NR_Linux + 176)
447 #define __NR_recvmsg                    (__NR_Linux + 177)
448 #define __NR_send                       (__NR_Linux + 178)
449 #define __NR_sendmsg                    (__NR_Linux + 179)
450 #define __NR_sendto                     (__NR_Linux + 180)
451 #define __NR_setsockopt                 (__NR_Linux + 181)
452 #define __NR_shutdown                   (__NR_Linux + 182)
453 #define __NR_socket                     (__NR_Linux + 183)
454 #define __NR_socketpair                 (__NR_Linux + 184)
455 #define __NR_setresuid                  (__NR_Linux + 185)
456 #define __NR_getresuid                  (__NR_Linux + 186)
457 #define __NR_query_module               (__NR_Linux + 187)
458 #define __NR_poll                       (__NR_Linux + 188)
459 #define __NR_nfsservctl                 (__NR_Linux + 189)
460 #define __NR_setresgid                  (__NR_Linux + 190)
461 #define __NR_getresgid                  (__NR_Linux + 191)
462 #define __NR_prctl                      (__NR_Linux + 192)
463 #define __NR_rt_sigreturn               (__NR_Linux + 193)
464 #define __NR_rt_sigaction               (__NR_Linux + 194)
465 #define __NR_rt_sigprocmask             (__NR_Linux + 195)
466 #define __NR_rt_sigpending              (__NR_Linux + 196)
467 #define __NR_rt_sigtimedwait            (__NR_Linux + 197)
468 #define __NR_rt_sigqueueinfo            (__NR_Linux + 198)
469 #define __NR_rt_sigsuspend              (__NR_Linux + 199)
470 #define __NR_pread                      (__NR_Linux + 200)
471 #define __NR_pwrite                     (__NR_Linux + 201)
472 #define __NR_chown                      (__NR_Linux + 202)
473 #define __NR_getcwd                     (__NR_Linux + 203)
474 #define __NR_capget                     (__NR_Linux + 204)
475 #define __NR_capset                     (__NR_Linux + 205)
476 #define __NR_sigaltstack                (__NR_Linux + 206)
477 #define __NR_sendfile                   (__NR_Linux + 207)
478 #define __NR_getpmsg                    (__NR_Linux + 208)
479 #define __NR_putpmsg                    (__NR_Linux + 209)
480 #define __NR_root_pivot                 (__NR_Linux + 210)
481 #define __NR_mincore                    (__NR_Linux + 211)
482 #define __NR_madvise                    (__NR_Linux + 212)
483 #define __NR_getdents64                 (__NR_Linux + 213)
484 #define __NR__security                  (__NR_Linux + 214)
485 #define __NR__gettid                    (__NR_Linux + 215)
486 #define __NR__readahead                 (__NR_Linux + 216)
487 #define __NR_setxattr                   (__NR_Linux + 217)
488 #define __NR_lsetxattr                  (__NR_Linux + 218)
489 #define __NR_fsetxattr                  (__NR_Linux + 219)
490 #define __NR_getxattr                   (__NR_Linux + 220)
491 #define __NR_lgetxattr                  (__NR_Linux + 221)
492 #define __NR_fgetxattr                  (__NR_Linux + 222)
493 #define __NR_listxattr                  (__NR_Linux + 223)
494 #define __NR_llistxattr                 (__NR_Linux + 224)
495 #define __NR_flistxattr                 (__NR_Linux + 225)
496 #define __NR_removexattr                (__NR_Linux + 226)
497 #define __NR_lremovexattr               (__NR_Linux + 227)
498 #define __NR_fremovexattr               (__NR_Linux + 228)
499 #define __NR_tkill                      (__NR_Linux + 229)
500 #define __NR_sendfile64                 (__NR_Linux + 230)
501 #define __NR_futex                      (__NR_Linux + 231)
502 #define __NR_sched_setaffinity          (__NR_Linux + 232)
503 #define __NR_sched_getaffinity          (__NR_Linux + 233)
504
505 /*
506  * Offset of the last Linux flavoured syscall
507  */
508 #define __NR_Linux_syscalls             233
509
510 #ifndef __ASSEMBLY__
511
512 /* XXX - _foo needs to be __foo, while __NR_bar could be _NR_bar. */
513 #define _syscall0(type,name) \
514 type name(void) \
515 { \
516         register unsigned long __v0 asm("$2") = __NR_##name; \
517         register unsigned long __a3 asm("$7"); \
518         \
519         __asm__ volatile ( \
520         ".set\tnoreorder\n\t" \
521         "li\t$2, %2\t\t\t# " #name "\n\t" \
522         "syscall\n\t" \
523         ".set\treorder" \
524         : "=&r" (__v0), "=r" (__a3) \
525         : "i" (__NR_##name) \
526         : "$8", "$9", "$10", "$11", "$12", "$13", "$14", "$15", "$24"); \
527         \
528         if (__a3 == 0) \
529                 return (type) __v0; \
530         errno = __v0; \
531         return -1; \
532 }
533
534 /*
535  * DANGER: This macro isn't usable for the pipe(2) call
536  * which has a unusual return convention.
537  */
538 #define _syscall1(type,name,atype,a) \
539 type name(atype a) \
540 { \
541         register unsigned long __v0 asm("$2") = __NR_##name; \
542         register unsigned long __a0 asm("$4") = (unsigned long) a; \
543         register unsigned long __a3 asm("$7"); \
544         \
545         __asm__ volatile ( \
546         ".set\tnoreorder\n\t" \
547         "li\t$2, %3\t\t\t# " #name "\n\t" \
548         "syscall\n\t" \
549         ".set\treorder" \
550         : "=&r" (__v0), "=r" (__a3) \
551         : "r" (__a0), "i" (__NR_##name) \
552         : "$8", "$9", "$10", "$11", "$12", "$13", "$14", "$15", "$24"); \
553         \
554         if (__a3 == 0) \
555                 return (type) __v0; \
556         errno = __v0; \
557         return -1; \
558 }
559
560 #define _syscall2(type,name,atype,a,btype,b) \
561 type name(atype a, btype b) \
562 { \
563         register unsigned long __v0 asm("$2") = __NR_##name; \
564         register unsigned long __a0 asm("$4") = (unsigned long) a; \
565         register unsigned long __a1 asm("$5") = (unsigned long) b; \
566         register unsigned long __a3 asm("$7"); \
567         \
568         __asm__ volatile ( \
569         ".set\tnoreorder\n\t" \
570         "li\t$2, %4\t\t\t# " #name "\n\t" \
571         "syscall\n\t" \
572         ".set\treorder" \
573         : "=&r" (__v0), "=r" (__a3) \
574         : "r" (__a0), "r" (__a1), "i" (__NR_##name) \
575         : "$8", "$9", "$10", "$11", "$12", "$13", "$14", "$15", "$24"); \
576         \
577         if (__a3 == 0) \
578                 return (type) __v0; \
579         errno = __v0; \
580         return -1; \
581 }
582
583 #define _syscall3(type,name,atype,a,btype,b,ctype,c) \
584 type name(atype a, btype b, ctype c) \
585 { \
586         register unsigned long __v0 asm("$2") = __NR_##name; \
587         register unsigned long __a0 asm("$4") = (unsigned long) a; \
588         register unsigned long __a1 asm("$5") = (unsigned long) b; \
589         register unsigned long __a2 asm("$6") = (unsigned long) c; \
590         register unsigned long __a3 asm("$7"); \
591         \
592         __asm__ volatile ( \
593         ".set\tnoreorder\n\t" \
594         "li\t$2, %5\t\t\t# " #name "\n\t" \
595         "syscall\n\t" \
596         ".set\treorder" \
597         : "=&r" (__v0), "=r" (__a3) \
598         : "r" (__a0), "r" (__a1), "r" (__a2), "i" (__NR_##name) \
599         : "$8", "$9", "$10", "$11", "$12", "$13", "$14", "$15", "$24"); \
600         \
601         if (__a3 == 0) \
602                 return (type) __v0; \
603         errno = __v0; \
604         return -1; \
605 }
606
607 #define _syscall4(type,name,atype,a,btype,b,ctype,c,dtype,d) \
608 type name(atype a, btype b, ctype c, dtype d) \
609 { \
610         register unsigned long __v0 asm("$2") = __NR_##name; \
611         register unsigned long __a0 asm("$4") = (unsigned long) a; \
612         register unsigned long __a1 asm("$5") = (unsigned long) b; \
613         register unsigned long __a2 asm("$6") = (unsigned long) c; \
614         register unsigned long __a3 asm("$7") = (unsigned long) d; \
615         \
616         __asm__ volatile ( \
617         ".set\tnoreorder\n\t" \
618         "li\t$2, %5\t\t\t# " #name "\n\t" \
619         "syscall\n\t" \
620         ".set\treorder" \
621         : "=&r" (__v0), "+r" (__a3) \
622         : "r" (__a0), "r" (__a1), "r" (__a2), "i" (__NR_##name) \
623         : "$8", "$9", "$10", "$11", "$12", "$13", "$14", "$15", "$24"); \
624         \
625         if (__a3 == 0) \
626                 return (type) __v0; \
627         errno = __v0; \
628         return -1; \
629 }
630
631 #if (_MIPS_SIM == _ABIN32) || (_MIPS_SIM == _ABI64)
632
633 #define _syscall5(type,name,atype,a,btype,b,ctype,c,dtype,d,etype,e) \
634 type name (atype a,btype b,ctype c,dtype d,etype e) \
635 { \
636         register unsigned long __v0 asm("$2") = __NR_##name; \
637         register unsigned long __a0 asm("$4") = (unsigned long) a; \
638         register unsigned long __a1 asm("$5") = (unsigned long) b; \
639         register unsigned long __a2 asm("$6") = (unsigned long) c; \
640         register unsigned long __a3 asm("$7") = (unsigned long) d; \
641         register unsigned long __a4 asm("$8") = (unsigned long) e; \
642         \
643         __asm__ volatile ( \
644         ".set\tnoreorder\n\t" \
645         "li\t$2, %6\t\t\t# " #name "\n\t" \
646         "syscall\n\t" \
647         ".set\treorder" \
648         : "=&r" (__v0), "+r" (__a3), "+r" (__a4) \
649         : "r" (__a0), "r" (__a1), "r" (__a2), "i" (__NR_##name) \
650         : "$9", "$10", "$11", "$12", "$13", "$14", "$15", "$24"); \
651         \
652         if (__a3 == 0) \
653                 return (type) __v0; \
654         errno = __v0; \
655         return -1; \
656 }
657
658 #define _syscall6(type,name,atype,a,btype,b,ctype,c,dtype,d,etype,e,ftype,f) \
659 type name (atype a,btype b,ctype c,dtype d,etype e,ftype f) \
660 { \
661         register unsigned long __v0 asm("$2") = __NR_##name; \
662         register unsigned long __a0 asm("$4") = (unsigned long) a; \
663         register unsigned long __a1 asm("$5") = (unsigned long) b; \
664         register unsigned long __a2 asm("$6") = (unsigned long) c; \
665         register unsigned long __a3 asm("$7") = (unsigned long) d; \
666         register unsigned long __a4 asm("$8") = (unsigned long) e; \
667         register unsigned long __a5 asm("$9") = (unsigned long) f; \
668         \
669         __asm__ volatile ( "" \
670         : "+r" (__a5) \
671         : \
672         : "$9", "$10", "$11", "$12", "$13", "$14", "$15", "$24"); \
673         \
674         __asm__ volatile ( \
675         ".set\tnoreorder\n\t" \
676         "li\t$2, %6\t\t\t# " #name "\n\t" \
677         "syscall\n\t" \
678         ".set\treorder" \
679         : "=&r" (__v0), "+r" (__a3), "+r" (__a4) \
680         : "r" (__a0), "r" (__a1), "r" (__a2), "i" (__NR_##name) \
681         : "$9", "$10", "$11", "$12", "$13", "$14", "$15", "$24"); \
682         \
683         if (__a3 == 0) \
684                 return (type) __v0; \
685         errno = __v0; \
686         return -1; \
687 }
688
689 #define _syscall7(type,name,atype,a,btype,b,ctype,c,dtype,d,etype,e,ftype,f,gtype,g) \
690 type name (atype a,btype b,ctype c,dtype d,etype e,ftype f,gtype g) \
691 { \
692         register unsigned long __v0 asm("$2") = __NR_##name; \
693         register unsigned long __a0 asm("$4") = (unsigned long) a; \
694         register unsigned long __a1 asm("$5") = (unsigned long) b; \
695         register unsigned long __a2 asm("$6") = (unsigned long) c; \
696         register unsigned long __a3 asm("$7") = (unsigned long) d; \
697         register unsigned long __a4 asm("$8") = (unsigned long) e; \
698         register unsigned long __a5 asm("$9") = (unsigned long) f; \
699         register unsigned long __a6 asm("$10") = (unsigned long) g; \
700         \
701         __asm__ volatile ( "" \
702         : "+r" (__a5), "+r" (__a6) \
703         : \
704         : "$9", "$10", "$11", "$12", "$13", "$14", "$15", "$24"); \
705         \
706         __asm__ volatile ( \
707         ".set\tnoreorder\n\t" \
708         "li\t$2, %6\t\t\t# " #name "\n\t" \
709         "syscall\n\t" \
710         ".set\treorder" \
711         : "=&r" (__v0), "+r" (__a3), "+r" (__a4) \
712         : "r" (__a0), "r" (__a1), "r" (__a2), "i" (__NR_##name) \
713         : "$9", "$10", "$11", "$12", "$13", "$14", "$15", "$24"); \
714         \
715         if (__a3 == 0) \
716                 return (type) __v0; \
717         errno = __v0; \
718         return -1; \
719 }
720
721 #else /* not N32 or 64 ABI */
722
723 /*
724  * Using those means your brain needs more than an oil change ;-)
725  */
726
727 #define _syscall5(type,name,atype,a,btype,b,ctype,c,dtype,d,etype,e) \
728 type name(atype a, btype b, ctype c, dtype d, etype e) \
729 { \
730         register unsigned long __v0 asm("$2") = __NR_##name; \
731         register unsigned long __a0 asm("$4") = (unsigned long) a; \
732         register unsigned long __a1 asm("$5") = (unsigned long) b; \
733         register unsigned long __a2 asm("$6") = (unsigned long) c; \
734         register unsigned long __a3 asm("$7") = (unsigned long) d; \
735         \
736         __asm__ volatile ( \
737         ".set\tnoreorder\n\t" \
738         "lw\t$2, %6\n\t" \
739         "subu\t$29, 32\n\t" \
740         "sw\t$2, 16($29)\n\t" \
741         "li\t$2, %5\t\t\t# " #name "\n\t" \
742         "syscall\n\t" \
743         "addiu\t$29, 32\n\t" \
744         ".set\treorder" \
745         : "=&r" (__v0), "+r" (__a3) \
746         : "r" (__a0), "r" (__a1), "r" (__a2), "i" (__NR_##name), \
747           "m" ((unsigned long)e) \
748         : "$8", "$9", "$10", "$11", "$12", "$13", "$14", "$15", "$24"); \
749         \
750         if (__a3 == 0) \
751                 return (type) __v0; \
752         errno = __v0; \
753         return -1; \
754 }
755
756 #define _syscall6(type,name,atype,a,btype,b,ctype,c,dtype,d,etype,e,ftype,f) \
757 type name(atype a, btype b, ctype c, dtype d, etype e, ftype f) \
758 { \
759         register unsigned long __v0 asm("$2") = __NR_##name; \
760         register unsigned long __a0 asm("$4") = (unsigned long) a; \
761         register unsigned long __a1 asm("$5") = (unsigned long) b; \
762         register unsigned long __a2 asm("$6") = (unsigned long) c; \
763         register unsigned long __a3 asm("$7") = (unsigned long) d; \
764         \
765         __asm__ volatile ( \
766         ".set\tnoreorder\n\t" \
767         "lw\t$2, %6\n\t" \
768         "lw\t$8, %7\n\t" \
769         "subu\t$29, 32\n\t" \
770         "sw\t$2, 16($29)\n\t" \
771         "sw\t$8, 20($29)\n\t" \
772         "li\t$2, %5\t\t\t# " #name "\n\t" \
773         "syscall\n\t" \
774         "addiu\t$29, 32\n\t" \
775         ".set\treorder" \
776         : "=&r" (__v0), "+r" (__a3) \
777         : "r" (__a0), "r" (__a1), "r" (__a2), "i" (__NR_##name), \
778           "m" ((unsigned long)e), "m" ((unsigned long)f) \
779         : "$8", "$9", "$10", "$11", "$12", "$13", "$14", "$15", "$24"); \
780         \
781         if (__a3 == 0) \
782                 return (type) __v0; \
783         errno = __v0; \
784         return -1; \
785 }
786
787 #define _syscall7(type,name,atype,a,btype,b,ctype,c,dtype,d,etype,e,ftype,f,gtype,g) \
788 type name(atype a, btype b, ctype c, dtype d, etype e, ftype f, gtype g) \
789 { \
790         register unsigned long __v0 asm("$2") = __NR_##name; \
791         register unsigned long __a0 asm("$4") = (unsigned long) a; \
792         register unsigned long __a1 asm("$5") = (unsigned long) b; \
793         register unsigned long __a2 asm("$6") = (unsigned long) c; \
794         register unsigned long __a3 asm("$7") = (unsigned long) d; \
795         \
796         __asm__ volatile ( \
797         ".set\tnoreorder\n\t" \
798         "lw\t$2, %6\n\t" \
799         "lw\t$8, %7\n\t" \
800         "lw\t$9, %8\n\t" \
801         "subu\t$29, 32\n\t" \
802         "sw\t$2, 16($29)\n\t" \
803         "sw\t$8, 20($29)\n\t" \
804         "sw\t$9, 24($29)\n\t" \
805         "li\t$2, %5\t\t\t# " #name "\n\t" \
806         "syscall\n\t" \
807         "addiu\t$29, 32\n\t" \
808         ".set\treorder" \
809         : "=&r" (__v0), "+r" (__a3) \
810         : "r" (__a0), "r" (__a1), "r" (__a2), "i" (__NR_##name), \
811           "m" ((unsigned long)e), "m" ((unsigned long)f), \
812           "m" ((unsigned long)g), \
813         : "$8", "$9", "$10", "$11", "$12", "$13", "$14", "$15", "$24"); \
814         \
815         if (__a3 == 0) \
816                 return (type) __v0; \
817         errno = __v0; \
818         return -1; \
819 }
820
821 #endif
822
823 #ifdef __KERNEL_SYSCALLS__
824
825 /*
826  * we need this inline - forking from kernel space will result
827  * in NO COPY ON WRITE (!!!), until an execve is executed. This
828  * is no problem, but for the stack. This is handled by not letting
829  * main() use the stack at all after fork(). Thus, no function
830  * calls - which means inline code for fork too, as otherwise we
831  * would use the stack upon exit from 'fork()'.
832  *
833  * Actually only pause and fork are needed inline, so that there
834  * won't be any messing with the stack from main(), but we define
835  * some others too.
836  */
837 #define __NR__exit __NR_exit
838 static inline _syscall0(int,sync)
839 static inline _syscall0(pid_t,setsid)
840 static inline _syscall3(int,write,int,fd,const char *,buf,off_t,count)
841 static inline _syscall3(int,read,int,fd,char *,buf,off_t,count)
842 static inline _syscall3(off_t,lseek,int,fd,off_t,offset,int,count)
843 static inline _syscall1(int,dup,int,fd)
844 static inline _syscall3(int,execve,const char *,file,char **,argv,char **,envp)
845 static inline _syscall3(int,open,const char *,file,int,flag,int,mode)
846 static inline _syscall1(int,close,int,fd)
847 static inline _syscall1(int,_exit,int,exitcode)
848 static inline _syscall3(pid_t,waitpid,pid_t,pid,int *,wait_stat,int,options)
849 static inline _syscall1(int,delete_module,const char *,name)
850
851 static inline pid_t wait(int * wait_stat)
852 {
853         return waitpid(-1,wait_stat,0);
854 }
855
856 #endif /* __KERNEL_SYSCALLS__ */
857 #endif /* !__ASSEMBLY__ */
858
859 #endif /* _ASM_UNISTD_H */