1 $FreeBSD$ 2; from: @(#)syscalls.master 8.2 (Berkeley) 1/13/94 3; 4; System call name/number master file. 5; Processed to created init_sysent.c, syscalls.c and syscall.h. 6 7; Columns: number type nargs namespc name alt{name,tag,rtyp}/comments 8; number system call number, must be in order 9; type one of STD, OBSOL, UNIMPL, COMPAT 10; namespc one of POSIX, BSD, NOHIDE 11; name psuedo-prototype of syscall routine 12; If one of the following alts is different, then all appear: 13; altname name of system call if different 14; alttag name of args struct tag if different from [o]`name'"_args" 15; altrtyp return type if not int (bogus - syscalls always return int) 16; for UNIMPL/OBSOL, name continues with comments 17 18; types: 19; STD always included 20; COMPAT included on COMPAT #ifdef 21; LIBCOMPAT included on COMPAT #ifdef, and placed in syscall.h 22; OBSOL obsolete, not included in system, only specifies name 23; UNIMPL not implemented, placeholder only 24 25; #ifdef's, etc. may be included, and are copied to the output files. 26 27#include <sys/param.h> 28#include <sys/sysent.h> 29#include <sys/sysproto.h> 30 31; Reserved/unimplemented system calls in the range 0-150 inclusive 32; are reserved for use in future Berkeley releases. 33; Additional system calls implemented in vendor and other 34; redistributions should be placed in the reserved range at the end 35; of the current calls. 36 370 STD NOHIDE { int nosys(void); } syscall nosys_args int 381 STD NOHIDE { void exit(int rval); } exit rexit_args void 392 STD POSIX { int fork(void); } 403 STD POSIX { int read(int fd, char *buf, u_int nbyte); } 414 STD POSIX { int write(int fd, char *buf, u_int nbyte); } 425 STD POSIX { int open(char *path, int flags, int mode); } 43; XXX should be { int open(const char *path, int flags, ...); } 44; but we're not ready for `const' or varargs. 45; XXX man page says `mode_t mode'. 466 STD POSIX { int close(int fd); } 477 STD BSD { int wait4(int pid, int *status, int options, \ 48 struct rusage *rusage); } wait4 wait_args int 498 COMPAT BSD { int creat(char *path, int mode); } 509 STD POSIX { int link(char *path, char *link); } 5110 STD POSIX { int unlink(char *path); } 5211 OBSOL NOHIDE execv 5312 STD POSIX { int chdir(char *path); } 5413 STD BSD { int fchdir(int fd); } 5514 STD POSIX { int mknod(char *path, int mode, int dev); } 5615 STD POSIX { int chmod(char *path, int mode); } 5716 STD POSIX { int chown(char *path, int uid, int gid); } 5817 STD BSD { int obreak(char *nsize); } break obreak_args int 5918 STD BSD { int getfsstat(struct statfs *buf, long bufsize, \ 60 int flags); } 6119 COMPAT POSIX { long lseek(int fd, long offset, int whence); } 6220 STD POSIX { pid_t getpid(void); } 6321 STD BSD { int mount(char *type, char *path, int flags, \ 64 caddr_t data); } 65; XXX 4.4lite2 uses `char *type' but we're not ready for that. 66; XXX `path' should have type `const char *' but we're not ready for that. 6722 STD BSD { int unmount(char *path, int flags); } 6823 STD POSIX { int setuid(uid_t uid); } 6924 STD POSIX { uid_t getuid(void); } 7025 STD POSIX { uid_t geteuid(void); } 7126 STD BSD { int ptrace(int req, pid_t pid, caddr_t addr, \ 72 int data); } 7327 STD BSD { int recvmsg(int s, struct msghdr *msg, int flags); } 7428 STD BSD { int sendmsg(int s, caddr_t msg, int flags); } 7529 STD BSD { int recvfrom(int s, caddr_t buf, size_t len, \ 76 int flags, caddr_t from, int *fromlenaddr); } 7730 STD BSD { int accept(int s, caddr_t name, int *anamelen); } 7831 STD BSD { int getpeername(int fdes, caddr_t asa, int *alen); } 7932 STD BSD { int getsockname(int fdes, caddr_t asa, int *alen); } 8033 STD POSIX { int access(char *path, int flags); } 8134 STD BSD { int chflags(char *path, int flags); } 8235 STD BSD { int fchflags(int fd, int flags); } 8336 STD BSD { int sync(void); } 8437 STD POSIX { int kill(int pid, int signum); } 8538 COMPAT POSIX { int stat(char *path, struct ostat *ub); } 8639 STD POSIX { pid_t getppid(void); } 8740 COMPAT POSIX { int lstat(char *path, struct ostat *ub); } 8841 STD POSIX { int dup(u_int fd); } 8942 STD POSIX { int pipe(void); } 9043 STD POSIX { gid_t getegid(void); } 9144 STD BSD { int profil(caddr_t samples, u_int size, \ 92 u_int offset, u_int scale); } 9345 STD BSD { int ktrace(char *fname, int ops, int facs, \ 94 int pid); } 9546 STD POSIX { int sigaction(int signum, struct sigaction *nsa, \ 96 struct sigaction *osa); } 9747 STD POSIX { gid_t getgid(void); } 9848 STD POSIX { int sigprocmask(int how, sigset_t mask); } 99; XXX note nonstandard (bogus) calling convention - the libc stub passes 100; us the mask, not a pointer to it, and we return the old mask as the 101; (int) return value. 10249 STD BSD { int getlogin(char *namebuf, u_int namelen); } 10350 STD BSD { int setlogin(char *namebuf); } 10451 STD BSD { int acct(char *path); } 10552 STD POSIX { int sigpending(void); } 10653 STD BSD { int sigaltstack(struct sigaltstack *nss, \ 107 struct sigaltstack *oss); } 10854 STD POSIX { int ioctl(int fd, u_long com, caddr_t data); } 10955 STD BSD { int reboot(int opt); } 11056 STD POSIX { int revoke(char *path); } 11157 STD POSIX { int symlink(char *path, char *link); } 11258 STD POSIX { int readlink(char *path, char *buf, int count); } 11359 STD POSIX { int execve(char *fname, char **argv, char **envv); } 11460 STD POSIX { int umask(int newmask); } umask umask_args int 11561 STD BSD { int chroot(char *path); } 11662 COMPAT POSIX { int fstat(int fd, struct ostat *sb); } 11763 COMPAT BSD { int getkerninfo(int op, char *where, int *size, \ 118 int arg); } getkerninfo getkerninfo_args int 11964 COMPAT BSD { int getpagesize(void); } \ 120 getpagesize getpagesize_args int 12165 STD BSD { int msync(caddr_t addr, size_t len, int flags); } 12266 STD BSD { int vfork(void); } 12367 OBSOL NOHIDE vread 12468 OBSOL NOHIDE vwrite 12569 STD BSD { int sbrk(int incr); } 12670 STD BSD { int sstk(int incr); } 12771 COMPAT BSD { int mmap(caddr_t addr, int len, int prot, \ 128 int flags, int fd, long pos); } 12972 STD BSD { int ovadvise(int anom); } vadvise ovadvise_args int 13073 STD BSD { int munmap(caddr_t addr, size_t len); } 13174 STD BSD { int mprotect(caddr_t addr, size_t len, int prot); } 13275 STD BSD { int madvise(caddr_t addr, size_t len, int behav); } 13376 OBSOL NOHIDE vhangup 13477 OBSOL NOHIDE vlimit 13578 STD BSD { int mincore(caddr_t addr, size_t len, char *vec); } 13679 STD POSIX { int getgroups(u_int gidsetsize, gid_t *gidset); } 13780 STD POSIX { int setgroups(u_int gidsetsize, gid_t *gidset); } 13881 STD POSIX { int getpgrp(void); } 13982 STD POSIX { int setpgid(int pid, int pgid); } 14083 STD BSD { int setitimer(u_int which, struct itimerval *itv, \ 141 struct itimerval *oitv); } 14284 COMPAT BSD { int wait(void); } 14385 STD BSD { int swapon(char *name); } 14486 STD BSD { int getitimer(u_int which, struct itimerval *itv); } 14587 COMPAT BSD { int gethostname(char *hostname, u_int len); } \ 146 gethostname gethostname_args int 14788 COMPAT BSD { int sethostname(char *hostname, u_int len); } \ 148 sethostname sethostname_args int 14989 STD BSD { int getdtablesize(void); } 15090 STD POSIX { int dup2(u_int from, u_int to); } 15191 UNIMPL BSD getdopt 15292 STD POSIX { int fcntl(int fd, int cmd, int arg); } 153; XXX should be { int fcntl(int fd, int cmd, ...); } 154; but we're not ready for varargs. 155; XXX man page says `int arg' too. 15693 STD BSD { int select(int nd, fd_set *in, fd_set *ou, \ 157 fd_set *ex, struct timeval *tv); } 15894 UNIMPL BSD setdopt 15995 STD POSIX { int fsync(int fd); } 16096 STD BSD { int setpriority(int which, int who, int prio); } 16197 STD BSD { int socket(int domain, int type, int protocol); } 16298 STD BSD { int connect(int s, caddr_t name, int namelen); } 16399 CPT_NOA BSD { int accept(int s, caddr_t name, int *anamelen); } \ 164 accept accept_args int 165100 STD BSD { int getpriority(int which, int who); } 166101 COMPAT BSD { int send(int s, caddr_t buf, int len, int flags); } 167102 COMPAT BSD { int recv(int s, caddr_t buf, int len, int flags); } 168103 STD BSD { int sigreturn(struct sigcontext *sigcntxp); } 169104 STD BSD { int bind(int s, caddr_t name, int namelen); } 170105 STD BSD { int setsockopt(int s, int level, int name, \ 171 caddr_t val, int valsize); } 172106 STD BSD { int listen(int s, int backlog); } 173107 OBSOL NOHIDE vtimes 174108 COMPAT BSD { int sigvec(int signum, struct sigvec *nsv, \ 175 struct sigvec *osv); } 176109 COMPAT BSD { int sigblock(int mask); } 177110 COMPAT BSD { int sigsetmask(int mask); } 178111 STD POSIX { int sigsuspend(sigset_t mask); } 179; XXX note nonstandard (bogus) calling convention - the libc stub passes 180; us the mask, not a pointer to it. 181112 COMPAT BSD { int sigstack(struct sigstack *nss, \ 182 struct sigstack *oss); } 183113 COMPAT BSD { int recvmsg(int s, struct omsghdr *msg, int flags); } 184114 COMPAT BSD { int sendmsg(int s, caddr_t msg, int flags); } 185115 OBSOL NOHIDE vtrace 186116 STD BSD { int gettimeofday(struct timeval *tp, \ 187 struct timezone *tzp); } 188117 STD BSD { int getrusage(int who, struct rusage *rusage); } 189118 STD BSD { int getsockopt(int s, int level, int name, \ 190 caddr_t val, int *avalsize); } 191119 UNIMPL NOHIDE resuba (BSD/OS 2.x) 192120 STD BSD { int readv(int fd, struct iovec *iovp, u_int iovcnt); } 193121 STD BSD { int writev(int fd, struct iovec *iovp, \ 194 u_int iovcnt); } 195122 STD BSD { int settimeofday(struct timeval *tv, \ 196 struct timezone *tzp); } 197123 STD BSD { int fchown(int fd, int uid, int gid); } 198124 STD BSD { int fchmod(int fd, int mode); } 199125 CPT_NOA BSD { int recvfrom(int s, caddr_t buf, size_t len, \ 200 int flags, caddr_t from, int *fromlenaddr); } \ 201 recvfrom recvfrom_args int 202126 STD BSD { int setreuid(int ruid, int euid); } 203127 STD BSD { int setregid(int rgid, int egid); } 204128 STD POSIX { int rename(char *from, char *to); } 205129 COMPAT BSD { int truncate(char *path, long length); } 206130 COMPAT BSD { int ftruncate(int fd, long length); } 207131 STD BSD { int flock(int fd, int how); } 208132 STD POSIX { int mkfifo(char *path, int mode); } 209133 STD BSD { int sendto(int s, caddr_t buf, size_t len, \ 210 int flags, caddr_t to, int tolen); } 211134 STD BSD { int shutdown(int s, int how); } 212135 STD BSD { int socketpair(int domain, int type, int protocol, \ 213 int *rsv); } 214136 STD POSIX { int mkdir(char *path, int mode); } 215137 STD POSIX { int rmdir(char *path); } 216138 STD BSD { int utimes(char *path, struct timeval *tptr); } 217139 OBSOL NOHIDE 4.2 sigreturn 218140 STD BSD { int adjtime(struct timeval *delta, \ 219 struct timeval *olddelta); } 220141 COMPAT BSD { int getpeername(int fdes, caddr_t asa, int *alen); } 221142 COMPAT BSD { long gethostid(void); } 222143 COMPAT BSD { int sethostid(long hostid); } 223144 COMPAT BSD { int getrlimit(u_int which, struct ogetrlimit *rlp); } 224145 COMPAT BSD { int setrlimit(u_int which, struct ogetrlimit *rlp); } 225146 COMPAT BSD { int killpg(int pgid, int signum); } 226147 STD POSIX { int setsid(void); } 227148 STD BSD { int quotactl(char *path, int cmd, int uid, \ 228 caddr_t arg); } 229149 COMPAT BSD { int quota(void); } 230150 CPT_NOA BSD { int getsockname(int fdec, caddr_t asa, int *alen); }\ 231 getsockname getsockname_args int 232 233; Syscalls 151-180 inclusive are reserved for vendor-specific 234; system calls. (This includes various calls added for compatibity 235; with other Unix variants.) 236; Some of these calls are now supported by BSD... 237151 UNIMPL NOHIDE sem_lock (BSD/OS 2.x) 238152 UNIMPL NOHIDE sem_wakeup (BSD/OS 2.x) 239153 UNIMPL NOHIDE asyncdaemon (BSD/OS 2.x) 240154 UNIMPL NOHIDE nosys 241#ifdef NFS 242155 STD BSD { int nfssvc(int flag, caddr_t argp); } 243#else 244155 UNIMPL BSD nosys 245#endif 246156 COMPAT BSD { int getdirentries(int fd, char *buf, u_int count, \ 247 long *basep); } 248157 STD BSD { int statfs(char *path, struct statfs *buf); } 249158 STD BSD { int fstatfs(int fd, struct statfs *buf); } 250159 UNIMPL NOHIDE nosys 251160 UNIMPL NOHIDE nosys 252#if defined(NFS) && !defined (NFS_NOSERVER) 253161 STD BSD { int getfh(char *fname, struct fhandle *fhp); } 254#else 255161 UNIMPL BSD nosys 256#endif 257162 STD BSD { int getdomainname(char *domainname, int len); } 258163 STD BSD { int setdomainname(char *domainname, int len); } 259164 STD BSD { int uname(struct utsname *name); } 260165 STD BSD { int sysarch(int op, char *parms); } 261166 STD BSD { int rtprio(int function, pid_t pid, \ 262 struct rtprio *rtp); } 263167 UNIMPL NOHIDE nosys 264168 UNIMPL NOHIDE nosys 265169 STD BSD { int semsys(int which, int a2, int a3, int a4, \ 266 int a5); } 267; XXX should be { int semsys(int which, ...); } 268170 STD BSD { int msgsys(int which, int a2, int a3, int a4, \ 269 int a5, int a6); } 270; XXX should be { int msgsys(int which, ...); } 271171 STD BSD { int shmsys(int which, int a2, int a3, int a4); } 272; XXX should be { int shmsys(int which, ...); } 273172 UNIMPL NOHIDE nosys 274173 UNIMPL NOHIDE nosys 275174 UNIMPL NOHIDE nosys 276175 UNIMPL NOHIDE nosys 277176 STD BSD { int ntp_adjtime(struct timex *tp); } 278177 UNIMPL NOHIDE sfork (BSD/OS 2.x) 279178 UNIMPL NOHIDE getdescriptor (BSD/OS 2.x) 280179 UNIMPL NOHIDE setdescriptor (BSD/OS 2.x) 281180 UNIMPL NOHIDE nosys 282 283; Syscalls 180-199 are used by/reserved for BSD 284181 STD POSIX { int setgid(gid_t gid); } 285182 STD BSD { int setegid(gid_t egid); } 286183 STD BSD { int seteuid(uid_t euid); } 287#ifdef LFS 288184 STD BSD { int lfs_bmapv(struct fsid **fsidp, \ 289 struct block_info *blkiov, int blkcnt); } 290185 STD BSD { int lfs_markv(struct fsid **fsidp, \ 291 struct block_info *blkiov, int blkcnt); } 292186 STD BSD { int lfs_segclean(struct fsid **fsidp, \ 293 u_long segment); } 294187 STD BSD { int lfs_segwait(struct fsid **fsidp, \ 295 struct timeval *tv); } 296#else 297184 UNIMPL BSD nosys 298185 UNIMPL BSD nosys 299186 UNIMPL BSD nosys 300187 UNIMPL BSD nosys 301#endif 302188 STD POSIX { int stat(char *path, struct stat *ub); } 303189 STD POSIX { int fstat(int fd, struct stat *sb); } 304190 STD POSIX { int lstat(char *path, struct stat *ub); } 305191 STD POSIX { int pathconf(char *path, int name); } 306192 STD POSIX { int fpathconf(int fd, int name); } 307193 UNIMPL NOHIDE nosys 308194 STD BSD { int getrlimit(u_int which, \ 309 struct orlimit *rlp); } \ 310 getrlimit __getrlimit_args int 311195 STD BSD { int setrlimit(u_int which, \ 312 struct orlimit *rlp); } \ 313 setrlimit __setrlimit_args int 314196 STD BSD { int getdirentries(int fd, char *buf, u_int count, \ 315 long *basep); } 316197 STD BSD { caddr_t mmap(caddr_t addr, size_t len, int prot, \ 317 int flags, int fd, long pad, off_t pos); } 318198 STD NOHIDE { int nosys(void); } __syscall __syscall_args int 319199 STD POSIX { off_t lseek(int fd, int pad, off_t offset, \ 320 int whence); } 321200 STD BSD { int truncate(char *path, int pad, off_t length); } 322201 STD BSD { int ftruncate(int fd, int pad, off_t length); } 323202 STD BSD { int __sysctl(int *name, u_int namelen, void *old, \ 324 size_t *oldlenp, void *new, size_t newlen); } \ 325 __sysctl sysctl_args int 326; properly, __sysctl should be a NOHIDE, but making an exception 327; here allows to avoid one in libc/sys/Makefile.inc. 328203 STD BSD { int mlock(caddr_t addr, size_t len); } 329204 STD BSD { int munlock(caddr_t addr, size_t len); } 330205 STD BSD { int utrace(caddr_t addr, size_t len); } 331206 STD BSD { int undelete(char *path); } 332207 UNIMPL NOHIDE nosys 333208 UNIMPL NOHIDE nosys 334209 UNIMPL NOHIDE nosys 335 336; 337; The following are reserved for loadable syscalls 338; 339210 NODEF NOHIDE lkmnosys lkmnosys nosys_args int 340211 NODEF NOHIDE lkmnosys lkmnosys nosys_args int 341212 NODEF NOHIDE lkmnosys lkmnosys nosys_args int 342213 NODEF NOHIDE lkmnosys lkmnosys nosys_args int 343214 NODEF NOHIDE lkmnosys lkmnosys nosys_args int 344215 NODEF NOHIDE lkmnosys lkmnosys nosys_args int 345216 NODEF NOHIDE lkmnosys lkmnosys nosys_args int 346217 NODEF NOHIDE lkmnosys lkmnosys nosys_args int 347218 NODEF NOHIDE lkmnosys lkmnosys nosys_args int 348219 NODEF NOHIDE lkmnosys lkmnosys nosys_args int 349 350; 351; The following were introduced with NetBSD/4.4Lite-2 352; 353220 STD BSD { int __semctl(int semid, int semnum, int cmd, \ 354 union semun *arg); } 355221 STD BSD { int semget(key_t key, int nsems, int semflg); } 356222 STD BSD { int semop(int semid, struct sembuf *sops, \ 357 u_int nsops); } 358223 STD BSD { int semconfig(int flag); } 359224 STD BSD { int msgctl(int msqid, int cmd, \ 360 struct msqid_ds *buf); } 361225 STD BSD { int msgget(key_t key, int msgflg); } 362226 STD BSD { int msgsnd(int msqid, void *msgp, size_t msgsz, \ 363 int msgflg); } 364227 STD BSD { int msgrcv(int msqid, void *msgp, size_t msgsz, \ 365 long msgtyp, int msgflg); } 366228 STD BSD { int shmat(int shmid, void *shmaddr, int shmflg); } 367229 STD BSD { int shmctl(int shmid, int cmd, \ 368 struct shmid_ds *buf); } 369230 STD BSD { int shmdt(void *shmaddr); } 370231 STD BSD { int shmget(key_t key, int size, int shmflg); } 371; 372232 UNIMPL NOHIDE nosys 373233 UNIMPL NOHIDE nosys 374234 UNIMPL NOHIDE nosys 375235 UNIMPL NOHIDE nosys 376236 UNIMPL NOHIDE nosys 377237 UNIMPL NOHIDE nosys 378238 UNIMPL NOHIDE nosys 379239 UNIMPL NOHIDE nosys 380240 UNIMPL NOHIDE nosys 381241 UNIMPL NOHIDE nosys 382242 UNIMPL NOHIDE nosys 383243 UNIMPL NOHIDE nosys 384244 UNIMPL NOHIDE nosys 385245 UNIMPL NOHIDE nosys 386246 UNIMPL NOHIDE nosys 387247 UNIMPL NOHIDE nosys 388248 UNIMPL NOHIDE nosys 389249 UNIMPL NOHIDE nosys 390; syscall numbers initially used in OpenBSD 391250 STD BSD { int minherit(caddr_t addr, size_t len, int inherit); } 392251 STD BSD { int rfork(int flags); } 393