xref: /freebsd/sys/amd64/linux32/syscalls.master (revision d3d381b2b194b4d24853e92eecef55f262688d1a)
1 $FreeBSD$
2
3;	@(#)syscalls.master	8.1 (Berkeley) 7/19/93
4; System call name/number master file (or rather, slave, from LINUX).
5; Processed to create linux32_sysent.c, linux32_proto.h and linux32_syscall.h.
6
7; Columns: number audit type nargs name alt{name,tag,rtyp}/comments
8;	number	system call number, must be in order
9;	audit	the audit event associated with the system call
10;		A value of AUE_NULL means no auditing, but it also means that
11;		there is no audit event for the call at this time. For the
12;		case where the event exists, but we don't want auditing, the
13;		event should be #defined to AUE_NULL in audit_kevents.h.
14;	type	one of STD, NOPROTO, UNIMPL
15;	name	pseudo-prototype of syscall routine
16;		If one of the following alts is different, then all appear:
17;	altname	name of system call if different
18;	alttag	name of args struct tag if different from [o]`name'"_args"
19;	altrtyp	return type if not int (bogus - syscalls always return int)
20;		for UNIMPL, name continues with comments
21
22; types:
23;	STD	always included
24;	UNIMPL	not implemented, placeholder only
25;	NOPROTO	same as STD except do not create structure or
26;		function prototype in sys/sysproto.h.  Does add a
27;		definition to syscall.h besides adding a sysent.
28
29#include <sys/param.h>
30#include <sys/sysent.h>
31#include <sys/sysproto.h>
32#include <compat/linux/linux_sysproto.h>
33#include <amd64/linux32/linux.h>
34#include <amd64/linux32/linux32_proto.h>
35
36; Isn't pretty, but there seems to be no other way to trap nosys
37#define	nosys	linux_nosys
38
39; #ifdef's, etc. may be included, and are copied to the output files.
40
410	AUE_NULL	UNIMPL	setup
421	AUE_EXIT	STD	{ void linux_exit(int rval); }
432	AUE_FORK	STD	{ int linux_fork(void); }
443	AUE_NULL	NOPROTO	{ int read(int fd, char *buf, \
45				    u_int nbyte); }
464	AUE_NULL	NOPROTO	{ int write(int fd, char *buf, \
47				    u_int nbyte); }
485	AUE_OPEN_RWTC	STD	{ int linux_open(char *path, l_int flags, \
49				    l_int mode); }
506	AUE_CLOSE	NOPROTO	{ int close(int fd); }
517	AUE_WAIT4	STD	{ int linux_waitpid(l_pid_t pid, \
52				    l_int *status, l_int options); }
538	AUE_CREAT	STD	{ int linux_creat(char *path, \
54				    l_int mode); }
559	AUE_LINK	STD	{ int linux_link(char *path, char *to); }
5610	AUE_UNLINK	STD	{ int linux_unlink(char *path); }
5711	AUE_EXECVE	STD	{ int linux_execve(char *path, uint32_t *argp, \
58				    uint32_t *envp); }
5912	AUE_CHDIR	STD	{ int linux_chdir(char *path); }
6013	AUE_NULL	STD	{ int linux_time(l_time_t *tm); }
6114	AUE_MKNOD	STD	{ int linux_mknod(char *path, l_int mode, \
62				    l_dev_t dev); }
6315	AUE_CHMOD	STD	{ int linux_chmod(char *path, \
64				    l_mode_t mode); }
6516	AUE_LCHOWN	STD	{ int linux_lchown16(char *path, \
66				    l_uid16_t uid, l_gid16_t gid); }
6717	AUE_NULL	UNIMPL	break
6818	AUE_STAT	STD	{ int linux_stat(char *path, \
69				    struct linux_stat *up); }
7019	AUE_LSEEK	STD	{ int linux_lseek(l_uint fdes, l_off_t off, \
71				    l_int whence); }
7220	AUE_GETPID	STD	{ int linux_getpid(void); }
7321	AUE_MOUNT	STD	{ int linux_mount(char *specialfile, \
74				    char *dir, char *filesystemtype, \
75				    l_ulong rwflag, void *data); }
7622	AUE_UMOUNT	STD	{ int linux_oldumount(char *path); }
7723	AUE_SETUID	STD	{ int linux_setuid16(l_uid16_t uid); }
7824	AUE_GETUID	STD	{ int linux_getuid16(void); }
7925	AUE_SETTIMEOFDAY	STD	{ int linux_stime(void); }
8026	AUE_PTRACE	STD	{ int linux_ptrace(l_long req, l_long pid, \
81				    l_long addr, l_long data); }
8227	AUE_NULL	STD	{ int linux_alarm(l_uint secs); }
8328	AUE_FSTAT	UNIMPL	fstat
8429	AUE_NULL	STD	{ int linux_pause(void); }
8530	AUE_UTIME	STD	{ int linux_utime(char *fname, \
86				    struct l_utimbuf *times); }
8731	AUE_NULL	UNIMPL	stty
8832	AUE_NULL	UNIMPL	gtty
8933	AUE_ACCESS	STD	{ int linux_access(char *path, l_int amode); }
9034	AUE_NICE	STD	{ int linux_nice(l_int inc); }
9135	AUE_NULL	UNIMPL	ftime
9236	AUE_SYNC	NOPROTO	{ int sync(void); }
9337	AUE_KILL	STD	{ int linux_kill(l_int pid, l_int signum); }
9438	AUE_RENAME	STD	{ int linux_rename(char *from, char *to); }
9539	AUE_MKDIR	STD	{ int linux_mkdir(char *path, l_int mode); }
9640	AUE_RMDIR	STD	{ int linux_rmdir(char *path); }
9741	AUE_DUP		NOPROTO	{ int dup(u_int fd); }
9842	AUE_PIPE	STD	{ int linux_pipe(l_int *pipefds); }
9943	AUE_NULL	STD	{ int linux_times(struct l_times_argv *buf); }
10044	AUE_NULL	UNIMPL	prof
10145	AUE_NULL	STD	{ int linux_brk(l_ulong dsend); }
10246	AUE_SETGID	STD	{ int linux_setgid16(l_gid16_t gid); }
10347	AUE_GETGID	STD	{ int linux_getgid16(void); }
10448	AUE_NULL	STD	{ int linux_signal(l_int sig, \
105				    l_handler_t handler); }
10649	AUE_GETEUID	STD	{ int linux_geteuid16(void); }
10750	AUE_GETEGID	STD	{ int linux_getegid16(void); }
10851	AUE_ACCT	NOPROTO	{ int acct(char *path); }
10952	AUE_UMOUNT	STD	{ int linux_umount(char *path, l_int flags); }
11053	AUE_NULL	UNIMPL	lock
11154	AUE_IOCTL	STD	{ int linux_ioctl(l_uint fd, l_uint cmd, \
112				    uintptr_t arg); }
11355	AUE_FCNTL	STD	{ int linux_fcntl(l_uint fd, l_uint cmd, \
114				    uintptr_t arg); }
11556	AUE_NULL	UNIMPL	mpx
11657	AUE_SETPGRP	NOPROTO	{ int setpgid(int pid, int pgid); }
11758	AUE_NULL	UNIMPL	ulimit
11859	AUE_NULL	STD	{ int linux_olduname(void); }
11960	AUE_UMASK	NOPROTO	{ int umask(int newmask); }
12061	AUE_CHROOT	NOPROTO	{ int chroot(char *path); }
12162	AUE_NULL	STD	{ int linux_ustat(l_dev_t dev, \
122				    struct l_ustat *ubuf); }
12363	AUE_DUP2	NOPROTO	{ int dup2(u_int from, u_int to); }
12464	AUE_GETPPID	STD	{ int linux_getppid(void); }
12565	AUE_GETPGRP	NOPROTO	{ int getpgrp(void); }
12666	AUE_SETSID	NOPROTO	{ int setsid(void); }
12767	AUE_NULL	STD	{ int linux_sigaction(l_int sig, \
128				    l_osigaction_t *nsa, \
129				    l_osigaction_t *osa); }
13068	AUE_NULL	STD	{ int linux_sgetmask(void); }
13169	AUE_NULL	STD	{ int linux_ssetmask(l_osigset_t mask); }
13270	AUE_SETREUID	STD	{ int linux_setreuid16(l_uid16_t ruid, \
133				    l_uid16_t euid); }
13471	AUE_SETREGID	STD	{ int linux_setregid16(l_gid16_t rgid, \
135				    l_gid16_t egid); }
13672	AUE_NULL	STD	{ int linux_sigsuspend(l_int hist0, \
137				    l_int hist1, l_osigset_t mask); }
13873	AUE_NULL	STD	{ int linux_sigpending(l_osigset_t *mask); }
13974	AUE_SYSCTL	STD	{ int linux_sethostname(char *hostname, \
140				    u_int len); }
14175	AUE_SETRLIMIT	STD	{ int linux_setrlimit(l_uint resource, \
142				    struct l_rlimit *rlim); }
14376	AUE_GETRLIMIT	STD	{ int linux_old_getrlimit(l_uint resource, \
144				    struct l_rlimit *rlim); }
14577	AUE_GETRUSAGE	STD	{ int linux_getrusage(int who, \
146				    struct l_rusage *rusage); }
14778	AUE_NULL	STD	{ int linux_gettimeofday( \
148				    struct l_timeval *tp, \
149				    struct timezone *tzp); }
15079	AUE_SETTIMEOFDAY STD	{ int linux_settimeofday( \
151				    struct l_timeval *tp, \
152				    struct timezone *tzp); }
15380	AUE_GETGROUPS	STD	{ int linux_getgroups16(l_uint gidsetsize, \
154				    l_gid16_t *gidset); }
15581	AUE_SETGROUPS	STD	{ int linux_setgroups16(l_uint gidsetsize, \
156				    l_gid16_t *gidset); }
15782	AUE_SELECT	STD	{ int linux_old_select( \
158				    struct l_old_select_argv *ptr); }
15983	AUE_SYMLINK	STD	{ int linux_symlink(char *path, char *to); }
160; 84: oldlstat
16184	AUE_LSTAT	STD	{ int linux_lstat(char *path, struct linux_lstat *up); }
16285	AUE_READLINK	STD	{ int linux_readlink(char *name, char *buf, \
163				    l_int count); }
16486	AUE_USELIB	UNIMPL	linux_uselib
16587	AUE_SWAPON	NOPROTO	{ int swapon(char *name); }
16688	AUE_REBOOT	STD	{ int linux_reboot(l_int magic1, \
167				    l_int magic2, l_uint cmd, void *arg); }
168; 89: old_readdir
16989	AUE_GETDIRENTRIES	STD { int linux_readdir(l_uint fd, \
170				    struct l_dirent *dent, l_uint count); }
171; 90: old_mmap
17290	AUE_MMAP	STD	{ int linux_mmap(struct l_mmap_argv *ptr); }
17391	AUE_MUNMAP	NOPROTO	{ int munmap(caddr_t addr, int len); }
17492	AUE_TRUNCATE	STD	{ int linux_truncate(char *path, \
175				    l_ulong length); }
17693	AUE_FTRUNCATE	STD	{ int linux_ftruncate(int fd, long length); }
17794	AUE_FCHMOD	NOPROTO	{ int fchmod(int fd, int mode); }
17895	AUE_FCHOWN	NOPROTO	{ int fchown(int fd, int uid, int gid); }
17996	AUE_GETPRIORITY	STD	{ int linux_getpriority(int which, int who); }
18097	AUE_SETPRIORITY	NOPROTO	{ int setpriority(int which, int who, \
181				    int prio); }
18298	AUE_PROFILE	UNIMPL	profil
18399	AUE_STATFS	STD	{ int linux_statfs(char *path, \
184				    struct l_statfs_buf *buf); }
185100	AUE_FSTATFS	STD	{ int linux_fstatfs(l_uint fd, \
186				    struct l_statfs_buf *buf); }
187101	AUE_NULL	UNIMPL	ioperm
188102	AUE_NULL	STD	{ int linux_socketcall(l_int what, \
189				    l_ulong args); }
190103	AUE_NULL	STD	{ int linux_syslog(l_int type, char *buf, \
191				    l_int len); }
192104	AUE_SETITIMER	STD	{ int linux_setitimer(l_int which, \
193				    struct l_itimerval *itv, \
194				    struct l_itimerval *oitv); }
195105	AUE_GETITIMER	STD	{ int linux_getitimer(l_int which, \
196				    struct l_itimerval *itv); }
197106	AUE_STAT	STD	{ int linux_newstat(char *path, \
198				    struct l_newstat *buf); }
199107	AUE_LSTAT	STD	{ int linux_newlstat(char *path, \
200				    struct l_newstat *buf); }
201108	AUE_FSTAT	STD	{ int linux_newfstat(l_uint fd, \
202				    struct l_newstat *buf); }
203; 109: olduname
204109	AUE_NULL	STD	{ int linux_uname(void); }
205110	AUE_NULL	STD	{ int linux_iopl(l_int level); }
206111	AUE_NULL	STD	{ int linux_vhangup(void); }
207112	AUE_NULL	UNIMPL	idle
208113	AUE_NULL	UNIMPL	vm86old
209114	AUE_WAIT4	STD	{ int linux_wait4(l_pid_t pid, \
210				    l_int *status, l_int options, \
211				    struct l_rusage *rusage); }
212115	AUE_SWAPOFF	STD	{ int linux_swapoff(void); }
213116	AUE_NULL	STD	{ int linux_sysinfo(struct l_sysinfo *info); }
214117	AUE_NULL	STD	{ int linux_ipc(l_uint what, l_int arg1, \
215				    l_int arg2, l_int arg3, void *ptr, \
216				    l_long arg5); }
217118	AUE_FSYNC	NOPROTO	{ int fsync(int fd); }
218119	AUE_SIGRETURN	STD	{ int linux_sigreturn( \
219				    struct l_sigframe *sfp); }
220120	AUE_RFORK	STD	{ int linux_clone(l_int flags, void *stack, \
221				    void *parent_tidptr, void *tls, void * child_tidptr); }
222121	AUE_SYSCTL	STD	{ int linux_setdomainname(char *name, \
223				    int len); }
224122	AUE_NULL	STD	{ int linux_newuname( \
225				    struct l_new_utsname *buf); }
226123	AUE_NULL	UNIMPL	modify_ldt
227124	AUE_ADJTIME	STD	{ int linux_adjtimex(void); }
228125	AUE_MPROTECT	STD	{ int linux_mprotect(caddr_t addr, int len, \
229				    int prot); }
230126	AUE_SIGPROCMASK	STD	{ int linux_sigprocmask(l_int how, \
231				    l_osigset_t *mask, l_osigset_t *omask); }
232127	AUE_NULL	UNIMPL	create_module
233128	AUE_NULL	STD	{ int linux_init_module(void); }
234129	AUE_NULL	STD	{ int linux_delete_module(void); }
235130	AUE_NULL	UNIMPL	get_kernel_syms
236131	AUE_QUOTACTL	STD	{ int linux_quotactl(void); }
237132	AUE_GETPGID	NOPROTO	{ int getpgid(int pid); }
238133	AUE_FCHDIR	NOPROTO	{ int fchdir(int fd); }
239134	AUE_BDFLUSH	STD	{ int linux_bdflush(void); }
240135	AUE_NULL	STD	{ int linux_sysfs(l_int option, \
241				    l_ulong arg1, l_ulong arg2); }
242136	AUE_PERSONALITY	STD	{ int linux_personality(l_uint per); }
243137	AUE_NULL	UNIMPL	afs_syscall
244138	AUE_SETFSUID	STD	{ int linux_setfsuid16(l_uid16_t uid); }
245139	AUE_SETFSGID	STD	{ int linux_setfsgid16(l_gid16_t gid); }
246140	AUE_LSEEK	STD	{ int linux_llseek(l_int fd, l_ulong ohigh, \
247				    l_ulong olow, l_loff_t *res, \
248				    l_uint whence); }
249141	AUE_GETDIRENTRIES	STD { int linux_getdents(l_uint fd, void *dent, \
250				    l_uint count); }
251; 142: newselect
252142	AUE_SELECT	STD	{ int linux_select(l_int nfds, \
253				    l_fd_set *readfds, l_fd_set *writefds, \
254				    l_fd_set *exceptfds, \
255				    struct l_timeval *timeout); }
256143	AUE_FLOCK	NOPROTO	{ int flock(int fd, int how); }
257144	AUE_MSYNC	STD	{ int linux_msync(l_ulong addr, \
258				    l_size_t len, l_int fl); }
259145	AUE_READV	STD { int linux_readv(l_ulong fd, struct l_iovec32 *iovp, \
260				    l_ulong iovcnt); }
261146	AUE_WRITEV	STD { int linux_writev(l_ulong fd, struct l_iovec32 *iovp, \
262				    l_ulong iovcnt); }
263147	AUE_GETSID	STD	{ int linux_getsid(l_pid_t pid); }
264148	AUE_NULL	STD	{ int linux_fdatasync(l_uint fd); }
265149	AUE_SYSCTL	STD	{ int linux_sysctl( \
266				    struct l___sysctl_args *args); }
267150	AUE_MLOCK	NOPROTO	{ int mlock(const void *addr, size_t len); }
268151	AUE_MUNLOCK	NOPROTO	{ int munlock(const void *addr, size_t len); }
269152	AUE_MLOCKALL	NOPROTO	{ int mlockall(int how); }
270153	AUE_MUNLOCKALL	NOPROTO	{ int munlockall(void); }
271154	AUE_SCHED_SETPARAM	STD	{ int linux_sched_setparam(l_pid_t pid, \
272				    struct sched_param *param); }
273155	AUE_SCHED_GETPARAM	STD	{ int linux_sched_getparam(l_pid_t pid, \
274				    struct sched_param *param); }
275156	AUE_SCHED_SETSCHEDULER	STD { int linux_sched_setscheduler( \
276				    l_pid_t pid, l_int policy, \
277				    struct sched_param *param); }
278157	AUE_SCHED_GETSCHEDULER	STD { int linux_sched_getscheduler( \
279				    l_pid_t pid); }
280158	AUE_NULL	NOPROTO	{ int sched_yield(void); }
281159	AUE_SCHED_GET_PRIORITY_MAX	STD { int linux_sched_get_priority_max( \
282				    l_int policy); }
283160	AUE_SCHED_GET_PRIORITY_MIN	STD { int linux_sched_get_priority_min( \
284				    l_int policy); }
285161	AUE_SCHED_RR_GET_INTERVAL	STD { int linux_sched_rr_get_interval(l_pid_t pid, \
286				    struct l_timespec *interval); }
287162	AUE_NULL	STD	{ int linux_nanosleep( \
288				    const struct l_timespec *rqtp, \
289				    struct l_timespec *rmtp); }
290163	AUE_NULL	STD	{ int linux_mremap(l_ulong addr, \
291				    l_ulong old_len, l_ulong new_len, \
292				    l_ulong flags, l_ulong new_addr); }
293164	AUE_SETRESUID	STD	{ int linux_setresuid16(l_uid16_t ruid, \
294				    l_uid16_t euid, l_uid16_t suid); }
295165	AUE_GETRESUID	STD	{ int linux_getresuid16(l_uid16_t *ruid, \
296				    l_uid16_t *euid, l_uid16_t *suid); }
297166	AUE_NULL	UNIMPL	vm86
298167	AUE_NULL	UNIMPL	query_module
299168	AUE_POLL	NOPROTO	{ int poll(struct pollfd *fds, \
300				    unsigned int nfds, int timeout); }
301169	AUE_NULL	UNIMPL	nfsservctl
302170	AUE_SETRESGID	STD	{ int linux_setresgid16(l_gid16_t rgid, \
303				    l_gid16_t egid, l_gid16_t sgid); }
304171	AUE_GETRESGID	STD	{ int linux_getresgid16(l_gid16_t *rgid, \
305				    l_gid16_t *egid, l_gid16_t *sgid); }
306172	AUE_PRCTL	STD	{ int linux_prctl(l_int option, l_int arg2, l_int arg3, \
307				    l_int arg4, l_int arg5); }
308173	AUE_NULL	STD	{ int linux_rt_sigreturn( \
309				    struct l_ucontext *ucp); }
310174	AUE_NULL	STD	{ int linux_rt_sigaction(l_int sig, \
311				    l_sigaction_t *act, l_sigaction_t *oact, \
312				    l_size_t sigsetsize); }
313175	AUE_NULL	STD	{ int linux_rt_sigprocmask(l_int how, \
314				    l_sigset_t *mask, l_sigset_t *omask, \
315				    l_size_t sigsetsize); }
316176	AUE_NULL	STD	{ int linux_rt_sigpending(l_sigset_t *set, \
317				    l_size_t sigsetsize); }
318177	AUE_NULL	STD	{ int linux_rt_sigtimedwait(l_sigset_t *mask, \
319				    l_siginfo_t *ptr, \
320				    struct l_timeval *timeout, \
321				    l_size_t sigsetsize); }
322178	AUE_NULL	STD	{ int linux_rt_sigqueueinfo(l_pid_t pid, l_int sig, \
323				    l_siginfo_t *info); }
324179	AUE_NULL	STD	{ int linux_rt_sigsuspend( \
325				    l_sigset_t *newset, \
326				    l_size_t sigsetsize); }
327180	AUE_PREAD	STD	{ int linux_pread(l_uint fd, char *buf, \
328				    l_size_t nbyte, l_loff_t offset); }
329181	AUE_PWRITE	STD	{ int linux_pwrite(l_uint fd, char *buf, \
330				    l_size_t nbyte, l_loff_t offset); }
331182	AUE_CHOWN	STD	{ int linux_chown16(char *path, \
332				    l_uid16_t uid, l_gid16_t gid); }
333183	AUE_GETCWD	STD	{ int linux_getcwd(char *buf, \
334				    l_ulong bufsize); }
335184	AUE_CAPGET	STD	{ int linux_capget(struct l_user_cap_header *hdrp, \
336				    struct l_user_cap_data *datap); }
337185	AUE_CAPSET	STD	{ int linux_capset(struct l_user_cap_header *hdrp, \
338				    struct l_user_cap_data *datap); }
339186	AUE_NULL	STD	{ int linux_sigaltstack(l_stack_t *uss, \
340				    l_stack_t *uoss); }
341187	AUE_SENDFILE	STD	{ int linux_sendfile(void); }
342188	AUE_GETPMSG	UNIMPL	getpmsg
343189	AUE_PUTPMSG	UNIMPL	putpmsg
344190	AUE_VFORK	STD	{ int linux_vfork(void); }
345; 191: ugetrlimit
346191	AUE_GETRLIMIT	STD	{ int linux_getrlimit(l_uint resource, \
347				    struct l_rlimit *rlim); }
348192	AUE_MMAP	STD	{ int linux_mmap2(l_ulong addr, l_ulong len, \
349				    l_ulong prot, l_ulong flags, l_ulong fd, \
350				    l_ulong pgoff); }
351193	AUE_TRUNCATE	STD	{ int linux_truncate64(char *path, \
352				    l_loff_t length); }
353194	AUE_FTRUNCATE	STD	{ int linux_ftruncate64(l_uint fd, \
354				    l_loff_t length); }
355195	AUE_STAT	STD	{ int linux_stat64(const char *filename, \
356				    struct l_stat64 *statbuf); }
357196	AUE_LSTAT	STD	{ int linux_lstat64(const char *filename, \
358				    struct l_stat64 *statbuf); }
359197	AUE_FSTAT	STD	{ int linux_fstat64(l_int fd, \
360				    struct l_stat64 *statbuf); }
361198	AUE_LCHOWN	STD	{ int linux_lchown(char *path, l_uid_t uid, \
362				    l_gid_t gid); }
363199	AUE_GETUID	STD	{ int linux_getuid(void); }
364200	AUE_GETGID	STD	{ int linux_getgid(void); }
365201	AUE_GETEUID	NOPROTO	{ int geteuid(void); }
366202	AUE_GETEGID	NOPROTO	{ int getegid(void); }
367203	AUE_SETREUID	NOPROTO	{ int setreuid(uid_t ruid, uid_t euid); }
368204	AUE_SETREGID	NOPROTO	{ int setregid(gid_t rgid, gid_t egid); }
369205	AUE_GETGROUPS	STD	{ int linux_getgroups(l_int gidsetsize, \
370				    l_gid_t *grouplist); }
371206	AUE_SETGROUPS	STD	{ int linux_setgroups(l_int gidsetsize, \
372				    l_gid_t *grouplist); }
373207	AUE_FCHOWN	NODEF	fchown fchown fchown_args int
374208	AUE_SETRESUID	NOPROTO	{ int setresuid(uid_t ruid, uid_t euid, \
375				    uid_t suid); }
376209	AUE_GETRESUID	NOPROTO	{ int getresuid(uid_t *ruid, uid_t *euid, \
377				    uid_t *suid); }
378210	AUE_SETRESGID	NOPROTO	{ int setresgid(gid_t rgid, gid_t egid, \
379				    gid_t sgid); }
380211	AUE_GETRESGID	NOPROTO	{ int getresgid(gid_t *rgid, gid_t *egid, \
381				    gid_t *sgid); }
382212	AUE_CHOWN	STD	{ int linux_chown(char *path, l_uid_t uid, \
383				    l_gid_t gid); }
384213	AUE_SETUID	NOPROTO	{ int setuid(uid_t uid); }
385214	AUE_SETGID	NOPROTO	{ int setgid(gid_t gid); }
386215	AUE_SETFSUID	STD	{ int linux_setfsuid(l_uid_t uid); }
387216	AUE_SETFSGID	STD	{ int linux_setfsgid(l_gid_t gid); }
388217	AUE_PIVOT_ROOT	STD	{ int linux_pivot_root(char *new_root, \
389				    char *put_old); }
390218	AUE_MINCORE	STD	{ int linux_mincore(l_ulong start, \
391				    l_size_t len, u_char *vec); }
392219	AUE_MADVISE	NOPROTO	{ int madvise(void *addr, size_t len, \
393				    int behav); }
394220	AUE_GETDIRENTRIES	STD { int linux_getdents64(l_uint fd, \
395				    void *dirent, l_uint count); }
396221	AUE_FCNTL	STD	{ int linux_fcntl64(l_uint fd, l_uint cmd, \
397				    uintptr_t arg); }
398222	AUE_NULL	UNIMPL
399223	AUE_NULL	UNIMPL
400224	AUE_NULL	STD	{ long linux_gettid(void); }
401225	AUE_NULL	UNIMPL	linux_readahead
402226	AUE_NULL	STD	{ int linux_setxattr(void); }
403227	AUE_NULL	STD	{ int linux_lsetxattr(void); }
404228	AUE_NULL	STD	{ int linux_fsetxattr(void); }
405229	AUE_NULL	STD	{ int linux_getxattr(void); }
406230	AUE_NULL	STD	{ int linux_lgetxattr(void); }
407231	AUE_NULL	STD	{ int linux_fgetxattr(void); }
408232	AUE_NULL	STD	{ int linux_listxattr(void); }
409233	AUE_NULL	STD	{ int linux_llistxattr(void); }
410234	AUE_NULL	STD	{ int linux_flistxattr(void); }
411235	AUE_NULL	STD	{ int linux_removexattr(void); }
412236	AUE_NULL	STD	{ int linux_lremovexattr(void); }
413237	AUE_NULL	STD	{ int linux_fremovexattr(void); }
414238	AUE_NULL	STD	{ int linux_tkill(int tid, int sig); }
415239	AUE_SENDFILE	UNIMPL	linux_sendfile64
416240	AUE_NULL	STD	{ int linux_sys_futex(void *uaddr, int op, uint32_t val, \
417					struct l_timespec *timeout, uint32_t *uaddr2, uint32_t val3); }
418241	AUE_NULL	STD	{ int linux_sched_setaffinity(l_pid_t pid, l_uint len, \
419					l_ulong *user_mask_ptr); }
420242	AUE_NULL	STD	{ int linux_sched_getaffinity(l_pid_t pid, l_uint len, \
421					l_ulong *user_mask_ptr); }
422243	AUE_NULL	STD	{ int linux_set_thread_area(struct l_user_desc *desc); }
423244	AUE_NULL	UNIMPL	linux_get_thread_area
424245	AUE_NULL	UNIMPL	linux_io_setup
425246	AUE_NULL	UNIMPL	linux_io_destroy
426247	AUE_NULL	UNIMPL	linux_io_getevents
427248	AUE_NULL	UNIMPL	linux_io_submit
428249	AUE_NULL	UNIMPL	linux_io_cancel
429250	AUE_NULL	STD	{ int linux_fadvise64(int fd, l_loff_t offset, \
430					l_size_t len, int advice); }
431251	AUE_NULL	UNIMPL
432252	AUE_EXIT	STD	{ int linux_exit_group(int error_code); }
433253	AUE_NULL	STD	{ int linux_lookup_dcookie(void); }
434254	AUE_NULL	STD	{ int linux_epoll_create(l_int size); }
435255	AUE_NULL	STD	{ int linux_epoll_ctl(l_int epfd, l_int op, l_int fd, \
436					struct epoll_event *event); }
437256	AUE_NULL	STD	{ int linux_epoll_wait(l_int epfd, struct epoll_event *events, \
438					l_int maxevents, l_int timeout); }
439257	AUE_NULL	STD	{ int linux_remap_file_pages(void); }
440258	AUE_NULL	STD	{ int linux_set_tid_address(int *tidptr); }
441259	AUE_NULL	STD	{ int linux_timer_create(clockid_t clock_id, \
442					struct sigevent *evp, l_timer_t *timerid); }
443260	AUE_NULL	STD	{ int linux_timer_settime(l_timer_t timerid, l_int flags, \
444					const struct itimerspec *new, struct itimerspec *old); }
445261	AUE_NULL	STD	{ int linux_timer_gettime(l_timer_t timerid, struct itimerspec *setting); }
446262	AUE_NULL	STD	{ int linux_timer_getoverrun(l_timer_t timerid); }
447263	AUE_NULL	STD	{ int linux_timer_delete(l_timer_t timerid); }
448264	AUE_CLOCK_SETTIME	STD	{ int linux_clock_settime(clockid_t which, struct l_timespec *tp); }
449265	AUE_NULL	STD	{ int linux_clock_gettime(clockid_t which, struct l_timespec *tp); }
450266	AUE_NULL	STD	{ int linux_clock_getres(clockid_t which, struct l_timespec *tp); }
451267	AUE_NULL	STD	{ int linux_clock_nanosleep(clockid_t which, int flags, \
452					struct l_timespec *rqtp, struct l_timespec *rmtp); }
453268	AUE_STATFS	STD	{ int linux_statfs64(char *path, size_t bufsize, struct l_statfs64_buf *buf); }
454269	AUE_FSTATFS	STD	{ int linux_fstatfs64(l_uint fd, size_t bufsize, struct l_statfs64_buf *buf); }
455270	AUE_NULL	STD	{ int linux_tgkill(int tgid, int pid, int sig); }
456271	AUE_UTIMES	STD	{ int linux_utimes(char *fname, \
457					struct l_timeval *tptr); }
458272	AUE_NULL	STD	{ int linux_fadvise64_64(int fd, \
459					l_loff_t offset, l_loff_t len, \
460					int advice); }
461273	AUE_NULL	UNIMPL	vserver
462274	AUE_NULL	STD	{ int linux_mbind(void); }
463275	AUE_NULL	STD	{ int linux_get_mempolicy(void); }
464276	AUE_NULL	STD	{ int linux_set_mempolicy(void); }
465; Linux 2.6.6:
466277	AUE_NULL	STD	{ int linux_mq_open(void); }
467278	AUE_NULL	STD	{ int linux_mq_unlink(void); }
468279	AUE_NULL	STD	{ int linux_mq_timedsend(void); }
469280	AUE_NULL	STD	{ int linux_mq_timedreceive(void); }
470281	AUE_NULL	STD	{ int linux_mq_notify(void); }
471282	AUE_NULL	STD	{ int linux_mq_getsetattr(void); }
472283	AUE_NULL	STD	{ int linux_kexec_load(void); }
473284	AUE_WAIT6	STD	{ int linux_waitid(int idtype, l_pid_t id, \
474				    l_siginfo_t *info, int options, \
475				    struct l_rusage *rusage); }
476285	AUE_NULL	UNIMPL
477; Linux 2.6.11:
478286	AUE_NULL	STD	{ int linux_add_key(void); }
479287	AUE_NULL	STD	{ int linux_request_key(void); }
480288	AUE_NULL	STD	{ int linux_keyctl(void); }
481; Linux 2.6.13:
482289	AUE_NULL	STD	{ int linux_ioprio_set(void); }
483290	AUE_NULL	STD	{ int linux_ioprio_get(void); }
484291	AUE_NULL	STD	{ int linux_inotify_init(void); }
485292	AUE_NULL	STD	{ int linux_inotify_add_watch(void); }
486293	AUE_NULL	STD	{ int linux_inotify_rm_watch(void); }
487; Linux 2.6.16:
488294	AUE_NULL	STD	{ int linux_migrate_pages(void); }
489295	AUE_OPEN_RWTC	STD	{ int linux_openat(l_int dfd, const char *filename, \
490					l_int flags, l_int mode); }
491296	AUE_MKDIRAT	STD	{ int linux_mkdirat(l_int dfd, const char *pathname, \
492					l_int mode); }
493297	AUE_MKNODAT	STD	{ int linux_mknodat(l_int dfd, const char *filename, \
494					l_int mode, l_uint dev); }
495298	AUE_FCHOWNAT	STD	{ int linux_fchownat(l_int dfd, const char *filename, \
496					l_uid16_t uid, l_gid16_t gid, l_int flag); }
497299	AUE_FUTIMESAT	STD	{ int linux_futimesat(l_int dfd, char *filename, \
498					struct l_timeval *utimes); }
499300	AUE_FSTATAT	STD	{ int linux_fstatat64(l_int dfd, char *pathname, \
500					struct l_stat64 *statbuf, l_int flag); }
501301	AUE_UNLINKAT	STD	{ int linux_unlinkat(l_int dfd, const char *pathname, \
502					l_int flag); }
503302	AUE_RENAMEAT	STD	{ int linux_renameat(l_int olddfd, const char *oldname, \
504					l_int newdfd, const char *newname); }
505303	AUE_LINKAT	STD	{ int linux_linkat(l_int olddfd, const char *oldname, \
506					l_int newdfd, const char *newname, l_int flag); }
507304	AUE_SYMLINKAT	STD	{ int linux_symlinkat(const char *oldname, l_int newdfd, \
508					const char *newname); }
509305	AUE_READLINKAT	STD	{ int linux_readlinkat(l_int dfd, const char *path, \
510					char *buf, l_int bufsiz); }
511306	AUE_FCHMODAT	STD	{ int linux_fchmodat(l_int dfd, const char *filename, \
512					l_mode_t mode); }
513307	AUE_FACCESSAT	STD	{ int linux_faccessat(l_int dfd, const char *filename, \
514					l_int amode); }
515308	AUE_SELECT	STD	{ int linux_pselect6(l_int nfds, l_fd_set *readfds,	\
516					l_fd_set *writefds, l_fd_set *exceptfds,	\
517					struct l_timespec *tsp, l_uintptr_t *sig); }
518309	AUE_POLL	STD	{ int linux_ppoll(struct pollfd *fds, uint32_t nfds,	\
519				    struct l_timespec *tsp, l_sigset_t *sset, l_size_t ssize); }
520310	AUE_NULL	STD	{ int linux_unshare(void); }
521; Linux 2.6.17:
522311	AUE_NULL	STD	{ int linux_set_robust_list(struct linux_robust_list_head *head, \
523					l_size_t len); }
524312	AUE_NULL	STD	{ int linux_get_robust_list(l_int pid, \
525				    struct linux_robust_list_head **head, l_size_t *len); }
526313	AUE_NULL	STD	{ int linux_splice(void); }
527314	AUE_NULL	STD	{ int linux_sync_file_range(void); }
528315	AUE_NULL	STD	{ int linux_tee(void); }
529316	AUE_NULL	STD	{ int linux_vmsplice(void); }
530; Linux 2.6.18:
531317	AUE_NULL	STD	{ int linux_move_pages(void); }
532; Linux 2.6.19:
533318	AUE_NULL	STD	{ int linux_getcpu(void); }
534319	AUE_NULL	STD	{ int linux_epoll_pwait(l_int epfd, struct epoll_event *events, \
535				    l_int maxevents, l_int timeout, l_sigset_t *mask, \
536				    l_size_t sigsetsize); }
537; Linux 2.6.22:
538320	AUE_FUTIMESAT	STD	{ int linux_utimensat(l_int dfd, const char *pathname, \
539					const struct l_timespec *times, l_int flags); }
540321	AUE_NULL	STD	{ int linux_signalfd(void); }
541322	AUE_NULL	STD	{ int linux_timerfd_create(l_int clockid, l_int flags); }
542323	AUE_NULL	STD	{ int linux_eventfd(l_uint initval); }
543; Linux 2.6.23:
544324	AUE_NULL	STD	{ int linux_fallocate(l_int fd, l_int mode, \
545				    l_loff_t offset, l_loff_t len); }
546; Linux 2.6.25:
547325	AUE_NULL	STD	{ int linux_timerfd_settime(l_int fd, l_int flags,	\
548				    const struct l_itimerspec *new_value,		\
549				    struct l_itimerspec *old_value); }
550326	AUE_NULL	STD	{ int linux_timerfd_gettime(l_int fd,	\
551				    struct l_itimerspec *old_value); }
552; Linux 2.6.27:
553327	AUE_NULL	STD	{ int linux_signalfd4(void); }
554328	AUE_NULL	STD	{ int linux_eventfd2(l_uint initval, l_int flags); }
555329	AUE_NULL	STD	{ int linux_epoll_create1(l_int flags); }
556330	AUE_NULL	STD	{ int linux_dup3(l_int oldfd,		\
557					l_int newfd, l_int flags); }
558331	AUE_NULL	STD	{ int linux_pipe2(l_int *pipefds, l_int flags); }
559332	AUE_NULL	STD	{ int linux_inotify_init1(void); }
560; Linux 2.6.30:
561333	AUE_NULL	STD	{ int linux_preadv(l_ulong fd, 			\
562				    struct iovec *vec, l_ulong vlen,		\
563				    l_ulong pos_l, l_ulong pos_h); }
564334	AUE_NULL	STD	{ int linux_pwritev(l_ulong fd, 		\
565				    struct iovec *vec, l_ulong vlen,		\
566				    l_ulong pos_l, l_ulong pos_h); }
567; Linux 2.6.31:
568335	AUE_NULL	STD	{ int linux_rt_tgsigqueueinfo(l_pid_t tgid,	\
569				    l_pid_t tid, l_int sig, l_siginfo_t *uinfo); }
570336	AUE_NULL	STD	{ int linux_perf_event_open(void); }
571; Linux 2.6.33:
572337	AUE_NULL	STD	{ int linux_recvmmsg(l_int s,			\
573				    struct l_mmsghdr *msg, l_uint vlen,		\
574				    l_uint flags, struct l_timespec *timeout); }
575338	AUE_NULL	STD	{ int linux_fanotify_init(void); }
576339	AUE_NULL	STD	{ int linux_fanotify_mark(void); }
577; Linux 2.6.36:
578340	AUE_NULL	STD	{ int linux_prlimit64(l_pid_t pid,	\
579				    l_uint resource,			\
580				    struct rlimit *new,			\
581				    struct rlimit *old); }
582; Linux 2.6.39:
583341	AUE_NULL	STD	{ int linux_name_to_handle_at(void); }
584342	AUE_NULL	STD	{ int linux_open_by_handle_at(void); }
585343	AUE_NULL	STD	{ int linux_clock_adjtime(void); }
586344	AUE_SYNC	STD	{ int linux_syncfs(l_int fd); }
587; Linux 3.0:
588345	AUE_NULL	STD	{ int linux_sendmmsg(l_int s,			\
589				    struct l_mmsghdr *msg, l_uint vlen,		\
590				    l_uint flags); }
591346	AUE_NULL	STD	{ int linux_setns(void); }
592; Linux 3.2 (glibc 2.15):
593347	AUE_NULL	STD	{ int linux_process_vm_readv(l_pid_t pid,	\
594				    const struct iovec *lvec, l_ulong liovcnt,	\
595				    const struct iovec *rvec, l_ulong riovcnt,	\
596				    l_ulong flags); }
597348	AUE_NULL	STD	{ int linux_process_vm_writev(l_pid_t pid,	\
598				    const struct iovec *lvec, l_ulong liovcnt,	\
599				    const struct iovec *rvec, l_ulong riovcnt,	\
600				    l_ulong flags); }
601; Linux 3.5 (no glibc wrapper):
602349	AUE_NULL	STD	{ int linux_kcmp(l_pid_t pid1, l_pid_t pid2,	\
603				    l_int type, l_ulong idx1, l_ulong idx); }
604; Linux 3.8 (no glibc wrapper):
605350	AUE_NULL	STD	{ int linux_finit_module(l_int fd,		\
606				    const char *uargs, l_int flags); }
607; Linux 3.14:
608351	AUE_NULL	STD	{ int linux_sched_setattr(l_pid_t pid,		\
609				    void *attr, l_uint flags); }
610352	AUE_NULL	STD	{ int linux_sched_getattr(l_pid_t pid,		\
611				    void *attr, l_uint size, l_uint flags); }
612; Linux 3.15:
613353	AUE_NULL	STD	{ int linux_renameat2(l_int oldfd,		\
614				    const char *oldname, l_int newfd, 		\
615				    const char *newname, unsigned int flags); }
616; Linux 3.17:
617354	AUE_NULL	STD	{ int linux_seccomp(l_uint op, l_uint flags,	\
618				    const char *uargs); }
619355	AUE_NULL	STD	{ int linux_getrandom(char *buf,		\
620				    l_size_t count, l_uint flags); }
621356	AUE_NULL	STD	{ int linux_memfd_create(const char *uname_ptr,	\
622				    l_uint flags); }
623; Linux 3.18:
624357	AUE_NULL	STD	{ int linux_bpf(l_int cmd, void *attr,		\
625				    l_uint size); }
626; Linux 3.19:
627358	AUE_NULL	STD	{ int linux_execveat(l_int dfd,			\
628				    const char *filename, const char **argv,	\
629				    const char **envp, l_int flags); }
630; Linux 4.3: sockets now direct system calls:
631359	AUE_SOCKET	STD	{ int linux_socket(l_int domain, l_int type, \
632				    l_int protocol); }
633360	AUE_SOCKETPAIR	STD	{ int linux_socketpair(l_int domain, \
634				    l_int type, l_int protocol, l_uintptr_t rsv); }
635361	AUE_BIND	STD	{ int linux_bind(l_int s, l_uintptr_t name, \
636				    l_int namelen); }
637362	AUE_CONNECT	STD	{ int linux_connect(l_int s, l_uintptr_t name, \
638				    l_int namelen); }
639363	AUE_LISTEN	STD	{ int linux_listen(l_int s, l_int backlog); }
640364	AUE_ACCEPT	STD	{ int linux_accept4(l_int s, l_uintptr_t addr, \
641				    l_uintptr_t namelen, l_int flags); }
642365	AUE_GETSOCKOPT	STD	{ int linux_getsockopt(l_int s, l_int level, \
643				    l_int optname, l_uintptr_t optval, \
644				    l_uintptr_t optlen); }
645366	AUE_SETSOCKOPT	STD	{ int linux_setsockopt(l_int s, l_int level, \
646				    l_int optname, l_uintptr_t optval, \
647				    l_int optlen); }
648367	AUE_GETSOCKNAME	STD	{ int linux_getsockname(l_int s, \
649				    l_uintptr_t addr, l_uintptr_t namelen); }
650368	AUE_GETPEERNAME	STD	{ int linux_getpeername(l_int s, \
651				    l_uintptr_t addr, l_uintptr_t namelen); }
652369	AUE_SENDTO	STD	{ int linux_sendto(l_int s, l_uintptr_t msg, \
653				    l_int len, l_int flags, l_uintptr_t to, \
654				    l_int tolen); }
655370	AUE_SENDMSG	STD	{ int linux_sendmsg(l_int s, l_uintptr_t msg, \
656				    l_int flags); }
657371	AUE_RECVFROM	STD	{ int linux_recvfrom(l_int s, l_uintptr_t buf, \
658				    l_size_t len, l_int flags, l_uintptr_t from, \
659				    l_uintptr_t fromlen); }
660372	AUE_RECVMSG	STD	{ int linux_recvmsg(l_int s, l_uintptr_t msg, \
661				    l_int flags); }
662373	AUE_NULL	STD	{ int linux_shutdown(l_int s, l_int how); }
663;
664; Linux 4.2:
665374	AUE_NULL	STD	{ int linux_userfaultfd(l_int flags); }
666; Linux 4.3:
667375	AUE_NULL	STD	{ int linux_membarrier(l_int cmd, l_int flags); }
668; Linux 4.4:
669376	AUE_NULL	STD	{ int linux_mlock2(l_ulong start, l_size_t len,	\
670				    l_int flags); }
671; Linux 4.5:
672377	AUE_NULL	STD	{ int linux_copy_file_range(l_int fd_in,	\
673				    l_loff_t *off_in, l_int fd_out,		\
674				    l_loff_t *off_out, l_size_t len,		\
675				    l_uint flags); }
676; Linux 4.6:
677378	AUE_NULL	STD	{ int linux_preadv2(l_ulong fd,			\
678				    const struct iovec *vec, l_ulong vlen,	\
679				    l_ulong pos_l, l_ulong pos_h, l_int flags); }
680379	AUE_NULL	STD	{ int linux_pwritev2(l_ulong fd,		\
681				    const struct iovec *vec, l_ulong vlen,	\
682				    l_ulong pos_l, l_ulong pos_h, l_int flags); }
683; Linux 4.8:
684380	AUE_NULL	STD	{ int linux_pkey_mprotect(l_ulong start,	\
685				    l_size_t len, l_ulong prot, l_int pkey); }
686381	AUE_NULL	STD	{ int linux_pkey_alloc(l_ulong flags,		\
687				    l_ulong init_val); }
688382	AUE_NULL	STD	{ int linux_pkey_free(l_int pkey); }
689
690; please, keep this line at the end.
691383	AUE_NULL	UNIMPL	nosys
692; vim: syntax=off
693