xref: /netbsd-src/sys/compat/linux/arch/arm/syscalls.master (revision 5e4c038a45edbc7d63b7c2daa76e29f88b64a4e3)
1	$NetBSD: syscalls.master,v 1.11 2002/05/12 15:04:27 jdolecek 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/syscallargs.h>
47
48#include <compat/linux/common/linux_types.h>
49#include <compat/linux/common/linux_signal.h>
50#include <compat/linux/common/linux_siginfo.h>
51#include <compat/linux/common/linux_machdep.h>
52
53#include <compat/linux/linux_syscallargs.h>
54
55%%
56; XXX We have to explicitly declare linux_sys_nosys.
570	NOARGS		{ int linux_sys_nosys(void); }
581	NOARGS		{ int sys_exit(int rval); }
592	NOARGS		{ int sys_fork(void); }
603	NOARGS		{ int sys_read(int fd, char *buf, u_int nbyte); }
614	NOARGS		{ int sys_write(int fd, char *buf, u_int nbyte); }
625	STD		{ int linux_sys_open(const char *path, int flags, \
63			    int mode); }
646	NOARGS		{ int sys_close(int fd); }
657	STD		{ int linux_sys_waitpid(int pid, int *status, \
66			    int options);}
678	STD		{ int linux_sys_creat(const char *path, int mode); }
689	STD		{ int linux_sys_link(const char *path, const \
69			    char *link); }
7010	STD		{ int linux_sys_unlink(const char *path); }
7111	STD		{ int linux_sys_execve(const char *path, char **argp, \
72			    char **envp); }
7312	STD		{ int linux_sys_chdir(const char *path); }
7413	STD		{ int linux_sys_time(linux_time_t *t); }
7514	STD		{ int linux_sys_mknod(const char *path, int mode, \
76			    int dev); }
7715	STD		{ int linux_sys_chmod(const char *path, int mode); }
7816	STD		{ int linux_sys_lchown16(const char *path, int uid, \
79			    int gid); }
8017	OBSOL		break
8118	OBSOL		ostat
8219	NOARGS		{ long compat_43_sys_lseek(int fd, long offset, \
83			    int whence); }
8420	NOARGS MPSAFE	{ pid_t sys_getpid(void); }
8521	UNIMPL		mount
8622	OBSOL		umount
8723	NOARGS		{ int sys_setuid(uid_t uid); }
8824	NOARGS		{ uid_t sys_getuid(void); }
8925	STD		{ int linux_sys_stime(linux_time_t *t); }
9026	STD		{ int linux_sys_ptrace(int request, int pid, \
91			    int addr, int data); }
9227	STD		{ int linux_sys_alarm(unsigned int secs); }
9328	OBSOL		ofstat
9429	STD		{ int linux_sys_pause(void); }
9530	STD		{ int linux_sys_utime(const char *path, \
96			    struct linux_utimbuf *times); }
9731	OBSOL		stty
9832	OBSOL		gtty
9933	STD		{ int linux_sys_access(const char *path, int flags); }
10034	STD		{ int linux_sys_nice(int incr); }
10135	OBSOL		ftime
10236	NOARGS		{ int sys_sync(void); }
10337	STD		{ int linux_sys_kill(int pid, int signum); }
10438	STD		{ int linux_sys_rename(const char *from, \
105			    const char *to); }
10639	STD		{ int linux_sys_mkdir(const char *path, int mode); }
10740	STD		{ int linux_sys_rmdir(const char *path); }
10841	NOARGS		{ int sys_dup(u_int fd); }
10942	STD		{ int linux_sys_pipe(int *pfds); }
11043	STD		{ int linux_sys_times(struct times *tms); }
11144	OBSOL		prof
11245	STD		{ int linux_sys_brk(char *nsize); }
11346	NOARGS		{ int sys_setgid(gid_t gid); }
11447	NOARGS		{ gid_t sys_getgid(void); }
11548	STD		{ int linux_sys_signal(int signum, \
116			    linux_handler_t handler); }
11749	NOARGS		{ uid_t sys_geteuid(void); }
11850	NOARGS		{ gid_t sys_getegid(void); }
11951	NOARGS		{ int sys_acct(char *path); }
12052	UNIMPL		umount
12153	OBSOL		lock
12254	STD		{ int linux_sys_ioctl(int fd, u_long com, \
123			    caddr_t data); }
12455	STD		{ int linux_sys_fcntl(int fd, int cmd, void *arg); }
12556	OBSOL		mpx
12657	NOARGS		{ int sys_setpgid(int pid, int pgid); }
12758	OBSOL		ulimit
12859 	STD		{ int linux_sys_oldolduname( \
129			   struct linux_oldold_utsname *up); }
13060	NOARGS		{ int sys_umask(int newmask); }
13161	NOARGS		{ int sys_chroot(char *path); }
13262	UNIMPL		ustat
13363	NOARGS		{ int sys_dup2(u_int from, u_int to); }
13464	NOARGS		{ pid_t sys_getppid(void); }
13565	NOARGS		{ int sys_getpgrp(void); }
13666	NOARGS		{ int sys_setsid(void); }
13767	STD		{ int linux_sys_sigaction(int signum, \
138			    const struct linux_old_sigaction *nsa, \
139			    struct linux_old_sigaction *osa); }
14068	STD		{ int linux_sys_siggetmask(void); }
14169	STD		{ int linux_sys_sigsetmask(linux_old_sigset_t mask); }
14270	NOARGS		{ int sys_setreuid(uid_t ruid, uid_t euid); }
14371	NOARGS		{ int sys_setregid(gid_t rgid, gid_t egid); }
14472	STD		{ int linux_sys_sigsuspend(caddr_t restart, \
145			    int oldmask, int mask); }
14673	STD		{ int linux_sys_sigpending(linux_old_sigset_t *set); }
14774	NOARGS		{ int compat_43_sys_sethostname(char *hostname, \
148			    u_int len);}
14975	STD		{ int linux_sys_setrlimit(u_int which, \
150			    struct orlimit *rlp); }
15176	STD		{ int linux_sys_getrlimit(u_int which, \
152			    struct orlimit *rlp); }
15377	NOARGS		{ int sys_getrusage(int who, struct rusage *rusage); }
15478	STD		{ int linux_sys_gettimeofday(struct timeval *tp, \
155			    struct timezone *tzp); }
15679	STD		{ int linux_sys_settimeofday(struct timeval *tp, \
157			    struct timezone *tzp); }
15880	NOARGS		{ int sys_getgroups(u_int gidsetsize, gid_t *gidset); }
15981	NOARGS		{ int sys_setgroups(u_int gidsetsize, gid_t *gidset); }
16082	STD		{ int linux_sys_oldselect(struct linux_oldselect *lsp); }
16183	STD		{ int linux_sys_symlink(const char *path, \
162			    const char *to); }
16384	NOARGS		{ int compat_43_sys_lstat(const char *path, \
164			    struct stat43 *up); } oolstat
16585	STD		{ int linux_sys_readlink(const char *name, char *buf, \
166			    int count); }
167#ifdef EXEC_AOUT
16886	STD		{ int linux_sys_uselib(const char *path); }
169#else
17086	EXCL		uselib
171#endif
17287	STD		{ int linux_sys_swapon(char *name); }
17388	STD		{ int linux_sys_reboot(int magic1, int magic2, \
174			    int cmd, void *arg); }
17589	STD		{ int linux_sys_readdir(int fd, caddr_t dent, \
176			    unsigned int count); }
17790	STD		{ int linux_sys_old_mmap(struct linux_oldmmap *lmp); }
17891	NOARGS		{ int sys_munmap(caddr_t addr, int len); }
17992	STD		{ int linux_sys_truncate(const char *path, \
180			    long length); }
18193	NOARGS		{ int compat_43_sys_ftruncate(int fd, long length); }
18294	NOARGS		{ int sys_fchmod(int fd, int mode); }
18395	STD		{ int linux_sys_fchown16(int fd, int uid, int gid); }
18496	NOARGS		{ int sys_getpriority(int which, int who); }
18597	NOARGS		{ int sys_setpriority(int which, int who, int prio); }
18698	NOARGS		{ int sys_profil(caddr_t samples, u_int size, \
187			    u_int offset, u_int scale); }
18899	STD		{ int linux_sys_statfs(const char *path, \
189			    struct linux_statfs *sp); }
190100	STD		{ int linux_sys_fstatfs(int fd, \
191			    struct linux_statfs *sp); }
192101	UNIMPL
193102	STD		{ int linux_sys_socketcall(int what, void *args); }
194103	UNIMPL		syslog
195104	NOARGS		{ int sys_setitimer(u_int which, \
196			    struct itimerval *itv, struct itimerval *oitv); }
197105	NOARGS		{ int sys_getitimer(u_int which, \
198			    struct itimerval *itv); }
199106	STD		{ int linux_sys_stat(const char *path, \
200			    struct linux_stat *sp); }
201107	STD		{ int linux_sys_lstat(const char *path, \
202			    struct linux_stat *sp); }
203108	STD		{ int linux_sys_fstat(int fd, struct linux_stat *sp); }
204109	STD		{ int linux_sys_olduname(struct linux_oldutsname *up); }
205110	UNIMPL
206111	UNIMPL		vhangup
207112	UNIMPL		idle
208113	UNIMPL		syscall
209114	STD		{ int linux_sys_wait4(int pid, int *status, \
210			    int options, struct rusage *rusage); }
211115	STD		{ int linux_sys_swapoff(const char *path); }
212116	STD		{ int linux_sys_sysinfo(struct linux_sysinfo *arg); }
213117	STD		{ int linux_sys_ipc(int what, int a1, int a2, int a3, \
214			    caddr_t ptr); }
215118	NOARGS		{ int sys_fsync(int fd); }
216119	STD		{ int linux_sys_sigreturn(struct linux_sigcontext *scp); }
217120	STD		{ int linux_sys_clone(int flags, void *stack); }
218121	STD		{ int linux_sys_setdomainname(char *domainname, \
219			    int len); }
220122	STD		{ int linux_sys_uname(struct linux_utsname *up); }
221123	UNIMPL		modify_ldt
222124	UNIMPL		adjtimex
223125	STD		{ int linux_sys_mprotect(const void *start, \
224			    unsigned long len, int prot); }
225126	STD		{ int linux_sys_sigprocmask(int how, \
226			    const linux_old_sigset_t *set, \
227			    linux_old_sigset_t *oset); }
228127	UNIMPL		create_module
229128	UNIMPL		init_module
230129	UNIMPL		delete_module
231130	UNIMPL		get_kernel_syms
232131	UNIMPL		quotactl
233132	STD		{ int linux_sys_getpgid(int pid); }
234133	NOARGS		{ int sys_fchdir(int fd); }
235134	UNIMPL		bdflush
236135	UNIMPL		sysfs
237136	STD		{ int linux_sys_personality(int per); }
238137	UNIMPL		afs_syscall
239138	STD		{ int linux_sys_setfsuid(uid_t uid); }
240139	NOARGS		{ int linux_sys_getfsuid(void); }
241140	STD		{ int linux_sys_llseek(int fd, u_int32_t ohigh, \
242			    u_int32_t olow, caddr_t res, int whence); }
243141	STD		{ int linux_sys_getdents(int fd, \
244			    struct linux_dirent *dent, unsigned int count); }
245142	STD		{ int linux_sys_select(int nfds, fd_set *readfds, \
246			    fd_set *writefds, fd_set *exceptfds, \
247			    struct timeval *timeout); }
248143	NOARGS		{ int sys_flock(int fd, int how); }
249144	STD		{ int linux_sys_msync(caddr_t addr, int len, int fl); }
250145	NOARGS		{ int sys_readv(int fd, struct iovec *iovp, \
251				u_int iovcnt); }
252146	NOARGS		{ int sys_writev(int fd, struct iovec *iovp, \
253				u_int iovcnt); }
254147	NOARGS		{ pid_t sys_getsid(pid_t pid); }
255148	STD		{ int linux_sys_fdatasync(int fd); }
256149	STD		{ int linux_sys___sysctl(struct linux___sysctl *lsp); }
257150	NOARGS		{ int sys_mlock(caddr_t addr, size_t len); }
258151	NOARGS		{ int sys_munlock(caddr_t addr, size_t len); }
259152	NOARGS		{ int sys_mlockall(int flags); }
260153	NOARGS		{ int sys_munlockall(void); }
261154	STD		{ int linux_sys_sched_setparam(pid_t pid, \
262			    const struct linux_sched_param *sp); }
263155	STD		{ int linux_sys_sched_getparam(pid_t pid, \
264			    struct linux_sched_param *sp); }
265156	STD		{ int linux_sys_sched_setscheduler(pid_t pid, \
266			    int policy, const struct linux_sched_param *sp); }
267157	STD		{ int linux_sys_sched_getscheduler(pid_t pid); }
268158	STD		{ int linux_sys_sched_yield(void); }
269159	STD		{ int linux_sys_sched_get_priority_max(int policy); }
270160	STD		{ int linux_sys_sched_get_priority_min(int policy); }
271161	UNIMPL		sched_rr_get_interval
272162	NOARGS		{ int sys_nanosleep(const struct timespec *rqtp, \
273				struct timespec *rmtp); }
274163	STD		{ void *linux_sys_mremap(void *old_address, \
275			    size_t old_size, size_t new_size, u_long flags); }
276164	STD		{ int linux_sys_setresuid(uid_t ruid, uid_t euid, \
277			    uid_t suid); }
278165	STD		{ int linux_sys_getresuid(uid_t *ruid, uid_t *euid, \
279			    uid_t *suid); }
280166	UNIMPL
281167	UNIMPL		query_module
282168	NOARGS		{ int sys_poll(struct pollfd *fds, u_int nfds, \
283			    int timeout); }
284169	UNIMPL		nfsservctl
285170	STD		{ int linux_sys_setresgid(gid_t rgid, gid_t egid, \
286			    gid_t sgid); }
287171	STD		{ int linux_sys_getresgid(gid_t *rgid, gid_t *egid, \
288			    gid_t *sgid); }
289172	UNIMPL		prctl
290173	UNIMPL		rt_sigreturn
291;173	STD		{ int linux_sys_rt_sigreturn( \
292;			    struct linux_rt_sigframe *sfp); }
293174	STD		{ int linux_sys_rt_sigaction(int signum, \
294			    const struct linux_sigaction *nsa, \
295			    struct linux_sigaction *osa, \
296			    size_t sigsetsize); }
297175	STD		{ int linux_sys_rt_sigprocmask(int how, \
298			    const linux_sigset_t *set, \
299			    linux_sigset_t *oset, \
300			    size_t sigsetsize); }
301176	STD		{ int linux_sys_rt_sigpending( \
302			    linux_sigset_t *set, \
303			    size_t sigsetsize); }
304177	UNIMPL		rt_sigtimedwait
305; XXX XAX int here?  sigset_t here?  siginfo_t
306178	STD		{ int linux_sys_rt_queueinfo(int pid, int signum, \
307			    void *uinfo); }
308179	STD		{ int linux_sys_rt_sigsuspend(linux_sigset_t *unewset, \
309			    size_t sigsetsize); }
310180	STD		{ int linux_sys_pread(int fd, char *buf, \
311			    size_t nbyte, linux_off_t offset); }
312181	STD		{ int linux_sys_pwrite(int fd, char *buf, \
313			    size_t nbyte, linux_off_t offset); }
314182	STD		{ int linux_sys_chown16(const char *path, int uid, \
315			    int gid); }
316183	NOARGS		{ int sys___getcwd(char *bufp, size_t length); }
317184	UNIMPL		capget
318185	UNIMPL		capset
319186	STD		{ int linux_sys_sigaltstack( \
320			    const struct linux_sigaltstack *ss, \
321			    struct linux_sigaltstack *oss); }
322187	UNIMPL		sendfile
323188	UNIMPL		getpmsg
324189	UNIMPL		putpmsg
325190	NOARGS		vfork { int sys___vfork14(void); }
326191	STD		{ int linux_sys_ugetrlimit(int which, \
327			    struct rlimit *rlp); }
328192	UNIMPL		mmap2
329193	STD		{ int linux_sys_truncate64(const char *path, \
330				off_t length); }
331194	NOARGS		ftruncate64 { int sys_ftruncate(int fd, \
332				off_t length); }
333195	STD		{ int linux_sys_stat64(const char *path, \
334				struct linux_stat64 *sp); }
335196	STD		{ int linux_sys_lstat64(const char *path, \
336				struct linux_stat64 *sp); }
337197	STD		{ int linux_sys_fstat64(int fd, \
338				struct linux_stat64 *sp); }
339198	STD		{ int linux_sys_lchown(const char *path, uid_t uid, \
340				gid_t gid); }
341199	NOARGS		getuid32 { uid_t sys_getuid(void); }
342200	NOARGS		getgid32 { gid_t sys_getgid(void); }
343201	NOARGS		geteuid32 { uid_t sys_geteuid(void); }
344202	NOARGS		getegid32 { gid_t sys_getegid(void); }
345203	NOARGS		setreuid32 { int sys_setreuid(uid_t ruid, \
346				uid_t euid); }
347204	NOARGS		setregid32 { int sys_setregid(gid_t rgid, \
348				gid_t egid); }
349205	NOARGS		getgroups32 { int sys_getgroups(u_int gidsetsize, \
350				gid_t *gidset); }
351206	NOARGS		setgroups32 { int sys_setgroups(u_int gidsetsize, \
352				gid_t *gidset); }
353207	NOARGS		fchown32 { int sys___posix_fchown(int fd, uid_t uid, \
354				gid_t gid); }
355208	NOARGS		setresuid32 { int linux_sys_setresuid(uid_t ruid, \
356				uid_t euid, uid_t suid); }
357209	NOARGS		getresuid32 { int linux_sys_getresuid(uid_t *ruid, \
358				uid_t *euid, uid_t *suid); }
359210	NOARGS		setresgid32 { int linux_sys_setresgid(gid_t rgid, \
360				gid_t egid, gid_t sgid); }
361211	NOARGS		getresgid32 { int linux_sys_getresgid(gid_t *rgid, \
362				gid_t *egid, gid_t *sgid); }
363212	STD		chown32 { int linux_sys_chown(const char *path, \
364				uid_t uid, gid_t gid); }
365213	NOARGS		setuid32 { int sys_setuid(uid_t uid); }
366214	NOARGS		setgid32 { int sys_setgid(gid_t gid); }
367215	NOARGS		setfsuid32 { int linux_sys_setfsuid(uid_t uid); }
368216	NOARGS		getfsuid32 { int linux_sys_getfsuid(void); }
369217	STD		{ int linux_sys_getdents64(int fd, \
370			    struct linux_dirent64 *dent, unsigned int count); }
371218	UNIMPL		pivot_root
372219	UNIMPL		mincore
373220	UNIMPL		madvise
374221	STD		{ int linux_sys_fcntl64(int fd, int cmd, void *arg); }
375; Fill until 256
376222	UNIMPL
377223	UNIMPL
378224	UNIMPL
379225	UNIMPL
380226	UNIMPL
381227	UNIMPL
382228	UNIMPL
383229	UNIMPL
384230	UNIMPL
385231	UNIMPL
386232	UNIMPL
387233	UNIMPL
388234	UNIMPL
389235	UNIMPL
390236	UNIMPL
391237	UNIMPL
392238	UNIMPL
393239	UNIMPL
394240	UNIMPL
395241	UNIMPL
396242	UNIMPL
397243	UNIMPL
398244	UNIMPL
399245	UNIMPL
400246	UNIMPL
401247	UNIMPL
402248	UNIMPL
403249	UNIMPL
404250	UNIMPL
405251	UNIMPL
406252	UNIMPL
407253	UNIMPL
408254	UNIMPL
409255	UNIMPL
410
411; ARMLinux actually has two ranges of syscalls.  Normal syscalls use
412; SWI numbers starting at 0x900000 (__NR_SYSCALL_BASE).  Special
413; ARM-specific syscalls use SWI numbers starting at 0x9f00000
414; (__ARM_NR_BASE).  linux_syscall() (in arch/arm/arm/linux_syscall.c)
415; remaps these down to 0x900100 so that we can use one linux_sysent
416; array for the whole lot.
417
418256	UNIMPL
419257	STD		{ int linux_sys_breakpoint(void); }
420258	STD		{ int linux_sys_cacheflush(uintptr_t from, \
421				intptr_t to); }
422259	UNIMPL		usr26
423260	UNIMPL		usr32
424