NetBSD/sys/kern/syscalls.master

444 lines
17 KiB
Plaintext
Raw Normal View History

$NetBSD: syscalls.master,v 1.44 1996/12/22 07:00:57 cgd Exp $
; @(#)syscalls.master 8.2 (Berkeley) 1/13/94
; NetBSD 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
1994-10-21 03:14:36 +03:00
; the compatibility options defined in syscalls.conf.
;
; types:
; STD always included
; OBSOL obsolete, not included in system
1994-10-21 03:14:36 +03:00
; 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
; INDIR included, but don't define the syscall args structure,
; and allow it to be "really" varargs.
;
; 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>
; Reserved/unimplemented system calls in the range 0-150 inclusive
; are reserved for use in future Berkeley releases.
; Additional system calls implemented in vendor and other
; redistributions should be placed in the reserved range at the end
; of the current calls.
0 INDIR { int sys_syscall(int number, ...); }
1 STD { void sys_exit(int rval); }
2 STD { int sys_fork(void); }
3 STD { ssize_t sys_read(int fd, char *buf, u_int nbyte); }
4 STD { ssize_t sys_write(int fd, char *buf, u_int nbyte); }
5 STD { int sys_open(char *path, int flags, ... int mode); }
6 STD { int sys_close(int fd); }
7 STD { int sys_wait4(int pid, int *status, int options, \
struct rusage *rusage); }
1995-10-10 04:32:53 +03:00
8 COMPAT_43 { int sys_creat(char *path, int mode); } ocreat
9 STD { int sys_link(char *path, char *link); }
10 STD { int sys_unlink(char *path); }
11 OBSOL execv
12 STD { int sys_chdir(char *path); }
13 STD { int sys_fchdir(int fd); }
14 STD { int sys_mknod(char *path, int mode, int dev); }
15 STD { int sys_chmod(char *path, int mode); }
16 STD { int sys_chown(char *path, int uid, int gid); }
17 STD { int sys_obreak(char *nsize); } break
18 STD { int sys_getfsstat(struct statfs *buf, long bufsize, \
int flags); }
1995-10-10 04:32:53 +03:00
19 COMPAT_43 { long sys_lseek(int fd, long offset, int whence); } \
olseek
20 STD { pid_t sys_getpid(void); }
21 STD { int sys_mount(char *type, char *path, int flags, \
caddr_t data); }
22 STD { int sys_unmount(char *path, int flags); }
23 STD { int sys_setuid(uid_t uid); }
24 STD { uid_t sys_getuid(void); }
25 STD { uid_t sys_geteuid(void); }
26 STD { int sys_ptrace(int req, pid_t pid, caddr_t addr, \
int data); }
27 STD { ssize_t sys_recvmsg(int s, struct msghdr *msg, \
int flags); }
28 STD { ssize_t sys_sendmsg(int s, caddr_t msg, int flags); }
29 STD { ssize_t sys_recvfrom(int s, caddr_t buf, size_t len, \
int flags, caddr_t from, int *fromlenaddr); }
30 STD { int sys_accept(int s, caddr_t name, int *anamelen); }
31 STD { int sys_getpeername(int fdes, caddr_t asa, \
int *alen); }
32 STD { int sys_getsockname(int fdes, caddr_t asa, \
int *alen); }
33 STD { int sys_access(char *path, int flags); }
34 STD { int sys_chflags(char *path, int flags); }
35 STD { int sys_fchflags(int fd, int flags); }
36 STD { void sys_sync(void); }
37 STD { int sys_kill(int pid, int signum); }
1995-10-10 04:32:53 +03:00
38 COMPAT_43 { int sys_stat(char *path, struct ostat *ub); } ostat
39 STD { pid_t sys_getppid(void); }
1995-10-10 04:32:53 +03:00
40 COMPAT_43 { int sys_lstat(char *path, struct ostat *ub); } olstat
41 STD { int sys_dup(u_int fd); }
42 STD { int sys_pipe(void); }
43 STD { gid_t sys_getegid(void); }
44 STD { int sys_profil(caddr_t samples, size_t size, \
u_long offset, u_int scale); }
#ifdef KTRACE
45 STD { int sys_ktrace(char *fname, int ops, int facs, \
int pid); }
#else
45 UNIMPL ktrace
#endif
46 STD { int sys_sigaction(int signum, struct sigaction *nsa, \
struct sigaction *osa); }
47 STD { gid_t sys_getgid(void); }
48 STD { int sys_sigprocmask(int how, sigset_t mask); }
49 STD { int sys___getlogin(char *namebuf, u_int namelen); }
50 STD { int sys_setlogin(char *namebuf); }
51 STD { int sys_acct(char *path); }
52 STD { int sys_sigpending(void); }
53 STD { int sys_sigaltstack(struct sigaltstack *nss, \
struct sigaltstack *oss); }
54 STD { int sys_ioctl(int fd, u_long com, ... caddr_t data); }
55 COMPAT_12 { int sys_reboot(int opt); } oreboot
56 STD { int sys_revoke(char *path); }
57 STD { int sys_symlink(char *path, char *link); }
58 STD { int sys_readlink(char *path, char *buf, int count); }
59 STD { int sys_execve(char *path, char **argp, \
char **envp); }
60 STD { int sys_umask(int newmask); }
61 STD { int sys_chroot(char *path); }
1995-10-10 04:32:53 +03:00
62 COMPAT_43 { int sys_fstat(int fd, struct ostat *sb); } ofstat
63 COMPAT_43 { int sys_getkerninfo(int op, char *where, int *size, \
1995-10-10 04:32:53 +03:00
int arg); } ogetkerninfo
64 COMPAT_43 { int sys_getpagesize(void); } ogetpagesize
65 STD { int sys_msync(caddr_t addr, size_t len); }
66 STD { int sys_vfork(void); }
67 OBSOL vread
68 OBSOL vwrite
69 STD { int sys_sbrk(int incr); }
70 STD { int sys_sstk(int incr); }
71 COMPAT_43 { int sys_mmap(caddr_t addr, size_t len, int prot, \
1995-10-10 04:32:53 +03:00
int flags, int fd, long pos); } ommap
72 STD { int sys_ovadvise(int anom); } vadvise
73 STD { int sys_munmap(caddr_t addr, size_t len); }
74 STD { int sys_mprotect(caddr_t addr, size_t len, \
int prot); }
75 STD { int sys_madvise(caddr_t addr, size_t len, \
int behav); }
76 OBSOL vhangup
77 OBSOL vlimit
78 STD { int sys_mincore(caddr_t addr, size_t len, \
char *vec); }
79 STD { int sys_getgroups(u_int gidsetsize, gid_t *gidset); }
80 STD { int sys_setgroups(u_int gidsetsize, gid_t *gidset); }
81 STD { int sys_getpgrp(void); }
82 STD { int sys_setpgid(int pid, int pgid); }
83 STD { int sys_setitimer(u_int which, \
struct itimerval *itv, struct itimerval *oitv); }
1995-10-10 04:32:53 +03:00
84 COMPAT_43 { int sys_wait(void); } owait
85 STD { int sys_swapon(char *name); }
86 STD { int sys_getitimer(u_int which, \
struct itimerval *itv); }
1995-10-10 04:32:53 +03:00
87 COMPAT_43 { int sys_gethostname(char *hostname, u_int len); } \
ogethostname
88 COMPAT_43 { int sys_sethostname(char *hostname, u_int len); } \
osethostname
89 COMPAT_43 { int sys_getdtablesize(void); } ogetdtablesize
90 STD { int sys_dup2(u_int from, u_int to); }
91 UNIMPL getdopt
92 STD { int sys_fcntl(int fd, int cmd, ... void *arg); }
93 STD { int sys_select(u_int nd, fd_set *in, fd_set *ou, \
fd_set *ex, struct timeval *tv); }
94 UNIMPL setdopt
95 STD { int sys_fsync(int fd); }
96 STD { int sys_setpriority(int which, int who, int prio); }
97 STD { int sys_socket(int domain, int type, int protocol); }
98 STD { int sys_connect(int s, caddr_t name, int namelen); }
1995-10-10 04:32:53 +03:00
99 COMPAT_43 { int sys_accept(int s, caddr_t name, int *anamelen); } \
oaccept
100 STD { int sys_getpriority(int which, int who); }
101 COMPAT_43 { int sys_send(int s, caddr_t buf, int len, \
1995-10-10 04:32:53 +03:00
int flags); } osend
102 COMPAT_43 { int sys_recv(int s, caddr_t buf, int len, \
1995-10-10 04:32:53 +03:00
int flags); } orecv
103 STD { int sys_sigreturn(struct sigcontext *sigcntxp); }
104 STD { int sys_bind(int s, caddr_t name, int namelen); }
105 STD { int sys_setsockopt(int s, int level, int name, \
caddr_t val, int valsize); }
106 STD { int sys_listen(int s, int backlog); }
107 OBSOL vtimes
108 COMPAT_43 { int sys_sigvec(int signum, struct sigvec *nsv, \
1995-10-10 04:32:53 +03:00
struct sigvec *osv); } osigvec
109 COMPAT_43 { int sys_sigblock(int mask); } osigblock
110 COMPAT_43 { int sys_sigsetmask(int mask); } osigsetmask
111 STD { int sys_sigsuspend(int mask); }
112 COMPAT_43 { int sys_sigstack(struct sigstack *nss, \
1995-10-10 04:32:53 +03:00
struct sigstack *oss); } osigstack
113 COMPAT_43 { int sys_recvmsg(int s, struct omsghdr *msg, \
1995-10-10 04:32:53 +03:00
int flags); } orecvmsg
114 COMPAT_43 { int sys_sendmsg(int s, caddr_t msg, int flags); } \
osendmsg
#ifdef TRACE
115 STD { int sys_vtrace(int request, int value); }
#else
115 OBSOL vtrace
#endif
116 STD { int sys_gettimeofday(struct timeval *tp, \
struct timezone *tzp); }
117 STD { int sys_getrusage(int who, struct rusage *rusage); }
118 STD { int sys_getsockopt(int s, int level, int name, \
caddr_t val, int *avalsize); }
1995-01-06 03:08:17 +03:00
119 OBSOL resuba
120 STD { ssize_t sys_readv(int fd, struct iovec *iovp, \
u_int iovcnt); }
121 STD { ssize_t sys_writev(int fd, struct iovec *iovp, \
u_int iovcnt); }
122 STD { int sys_settimeofday(struct timeval *tv, \
struct timezone *tzp); }
123 STD { int sys_fchown(int fd, int uid, int gid); }
124 STD { int sys_fchmod(int fd, int mode); }
125 COMPAT_43 { int sys_recvfrom(int s, caddr_t buf, size_t len, \
1995-10-10 04:32:53 +03:00
int flags, caddr_t from, int *fromlenaddr); } \
orecvfrom
126 STD { int sys_setreuid(int ruid, int euid); }
127 STD { int sys_setregid(int rgid, int egid); }
128 STD { int sys_rename(char *from, char *to); }
1995-10-10 04:32:53 +03:00
129 COMPAT_43 { int sys_truncate(char *path, long length); } \
otruncate
130 COMPAT_43 { int sys_ftruncate(int fd, long length); } oftruncate
131 STD { int sys_flock(int fd, int how); }
132 STD { int sys_mkfifo(char *path, int mode); }
133 STD { ssize_t sys_sendto(int s, caddr_t buf, size_t len, \
int flags, caddr_t to, int tolen); }
134 STD { int sys_shutdown(int s, int how); }
135 STD { int sys_socketpair(int domain, int type, \
int protocol, int *rsv); }
136 STD { int sys_mkdir(char *path, int mode); }
137 STD { int sys_rmdir(char *path); }
138 STD { int sys_utimes(char *path, struct timeval *tptr); }
139 OBSOL 4.2 sigreturn
140 STD { int sys_adjtime(struct timeval *delta, \
struct timeval *olddelta); }
141 COMPAT_43 { int sys_getpeername(int fdes, caddr_t asa, \
1995-10-10 04:32:53 +03:00
int *alen); } ogetpeername
142 COMPAT_43 { int32_t sys_gethostid(void); } ogethostid
143 COMPAT_43 { int sys_sethostid(int32_t hostid); } osethostid
144 COMPAT_43 { int sys_getrlimit(u_int which, \
1995-10-10 04:32:53 +03:00
struct ogetrlimit *rlp); } ogetrlimit
145 COMPAT_43 { int sys_setrlimit(u_int which, \
1995-10-10 04:32:53 +03:00
struct ogetrlimit *rlp); } osetrlimit
146 COMPAT_43 { int sys_killpg(int pgid, int signum); } okillpg
147 STD { int sys_setsid(void); }
148 STD { int sys_quotactl(char *path, int cmd, int uid, \
caddr_t arg); }
1995-10-10 04:32:53 +03:00
149 COMPAT_43 { int sys_quota(void); } oquota
150 COMPAT_43 { int sys_getsockname(int fdec, caddr_t asa, \
1995-10-10 04:32:53 +03:00
int *alen); } ogetsockname
; Syscalls 151-180 inclusive are reserved for vendor-specific
; system calls. (This includes various calls added for compatibity
; with other Unix variants.)
; Some of these calls are now supported by BSD...
151 UNIMPL
152 UNIMPL
153 UNIMPL
154 UNIMPL
1994-06-08 15:28:29 +04:00
#if defined(NFSCLIENT) || defined(NFSSERVER)
155 STD { int sys_nfssvc(int flag, caddr_t argp); }
#else
155 UNIMPL
#endif
156 COMPAT_43 { int sys_getdirentries(int fd, char *buf, \
1995-10-10 04:32:53 +03:00
u_int count, long *basep); } ogetdirentries
157 STD { int sys_statfs(char *path, struct statfs *buf); }
158 STD { int sys_fstatfs(int fd, struct statfs *buf); }
159 UNIMPL
160 UNIMPL
#if defined(NFSCLIENT) || defined(NFSSERVER)
161 STD { int sys_getfh(char *fname, fhandle_t *fhp); }
#else
161 UNIMPL getfh
#endif
1995-10-10 04:32:53 +03:00
162 COMPAT_09 { int sys_getdomainname(char *domainname, int len); } \
ogetdomainname
163 COMPAT_09 { int sys_setdomainname(char *domainname, int len); } \
osetdomainname
164 COMPAT_09 { int sys_uname(struct outsname *name); } ouname
165 STD { int sys_sysarch(int op, char *parms); }
166 UNIMPL
167 UNIMPL
168 UNIMPL
; XXX more generally, never on machines where sizeof(void *) != sizeof(int)
#if defined(SYSVSEM) && !defined(alpha)
169 COMPAT_10 { int sys_semsys(int which, int a2, int a3, int a4, \
1995-10-10 04:32:53 +03:00
int a5); } osemsys
#else
169 UNIMPL 1.0 semsys
#endif
; XXX more generally, never on machines where sizeof(void *) != sizeof(int)
#if defined(SYSVMSG) && !defined(alpha)
170 COMPAT_10 { int sys_msgsys(int which, int a2, int a3, int a4, \
1995-10-10 04:32:53 +03:00
int a5, int a6); } omsgsys
#else
170 UNIMPL 1.0 msgsys
#endif
; XXX more generally, never on machines where sizeof(void *) != sizeof(int)
#if defined(SYSVSHM) && !defined(alpha)
1995-10-10 04:32:53 +03:00
171 COMPAT_10 { int sys_shmsys(int which, int a2, int a3, int a4); } \
oshmsys
#else
171 UNIMPL 1.0 shmsys
#endif
172 UNIMPL
173 UNIMPL
174 UNIMPL
175 STD { int sys_ntp_gettime(struct ntptimeval *tp); }
176 STD { int sys_ntp_adjtime(struct timex *tp); }
177 UNIMPL
178 UNIMPL
179 UNIMPL
180 UNIMPL
; Syscalls 180-199 are used by/reserved for BSD
181 STD { int sys_setgid(gid_t gid); }
182 STD { int sys_setegid(gid_t egid); }
183 STD { int sys_seteuid(uid_t euid); }
#ifdef LFS
184 STD { int lfs_bmapv(fsid_t *fsidp, \
struct block_info *blkiov, int blkcnt); }
185 STD { int lfs_markv(fsid_t *fsidp, \
struct block_info *blkiov, int blkcnt); }
186 STD { int lfs_segclean(fsid_t *fsidp, u_long segment); }
187 STD { int lfs_segwait(fsid_t *fsidp, struct timeval *tv); }
#else
184 UNIMPL
185 UNIMPL
186 UNIMPL
187 UNIMPL
#endif
188 STD { int sys_stat(char *path, struct stat *ub); }
189 STD { int sys_fstat(int fd, struct stat *sb); }
190 STD { int sys_lstat(char *path, struct stat *ub); }
191 STD { long sys_pathconf(char *path, int name); }
192 STD { long sys_fpathconf(int fd, int name); }
193 UNIMPL
194 STD { int sys_getrlimit(u_int which, struct rlimit *rlp); }
195 STD { int sys_setrlimit(u_int which, struct rlimit *rlp); }
196 STD { int sys_getdirentries(int fd, char *buf, \
u_int count, long *basep); }
197 STD { caddr_t sys_mmap(caddr_t addr, size_t len, int prot, \
int flags, int fd, long pad, off_t pos); }
198 INDIR { quad_t sys___syscall(quad_t num, ...); }
199 STD { off_t sys_lseek(int fd, int pad, off_t offset, \
int whence); }
200 STD { int sys_truncate(char *path, int pad, off_t length); }
201 STD { int sys_ftruncate(int fd, int pad, off_t length); }
202 STD { int sys___sysctl(int *name, u_int namelen, \
void *old, size_t *oldlenp, void *new, \
size_t newlen); }
203 STD { int sys_mlock(caddr_t addr, size_t len); }
204 STD { int sys_munlock(caddr_t addr, size_t len); }
205 STD { int sys_undelete(char *path); }
1996-04-23 14:24:21 +04:00
206 STD { int sys_futimes(int fd, struct timeval *tptr); }
207 STD { int sys_getpgid(pid_t pid); }
208 STD { int sys_reboot(int opt, char *bootstr); }
1996-09-07 18:16:42 +04:00
209 STD { int sys_poll(struct pollfd *fds, u_int nfds, \
1996-09-07 16:40:22 +04:00
int timeout); }
;
; Syscalls 210-219 are reserved for dynamically loaded syscalls
;
#ifdef LKM
210 NODEF { int sys_lkmnosys(void); }
211 NODEF { int sys_lkmnosys(void); }
212 NODEF { int sys_lkmnosys(void); }
213 NODEF { int sys_lkmnosys(void); }
214 NODEF { int sys_lkmnosys(void); }
215 NODEF { int sys_lkmnosys(void); }
216 NODEF { int sys_lkmnosys(void); }
217 NODEF { int sys_lkmnosys(void); }
218 NODEF { int sys_lkmnosys(void); }
219 NODEF { int sys_lkmnosys(void); }
#else /* !LKM */
210 UNIMPL
211 UNIMPL
212 UNIMPL
213 UNIMPL
214 UNIMPL
215 UNIMPL
216 UNIMPL
217 UNIMPL
218 UNIMPL
219 UNIMPL
#endif /* !LKM */
; System calls 220-240 are reserved for use by NetBSD
#ifdef SYSVSEM
220 STD { int sys___semctl(int semid, int semnum, int cmd, \
union semun *arg); }
221 STD { int sys_semget(key_t key, int nsems, int semflg); }
222 STD { int sys_semop(int semid, struct sembuf *sops, \
u_int nsops); }
223 STD { int sys_semconfig(int flag); }
#else
220 UNIMPL semctl
221 UNIMPL semget
222 UNIMPL semop
223 UNIMPL semconfig
#endif
#ifdef SYSVMSG
224 STD { int sys_msgctl(int msqid, int cmd, \
struct msqid_ds *buf); }
225 STD { int sys_msgget(key_t key, int msgflg); }
226 STD { int sys_msgsnd(int msqid, void *msgp, size_t msgsz, \
int msgflg); }
227 STD { int sys_msgrcv(int msqid, void *msgp, size_t msgsz, \
long msgtyp, int msgflg); }
#else
224 UNIMPL msgctl
225 UNIMPL msgget
226 UNIMPL msgsnd
227 UNIMPL msgrcv
#endif
#ifdef SYSVSHM
228 STD { void *sys_shmat(int shmid, void *shmaddr, \
int shmflg); }
229 STD { int sys_shmctl(int shmid, int cmd, \
struct shmid_ds *buf); }
230 STD { int sys_shmdt(void *shmaddr); }
231 STD { int sys_shmget(key_t key, int size, int shmflg); }
#else
228 UNIMPL shmat
229 UNIMPL shmctl
230 UNIMPL shmdt
231 UNIMPL shmget
#endif
232 STD { int sys_clock_gettime(clockid_t clock_id, \
struct timespec *tp); }
233 STD { int sys_clock_settime(clockid_t clock_id, \
const struct timespec *tp); }
234 STD { int sys_clock_getres(clockid_t clock_id, \
struct timespec *tp); }
235 UNIMPL timer_create
236 UNIMPL timer_delete
237 UNIMPL timer_settime
238 UNIMPL timer_gettime
239 UNIMPL timer_getoverrun
240 UNIMPL nanosleep