1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
|
$OpenBSD: syscalls.master,v 1.51 2010/06/30 21:54:12 guenther Exp $
; $NetBSD: syscalls.master,v 1.15 1995/12/18 14:35:10 fvdl Exp $
; @(#)syscalls.master 8.1 (Berkeley) 7/19/93
; OpenBSD COMPAT_LINUX system call name/number "master" file.
; (See syscalls.conf to see what it is processed into.)
;
; Fields: number type [type-dependent ...]
; number system call number, must be in order
; type one of STD, OBSOL, UNIMPL, NODEF, NOARGS, or one of
; the compatibility options defined in syscalls.conf.
;
; types:
; STD always included
; OBSOL obsolete, not included in system
; UNIMPL unimplemented, not included in system
; NODEF included, but don't define the syscall number
; NOARGS included, but don't define the syscall args structure
;
; The compat options are defined in the syscalls.conf file, and the
; compat option name is prefixed to the syscall name. Other than
; that, they're like NODEF (for 'compat' options), or STD (for
; 'libcompat' options).
;
; The type-dependent arguments are as follows:
; For STD, NODEF, NOARGS, and compat syscalls:
; { pseudo-proto } [alias]
; For other syscalls:
; [comment]
;
; #ifdef's, etc. may be included, and are copied to the output files.
; #include's are copied to the syscall switch definition file only.
#include <sys/param.h>
#include <sys/systm.h>
#include <sys/signal.h>
#include <sys/mount.h>
#include <sys/syscallargs.h>
#include <compat/linux/linux_types.h>
#include <compat/linux/linux_signal.h>
#include <compat/linux/linux_misc.h>
#include <compat/linux/linux_syscallargs.h>
#include <machine/linux_machdep.h>
0 NOARGS { int sys_nosys(void); } syscall
1 NOARGS { int sys_exit(int rval); }
2 NOARGS { int sys_fork(void); }
3 NOARGS { int sys_read(int fd, char *buf, u_int nbyte); }
4 NOARGS { int sys_write(int fd, char *buf, u_int nbyte); }
5 STD { int linux_sys_open(char *path, int flags, int mode); }
6 NOARGS { int sys_close(int fd); }
7 STD { int linux_sys_waitpid(int pid, int *status, \
int options);}
8 STD { int linux_sys_creat(char *path, int mode); }
9 NOARGS { int sys_link(char *path, char *link); }
10 STD { int linux_sys_unlink(char *path); }
11 STD { int linux_sys_execve(char *path, char **argp, \
char **envp); }
12 STD { int linux_sys_chdir(char *path); }
13 STD { int linux_sys_time(linux_time_t *t); }
14 STD { int linux_sys_mknod(char *path, int mode, int dev); }
15 STD { int linux_sys_chmod(char *path, int mode); }
16 STD { int linux_sys_lchown16(char *path, int uid, \
int gid); }
17 STD { int linux_sys_break(char *nsize); }
18 STD { int linux_sys_ostat(void); }
19 NOARGS { long compat_43_sys_lseek(int fd, long offset, \
int whence); }
20 STD { pid_t linux_sys_getpid(void); }
21 STD { int linux_sys_mount(char *specialfile, char *dir, \
char *filesystemtype, long rwflag, void *data); }
22 STD { int linux_sys_umount(char *specialfile); }
23 NOARGS linux_setuid16 { int sys_setuid(uid_t uid); }
24 STD linux_getuid16 { uid_t linux_sys_getuid(void); }
25 STD { int linux_sys_stime(linux_time_t *t); }
#ifdef PTRACE
26 STD { int linux_sys_ptrace(void); }
#else
26 UNIMPL ptrace
#endif
27 STD { int linux_sys_alarm(unsigned int secs); }
28 STD { int linux_sys_ofstat(void); }
29 STD { int linux_sys_pause(void); }
30 STD { int linux_sys_utime(char *path, \
struct linux_utimbuf *times); }
31 STD { int linux_sys_stty(void); }
32 STD { int linux_sys_gtty(void); }
33 STD { int linux_sys_access(char *path, int flags); }
34 STD { int linux_sys_nice(int incr); }
35 STD { int linux_sys_ftime(void); }
36 NOARGS { int sys_sync(void); }
37 STD { int linux_sys_kill(int pid, int signum); }
38 STD { int linux_sys_rename(char *from, char *to); }
39 STD { int linux_sys_mkdir(char *path, int mode); }
40 STD { int linux_sys_rmdir(char *path); }
41 NOARGS { int sys_dup(u_int fd); }
42 STD { int linux_sys_pipe(int *pfds); }
43 STD { int linux_sys_times(struct times *tms); }
44 STD { int linux_sys_prof(void); }
45 STD { int linux_sys_brk(char *nsize); }
46 NOARGS linux_setgid16 { int sys_setgid(gid_t gid); }
47 STD linux_getgid16 { gid_t linux_sys_getgid(void); }
48 STD { int linux_sys_signal(int sig, \
linux_handler_t handler); }
49 NOARGS linux_geteuid16 { uid_t sys_geteuid(void); }
50 NOARGS linux_getegid16 { gid_t sys_getegid(void); }
#ifdef ACCOUNTING
51 NOARGS { int sys_acct(char *path); }
#else
51 UNIMPL acct
#endif
52 STD { int linux_sys_phys(void); }
53 STD { int linux_sys_lock(void); }
54 STD { int linux_sys_ioctl(int fd, u_long com, \
caddr_t data); }
55 STD { int linux_sys_fcntl(int fd, int cmd, void *arg); }
56 STD { int linux_sys_mpx(void); }
57 NOARGS { int sys_setpgid(int pid, int pgid); }
58 STD { int linux_sys_ulimit(void); }
59 STD { int linux_sys_oldolduname(struct linux_oldold_utsname *up); }
60 NOARGS { int sys_umask(int newmask); }
61 NOARGS { int sys_chroot(char *path); }
62 STD { int linux_sys_ustat(void); }
63 NOARGS { int sys_dup2(u_int from, u_int to); }
64 NOARGS { pid_t sys_getppid(void); }
65 NOARGS { int sys_getpgrp(void); }
66 NOARGS { int sys_setsid(void); }
67 STD { int linux_sys_sigaction(int signum, \
struct linux_old_sigaction *nsa, \
struct linux_old_sigaction *osa); }
68 STD { int linux_sys_siggetmask(void); }
69 STD { int linux_sys_sigsetmask(linux_old_sigset_t mask); }
70 STD { int linux_sys_setreuid16(int ruid, int euid); }
71 STD { int linux_sys_setregid16(int rgid, int egid); }
72 STD { int linux_sys_sigsuspend(caddr_t restart, \
int oldmask, int mask); }
73 STD { int linux_sys_sigpending(linux_old_sigset_t *mask); }
74 NOARGS { int compat_43_sys_sethostname(char *hostname, \
u_int len);}
75 STD { int linux_sys_setrlimit(u_int which, \
struct linux_rlimit *rlp); }
76 STD { int linux_sys_getrlimit(u_int which, \
struct linux_rlimit *rlp); }
77 NOARGS { int sys_getrusage(int who, struct rusage *rusage); }
78 NOARGS { int sys_gettimeofday(struct timeval *tp, \
struct timezone *tzp); }
79 NOARGS { int sys_settimeofday(struct timeval *tp, \
struct timezone *tzp); }
80 NOARGS linux_getgroups { int sys_getgroups(u_int gidsetsize, \
gid_t *gidset); }
81 NOARGS linux_setgroups { int sys_setgroups(u_int gidsetsize, \
gid_t *gidset); }
82 STD { int linux_sys_oldselect(struct linux_select *lsp); }
83 STD { int linux_sys_symlink(char *path, char *to); }
84 NOARGS { int compat_43_sys_lstat(char *path, \
struct stat43 *up); } olstat
85 STD { int linux_sys_readlink(char *name, char *buf, \
int count); }
86 STD { int linux_sys_uselib(char *path); }
87 NOARGS { int compat_25_sys_swapon(char *name); }
88 NOARGS { int sys_reboot(int opt); }
89 STD { int linux_sys_readdir(int fd, caddr_t dent, \
unsigned int count); }
90 STD { int linux_sys_mmap(struct linux_mmap *lmp); }
91 NOARGS { int sys_munmap(caddr_t addr, int len); }
92 STD { int linux_sys_truncate(char *path, long length); }
93 NOARGS { int compat_43_sys_ftruncate(int fd, long length); }
94 NOARGS { int sys_fchmod(int fd, int mode); }
95 STD { int linux_sys_fchown16(int fd, int uid, int gid); }
96 NOARGS { int sys_getpriority(int which, int who); }
97 NOARGS { int sys_setpriority(int which, int who, int prio); }
98 NOARGS { int sys_profil(caddr_t samples, u_int size, \
u_int offset, u_int scale); }
99 STD { int linux_sys_statfs(char *path, \
struct linux_statfs *sp); }
100 STD { int linux_sys_fstatfs(int fd, \
struct linux_statfs *sp); }
#ifdef __i386__
101 STD { int linux_sys_ioperm(unsigned int lo, \
unsigned int hi, int val); }
#else
101 STD { int linux_sys_ioperm(void); }
#endif
102 STD { int linux_sys_socketcall(int what, void *args); }
103 STD { int linux_sys_klog(void); }
104 NOARGS { int sys_setitimer(u_int which, \
struct itimerval *itv, struct itimerval *oitv); }
105 NOARGS { int sys_getitimer(u_int which, \
struct itimerval *itv); }
106 STD { int linux_sys_stat(char *path, \
struct linux_stat *sp); }
107 STD { int linux_sys_lstat(char *path, \
struct linux_stat *sp); }
108 STD { int linux_sys_fstat(int fd, struct linux_stat *sp); }
109 STD { int linux_sys_olduname(struct linux_old_utsname *up); }
#ifdef __i386__
110 STD { int linux_sys_iopl(int level); }
#else
110 STD { int linux_sys_iopl(void); }
#endif
111 STD { int linux_sys_vhangup(void); }
112 STD { int linux_sys_idle(void); }
113 STD { int linux_sys_vm86old(void); }
114 STD { int linux_sys_wait4(int pid, int *status, \
int options, struct rusage *rusage); }
115 STD { int linux_sys_swapoff(void); }
116 STD { int linux_sys_sysinfo(struct linux_sys_sysinfo_args *sysinfo); }
117 STD { int linux_sys_ipc(int what, int a1, int a2, int a3, \
caddr_t ptr); }
118 NOARGS { int sys_fsync(int fd); }
119 STD { int linux_sys_sigreturn(struct linux_sigcontext *scp); }
120 STD { int linux_sys_clone(int flags, void *stack); }
121 NOARGS { int compat_09_sys_setdomainname(char *name, \
int len); }
122 STD { int linux_sys_uname(struct linux_utsname *up); }
#ifdef __i386__
123 STD { int linux_sys_modify_ldt(int func, void *ptr, \
size_t bytecount); }
#else
123 STD { int linux_sys_modify_ldt(void); }
#endif
124 STD { int linux_sys_adjtimex(void); }
125 NOARGS { int sys_mprotect(caddr_t addr, int len, int prot); }
126 STD { int linux_sys_sigprocmask(int how, \
linux_old_sigset_t *set, linux_old_sigset_t *oset); }
127 STD { int linux_sys_create_module(void); }
128 STD { int linux_sys_init_module(void); }
129 STD { int linux_sys_delete_module(void); }
130 STD { int linux_sys_get_kernel_syms(void); }
131 STD { int linux_sys_quotactl(void); }
132 STD { int linux_sys_getpgid(int pid); }
133 NOARGS { int sys_fchdir(int fd); }
134 STD { int linux_sys_bdflush(void); }
135 STD { int linux_sys_sysfs(void); }
136 STD { int linux_sys_personality(int per); }
137 STD { int linux_sys_afs_syscall(void); }
138 NOARGS linux_setfsuid16 { int linux_sys_setfsuid(uid_t uid); }
139 NOARGS linux_getfsuid16 { int linux_sys_getfsuid(void); }
140 STD { int linux_sys_llseek(int fd, u_int32_t ohigh, \
u_int32_t olow, caddr_t res, int whence); }
141 STD { int linux_sys_getdents(int fd, void *dirent, \
unsigned count); }
142 STD { int linux_sys_select(int nfds, fd_set *readfds, \
fd_set *writefds, fd_set *exceptfds, \
struct timeval *timeout); }
143 NOARGS { int sys_flock(int fd, int how); }
144 NOARGS { int sys_msync(void *addr, int len, int fl); }
145 NOARGS { int sys_readv(int fd, struct iovec *iovp, \
u_int iovcnt); }
146 NOARGS { int sys_writev(int fd, struct iovec *iovp, \
u_int iovcnt); }
147 NOARGS { int sys_getsid(pid_t pid); }
148 STD { int linux_sys_fdatasync(int fd); }
149 STD { int linux_sys___sysctl(struct linux___sysctl *lsp); }
150 NOARGS { int sys_mlock(caddr_t addr, size_t len); }
151 NOARGS { int sys_munlock(caddr_t addr, size_t len); }
152 STD { int linux_sys_mlockall(void); }
153 STD { int linux_sys_munlockall(void); }
154 STD { int linux_sys_sched_setparam(linux_pid_t pid, \
const struct linux_sched_param *sp); }
155 STD { int linux_sys_sched_getparam(linux_pid_t pid, \
struct linux_sched_param *sp); }
156 STD { int linux_sys_sched_setscheduler(linux_pid_t pid, \
int policy, const struct linux_sched_param *sp); }
157 STD { int linux_sys_sched_getscheduler(linux_pid_t pid); }
158 STD { int linux_sys_sched_yield(void); }
159 STD { int linux_sys_sched_get_priority_max(int policy); }
160 STD { int linux_sys_sched_get_priority_min(int policy); }
161 STD { int linux_sys_sched_rr_get_interval(void); }
162 NOARGS { int sys_nanosleep(const struct timespec *rqtp, \
struct timespec *rmtp); }
163 STD { int linux_sys_mremap(void *old_address, \
size_t old_size, size_t new_size, long flags); }
164 STD { int linux_sys_setresuid16(u_int16_t ruid, \
u_int16_t euid, u_int16_t suid); }
165 STD { int linux_sys_getresuid16(u_int16_t *ruid, \
u_int16_t *euid, u_int16_t *suid); }
166 STD { int linux_sys_vm86(void); }
167 STD { int linux_sys_query_module(void); }
168 NOARGS { int sys_poll(struct pollfd *fds, u_int nfds, \
int timeout); }
169 STD { int linux_sys_nfsservctl(void); }
170 STD { int linux_sys_setresgid16(u_int16_t rgid, \
u_int16_t egid, u_int16_t sgid); }
171 STD { int linux_sys_getresgid16(u_int16_t *rgid, \
u_int16_t *egid, u_int16_t *sgid); }
172 STD { int linux_sys_prctl(void); }
173 STD { int linux_sys_rt_sigreturn( \
struct linux_rt_sigframe *sfp); }
174 STD { int linux_sys_rt_sigaction(int signum, \
struct linux_sigaction *nsa, \
struct linux_sigaction *osa, \
size_t sigsetsize); }
175 STD { int linux_sys_rt_sigprocmask(int how, \
const linux_sigset_t *set, \
linux_sigset_t *oset, size_t sigsetsize); }
176 STD { int linux_sys_rt_sigpending(linux_sigset_t *set, \
size_t sigsetsize); }
177 STD { int linux_sys_rt_sigtimedwait(void); }
178 STD { int linux_sys_rt_queueinfo(void); }
179 STD { int linux_sys_rt_sigsuspend(linux_sigset_t *unewset, \
size_t sigsetsize); }
180 STD { int linux_sys_pread(int fd, char *buf, \
size_t nbyte, linux_off_t offset); }
181 STD { int linux_sys_pwrite(int fd, char *buf, \
size_t nbyte, linux_off_t offset); }
182 STD { int linux_sys_chown16(char *path, int uid, \
int gid); }
183 NOARGS { int sys___getcwd(char *bufp, size_t length); }
184 STD { int linux_sys_capget(void); }
185 STD { int linux_sys_capset(void); }
186 STD { int linux_sys_sigaltstack( \
const struct linux_sigaltstack *nss, \
struct linux_sigaltstack *oss); }
187 STD { int linux_sys_sendfile(void); }
188 STD { int linux_sys_getpmsg(void); }
189 STD { int linux_sys_putpmsg(void); }
190 STD { int sys_vfork(void); }
191 STD { int linux_sys_ugetrlimit(u_int which, \
struct linux_rlimit *rlp); }
192 STD { linux_off_t linux_sys_mmap2(unsigned long addr, \
size_t len, int prot, int flags, int fd, \
linux_off_t offset); }
193 STD { int linux_sys_truncate64(char *path, off_t length); }
194 STD { int linux_sys_ftruncate64(int fd, off_t length); }
195 STD { int linux_sys_stat64(char *path, \
struct linux_stat64 *sp); }
196 STD { int linux_sys_lstat64(char *path, \
struct linux_stat64 *sp); }
197 STD { int linux_sys_fstat64(int fd, \
struct linux_stat64 *sp); }
198 NOARGS { int linux_sys_lchown(void); }
199 STD { uid_t linux_sys_getuid(void); }
200 STD { gid_t linux_sys_getgid(void); }
201 NOARGS { uid_t sys_geteuid(void); }
202 NOARGS { gid_t sys_getegid(void); }
203 NOARGS { int sys_setreuid(int ruid, int euid); }
204 NOARGS { int sys_setregid(int rgid, int egid); }
205 NOARGS { int sys_getgroups(u_int gidsetsize, gid_t *gidset); }
206 NOARGS { int sys_setgroups(u_int gidsetsize, gid_t *gidset); }
207 NOARGS { int linux_sys_fchown(void); }
208 NOARGS { int sys_setresuid(uid_t ruid, uid_t euid, \
uid_t suid); }
209 NOARGS { int sys_getresuid(uid_t *ruid, uid_t *euid, \
uid_t *suid); }
210 NOARGS { int sys_setresgid(gid_t rgid, gid_t egid, \
gid_t sgid); }
211 NOARGS { int sys_getresgid(gid_t *rgid, gid_t *egid, \
gid_t *sgid); }
212 NOARGS { int linux_sys_chown(void); }
213 NOARGS { int sys_setuid(uid_t uid); }
214 NOARGS { int sys_setgid(gid_t gid); }
215 STD { int linux_sys_setfsuid(uid_t uid); }
216 NOARGS { int linux_sys_setfsgid(void); }
217 NOARGS { int linux_sys_pivot_root(void); }
218 NOARGS { int linux_sys_mincore(void); }
219 NOARGS { int sys_madvise(void *addr, size_t len, int behav); }
220 STD { int linux_sys_getdents64(int fd, void *dirent, \
unsigned count); }
221 STD { int linux_sys_fcntl64(u_int fd, u_int cmd, \
void *arg); }
222 UNIMPL
223 UNIMPL
224 UNIMPL linux_sys_gettid
225 UNIMPL linux_sys_readahead
226 NOARGS { int linux_sys_setxattr(void); }
227 NOARGS { int linux_sys_lsetxattr(void); }
228 NOARGS { int linux_sys_fsetxattr(void); }
229 NOARGS { int linux_sys_getxattr(void); }
230 NOARGS { int linux_sys_lgetxattr(void); }
231 NOARGS { int linux_sys_fgetxattr(void); }
232 NOARGS { int linux_sys_listxattr(void); }
233 NOARGS { int linux_sys_llistxattr(void); }
234 NOARGS { int linux_sys_flistxattr(void); }
235 NOARGS { int linux_sys_removexattr(void); }
236 NOARGS { int linux_sys_lremovexattr(void); }
237 NOARGS { int linux_sys_fremovexattr(void); }
238 UNIMPL linux_sys_tkill
239 UNIMPL linux_sys_sendfile64
240 UNIMPL linux_sys_futex
241 UNIMPL linux_sys_sched_setaffinity
242 UNIMPL linux_sys_sched_getaffinity
243 UNIMPL linux_sys_set_thread_area
244 UNIMPL linux_sys_get_thread_area
245 UNIMPL linux_sys_io_setup
246 UNIMPL linux_sys_io_destroy
247 UNIMPL linux_sys_io_getevents
248 UNIMPL linux_sys_io_submit
249 UNIMPL linux_sys_io_cancel
250 NOARGS { int linux_sys_fadvise64(void); }
251 UNIMPL
252 NOARGS linux_exit_group { int sys_exit(int rval); }
253 UNIMPL linux_sys_lookup_dcookie
254 UNIMPL linux_sys_epoll_create
255 UNIMPL linux_sys_epoll_ctl
256 UNIMPL linux_sys_epoll_wait
257 UNIMPL linux_sys_remap_file_pages
258 UNIMPL linux_sys_set_tid_address
259 UNIMPL linux_sys_timer_create
260 UNIMPL linux_sys_timer_settime
261 UNIMPL linux_sys_timer_gettime
262 UNIMPL linux_sys_timer_getoverrun
263 UNIMPL linux_sys_timer_delete
264 UNIMPL linux_sys_clock_settime
265 UNIMPL linux_sys_clock_gettime
266 UNIMPL linux_sys_clock_getres
267 UNIMPL linux_sys_clock_nanosleep
|