xref: /netbsd-src/sys/compat/linux/arch/arm/syscalls.master (revision d710132b4b8ce7f7cccaaf660cb16aa16b4077a0)
1	$NetBSD: syscalls.master,v 1.13 2003/06/23 21:25:56 christos Exp $
2
3; Derived from sys/compat/linux/arch/*/syscalls.master
4; and from Linux 2.4.12 arch/arm/kernel/calls.S
5
6; NetBSD/arm COMPAT_LINUX system call name/number "master" file.
7; (See syscalls.conf to see what it is processed into.)
8;
9; Fields: number type [type-dependent ...]
10;	number	system call number, must be in order
11;	type	one of STD, OBSOL, UNIMPL, NODEF, NOARGS, or one of
12;		the compatibility options defined in syscalls.conf.
13;
14; types:
15;	STD	always included
16;	OBSOL	obsolete, not included in system
17;	UNIMPL	unimplemented, not included in system
18;	NODEF	included, but don't define the syscall number
19;	NOARGS	included, but don't define the syscall args structure
20;	INDIR	included, but don't define the syscall args structure
21;		and allow it to be "really" varargs.
22;
23; The compat options are defined in the syscalls.conf file, and the
24; compat option name is prefixed to the syscall name.  Other than
25; that, they're like NODEF (for 'compat' options), or STD (for
26; 'libcompat' options).
27;
28; The type-dependent arguments are as follows:
29; For STD, NODEF, NOARGS, and compat syscalls:
30;	{ pseudo-proto } [alias]
31; For other syscalls:
32;	[comment]
33;
34; #ifdef's, etc. may be included, and are copied to the output files.
35; #include's are copied to the syscall names and switch definition files only.
36
37#if defined(_KERNEL_OPT)
38#include "opt_compat_43.h"
39#endif
40
41#include <sys/param.h>
42#include <sys/poll.h>
43#include <sys/systm.h>
44#include <sys/signal.h>
45#include <sys/mount.h>
46#include <sys/sa.h>
47#include <sys/syscallargs.h>
48
49#include <compat/linux/common/linux_types.h>
50#include <compat/linux/common/linux_signal.h>
51#include <compat/linux/common/linux_siginfo.h>
52#include <compat/linux/common/linux_machdep.h>
53
54#include <compat/linux/linux_syscallargs.h>
55
56%%
57; XXX We have to explicitly declare linux_sys_nosys.
580	NOARGS		{ int linux_sys_nosys(void); }
591	NOARGS		{ int sys_exit(int rval); }
602	NOARGS		{ int sys_fork(void); }
613	NOARGS		{ int sys_read(int fd, char *buf, u_int nbyte); }
624	NOARGS		{ int sys_write(int fd, char *buf, u_int nbyte); }
635	STD		{ int linux_sys_open(const char *path, int flags, \
64			    int mode); }
656	NOARGS		{ int sys_close(int fd); }
667	STD		{ int linux_sys_waitpid(int pid, int *status, \
67			    int options);}
688	STD		{ int linux_sys_creat(const char *path, int mode); }
699	STD		{ int linux_sys_link(const char *path, const \
70			    char *link); }
7110	STD		{ int linux_sys_unlink(const char *path); }
7211	STD		{ int linux_sys_execve(const char *path, char **argp, \
73			    char **envp); }
7412	STD		{ int linux_sys_chdir(const char *path); }
7513	STD		{ int linux_sys_time(linux_time_t *t); }
7614	STD		{ int linux_sys_mknod(const char *path, int mode, \
77			    int dev); }
7815	STD		{ int linux_sys_chmod(const char *path, int mode); }
7916	STD		{ int linux_sys_lchown16(const char *path, int uid, \
80			    int gid); }
8117	OBSOL		break
8218	OBSOL		ostat
8319	NOARGS		{ long compat_43_sys_lseek(int fd, long offset, \
84			    int whence); }
8520	NOARGS MPSAFE	{ pid_t sys_getpid(void); }
8621	UNIMPL		mount
8722	OBSOL		umount
8823	NOARGS		{ int sys_setuid(uid_t uid); }
8924	NOARGS		{ uid_t sys_getuid(void); }
9025	STD		{ int linux_sys_stime(linux_time_t *t); }
9126	STD		{ int linux_sys_ptrace(int request, int pid, \
92			    int addr, int data); }
9327	STD		{ int linux_sys_alarm(unsigned int secs); }
9428	OBSOL		ofstat
9529	STD		{ int linux_sys_pause(void); }
9630	STD		{ int linux_sys_utime(const char *path, \
97			    struct linux_utimbuf *times); }
9831	OBSOL		stty
9932	OBSOL		gtty
10033	STD		{ int linux_sys_access(const char *path, int flags); }
10134	STD		{ int linux_sys_nice(int incr); }
10235	OBSOL		ftime
10336	NOARGS		{ int sys_sync(void); }
10437	STD		{ int linux_sys_kill(int pid, int signum); }
10538	STD		{ int linux_sys_rename(const char *from, \
106			    const char *to); }
10739	STD		{ int linux_sys_mkdir(const char *path, int mode); }
10840	STD		{ int linux_sys_rmdir(const char *path); }
10941	NOARGS		{ int sys_dup(u_int fd); }
11042	STD		{ int linux_sys_pipe(int *pfds); }
11143	STD		{ int linux_sys_times(struct times *tms); }
11244	OBSOL		prof
11345	STD		{ int linux_sys_brk(char *nsize); }
11446	NOARGS		{ int sys_setgid(gid_t gid); }
11547	NOARGS		{ gid_t sys_getgid(void); }
11648	STD		{ int linux_sys_signal(int signum, \
117			    linux_handler_t handler); }
11849	NOARGS		{ uid_t sys_geteuid(void); }
11950	NOARGS		{ gid_t sys_getegid(void); }
12051	NOARGS		{ int sys_acct(char *path); }
12152	UNIMPL		umount
12253	OBSOL		lock
12354	STD		{ int linux_sys_ioctl(int fd, u_long com, \
124			    caddr_t data); }
12555	STD		{ int linux_sys_fcntl(int fd, int cmd, void *arg); }
12656	OBSOL		mpx
12757	NOARGS		{ int sys_setpgid(int pid, int pgid); }
12858	OBSOL		ulimit
12959 	STD		{ int linux_sys_oldolduname( \
130			   struct linux_oldold_utsname *up); }
13160	NOARGS		{ int sys_umask(int newmask); }
13261	NOARGS		{ int sys_chroot(char *path); }
13362	UNIMPL		ustat
13463	NOARGS		{ int sys_dup2(u_int from, u_int to); }
13564	NOARGS		{ pid_t sys_getppid(void); }
13665	NOARGS		{ int sys_getpgrp(void); }
13766	NOARGS		{ int sys_setsid(void); }
13867	STD		{ int linux_sys_sigaction(int signum, \
139			    const struct linux_old_sigaction *nsa, \
140			    struct linux_old_sigaction *osa); }
14168	STD		{ int linux_sys_siggetmask(void); }
14269	STD		{ int linux_sys_sigsetmask(linux_old_sigset_t mask); }
14370	NOARGS		{ int sys_setreuid(uid_t ruid, uid_t euid); }
14471	NOARGS		{ int sys_setregid(gid_t rgid, gid_t egid); }
14572	STD		{ int linux_sys_sigsuspend(caddr_t restart, \
146			    int oldmask, int mask); }
14773	STD		{ int linux_sys_sigpending(linux_old_sigset_t *set); }
14874	NOARGS		{ int compat_43_sys_sethostname(char *hostname, \
149			    u_int len);}
15075	STD		{ int linux_sys_setrlimit(u_int which, \
151			    struct orlimit *rlp); }
15276	STD		{ int linux_sys_getrlimit(u_int which, \
153			    struct orlimit *rlp); }
15477	NOARGS		{ int sys_getrusage(int who, struct rusage *rusage); }
15578	STD		{ int linux_sys_gettimeofday(struct timeval *tp, \
156			    struct timezone *tzp); }
15779	STD		{ int linux_sys_settimeofday(struct timeval *tp, \
158			    struct timezone *tzp); }
15980	NOARGS		{ int sys_getgroups(u_int gidsetsize, gid_t *gidset); }
16081	NOARGS		{ int sys_setgroups(u_int gidsetsize, gid_t *gidset); }
16182	STD		{ int linux_sys_oldselect(struct linux_oldselect *lsp); }
16283	STD		{ int linux_sys_symlink(const char *path, \
163			    const char *to); }
16484	NOARGS		{ int compat_43_sys_lstat(const char *path, \
165			    struct stat43 *up); } oolstat
16685	STD		{ int linux_sys_readlink(const char *name, char *buf, \
167			    int count); }
168#ifdef EXEC_AOUT
16986	STD		{ int linux_sys_uselib(const char *path); }
170#else
17186	EXCL		uselib
172#endif
17387	STD		{ int linux_sys_swapon(char *name); }
17488	STD		{ int linux_sys_reboot(int magic1, int magic2, \
175			    int cmd, void *arg); }
17689	STD		{ int linux_sys_readdir(int fd, caddr_t dent, \
177			    unsigned int count); }
17890	STD		{ int linux_sys_old_mmap(struct linux_oldmmap *lmp); }
17991	NOARGS		{ int sys_munmap(caddr_t addr, int len); }
18092	STD		{ int linux_sys_truncate(const char *path, \
181			    long length); }
18293	NOARGS		{ int compat_43_sys_ftruncate(int fd, long length); }
18394	NOARGS		{ int sys_fchmod(int fd, int mode); }
18495	STD		{ int linux_sys_fchown16(int fd, int uid, int gid); }
18596	NOARGS		{ int sys_getpriority(int which, int who); }
18697	NOARGS		{ int sys_setpriority(int which, int who, int prio); }
18798	NOARGS		{ int sys_profil(caddr_t samples, u_int size, \
188			    u_int offset, u_int scale); }
18999	STD		{ int linux_sys_statfs(const char *path, \
190			    struct linux_statfs *sp); }
191100	STD		{ int linux_sys_fstatfs(int fd, \
192			    struct linux_statfs *sp); }
193101	UNIMPL
194102	STD		{ int linux_sys_socketcall(int what, void *args); }
195103	UNIMPL		syslog
196104	NOARGS		{ int sys_setitimer(u_int which, \
197			    struct itimerval *itv, struct itimerval *oitv); }
198105	NOARGS		{ int sys_getitimer(u_int which, \
199			    struct itimerval *itv); }
200106	STD		{ int linux_sys_stat(const char *path, \
201			    struct linux_stat *sp); }
202107	STD		{ int linux_sys_lstat(const char *path, \
203			    struct linux_stat *sp); }
204108	STD		{ int linux_sys_fstat(int fd, struct linux_stat *sp); }
205109	STD		{ int linux_sys_olduname(struct linux_oldutsname *up); }
206110	UNIMPL
207111	UNIMPL		vhangup
208112	UNIMPL		idle
209113	UNIMPL		syscall
210114	STD		{ int linux_sys_wait4(int pid, int *status, \
211			    int options, struct rusage *rusage); }
212115	STD		{ int linux_sys_swapoff(const char *path); }
213116	STD		{ int linux_sys_sysinfo(struct linux_sysinfo *arg); }
214117	STD		{ int linux_sys_ipc(int what, int a1, int a2, int a3, \
215			    caddr_t ptr); }
216118	NOARGS		{ int sys_fsync(int fd); }
217119	STD		{ int linux_sys_sigreturn(struct linux_sigcontext *scp); }
218120	STD		{ int linux_sys_clone(int flags, void *stack); }
219121	STD		{ int linux_sys_setdomainname(char *domainname, \
220			    int len); }
221122	STD		{ int linux_sys_uname(struct linux_utsname *up); }
222123	UNIMPL		modify_ldt
223124	UNIMPL		adjtimex
224125	STD		{ int linux_sys_mprotect(const void *start, \
225			    unsigned long len, int prot); }
226126	STD		{ int linux_sys_sigprocmask(int how, \
227			    const linux_old_sigset_t *set, \
228			    linux_old_sigset_t *oset); }
229127	UNIMPL		create_module
230128	UNIMPL		init_module
231129	UNIMPL		delete_module
232130	UNIMPL		get_kernel_syms
233131	UNIMPL		quotactl
234132	STD		{ int linux_sys_getpgid(int pid); }
235133	NOARGS		{ int sys_fchdir(int fd); }
236134	UNIMPL		bdflush
237135	UNIMPL		sysfs
238136	STD		{ int linux_sys_personality(int per); }
239137	UNIMPL		afs_syscall
240138	STD		{ int linux_sys_setfsuid(uid_t uid); }
241139	NOARGS		{ int linux_sys_getfsuid(void); }
242140	STD		{ int linux_sys_llseek(int fd, u_int32_t ohigh, \
243			    u_int32_t olow, caddr_t res, int whence); }
244141	STD		{ int linux_sys_getdents(int fd, \
245			    struct linux_dirent *dent, unsigned int count); }
246142	STD		{ int linux_sys_select(int nfds, fd_set *readfds, \
247			    fd_set *writefds, fd_set *exceptfds, \
248			    struct timeval *timeout); }
249143	NOARGS		{ int sys_flock(int fd, int how); }
250144	STD		{ int linux_sys_msync(caddr_t addr, int len, int fl); }
251145	NOARGS		{ int sys_readv(int fd, struct iovec *iovp, \
252				u_int iovcnt); }
253146	NOARGS		{ int sys_writev(int fd, struct iovec *iovp, \
254				u_int iovcnt); }
255147	NOARGS		{ pid_t sys_getsid(pid_t pid); }
256148	STD		{ int linux_sys_fdatasync(int fd); }
257149	STD		{ int linux_sys___sysctl(struct linux___sysctl *lsp); }
258150	NOARGS		{ int sys_mlock(caddr_t addr, size_t len); }
259151	NOARGS		{ int sys_munlock(caddr_t addr, size_t len); }
260152	NOARGS		{ int sys_mlockall(int flags); }
261153	NOARGS		{ int sys_munlockall(void); }
262154	STD		{ int linux_sys_sched_setparam(pid_t pid, \
263			    const struct linux_sched_param *sp); }
264155	STD		{ int linux_sys_sched_getparam(pid_t pid, \
265			    struct linux_sched_param *sp); }
266156	STD		{ int linux_sys_sched_setscheduler(pid_t pid, \
267			    int policy, const struct linux_sched_param *sp); }
268157	STD		{ int linux_sys_sched_getscheduler(pid_t pid); }
269158	STD		{ int linux_sys_sched_yield(void); }
270159	STD		{ int linux_sys_sched_get_priority_max(int policy); }
271160	STD		{ int linux_sys_sched_get_priority_min(int policy); }
272161	UNIMPL		sched_rr_get_interval
273162	NOARGS		{ int sys_nanosleep(const struct timespec *rqtp, \
274				struct timespec *rmtp); }
275163	STD		{ void *linux_sys_mremap(void *old_address, \
276			    size_t old_size, size_t new_size, u_long flags); }
277164	STD		{ int linux_sys_setresuid(uid_t ruid, uid_t euid, \
278			    uid_t suid); }
279165	STD		{ int linux_sys_getresuid(uid_t *ruid, uid_t *euid, \
280			    uid_t *suid); }
281166	UNIMPL
282167	UNIMPL		query_module
283168	NOARGS		{ int sys_poll(struct pollfd *fds, u_int nfds, \
284			    int timeout); }
285169	UNIMPL		nfsservctl
286170	STD		{ int linux_sys_setresgid(gid_t rgid, gid_t egid, \
287			    gid_t sgid); }
288171	STD		{ int linux_sys_getresgid(gid_t *rgid, gid_t *egid, \
289			    gid_t *sgid); }
290172	UNIMPL		prctl
291173	UNIMPL		rt_sigreturn
292;173	STD		{ int linux_sys_rt_sigreturn( \
293;			    struct linux_rt_sigframe *sfp); }
294174	STD		{ int linux_sys_rt_sigaction(int signum, \
295			    const struct linux_sigaction *nsa, \
296			    struct linux_sigaction *osa, \
297			    size_t sigsetsize); }
298175	STD		{ int linux_sys_rt_sigprocmask(int how, \
299			    const linux_sigset_t *set, \
300			    linux_sigset_t *oset, \
301			    size_t sigsetsize); }
302176	STD		{ int linux_sys_rt_sigpending( \
303			    linux_sigset_t *set, \
304			    size_t sigsetsize); }
305177	UNIMPL		rt_sigtimedwait
306; XXX XAX int here?  sigset_t here?  siginfo_t
307178	STD		{ int linux_sys_rt_queueinfo(int pid, int signum, \
308			    void *uinfo); }
309179	STD		{ int linux_sys_rt_sigsuspend(linux_sigset_t *unewset, \
310			    size_t sigsetsize); }
311180	STD		{ int linux_sys_pread(int fd, char *buf, \
312			    size_t nbyte, linux_off_t offset); }
313181	STD		{ int linux_sys_pwrite(int fd, char *buf, \
314			    size_t nbyte, linux_off_t offset); }
315182	STD		{ int linux_sys_chown16(const char *path, int uid, \
316			    int gid); }
317183	NOARGS		{ int sys___getcwd(char *bufp, size_t length); }
318184	UNIMPL		capget
319185	UNIMPL		capset
320186	STD		{ int linux_sys_sigaltstack( \
321			    const struct linux_sigaltstack *ss, \
322			    struct linux_sigaltstack *oss); }
323187	UNIMPL		sendfile
324188	UNIMPL		getpmsg
325189	UNIMPL		putpmsg
326190	NOARGS		vfork { int sys___vfork14(void); }
327191	STD		{ int linux_sys_ugetrlimit(int which, \
328			    struct rlimit *rlp); }
329192	NOARGS		{ linux_off_t linux_sys_mmap2(unsigned long addr, \
330			    size_t len, int prot, int flags, int fd, \
331			    linux_off_t offset); }
332193	STD		{ int linux_sys_truncate64(const char *path, \
333				off_t length); }
334194	NOARGS		ftruncate64 { int sys_ftruncate(int fd, \
335				off_t length); }
336195	STD		{ int linux_sys_stat64(const char *path, \
337				struct linux_stat64 *sp); }
338196	STD		{ int linux_sys_lstat64(const char *path, \
339				struct linux_stat64 *sp); }
340197	STD		{ int linux_sys_fstat64(int fd, \
341				struct linux_stat64 *sp); }
342198	STD		{ int linux_sys_lchown(const char *path, uid_t uid, \
343				gid_t gid); }
344199	NOARGS		getuid32 { uid_t sys_getuid(void); }
345200	NOARGS		getgid32 { gid_t sys_getgid(void); }
346201	NOARGS		geteuid32 { uid_t sys_geteuid(void); }
347202	NOARGS		getegid32 { gid_t sys_getegid(void); }
348203	NOARGS		setreuid32 { int sys_setreuid(uid_t ruid, \
349				uid_t euid); }
350204	NOARGS		setregid32 { int sys_setregid(gid_t rgid, \
351				gid_t egid); }
352205	NOARGS		getgroups32 { int sys_getgroups(u_int gidsetsize, \
353				gid_t *gidset); }
354206	NOARGS		setgroups32 { int sys_setgroups(u_int gidsetsize, \
355				gid_t *gidset); }
356207	NOARGS		fchown32 { int sys___posix_fchown(int fd, uid_t uid, \
357				gid_t gid); }
358208	NOARGS		setresuid32 { int linux_sys_setresuid(uid_t ruid, \
359				uid_t euid, uid_t suid); }
360209	NOARGS		getresuid32 { int linux_sys_getresuid(uid_t *ruid, \
361				uid_t *euid, uid_t *suid); }
362210	NOARGS		setresgid32 { int linux_sys_setresgid(gid_t rgid, \
363				gid_t egid, gid_t sgid); }
364211	NOARGS		getresgid32 { int linux_sys_getresgid(gid_t *rgid, \
365				gid_t *egid, gid_t *sgid); }
366212	STD		chown32 { int linux_sys_chown(const char *path, \
367				uid_t uid, gid_t gid); }
368213	NOARGS		setuid32 { int sys_setuid(uid_t uid); }
369214	NOARGS		setgid32 { int sys_setgid(gid_t gid); }
370215	NOARGS		setfsuid32 { int linux_sys_setfsuid(uid_t uid); }
371216	NOARGS		getfsuid32 { int linux_sys_getfsuid(void); }
372217	STD		{ int linux_sys_getdents64(int fd, \
373			    struct linux_dirent64 *dent, unsigned int count); }
374218	UNIMPL		pivot_root
375219	UNIMPL		mincore
376220	UNIMPL		madvise
377221	STD		{ int linux_sys_fcntl64(int fd, int cmd, void *arg); }
378; Fill until 256
379222	UNIMPL
380223	UNIMPL
381224	UNIMPL
382225	UNIMPL
383226	UNIMPL
384227	UNIMPL
385228	UNIMPL
386229	UNIMPL
387230	UNIMPL
388231	UNIMPL
389232	UNIMPL
390233	UNIMPL
391234	UNIMPL
392235	UNIMPL
393236	UNIMPL
394237	UNIMPL
395238	UNIMPL
396239	UNIMPL
397240	UNIMPL
398241	UNIMPL
399242	UNIMPL
400243	UNIMPL
401244	UNIMPL
402245	UNIMPL
403246	UNIMPL
404247	UNIMPL
405248	UNIMPL
406249	UNIMPL
407250	UNIMPL
408251	UNIMPL
409252	UNIMPL
410253	UNIMPL
411254	UNIMPL
412255	UNIMPL
413
414; ARMLinux actually has two ranges of syscalls.  Normal syscalls use
415; SWI numbers starting at 0x900000 (__NR_SYSCALL_BASE).  Special
416; ARM-specific syscalls use SWI numbers starting at 0x9f00000
417; (__ARM_NR_BASE).  linux_syscall() (in arch/arm/arm/linux_syscall.c)
418; remaps these down to 0x900100 so that we can use one linux_sysent
419; array for the whole lot.
420
421256	UNIMPL
422257	STD		{ int linux_sys_breakpoint(void); }
423258	STD		{ int linux_sys_cacheflush(uintptr_t from, \
424				intptr_t to); }
425259	UNIMPL		usr26
426260	UNIMPL		usr32
427