syscalls.master revision 1.49 1 $NetBSD: syscalls.master,v 1.49 2000/12/12 22:23:02 jdolecek Exp $
2
3 ; @(#)syscalls.master 8.1 (Berkeley) 7/19/93
4
5 ; NetBSD i386 COMPAT_LINUX system call name/number "master" file.
6 ; (See syscalls.conf to see what it is processed into.)
7 ;
8 ; Fields: number type [type-dependent ...]
9 ; number system call number, must be in order
10 ; type one of STD, OBSOL, UNIMPL, NODEF, NOARGS, or one of
11 ; the compatibility options defined in syscalls.conf.
12 ;
13 ; types:
14 ; STD always included
15 ; OBSOL obsolete, not included in system
16 ; UNIMPL unimplemented, not included in system
17 ; NODEF included, but don't define the syscall number
18 ; NOARGS included, but don't define the syscall args structure
19 ; INDIR included, but don't define the syscall args structure
20 ; and allow it to be "really" varargs.
21 ;
22 ; The compat options are defined in the syscalls.conf file, and the
23 ; compat option name is prefixed to the syscall name. Other than
24 ; that, they're like NODEF (for 'compat' options), or STD (for
25 ; 'libcompat' options).
26 ;
27 ; The type-dependent arguments are as follows:
28 ; For STD, NODEF, NOARGS, and compat syscalls:
29 ; { pseudo-proto } [alias]
30 ; For other syscalls:
31 ; [comment]
32 ;
33 ; #ifdef's, etc. may be included, and are copied to the output files.
34 ; #include's are copied to the syscall names and switch definition files only.
35
36 #if defined(_KERNEL) && !defined(_LKM)
37 #include "opt_compat_43.h"
38 #endif
39
40 #include <sys/param.h>
41 #include <sys/poll.h>
42 #include <sys/systm.h>
43 #include <sys/signal.h>
44 #include <sys/mount.h>
45 #include <sys/syscallargs.h>
46
47 #include <compat/linux/common/linux_types.h>
48 #include <compat/linux/common/linux_signal.h>
49 #include <compat/linux/common/linux_siginfo.h>
50 #include <compat/linux/common/linux_machdep.h>
51
52 #include <compat/linux/linux_syscallargs.h>
53
54 %%
55
56 0 NOARGS { int sys_nosys(void); } syscall
57 1 NOARGS { int sys_exit(int rval); }
58 2 NOARGS { int sys_fork(void); }
59 3 NOARGS { int sys_read(int fd, char *buf, u_int nbyte); }
60 4 NOARGS { int sys_write(int fd, char *buf, u_int nbyte); }
61 5 STD { int linux_sys_open(const char *path, int flags, \
62 int mode); }
63 6 NOARGS { int sys_close(int fd); }
64 7 STD { int linux_sys_waitpid(int pid, int *status, \
65 int options);}
66 8 STD { int linux_sys_creat(const char *path, int mode); }
67 9 NOARGS { int sys_link(const char *path, const char *link); }
68 10 STD { int linux_sys_unlink(const char *path); }
69 11 STD { int linux_sys_execve(const char *path, char **argp, \
70 char **envp); }
71 12 STD { int linux_sys_chdir(const char *path); }
72 13 STD { int linux_sys_time(linux_time_t *t); }
73 14 STD { int linux_sys_mknod(const char *path, int mode, \
74 int dev); }
75 15 STD { int linux_sys_chmod(const char *path, int mode); }
76 16 STD { int linux_sys_lchown(const char *path, \
77 int uid, int gid); }
78 ;17 - no longer in linux source.
79 17 STD { int linux_sys_break(char *nsize); }
80 18 OBSOL ostat
81 19 NOARGS { long compat_43_sys_lseek(int fd, long offset, \
82 int whence); }
83 20 NOARGS { pid_t sys_getpid(void); }
84 21 UNIMPL mount
85 22 UNIMPL umount
86 23 NOARGS { int sys_setuid(uid_t uid); }
87 24 NOARGS { uid_t sys_getuid(void); }
88 25 STD { int linux_sys_stime(linux_time_t *t); }
89 26 STD { int linux_sys_ptrace(int request, int pid, \
90 int addr, int data); }
91 27 STD { int linux_sys_alarm(unsigned int secs); }
92 28 OBSOL ofstat
93 29 STD { int linux_sys_pause(void); }
94 30 STD { int linux_sys_utime(const char *path, \
95 struct linux_utimbuf *times); }
96 31 OBSOL stty
97 32 OBSOL gtty
98 33 STD { int linux_sys_access(const char *path, int flags); }
99 34 STD { int linux_sys_nice(int incr); }
100 35 OBSOL ftime
101 36 NOARGS { int sys_sync(void); }
102 37 STD { int linux_sys_kill(int pid, int signum); }
103 38 STD { int linux_sys_rename(const char *from, \
104 const char *to); }
105 39 STD { int linux_sys_mkdir(const char *path, int mode); }
106 40 STD { int linux_sys_rmdir(const char *path); }
107 41 NOARGS { int sys_dup(u_int fd); }
108 42 STD { int linux_sys_pipe(int *pfds); }
109 43 STD { int linux_sys_times(struct times *tms); }
110 44 OBSOL prof
111 45 STD { int linux_sys_brk(char *nsize); }
112 46 NOARGS { int sys_setgid(gid_t gid); }
113 47 NOARGS { gid_t sys_getgid(void); }
114 48 STD { int linux_sys_signal(int signum, \
115 linux_handler_t handler); }
116 49 NOARGS { uid_t sys_geteuid(void); }
117 50 NOARGS { gid_t sys_getegid(void); }
118 51 NOARGS { int sys_acct(char *path); }
119 52 OBSOL phys
120 53 OBSOL lock
121 54 STD { int linux_sys_ioctl(int fd, u_long com, \
122 caddr_t data); }
123 55 STD { int linux_sys_fcntl(int fd, int cmd, void *arg); }
124 56 OBSOL mpx
125 57 NOARGS { int sys_setpgid(int pid, int pgid); }
126 58 OBSOL ulimit
127 59 STD { int linux_sys_oldolduname(struct linux_oldold_utsname *up); }
128 60 NOARGS { int sys_umask(int newmask); }
129 61 NOARGS { int sys_chroot(char *path); }
130 62 UNIMPL ustat
131 63 NOARGS { int sys_dup2(u_int from, u_int to); }
132 64 NOARGS { pid_t sys_getppid(void); }
133 65 NOARGS { int sys_getpgrp(void); }
134 66 NOARGS { int sys_setsid(void); }
135 67 STD { int linux_sys_sigaction(int signum, \
136 const struct linux_old_sigaction *nsa, \
137 struct linux_old_sigaction *osa); }
138 68 STD { int linux_sys_siggetmask(void); }
139 69 STD { int linux_sys_sigsetmask(linux_old_sigset_t mask); }
140 70 STD { int linux_sys_setreuid(int ruid, int euid); }
141 71 STD { int linux_sys_setregid(int rgid, int egid); }
142 72 STD { int linux_sys_sigsuspend(caddr_t restart, \
143 int oldmask, int mask); }
144 73 STD { int linux_sys_sigpending(linux_old_sigset_t *set); }
145 74 NOARGS { int compat_43_sys_sethostname(char *hostname, \
146 u_int len);}
147 75 NOARGS { int compat_43_sys_setrlimit(u_int which, \
148 struct orlimit *rlp); }
149 76 NOARGS { int compat_43_sys_getrlimit(u_int which, \
150 struct orlimit *rlp); }
151 77 NOARGS { int sys_getrusage(int who, struct rusage *rusage); }
152 78 NOARGS { int sys_gettimeofday(struct timeval *tp, \
153 struct timezone *tzp); }
154 79 NOARGS { int sys_settimeofday(struct timeval *tp, \
155 struct timezone *tzp); }
156 80 NOARGS { int sys_getgroups(u_int gidsetsize, gid_t *gidset); }
157 81 NOARGS { int sys_setgroups(u_int gidsetsize, gid_t *gidset); }
158 82 STD { int linux_sys_oldselect(struct linux_oldselect *lsp); }
159 83 STD { int linux_sys_symlink(const char *path, \
160 const char *to); }
161 84 NOARGS { int compat_43_sys_lstat(const char *path, \
162 struct stat43 *up); } oolstat
163 85 STD { int linux_sys_readlink(const char *name, char *buf, \
164 int count); }
165 86 STD { int linux_sys_uselib(const char *path); }
166 87 STD { int linux_sys_swapon(char *name); }
167 88 STD { int linux_sys_reboot(int magic1, int magic2, \
168 int cmd, void *arg); }
169 89 STD { int linux_sys_readdir(int fd, caddr_t dent, \
170 unsigned int count); }
171 90 STD { int linux_sys_old_mmap(struct linux_oldmmap *lmp); }
172 91 NOARGS { int sys_munmap(caddr_t addr, int len); }
173 92 STD { int linux_sys_truncate(const char *path, \
174 long length); }
175 93 NOARGS { int compat_43_sys_ftruncate(int fd, long length); }
176 94 NOARGS { int sys_fchmod(int fd, int mode); }
177 95 STD { int linux_sys_fchown(int fd, int uid, int gid); }
178 96 NOARGS { int sys_getpriority(int which, int who); }
179 97 NOARGS { int sys_setpriority(int which, int who, int prio); }
180 98 NOARGS { int sys_profil(caddr_t samples, u_int size, \
181 u_int offset, u_int scale); }
182 99 STD { int linux_sys_statfs(const char *path, \
183 struct linux_statfs *sp); }
184 100 STD { int linux_sys_fstatfs(int fd, \
185 struct linux_statfs *sp); }
186 101 STD { int linux_sys_ioperm(unsigned int lo, \
187 unsigned int hi, int val); }
188 102 STD { int linux_sys_socketcall(int what, void *args); }
189 103 UNIMPL syslog
190 104 NOARGS { int sys_setitimer(u_int which, \
191 struct itimerval *itv, struct itimerval *oitv); }
192 105 NOARGS { int sys_getitimer(u_int which, \
193 struct itimerval *itv); }
194 106 STD { int linux_sys_stat(const char *path, \
195 struct linux_stat *sp); }
196 107 STD { int linux_sys_lstat(const char *path, \
197 struct linux_stat *sp); }
198 108 STD { int linux_sys_fstat(int fd, struct linux_stat *sp); }
199 109 STD { int linux_sys_olduname(struct linux_old_utsname *up); }
200 110 STD { int linux_sys_iopl(int level); }
201 111 UNIMPL vhangup
202 112 UNIMPL idle
203 113 UNIMPL vm86old
204 114 STD { int linux_sys_wait4(int pid, int *status, \
205 int options, struct rusage *rusage); }
206 115 STD { int linux_sys_swapoff(const char *path); }
207 116 UNIMPL sysinfo
208 117 STD { int linux_sys_ipc(int what, int a1, int a2, int a3, \
209 caddr_t ptr); }
210 118 NOARGS { int sys_fsync(int fd); }
211 119 STD { int linux_sys_sigreturn(struct linux_sigcontext *scp); }
212 120 STD { int linux_sys_clone(int flags, void *stack); }
213 121 STD { int linux_sys_setdomainname(char *domainname, \
214 int len); }
215 122 STD { int linux_sys_uname(struct linux_utsname *up); }
216 123 STD { int linux_sys_modify_ldt(int func, void *ptr, \
217 size_t bytecount); }
218 124 UNIMPL adjtimex
219 125 NOARGS { int sys_mprotect(caddr_t addr, int len, int prot); }
220 126 STD { int linux_sys_sigprocmask(int how, \
221 const linux_old_sigset_t *set, \
222 linux_old_sigset_t *oset); }
223 127 UNIMPL create_module
224 128 UNIMPL init_module
225 129 UNIMPL delete_module
226 130 UNIMPL get_kernel_syms
227 131 UNIMPL quotactl
228 132 STD { int linux_sys_getpgid(int pid); }
229 133 NOARGS { int sys_fchdir(int fd); }
230 134 UNIMPL bdflush
231 135 UNIMPL sysfs
232 136 STD { int linux_sys_personality(int per); }
233 137 UNIMPL afs_syscall
234 138 STD { int linux_sys_setfsuid(uid_t uid); }
235 139 NOARGS { int linux_sys_getfsuid(void); }
236 140 STD { int linux_sys_llseek(int fd, u_int32_t ohigh, \
237 u_int32_t olow, caddr_t res, int whence); }
238 141 STD { int linux_sys_getdents(int fd, \
239 struct linux_dirent *dent, unsigned int count); }
240 142 STD { int linux_sys_select(int nfds, fd_set *readfds, \
241 fd_set *writefds, fd_set *exceptfds, \
242 struct timeval *timeout); }
243 143 NOARGS { int sys_flock(int fd, int how); }
244 144 STD { int linux_sys_msync(caddr_t addr, int len, int fl); }
245 145 NOARGS { int sys_readv(int fd, struct iovec *iovp, \
246 u_int iovcnt); }
247 146 NOARGS { int sys_writev(int fd, struct iovec *iovp, \
248 u_int iovcnt); }
249 147 NOARGS { pid_t sys_getsid(pid_t pid); }
250 148 STD { int linux_sys_fdatasync(int fd); }
251 149 STD { int linux_sys___sysctl(struct linux___sysctl *lsp); }
252 150 NOARGS { int sys_mlock(caddr_t addr, size_t len); }
253 151 NOARGS { int sys_munlock(caddr_t addr, size_t len); }
254 152 NOARGS { int sys_mlockall(int flags); }
255 153 NOARGS { int sys_munlockall(void); }
256 154 STD { int linux_sys_sched_setparam(pid_t pid, \
257 const struct linux_sched_param *sp); }
258 155 STD { int linux_sys_sched_getparam(pid_t pid, \
259 struct linux_sched_param *sp); }
260 156 STD { int linux_sys_sched_setscheduler(pid_t pid, \
261 int policy, const struct linux_sched_param *sp); }
262 157 STD { int linux_sys_sched_getscheduler(pid_t pid); }
263 158 STD { int linux_sys_sched_yield(void); }
264 159 STD { int linux_sys_sched_get_priority_max(int policy); }
265 160 STD { int linux_sys_sched_get_priority_min(int policy); }
266 161 UNIMPL sys_sched_rr_get_interval
267 162 NOARGS { int sys_nanosleep(const struct timespec *rqtp, \
268 struct timespec *rmtp); }
269 163 STD { void *linux_sys_mremap(void *old_address, \
270 size_t old_size, size_t new_size, u_long flags); }
271 164 STD { int linux_sys_setresuid(uid_t ruid, uid_t euid, \
272 uid_t suid); }
273 165 STD { int linux_sys_getresuid(uid_t *ruid, uid_t *euid, \
274 uid_t *suid); }
275 166 UNIMPL vm86
276 167 UNIMPL query_module
277 168 NOARGS { int sys_poll(struct pollfd *fds, u_int nfds, \
278 int timeout); }
279 169 UNIMPL nfsservctl
280 170 STD { int linux_sys_setresgid(gid_t rgid, gid_t egid, \
281 gid_t sgid); }
282 171 STD { int linux_sys_getresgid(gid_t *rgid, gid_t *egid, \
283 gid_t *sgid); }
284 172 UNIMPL prctl
285 173 STD { int linux_sys_rt_sigreturn( \
286 struct linux_rt_sigframe *sfp); }
287 174 STD { int linux_sys_rt_sigaction(int signum, \
288 const struct linux_sigaction *nsa, \
289 struct linux_sigaction *osa, \
290 size_t sigsetsize); }
291 175 STD { int linux_sys_rt_sigprocmask(int how, \
292 const linux_sigset_t *set, \
293 linux_sigset_t *oset, \
294 size_t sigsetsize); }
295 176 STD { int linux_sys_rt_sigpending( \
296 linux_sigset_t *set, \
297 size_t sigsetsize); }
298 177 UNIMPL rt_sigtimedwait
299 ; XXX XAX int here? sigset_t here? siginfo_t
300 178 STD { int linux_sys_rt_queueinfo(int pid, int signum, \
301 void *uinfo); }
302 179 STD { int linux_sys_rt_sigsuspend(linux_sigset_t *unewset, \
303 size_t sigsetsize); }
304 180 STD { int linux_sys_pread(int fd, char *buf, \
305 size_t nbyte, linux_off_t offset); }
306 181 STD { int linux_sys_pwrite(int fd, char *buf, \
307 size_t nbyte, linux_off_t offset); }
308 182 STD { int linux_sys_chown(const char *path, int uid, \
309 int gid); }
310 183 NOARGS { int sys___getcwd(char *bufp, size_t length); }
311 184 UNIMPL capget
312 185 UNIMPL capset
313 186 STD { int linux_sys_sigaltstack( \
314 const struct linux_sigaltstack *ss, \
315 struct linux_sigaltstack *oss); }
316 187 UNIMPL sendfile
317 188 UNIMPL getpmsg
318 189 UNIMPL putpmsg
319 190 NOARGS { int sys___vfork14(void); }
320 191 UNIMPL getrlimit
321 192 UNIMPL mmap2
322 193 STD { int linux_sys_truncate64(const char *path, \
323 off_t length); }
324 194 NOARGS ftruncate64 { int sys_ftruncate(int fd, off_t length); }
325 195 STD { int linux_sys_stat64(const char *path, \
326 struct linux_stat64 *sp); }
327 196 STD { int linux_sys_lstat64(const char *path, \
328 struct linux_stat64 *sp); }
329 197 STD { int linux_sys_fstat64(int fd, \
330 struct linux_stat64 *sp); }
331 198 UNIMPL lchown
332 199 UNIMPL getuid
333 200 UNIMPL getgid
334 201 UNIMPL geteuid
335 202 UNIMPL getegid
336 203 UNIMPL getreuid
337 204 UNIMPL getregid
338 205 UNIMPL getgroups
339 206 UNIMPL setgroups
340 207 UNIMPL fchown
341 208 UNIMPL setresuid
342 209 UNIMPL getresuid
343 210 UNIMPL setresgid
344 211 UNIMPL getresgid
345 212 UNIMPL chown
346 213 UNIMPL setuid
347 214 UNIMPL setgid
348 215 UNIMPL setfsuid
349 216 UNIMPL setfsgid
350 217 UNIMPL pivot_root
351