NetBSD/sys/compat/irix/syscalls.master
manu 022bd85d32 When sproc is used to create a share group with shared memory, there is a
private area called PRDA that remains unshared. We implement this by using
different vmspace for each share group member, and keeping the memory
appings in sync on each mmap/munmap/mprotect/break...

We use irix_saddr_sync_vmcmd and irix_saddr_sync_syscall to apply a
vmcmd or a syscall to all share group member, this makes the job a bit
easier.

Also implements {get|set}rlimit{64}.
2002-06-12 20:33:20 +00:00

397 lines
14 KiB
Plaintext

$NetBSD: syscalls.master,v 1.45 2002/06/12 20:33:21 manu Exp $
; @(#)syscalls.master 8.1 (Berkeley) 7/19/93
; NetBSD COMPAT_IRIX 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 names and switch definition files only.
#if defined(_KERNEL_OPT)
#include "opt_ntp.h"
#include "opt_sysv.h"
#include "opt_compat_43.h"
#endif
#include <sys/param.h>
#include <sys/systm.h>
#include <sys/signal.h>
#include <sys/mount.h>
#include <sys/poll.h>
#include <sys/ioctl_compat.h>
#include <sys/syscallargs.h>
#include <compat/svr4/svr4_types.h>
#include <compat/svr4/svr4_signal.h>
#include <compat/svr4/svr4_ucontext.h>
#include <compat/svr4/svr4_lwp.h>
#include <compat/svr4/svr4_statvfs.h>
#include <compat/svr4/svr4_syscallargs.h>
#include <compat/irix/irix_types.h>
#include <compat/irix/irix_signal.h>
#include <compat/irix/irix_syscallargs.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 irix_sys_open(const char *path, int flags, \
int mode); }
6 NOARGS { int sys_close(int fd); }
7 OBSOL wait
8 NOARGS { int svr4_sys_creat(const char *path, int mode); }
9 NOARGS { int sys_link(char *path, char *link); }
10 NOARGS { int sys_unlink(char *path); }
11 NOARGS { int svr4_sys_execv(const char *path, char **argp); }
12 NOARGS { int sys_chdir(char *path); }
13 NOARGS { int svr4_sys_time(svr4_time_t *t); }
14 OBSOL mknod
15 NOARGS { int sys_chmod(char *path, int mode); }
16 NOARGS { int sys___posix_chown(char *path, int uid, \
int gid); } chown
17 STD { int irix_sys_break(caddr_t nsize); }
18 OBSOL stat
19 NOARGS { long compat_43_sys_lseek(int fd, long offset, \
int whence); }
20 NOARGS MPSAFE { pid_t sys_getpid(void); }
21 UNIMPL old_mount
22 UNIMPL System V umount
23 NOARGS { int sys_setuid(uid_t uid); }
24 NOARGS { uid_t sys_getuid_with_euid(void); }
25 UNIMPL stime
26 UNIMPL ptrace
27 NOARGS { int svr4_sys_alarm(unsigned sec); }
28 NOARGS { int svr4_sys_fstat(int fd, struct svr4_stat *sb); }
29 NOARGS { int svr4_sys_pause(void); }
30 NOARGS { int svr4_sys_utime(const char *path, \
struct svr4_utimbuf *ubuf); }
31 UNIMPL was stty
32 UNIMPL was gtty
33 NOARGS { int svr4_sys_access(const char *path, int flags); }
34 NOARGS { int svr4_sys_nice(int prio); }
35 UNIMPL statfs
36 NOARGS { int sys_sync(void); }
37 NOARGS { int svr4_sys_kill(int pid, int signum); }
38 UNIMPL fstatfs
39 NOARGS { int svr4_sys_pgrpsys(int cmd, int pid, int pgid); }
40 STD { ptrdiff_t irix_sys_syssgi(int request, void *arg1, \
void *arg2, void *arg3, void *arg4, void *arg5); }
41 NOARGS { int sys_dup(u_int fd); }
42 NOARGS { int sys_pipe(void); }
43 NOARGS { int svr4_sys_times(struct tms *tp); }
44 UNIMPL profil
45 UNIMPL plock
46 NOARGS { int sys_setgid(gid_t gid); }
47 NOARGS { gid_t sys_getgid_with_egid(void); }
48 OBSOL ssig
#ifdef SYSVMSG
49 NOARGS { int svr4_sys_msgsys(int what, int a2, int a3, \
int a4, int a5); }
#else
49 UNIMPL msgsys
#endif
50 UNIMPL sysmips
51 UNIMPL acct
#ifdef SYSVSHM
52 STD { int irix_sys_shmsys(int what, int a2, int a3, \
int a4); }
#else
52 UNIMPL shmsys
#endif
#ifdef SYSVSEM
53 NOARGS { int svr4_sys_semsys(int what, int a2, int a3, \
int a4, int a5); }
#else
53 UNIMPL semsys
#endif
54 STD { int irix_sys_ioctl(int fd, u_long com, \
caddr_t data); }
55 UNIMPL uadmin
56 STD { int irix_sys_sysmp(int cmd, void *arg1, void *arg2, \
void *arg3, void *arg4); }
57 NOARGS { int svr4_sys_utssys(void *a1, void *a2, int sel, \
void *a3); }
58 UNIMPL
59 NOARGS { int svr4_sys_execve(const char *path, char **argp, \
char **envp); }
60 NOARGS { int sys_umask(int newmask); }
61 NOARGS { int sys_chroot(char *path); }
62 STD { int irix_sys_fcntl(int fd, int cmd, char *arg); }
63 NOARGS { long svr4_sys_ulimit(int cmd, long newlimit); }
64 UNIMPL reserved for unix/pc
65 UNIMPL reserved for unix/pc
66 UNIMPL reserved for unix/pc
67 UNIMPL reserved for unix/pc
68 UNIMPL reserved for unix/pc
69 UNIMPL reserved for unix/pc
70 OBSOL advfs
71 OBSOL unadvfs
72 OBSOL rmount
73 OBSOL rumount
74 OBSOL rfstart
75 STD { int irix_sys_getrlimit64(int resource, \
struct irix_rlimit64 *rlp); }
76 STD { int irix_sys_setrlimit64(int resource, \
const struct irix_rlimit64 *rlp); }
77 NOARGS { int sys_nanosleep(const struct timespec *rqtp, \
struct timespec *rmtp); }
78 STD { irix_off64_t irix_sys_lseek64(int fd, int pad1, \
irix_off64_t offset, int whence, \
int pad2, int pad3, int pad4); }
79 NOARGS { int sys_rmdir(char *path); }
80 NOARGS { int sys_mkdir(char *path, int mode); }
81 STD { int irix_sys_getdents(int fildes, \
irix_dirent_t *buf, int nbytes); }
82 STD { long irix_sys_sginap (long ticks); }
83 UNIMPL sgikopt
84 UNIMPL sysfs
85 NOARGS { int svr4_sys_getmsg(int fd, struct svr4_strbuf *ctl, \
struct svr4_strbuf *dat, int *flags); }
86 NOARGS { int svr4_sys_putmsg(int fd, struct svr4_strbuf *ctl, \
struct svr4_strbuf *dat, int flags); }
87 NOARGS { int sys_poll(struct pollfd *fds, u_int nfds, \
int timeout); }
88 STD { int irix_sys_sigreturn(struct irix_sigcontext *scp, \
struct irix_ucontext *ucp, int signo); }
89 NOARGS { int compat_43_sys_accept(int s, \
struct sockaddr *name, int *anamelen); }
90 NOARGS { int sys_bind(int s, const struct sockaddr *name, \
int namelen); }
91 NOARGS { int sys_connect(int s, const struct sockaddr *name, \
int namelen); }
92 NOARGS { int32_t compat_43_sys_gethostid(void); }
93 NOARGS { int compat_43_sys_getpeername(int fdes, \
struct sockaddr *asa, int *alen); }
94 NOARGS { int compat_43_sys_getsockname(int fdes, \
struct sockaddr *asa, int *alen); }
95 NOARGS { int sys_getsockopt(int s, int level, int name, \
void *val, int *avalsize); }
96 NOARGS { int sys_listen(int s, int backlog); }
97 NOARGS { int compat_43_sys_recv(int s, caddr_t buf, int len, \
int flags); }
98 NOARGS { ssize_t compat_43_sys_recvfrom(int s, void *buf, \
size_t len, int flags, struct sockaddr *from, \
int *fromlenaddr); }
99 NOARGS { ssize_t compat_43_sys_recvmsg(int s, \
struct msghdr *msg, int flags); }
100 NOARGS { int sys_select(int nd, fd_set *in, fd_set *ou, \
fd_set *ex, struct timeval *tv); }
101 NOARGS { int compat_43_sys_send(int s, caddr_t buf, int len, \
int flags); }
102 NOARGS { ssize_t compat_43_sys_sendmsg(int s, \
const struct msghdr *msg, int flags); }
103 NOARGS { ssize_t sys_sendto(int s, const void *buf, \
size_t len, int flags, const struct sockaddr *to, \
int tolen); }
104 NOARGS { int compat_43_sys_sethostid(int32_t hostid); }
105 NOARGS { int sys_setsockopt(int s, int level, int name, \
const void *val, int valsize); }
106 NOARGS { int sys_shutdown(int s, int how); }
107 NOARGS { int svr4_sys_socket(int domain, int type, \
int protocol); }
108 NOARGS { int compat_43_sys_gethostname(char *hostname, \
u_int len); }
109 NOARGS { int compat_43_sys_sethostname(const char *hostname, \
u_int len); }
110 NOARGS { int compat_09_sys_getdomainname(char *domainname, \
int len); }
111 NOARGS { int compat_09_sys_setdomainname(char *domainname, \
int len); }
112 NOARGS { int sys_truncate(const char *path, long length); }
113 NOARGS { int sys_ftruncate(int fd, long length); }
114 NOARGS { int sys_rename(const char *from, const char *to); }
115 NOARGS { int sys_symlink(const char *path, \
const char *link); }
116 NOARGS { int sys_readlink(const char *path, char *buf, \
size_t count); }
117 UNIMPL lstat
118 UNIMPL
119 UNIMPL nfs_svc
120 UNIMPL nfs_getfh
121 UNIMPL async_daemon
122 UNIMPL exportfs
123 NOARGS { int sys_setregid(gid_t rgid, gid_t egid); }
124 NOARGS { int sys_setreuid(uid_t ruid, uid_t euid); }
125 NOARGS { int sys_getitimer(u_int which, \
struct itimerval *itv); }
126 NOARGS { int sys_setitimer(u_int which, \
struct itimerval *itv, struct itimerval *oitv); }
127 NOARGS { int sys_adjtime(struct timeval *delta, \
struct timeval *olddelta); }
128 NOARGS { int svr4_sys_gettimeofday(struct timeval *tp); }
129 STD { irix_pid_t irix_sys_sproc(void *entry, \
unsigned int inh, void *arg); }
130 STD { ptrdiff_t irix_sys_prctl(unsigned int option, \
void *arg1); }
131 STD { int irix_sys_procblk(int cmd, pid_t pid, int count); }
132 STD { irix_pid_t irix_sys_sprocsp(void *entry, \
unsigned int inh, void *arg, caddr_t sp, \
irix_size_t len); }
133 UNIMPL sgigsc
134 STD { void *irix_sys_mmap(void *addr, irix_size_t len, \
int prot, int flags, int fd, irix_off_t pos); }
135 STD { int irix_sys_munmap(void *addr, int len); }
136 STD { int irix_sys_mprotect(void *addr, \
int len, int prot); }
137 NOARGS { int sys___msync13(void *addr, \
size_t len, int flags); }
138 UNIMPL madvise
139 UNIMPL pagelock
140 UNIMPL getpagesize
141 UNIMPL quotactl
142 UNIMPL
143 NOARGS { int sys_getpgrp(void); }
144 STD { int irix_sys_setpgrp(int pid, int pgid); }
145 UNIMPL vhangup
146 NOARGS { int sys_fsync(int fd); }
147 NOARGS { int sys_fchdir(int fd); }
148 STD { int irix_sys_getrlimit(int resource, \
struct irix_rlimit *rlp); }
149 STD { int irix_sys_setrlimit(int resource, \
const struct irix_rlimit *rlp); }
150 UNIMPL cacheflush
151 UNIMPL cachectl
152 NOARGS { int sys___posix_fchown(int fd, int uid, int gid); } \
fchown
153 NOARGS { int sys_fchmod(int fd, int mode); }
154 UNIMPL wait3
155 UNIMPL socketpair
156 STD { long irix_sys_systeminfo(int what, char *buf, \
long len); }
157 UNIMPL uname
158 STD { int irix_sys_xstat(const int version, \
const char *path, struct stat *buf); }
159 STD { int irix_sys_lxstat(const int version, \
const char *path, struct stat *buf); }
160 STD { int irix_sys_fxstat(const int version, \
const int fd, struct stat *buf); }
161 UNIMPL xmknod
162 STD { int irix_sys_sigaction(int signum, \
const struct svr4_sigaction *nsa, \
struct svr4_sigaction *osa, void *sigtramp); }
163 NOARGS { int svr4_sys_sigpending(int what, \
svr4_sigset_t *set); }
164 STD { int irix_sys_sigprocmask(int how, \
const irix_sigset_t *set, \
irix_sigset_t *oset); }
165 NOARGS { int svr4_sys_sigsuspend( \
const svr4_sigset_t *set); }
166 UNIMPL sigpoll_sys
167 STD { int irix_sys_swapctl(int cmd, void *arg); }
168 STD { int irix_sys_getcontext(irix_ucontext_t *ucp); }
169 STD { int irix_sys_setcontext(const irix_ucontext_t *ucp); }
170 STD { int irix_sys_waitsys(int type, int pid, \
struct irix_irix5_siginfo *info, int options, \
struct rusage *ru); }
171 UNIMPL sigstack
172 UNIMPL sigaltstack
173 UNIMPL sigsendset
174 NOARGS { int svr4_sys_statvfs(const char *path, \
struct svr4_statvfs *fs); }
175 NOARGS { int svr4_sys_fstatvfs(int fd, \
struct svr4_statvfs *fs); }
176 UNIMPL getpmsg
177 UNIMPL putpmsg
178 UNIMPL lchown
179 UNIMPL priocntl
180 UNIMPL sigqueue
181 NOARGS { ssize_t sys_readv(int fd, \
const struct iovec *iovp, int iovcnt); }
182 NOARGS { ssize_t sys_writev(int fd, \
const struct iovec *iovp, int iovcnt); }
183 NOARGS { int sys_truncate(const char *path, int pad, \
off_t length); } truncate64
184 NOARGS { int sys_ftruncate(int fd, int pad, off_t length); } \
ftruncate64
185 STD { void *irix_sys_mmap64(void *addr, irix_size_t len, \
int prot, int flags, int fd, int pad1, \
irix_off_t pos); }
186 UNIMPL dmi
187 NOARGS { ssize_t svr4_sys_pread(int fd, void *buf, \
size_t nbyte, svr4_off_t off); }
188 NOARGS { ssize_t svr4_sys_pwrite(int fd, const void *buf, \
size_t nbyte, svr4_off_t off); }
189 UNIMPL fdatasync
190 UNIMPL sgifastpath
191 UNIMPL attr_get
192 UNIMPL attr_getf
193 UNIMPL attr_set
194 UNIMPL attr_setf
195 UNIMPL attr_remove
196 UNIMPL attr_removef
197 UNIMPL attr_list
198 UNIMPL attr_listf
199 UNIMPL attr_multi
200 UNIMPL attr_multif
201 UNIMPL statvfs64
202 UNIMPL fstatvfs64
203 STD { int irix_sys_getmountid(const char *path, \
irix_mountid_t *buf); }
204 UNIMPL nsproc
205 STD { int irix_sys_getdents64(int fildes, \
irix_dirent64_t *buf, int nbytes); }
206 UNIMPL afs_syscall
207 STD { int irix_sys_ngetdents(int fildes, \
irix_dirent_t *buf, unsigned short nbyte, \
int *eof); }
208 STD { int irix_sys_ngetdents64(int fildes, \
irix_dirent64_t *buf, unsigned short nbyte, \
int *eof); }
209 UNIMPL sgi_sesmgr
210 STD { irix_pid_t irix_sys_pidsprocsp(void *entry, \
unsigned int inh, void *arg, caddr_t sp, \
irix_size_t len, irix_pid_t pid); }
211 UNIMPL rexec
212 UNIMPL timer_create
213 UNIMPL timer_delete
214 UNIMPL timer_settime
215 UNIMPL timer_gettime
216 UNIMPL timer_setoverrun
217 UNIMPL sched_rr_get_interval
218 UNIMPL sched_yield
219 UNIMPL sched_getscheduler
220 UNIMPL sched_setscheduler
221 UNIMPL sched_getparam
222 UNIMPL sched_setparam
223 STD { int irix_sys_usync_cntl(int cmd, void *arg); }
224 UNIMPL psema_cntl
225 UNIMPL restartreturn
226 UNIMPL sysget
227 UNIMPL xpg4_recvmsg
228 UNIMPL umfscall
229 UNIMPL nsproctid
230 UNIMPL rexec_complete
231 UNIMPL xpg4_sigaltstack
232 UNIMPL xpg4_sigaltstack
233 UNIMPL xpg4_setregid
234 UNIMPL linkfollow
235 UNIMPL utimets