1 $NetBSD: syscalls.master,v 1.226 2009/03/28 16:33:40 pooka Exp $ 2 3; @(#)syscalls.master 8.2 (Berkeley) 1/13/94 4 5; NetBSD system call name/number "master" file. 6; (See syscalls.conf to see what it is processed into.) 7; 8; Fields: number type [type-dependent ...] 9; number system call number, must be in order 10; type one of STD, OBSOL, UNIMPL, IGNORED, NODEF, NOARGS, or one of 11; the compatibility options defined in syscalls.conf. 12; 13; Optional fields are specified after the type field 14; (NOTE! they *must* be specified in this order): 15; MODULAR:attempt to autoload system call if not present 16; RUMP: the system call can be called directly from rumps 17; 18; types: 19; STD always included 20; OBSOL obsolete, not included in system 21; IGNORED syscall is a null op, but always succeeds 22; UNIMPL unimplemented, not included in system 23; EXCL implemented, but not included in system 24; NODEF included, but don't define the syscall number 25; NOARGS included, but don't define the syscall args structure 26; INDIR included, but don't define the syscall args structure, 27; and allow it to be "really" varargs. 28; 29; The compat options are defined in the syscalls.conf file, and the 30; compat option name is prefixed to the syscall name. Other than 31; that, they're like NODEF (for 'compat' options), or STD (for 32; 'libcompat' options). 33; 34; The type-dependent arguments are as follows: 35; For STD, NODEF, NOARGS, and compat syscalls: 36; { return_type|prefix|compat(optional)|basename(pseudo-proto); } [alias] 37; For other syscalls: 38; [comment] 39; 40; #ifdef's, etc. may be included, and are copied to the output files. 41; #include's are copied to the syscall names and switch definition files only. 42 43#include "opt_modular.h" 44#include "opt_ntp.h" 45#include "opt_sysv.h" 46 47#include "fs_lfs.h" 48 49#include <sys/param.h> 50#include <sys/systm.h> 51#include <sys/signal.h> 52#include <sys/mount.h> 53#include <sys/sched.h> 54#include <sys/syscallargs.h> 55 56%% 57 58; Reserved/unimplemented system calls in the range 0-150 inclusive 59; are reserved for use in future Berkeley releases. 60; Additional system calls implemented in vendor and other 61; redistributions should be placed in the reserved range at the end 62; of the current calls. 63 640 INDIR { int|sys||syscall(int code, \ 65 ... register_t args[SYS_MAXSYSARGS]); } 661 STD { void|sys||exit(int rval); } 672 STD { int|sys||fork(void); } 683 STD RUMP { ssize_t|sys||read(int fd, void *buf, size_t nbyte); } 694 STD RUMP { ssize_t|sys||write(int fd, const void *buf, \ 70 size_t nbyte); } 715 STD RUMP { int|sys||open(const char *path, \ 72 int flags, ... mode_t mode); } 736 STD RUMP { int|sys||close(int fd); } 747 COMPAT_50 MODULAR { int|sys||wait4(int pid, int *status, \ 75 int options, struct rusage50 *rusage); } 768 COMPAT_43 MODULAR { int|sys||creat(const char *path, mode_t mode); } ocreat 779 STD RUMP { int|sys||link(const char *path, const char *link); } 7810 STD RUMP { int|sys||unlink(const char *path); } 7911 OBSOL execv 8012 STD RUMP { int|sys||chdir(const char *path); } 8113 STD RUMP { int|sys||fchdir(int fd); } 8214 COMPAT_50 MODULAR { int|sys||mknod(const char *path, mode_t mode, \ 83 uint32_t dev); } 8415 STD RUMP { int|sys||chmod(const char *path, mode_t mode); } 8516 STD RUMP { int|sys||chown(const char *path, uid_t uid, \ 86 gid_t gid); } 8717 STD { int|sys||obreak(char *nsize); } break 8818 COMPAT_20 MODULAR { int|sys||getfsstat(struct statfs12 *buf, \ 89 long bufsize, int flags); } 9019 COMPAT_43 MODULAR { long|sys||lseek(int fd, long offset, int whence); }\ 91 olseek 9220 STD { pid_t|sys||getpid_with_ppid(void); } getpid 9321 COMPAT_40 MODULAR { int|sys||mount(const char *type, const char *path, \ 94 int flags, void *data); } 9522 STD RUMP { int|sys||unmount(const char *path, int flags); } 9623 STD { int|sys||setuid(uid_t uid); } 9724 STD { uid_t|sys||getuid_with_euid(void); } getuid 9825 STD { uid_t|sys||geteuid(void); } 9926 STD { int|sys||ptrace(int req, pid_t pid, void *addr, \ 100 int data); } 10127 STD RUMP { ssize_t|sys||recvmsg(int s, struct msghdr *msg, \ 102 int flags); } 10328 STD RUMP { ssize_t|sys||sendmsg(int s, \ 104 const struct msghdr *msg, int flags); } 10529 STD RUMP { ssize_t|sys||recvfrom(int s, void *buf, size_t len, \ 106 int flags, struct sockaddr *from, \ 107 unsigned int *fromlenaddr); } 10830 STD RUMP { int|sys||accept(int s, struct sockaddr *name, \ 109 unsigned int *anamelen); } 11031 STD RUMP { int|sys||getpeername(int fdes, struct sockaddr *asa, \ 111 unsigned int *alen); } 11232 STD RUMP { int|sys||getsockname(int fdes, struct sockaddr *asa, \ 113 unsigned int *alen); } 11433 STD RUMP { int|sys||access(const char *path, int flags); } 11534 STD RUMP { int|sys||chflags(const char *path, u_long flags); } 11635 STD RUMP { int|sys||fchflags(int fd, u_long flags); } 11736 STD RUMP { void|sys||sync(void); } 11837 STD { int|sys||kill(int pid, int signum); } 11938 COMPAT_43 MODULAR { int|sys||stat(const char *path, struct stat43 *ub); } \ 120 stat43 12139 STD { pid_t|sys||getppid(void); } 12240 COMPAT_43 MODULAR { int|sys||lstat(const char *path, \ 123 struct stat43 *ub); } lstat43 12441 STD RUMP { int|sys||dup(int fd); } 12542 STD { int|sys||pipe(void); } 12643 STD { gid_t|sys||getegid(void); } 12744 STD { int|sys||profil(char *samples, size_t size, \ 128 u_long offset, u_int scale); } 12945 STD { int|sys||ktrace(const char *fname, int ops, \ 130 int facs, int pid); } 13146 COMPAT_13 MODULAR { int|sys||sigaction(int signum, \ 132 const struct sigaction13 *nsa, \ 133 struct sigaction13 *osa); } sigaction13 13447 STD { gid_t|sys||getgid_with_egid(void); } getgid 13548 COMPAT_13 MODULAR { int|sys||sigprocmask(int how, \ 136 int mask); } sigprocmask13 13749 STD { int|sys||__getlogin(char *namebuf, size_t namelen); } 13850 STD { int|sys||__setlogin(const char *namebuf); } 13951 STD { int|sys||acct(const char *path); } 14052 COMPAT_13 MODULAR { int|sys||sigpending(void); } sigpending13 14153 COMPAT_13 MODULAR { int|sys||sigaltstack( \ 142 const struct sigaltstack13 *nss, \ 143 struct sigaltstack13 *oss); } sigaltstack13 14454 STD RUMP { int|sys||ioctl(int fd, \ 145 u_long com, ... void *data); } 14655 COMPAT_12 MODULAR { int|sys||reboot(int opt); } oreboot 14756 STD RUMP { int|sys||revoke(const char *path); } 14857 STD RUMP { int|sys||symlink(const char *path, \ 149 const char *link); } 15058 STD RUMP { ssize_t|sys||readlink(const char *path, char *buf, \ 151 size_t count); } 15259 STD { int|sys||execve(const char *path, \ 153 char * const *argp, char * const *envp); } 15460 STD { mode_t|sys||umask(mode_t newmask); } 15561 STD RUMP { int|sys||chroot(const char *path); } 15662 COMPAT_43 MODULAR { int|sys||fstat(int fd, struct stat43 *sb); } fstat43 15763 COMPAT_43 MODULAR { int|sys||getkerninfo(int op, char *where, int *size, \ 158 int arg); } ogetkerninfo 15964 COMPAT_43 MODULAR { int|sys||getpagesize(void); } ogetpagesize 16065 COMPAT_12 MODULAR { int|sys||msync(void *addr, size_t len); } 161; XXX COMPAT_??? for 4.4BSD-compatible vfork(2)? 16266 STD { int|sys||vfork(void); } 16367 OBSOL vread 16468 OBSOL vwrite 16569 STD { int|sys||sbrk(intptr_t incr); } 16670 STD { int|sys||sstk(int incr); } 16771 COMPAT_43 MODULAR { int|sys||mmap(void *addr, size_t len, int prot, \ 168 int flags, int fd, long pos); } ommap 16972 STD { int|sys||ovadvise(int anom); } vadvise 17073 STD { int|sys||munmap(void *addr, size_t len); } 17174 STD { int|sys||mprotect(void *addr, size_t len, \ 172 int prot); } 17375 STD { int|sys||madvise(void *addr, size_t len, \ 174 int behav); } 17576 OBSOL vhangup 17677 OBSOL vlimit 17778 STD { int|sys||mincore(void *addr, size_t len, \ 178 char *vec); } 17979 STD { int|sys||getgroups(int gidsetsize, \ 180 gid_t *gidset); } 18180 STD { int|sys||setgroups(int gidsetsize, \ 182 const gid_t *gidset); } 18381 STD { int|sys||getpgrp(void); } 18482 STD { int|sys||setpgid(int pid, int pgid); } 18583 COMPAT_50 MODULAR { int|sys||setitimer(int which, \ 186 const struct itimerval50 *itv, \ 187 struct itimerval50 *oitv); } 18884 COMPAT_43 MODULAR { int|sys||wait(void); } owait 18985 COMPAT_12 MODULAR { int|sys||swapon(const char *name); } oswapon 19086 COMPAT_50 MODULAR { int|sys||getitimer(int which, \ 191 struct itimerval50 *itv); } 19287 COMPAT_43 MODULAR { int|sys||gethostname(char *hostname, u_int len); } \ 193 ogethostname 19488 COMPAT_43 MODULAR { int|sys||sethostname(char *hostname, u_int len); } \ 195 osethostname 19689 COMPAT_43 MODULAR { int|sys||getdtablesize(void); } ogetdtablesize 19790 STD RUMP { int|sys||dup2(int from, int to); } 19891 UNIMPL getdopt 19992 STD RUMP { int|sys||fcntl(int fd, int cmd, ... void *arg); } 20093 COMPAT_50 MODULAR { int|sys||select(int nd, fd_set *in, fd_set *ou, \ 201 fd_set *ex, struct timeval50 *tv); } 20294 UNIMPL setdopt 20395 STD RUMP { int|sys||fsync(int fd); } 20496 STD { int|sys||setpriority(int which, id_t who, int prio); } 20597 COMPAT_30 MODULAR { int|sys||socket(int domain, int type, int protocol); } 20698 STD RUMP { int|sys||connect(int s, const struct sockaddr *name, \ 207 unsigned int namelen); } 20899 COMPAT_43 MODULAR { int|sys||accept(int s, void *name, \ 209 int *anamelen); } oaccept 210100 STD { int|sys||getpriority(int which, id_t who); } 211101 COMPAT_43 MODULAR { int|sys||send(int s, void *buf, int len, \ 212 int flags); } osend 213102 COMPAT_43 MODULAR { int|sys||recv(int s, void *buf, int len, \ 214 int flags); } orecv 215103 COMPAT_13 MODULAR { int|sys||sigreturn(struct sigcontext13 *sigcntxp); } \ 216 sigreturn13 217104 STD RUMP { int|sys||bind(int s, const struct sockaddr *name, \ 218 unsigned int namelen); } 219105 STD RUMP { int|sys||setsockopt(int s, int level, int name, \ 220 const void *val, unsigned int valsize); } 221106 STD RUMP { int|sys||listen(int s, int backlog); } 222107 OBSOL vtimes 223108 COMPAT_43 MODULAR { int|sys||sigvec(int signum, struct sigvec *nsv, \ 224 struct sigvec *osv); } osigvec 225109 COMPAT_43 MODULAR { int|sys||sigblock(int mask); } osigblock 226110 COMPAT_43 MODULAR { int|sys||sigsetmask(int mask); } osigsetmask 227111 COMPAT_13 MODULAR { int|sys||sigsuspend(int mask); } sigsuspend13 228112 COMPAT_43 MODULAR { int|sys||sigstack(struct sigstack *nss, \ 229 struct sigstack *oss); } osigstack 230113 COMPAT_43 MODULAR { int|sys||recvmsg(int s, struct omsghdr *msg, \ 231 int flags); } orecvmsg 232114 COMPAT_43 MODULAR { int|sys||sendmsg(int s, void *msg, int flags); } \ 233 osendmsg 234115 OBSOL vtrace 235116 COMPAT_50 MODULAR { int|sys||gettimeofday(struct timeval50 *tp, \ 236 void *tzp); } 237117 COMPAT_50 MODULAR { int|sys||getrusage(int who, struct rusage50 *rusage); } 238118 STD RUMP { int|sys||getsockopt(int s, int level, int name, \ 239 void *val, unsigned int *avalsize); } 240119 OBSOL resuba 241120 STD RUMP { ssize_t|sys||readv(int fd, \ 242 const struct iovec *iovp, int iovcnt); } 243121 STD RUMP { ssize_t|sys||writev(int fd, \ 244 const struct iovec *iovp, int iovcnt); } 245122 COMPAT_50 MODULAR { int|sys||settimeofday(const struct timeval50 *tv, \ 246 const void *tzp); } 247123 STD RUMP { int|sys||fchown(int fd, uid_t uid, gid_t gid); } 248124 STD RUMP { int|sys||fchmod(int fd, mode_t mode); } 249125 COMPAT_43 MODULAR { int|sys||recvfrom(int s, void *buf, size_t len, \ 250 int flags, void *from, int *fromlenaddr); } \ 251 orecvfrom 252126 STD { int|sys||setreuid(uid_t ruid, uid_t euid); } 253127 STD { int|sys||setregid(gid_t rgid, gid_t egid); } 254128 STD RUMP { int|sys||rename(const char *from, const char *to); } 255129 COMPAT_43 MODULAR { int|sys||truncate(const char *path, long length); } \ 256 otruncate 257130 COMPAT_43 MODULAR { int|sys||ftruncate(int fd, long length); } oftruncate 258131 STD RUMP { int|sys||flock(int fd, int how); } 259132 STD RUMP { int|sys||mkfifo(const char *path, mode_t mode); } 260133 STD RUMP { ssize_t|sys||sendto(int s, const void *buf, \ 261 size_t len, int flags, const struct sockaddr *to, \ 262 unsigned int tolen); } 263134 STD RUMP { int|sys||shutdown(int s, int how); } 264135 STD RUMP { int|sys||socketpair(int domain, int type, \ 265 int protocol, int *rsv); } 266136 STD RUMP { int|sys||mkdir(const char *path, mode_t mode); } 267137 STD RUMP { int|sys||rmdir(const char *path); } 268138 COMPAT_50 MODULAR { int|sys||utimes(const char *path, \ 269 const struct timeval50 *tptr); } 270139 OBSOL 4.2 sigreturn 271140 COMPAT_50 MODULAR { int|sys||adjtime(const struct timeval50 *delta, \ 272 struct timeval50 *olddelta); } 273141 COMPAT_43 MODULAR { int|sys||getpeername(int fdes, void *asa, \ 274 int *alen); } ogetpeername 275142 COMPAT_43 MODULAR { int32_t|sys||gethostid(void); } ogethostid 276143 COMPAT_43 MODULAR { int|sys||sethostid(int32_t hostid); } osethostid 277144 COMPAT_43 MODULAR { int|sys||getrlimit(int which, \ 278 struct orlimit *rlp); } ogetrlimit 279145 COMPAT_43 MODULAR { int|sys||setrlimit(int which, \ 280 const struct orlimit *rlp); } osetrlimit 281146 COMPAT_43 MODULAR { int|sys||killpg(int pgid, int signum); } okillpg 282147 STD { int|sys||setsid(void); } 283148 STD { int|sys||quotactl(const char *path, int cmd, \ 284 int uid, void *arg); } 285149 COMPAT_43 MODULAR { int|sys||quota(void); } oquota 286150 COMPAT_43 MODULAR { int|sys||getsockname(int fdec, void *asa, \ 287 int *alen); } ogetsockname 288 289; Syscalls 151-180 inclusive are reserved for vendor-specific 290; system calls. (This includes various calls added for compatibity 291; with other Unix variants.) 292; Some of these calls are now supported by BSD... 293151 UNIMPL 294152 UNIMPL 295153 UNIMPL 296154 UNIMPL 297155 STD MODULAR RUMP { int|sys||nfssvc(int flag, void *argp); } 298156 COMPAT_43 MODULAR { int|sys||getdirentries(int fd, char *buf, \ 299 u_int count, long *basep); } ogetdirentries 300157 COMPAT_20 MODULAR { int|sys||statfs(const char *path, \ 301 struct statfs12 *buf); } 302158 COMPAT_20 MODULAR { int|sys||fstatfs(int fd, struct statfs12 *buf); } 303159 UNIMPL 304160 UNIMPL 305161 COMPAT_30 MODULAR { int|sys||getfh(const char *fname, \ 306 struct compat_30_fhandle *fhp); } 307162 COMPAT_09 MODULAR { int|sys||getdomainname(char *domainname, int len); } \ 308 ogetdomainname 309163 COMPAT_09 MODULAR { int|sys||setdomainname(char *domainname, int len); } \ 310 osetdomainname 311164 COMPAT_09 MODULAR { int|sys||uname(struct outsname *name); } ouname 312165 STD { int|sys||sysarch(int op, void *parms); } 313166 UNIMPL 314167 UNIMPL 315168 UNIMPL 316; XXX more generally, never on machines where sizeof(void *) != sizeof(int) 317#if (defined(SYSVSEM) || !defined(_KERNEL_OPT)) && !defined(_LP64) 318169 COMPAT_10 MODULAR { int|sys||semsys(int which, int a2, int a3, int a4, \ 319 int a5); } osemsys 320#else 321169 EXCL 1.0 semsys 322#endif 323; XXX more generally, never on machines where sizeof(void *) != sizeof(int) 324#if (defined(SYSVMSG) || !defined(_KERNEL_OPT)) && !defined(_LP64) 325170 COMPAT_10 MODULAR { int|sys||msgsys(int which, int a2, int a3, int a4, \ 326 int a5, int a6); } omsgsys 327#else 328170 EXCL 1.0 msgsys 329#endif 330; XXX more generally, never on machines where sizeof(void *) != sizeof(int) 331#if (defined(SYSVSHM) || !defined(_KERNEL_OPT)) && !defined(_LP64) 332171 COMPAT_10 MODULAR { int|sys||shmsys(int which, int a2, int a3, int a4); } \ 333 oshmsys 334#else 335171 EXCL 1.0 shmsys 336#endif 337172 UNIMPL 338173 STD RUMP { ssize_t|sys||pread(int fd, void *buf, \ 339 size_t nbyte, int pad, off_t offset); } 340174 STD RUMP { ssize_t|sys||pwrite(int fd, const void *buf, \ 341 size_t nbyte, int pad, off_t offset); } 342; For some reason, ntp_gettime doesn't want to raise SIGSYS when it's excluded. 343175 COMPAT_30 { int|sys||ntp_gettime(struct ntptimeval30 *ntvp); } 344#if defined(NTP) || !defined(_KERNEL_OPT) 345176 STD { int|sys||ntp_adjtime(struct timex *tp); } 346#else 347176 EXCL ntp_adjtime 348#endif 349177 UNIMPL 350178 UNIMPL 351179 UNIMPL 352180 UNIMPL 353 354; Syscalls 180-199 are used by/reserved for BSD 355181 STD { int|sys||setgid(gid_t gid); } 356182 STD { int|sys||setegid(gid_t egid); } 357183 STD { int|sys||seteuid(uid_t euid); } 358#if defined(LFS) || !defined(_KERNEL) 359184 STD { int|sys||lfs_bmapv(fsid_t *fsidp, \ 360 struct block_info *blkiov, int blkcnt); } 361185 STD { int|sys||lfs_markv(fsid_t *fsidp, \ 362 struct block_info *blkiov, int blkcnt); } 363186 STD { int|sys||lfs_segclean(fsid_t *fsidp, u_long segment); } 364187 COMPAT_50 MODULAR { int|sys||lfs_segwait(fsid_t *fsidp, \ 365 struct timeval50 *tv); } 366#else 367184 EXCL lfs_bmapv 368185 EXCL lfs_markv 369186 EXCL lfs_segclean 370187 EXCL lfs_segwait 371#endif 372188 COMPAT_12 MODULAR { int|sys||stat(const char *path, struct stat12 *ub); } \ 373 stat12 374189 COMPAT_12 MODULAR { int|sys||fstat(int fd, struct stat12 *sb); } fstat12 375190 COMPAT_12 MODULAR { int|sys||lstat(const char *path, \ 376 struct stat12 *ub); } lstat12 377191 STD { long|sys||pathconf(const char *path, int name); } 378192 STD { long|sys||fpathconf(int fd, int name); } 379193 UNIMPL 380194 STD { int|sys||getrlimit(int which, \ 381 struct rlimit *rlp); } 382195 STD { int|sys||setrlimit(int which, \ 383 const struct rlimit *rlp); } 384196 COMPAT_12 MODULAR { int|sys||getdirentries(int fd, char *buf, \ 385 u_int count, long *basep); } 386197 STD { void *|sys||mmap(void *addr, size_t len, int prot, \ 387 int flags, int fd, long pad, off_t pos); } 388198 INDIR { quad_t|sys||__syscall(quad_t code, \ 389 ... register_t args[SYS_MAXSYSARGS]); } 390199 STD RUMP { off_t|sys||lseek(int fd, int pad, off_t offset, \ 391 int whence); } 392200 STD RUMP { int|sys||truncate(const char *path, int pad, \ 393 off_t length); } 394201 STD RUMP { int|sys||ftruncate(int fd, int pad, off_t length); } 395202 STD RUMP { int|sys||__sysctl(const int *name, u_int namelen, \ 396 void *old, size_t *oldlenp, const void *new, \ 397 size_t newlen); } 398203 STD { int|sys||mlock(const void *addr, size_t len); } 399204 STD { int|sys||munlock(const void *addr, size_t len); } 400205 STD { int|sys||undelete(const char *path); } 401206 COMPAT_50 MODULAR { int|sys||futimes(int fd, \ 402 const struct timeval50 *tptr); } 403207 STD { pid_t|sys||getpgid(pid_t pid); } 404208 STD RUMP { int|sys||reboot(int opt, char *bootstr); } 405209 STD RUMP { int|sys||poll(struct pollfd *fds, u_int nfds, \ 406 int timeout); } 407; 408; Syscalls 210-219 are reserved for dynamically loaded syscalls 409; 410210 UNIMPL 411211 UNIMPL 412212 UNIMPL 413213 UNIMPL 414214 UNIMPL 415215 UNIMPL 416216 UNIMPL 417217 UNIMPL 418218 UNIMPL 419219 UNIMPL 420; System calls 220-300 are reserved for use by NetBSD 421#if defined(SYSVSEM) || !defined(_KERNEL_OPT) 422220 COMPAT_14 MODULAR { int|sys||__semctl(int semid, int semnum, int cmd, \ 423 union __semun *arg); } 424221 STD { int|sys||semget(key_t key, int nsems, int semflg); } 425222 STD { int|sys||semop(int semid, struct sembuf *sops, \ 426 size_t nsops); } 427223 STD { int|sys||semconfig(int flag); } 428#else 429220 EXCL compat_14_semctl 430221 EXCL semget 431222 EXCL semop 432223 EXCL semconfig 433#endif 434#if defined(SYSVMSG) || !defined(_KERNEL_OPT) 435224 COMPAT_14 MODULAR { int|sys||msgctl(int msqid, int cmd, \ 436 struct msqid_ds14 *buf); } 437225 STD { int|sys||msgget(key_t key, int msgflg); } 438226 STD { int|sys||msgsnd(int msqid, const void *msgp, \ 439 size_t msgsz, int msgflg); } 440227 STD { ssize_t|sys||msgrcv(int msqid, void *msgp, \ 441 size_t msgsz, long msgtyp, int msgflg); } 442#else 443224 EXCL compat_14_msgctl 444225 EXCL msgget 445226 EXCL msgsnd 446227 EXCL msgrcv 447#endif 448#if defined(SYSVSHM) || !defined(_KERNEL_OPT) 449228 STD { void *|sys||shmat(int shmid, const void *shmaddr, \ 450 int shmflg); } 451229 COMPAT_14 MODULAR { int|sys||shmctl(int shmid, int cmd, \ 452 struct shmid_ds14 *buf); } 453230 STD { int|sys||shmdt(const void *shmaddr); } 454231 STD { int|sys||shmget(key_t key, size_t size, int shmflg); } 455#else 456228 EXCL shmat 457229 EXCL compat_14_shmctl 458230 EXCL shmdt 459231 EXCL shmget 460#endif 461232 COMPAT_50 MODULAR { int|sys||clock_gettime(clockid_t clock_id, \ 462 struct timespec50 *tp); } 463233 COMPAT_50 MODULAR { int|sys||clock_settime(clockid_t clock_id, \ 464 const struct timespec50 *tp); } 465234 COMPAT_50 MODULAR { int|sys||clock_getres(clockid_t clock_id, \ 466 struct timespec50 *tp); } 467235 STD { int|sys||timer_create(clockid_t clock_id, \ 468 struct sigevent *evp, timer_t *timerid); } 469236 STD { int|sys||timer_delete(timer_t timerid); } 470237 COMPAT_50 MODULAR { int|sys||timer_settime(timer_t timerid, int flags, \ 471 const struct itimerspec50 *value, \ 472 struct itimerspec50 *ovalue); } 473238 COMPAT_50 MODULAR { int|sys||timer_gettime(timer_t timerid, struct \ 474 itimerspec50 *value); } 475239 STD { int|sys||timer_getoverrun(timer_t timerid); } 476; 477; Syscalls 240-269 are reserved for other IEEE Std1003.1b syscalls 478; 479240 COMPAT_50 MODULAR { int|sys||nanosleep(const struct timespec50 *rqtp, \ 480 struct timespec50 *rmtp); } 481241 STD RUMP { int|sys||fdatasync(int fd); } 482242 STD { int|sys||mlockall(int flags); } 483243 STD { int|sys||munlockall(void); } 484244 COMPAT_50 MODULAR { int|sys||__sigtimedwait(const sigset_t *set, \ 485 siginfo_t *info, \ 486 struct timespec50 *timeout); } 487245 UNIMPL sys_sigqueue 488246 STD { int|sys||modctl(int cmd, void *arg); } 489247 STD MODULAR { int|sys||_ksem_init(unsigned int value, intptr_t *idp); } 490248 STD MODULAR { int|sys||_ksem_open(const char *name, int oflag, \ 491 mode_t mode, unsigned int value, intptr_t *idp); } 492249 STD MODULAR { int|sys||_ksem_unlink(const char *name); } 493250 STD MODULAR { int|sys||_ksem_close(intptr_t id); } 494251 STD MODULAR { int|sys||_ksem_post(intptr_t id); } 495252 STD MODULAR { int|sys||_ksem_wait(intptr_t id); } 496253 STD MODULAR { int|sys||_ksem_trywait(intptr_t id); } 497254 STD MODULAR { int|sys||_ksem_getvalue(intptr_t id, \ 498 unsigned int *value); } 499255 STD MODULAR { int|sys||_ksem_destroy(intptr_t id); } 500256 UNIMPL sys__ksem_timedwait 501257 STD { mqd_t|sys||mq_open(const char * name, int oflag, \ 502 mode_t mode, struct mq_attr *attr); } 503258 STD { int|sys||mq_close(mqd_t mqdes); } 504259 STD { int|sys||mq_unlink(const char *name); } 505260 STD { int|sys||mq_getattr(mqd_t mqdes, \ 506 struct mq_attr *mqstat); } 507261 STD { int|sys||mq_setattr(mqd_t mqdes, \ 508 const struct mq_attr *mqstat, \ 509 struct mq_attr *omqstat); } 510262 STD { int|sys||mq_notify(mqd_t mqdes, \ 511 const struct sigevent *notification); } 512263 STD { int|sys||mq_send(mqd_t mqdes, const char *msg_ptr, \ 513 size_t msg_len, unsigned msg_prio); } 514264 STD { ssize_t|sys||mq_receive(mqd_t mqdes, char *msg_ptr, \ 515 size_t msg_len, unsigned *msg_prio); } 516265 COMPAT_50 MODULAR { int|sys||mq_timedsend(mqd_t mqdes, \ 517 const char *msg_ptr, size_t msg_len, \ 518 unsigned msg_prio, \ 519 const struct timespec50 *abs_timeout); } 520266 COMPAT_50 MODULAR { ssize_t|sys||mq_timedreceive(mqd_t mqdes, \ 521 char *msg_ptr, size_t msg_len, unsigned *msg_prio, \ 522 const struct timespec50 *abs_timeout); } 523267 UNIMPL 524268 UNIMPL 525269 UNIMPL 526270 STD { int|sys||__posix_rename(const char *from, \ 527 const char *to); } 528271 STD { int|sys||swapctl(int cmd, void *arg, int misc); } 529272 COMPAT_30 MODULAR { int|sys||getdents(int fd, char *buf, size_t count); } 530273 STD { int|sys||minherit(void *addr, size_t len, \ 531 int inherit); } 532274 STD RUMP { int|sys||lchmod(const char *path, mode_t mode); } 533275 STD RUMP { int|sys||lchown(const char *path, uid_t uid, \ 534 gid_t gid); } 535276 COMPAT_50 MODULAR { int|sys||lutimes(const char *path, \ 536 const struct timeval50 *tptr); } 537277 STD { int|sys|13|msync(void *addr, size_t len, int flags); } 538278 COMPAT_30 MODULAR { int|sys|13|stat(const char *path, struct stat13 *ub); } 539279 COMPAT_30 MODULAR { int|sys|13|fstat(int fd, struct stat13 *sb); } 540280 COMPAT_30 MODULAR { int|sys|13|lstat(const char *path, struct stat13 *ub); } 541281 STD { int|sys|14|sigaltstack( \ 542 const struct sigaltstack *nss, \ 543 struct sigaltstack *oss); } 544282 STD { int|sys|14|vfork(void); } 545283 STD { int|sys||__posix_chown(const char *path, uid_t uid, \ 546 gid_t gid); } 547284 STD { int|sys||__posix_fchown(int fd, uid_t uid, \ 548 gid_t gid); } 549285 STD { int|sys||__posix_lchown(const char *path, uid_t uid, \ 550 gid_t gid); } 551286 STD { pid_t|sys||getsid(pid_t pid); } 552287 STD { pid_t|sys||__clone(int flags, void *stack); } 553288 STD { int|sys||fktrace(int fd, int ops, \ 554 int facs, int pid); } 555289 STD { ssize_t|sys||preadv(int fd, \ 556 const struct iovec *iovp, int iovcnt, \ 557 int pad, off_t offset); } 558290 STD { ssize_t|sys||pwritev(int fd, \ 559 const struct iovec *iovp, int iovcnt, \ 560 int pad, off_t offset); } 561291 COMPAT_16 MODULAR { int|sys|14|sigaction(int signum, \ 562 const struct sigaction *nsa, \ 563 struct sigaction *osa); } 564292 STD { int|sys|14|sigpending(sigset_t *set); } 565293 STD { int|sys|14|sigprocmask(int how, \ 566 const sigset_t *set, \ 567 sigset_t *oset); } 568294 STD { int|sys|14|sigsuspend(const sigset_t *set); } 569295 COMPAT_16 MODULAR { int|sys|14|sigreturn(struct sigcontext *sigcntxp); } 570296 STD { int|sys||__getcwd(char *bufp, size_t length); } 571297 STD RUMP { int|sys||fchroot(int fd); } 572298 COMPAT_30 MODULAR { int|sys||fhopen(const struct compat_30_fhandle *fhp, int flags); } 573299 COMPAT_30 MODULAR { int|sys||fhstat(const struct compat_30_fhandle *fhp, \ 574 struct stat13 *sb); } 575300 COMPAT_20 MODULAR { int|sys||fhstatfs(const struct compat_30_fhandle *fhp, \ 576 struct statfs12 *buf); } 577#if defined(SYSVSEM) || !defined(_KERNEL_OPT) 578301 COMPAT_50 MODULAR { int|sys|13|__semctl(int semid, int semnum, int cmd, \ 579 ... union __semun *arg); } 580#else 581301 EXCL ____semctl13 582#endif 583#if defined(SYSVMSG) || !defined(_KERNEL_OPT) 584302 COMPAT_50 MODULAR { int|sys|13|msgctl(int msqid, int cmd, \ 585 struct msqid_ds *buf); } 586#else 587302 EXCL __msgctl13 588#endif 589#if defined(SYSVSHM) || !defined(_KERNEL_OPT) 590303 COMPAT_50 MODULAR { int|sys|13|shmctl(int shmid, int cmd, \ 591 struct shmid_ds13 *buf); } 592#else 593303 EXCL __shmctl13 594#endif 595304 STD RUMP { int|sys||lchflags(const char *path, u_long flags); } 596305 STD { int|sys||issetugid(void); } 597306 STD { int|sys||utrace(const char *label, void *addr, \ 598 size_t len); } 599307 STD { int|sys||getcontext(struct __ucontext *ucp); } 600308 STD { int|sys||setcontext(const struct __ucontext *ucp); } 601309 STD { int|sys||_lwp_create(const struct __ucontext *ucp, \ 602 u_long flags, lwpid_t *new_lwp); } 603310 STD { int|sys||_lwp_exit(void); } 604311 STD { lwpid_t|sys||_lwp_self(void); } 605312 STD { int|sys||_lwp_wait(lwpid_t wait_for, \ 606 lwpid_t *departed); } 607313 STD { int|sys||_lwp_suspend(lwpid_t target); } 608314 STD { int|sys||_lwp_continue(lwpid_t target); } 609315 STD { int|sys||_lwp_wakeup(lwpid_t target); } 610316 STD { void *|sys||_lwp_getprivate(void); } 611317 STD { void|sys||_lwp_setprivate(void *ptr); } 612318 STD { int|sys||_lwp_kill(lwpid_t target, int signo); } 613319 STD { int|sys||_lwp_detach(lwpid_t target); } 614320 COMPAT_50 MODULAR { int|sys||_lwp_park(const struct timespec50 *ts, \ 615 lwpid_t unpark, const void *hint, \ 616 const void *unparkhint); } 617321 STD { int|sys||_lwp_unpark(lwpid_t target, const void *hint); } 618322 STD { ssize_t|sys||_lwp_unpark_all(const lwpid_t *targets, \ 619 size_t ntargets, const void *hint); } 620323 STD { int|sys||_lwp_setname(lwpid_t target, \ 621 const char *name); } 622324 STD { int|sys||_lwp_getname(lwpid_t target, \ 623 char *name, size_t len); } 624325 STD { int|sys||_lwp_ctl(int features, \ 625 struct lwpctl **address); } 626; Syscalls 326-339 reserved for LWP syscalls. 627326 UNIMPL 628327 UNIMPL 629328 UNIMPL 630329 UNIMPL 631; SA system calls. 632330 STD { int|sys||sa_register(sa_upcall_t new, \ 633 sa_upcall_t *old, int flags, \ 634 ssize_t stackinfo_offset); } 635331 STD { int|sys||sa_stacks(int num, stack_t *stacks); } 636332 STD { int|sys||sa_enable(void); } 637333 STD { int|sys||sa_setconcurrency(int concurrency); } 638334 STD { int|sys||sa_yield(void); } 639335 STD { int|sys||sa_preempt(int sa_id); } 640336 OBSOL sys_sa_unblockyield 641; 642; Syscalls 337-339 are reserved for other scheduler activation syscalls. 643; 644337 UNIMPL 645338 UNIMPL 646339 UNIMPL 647340 STD { int|sys||__sigaction_sigtramp(int signum, \ 648 const struct sigaction *nsa, \ 649 struct sigaction *osa, \ 650 const void *tramp, int vers); } 651341 STD { int|sys||pmc_get_info(int ctr, int op, void *args); } 652342 STD { int|sys||pmc_control(int ctr, int op, void *args); } 653343 STD { int|sys||rasctl(void *addr, size_t len, int op); } 654344 STD RUMP { int|sys||kqueue(void); } 655345 COMPAT_50 MODULAR { int|sys||kevent(int fd, \ 656 const struct kevent *changelist, size_t nchanges, \ 657 struct kevent *eventlist, size_t nevents, \ 658 const struct timespec50 *timeout); } 659 660; Scheduling system calls. 661346 STD { int|sys||_sched_setparam(pid_t pid, lwpid_t lid, \ 662 int policy, const struct sched_param *params); } 663347 STD { int|sys||_sched_getparam(pid_t pid, lwpid_t lid, \ 664 int *policy, struct sched_param *params); } 665348 STD { int|sys||_sched_setaffinity(pid_t pid, lwpid_t lid, \ 666 size_t size, const cpuset_t *cpuset); } 667349 STD { int|sys||_sched_getaffinity(pid_t pid, lwpid_t lid, \ 668 size_t size, cpuset_t *cpuset); } 669350 STD { int|sys||sched_yield(void); } 670351 UNIMPL 671352 UNIMPL 672353 UNIMPL 673 674354 STD RUMP { int|sys||fsync_range(int fd, int flags, off_t start, \ 675 off_t length); } 676355 STD { int|sys||uuidgen(struct uuid *store, int count); } 677356 STD RUMP { int|sys||getvfsstat(struct statvfs *buf, \ 678 size_t bufsize, int flags); } 679357 STD RUMP { int|sys||statvfs1(const char *path, \ 680 struct statvfs *buf, int flags); } 681358 STD RUMP { int|sys||fstatvfs1(int fd, struct statvfs *buf, \ 682 int flags); } 683359 COMPAT_30 MODULAR { int|sys||fhstatvfs1(const struct compat_30_fhandle *fhp, \ 684 struct statvfs *buf, int flags); } 685360 STD RUMP { int|sys||extattrctl(const char *path, int cmd, \ 686 const char *filename, int attrnamespace, \ 687 const char *attrname); } 688361 STD RUMP { int|sys||extattr_set_file(const char *path, \ 689 int attrnamespace, const char *attrname, \ 690 const void *data, size_t nbytes); } 691362 STD RUMP { ssize_t|sys||extattr_get_file(const char *path, \ 692 int attrnamespace, const char *attrname, \ 693 void *data, size_t nbytes); } 694363 STD RUMP { int|sys||extattr_delete_file(const char *path, \ 695 int attrnamespace, const char *attrname); } 696364 STD RUMP { int|sys||extattr_set_fd(int fd, \ 697 int attrnamespace, const char *attrname, \ 698 const void *data, size_t nbytes); } 699365 STD RUMP { ssize_t|sys||extattr_get_fd(int fd, \ 700 int attrnamespace, const char *attrname, \ 701 void *data, size_t nbytes); } 702366 STD RUMP { int|sys||extattr_delete_fd(int fd, \ 703 int attrnamespace, const char *attrname); } 704367 STD RUMP { int|sys||extattr_set_link(const char *path, \ 705 int attrnamespace, const char *attrname, \ 706 const void *data, size_t nbytes); } 707368 STD RUMP { ssize_t|sys||extattr_get_link(const char *path, \ 708 int attrnamespace, const char *attrname, \ 709 void *data, size_t nbytes); } 710369 STD RUMP { int|sys||extattr_delete_link(const char *path, \ 711 int attrnamespace, const char *attrname); } 712370 STD RUMP { ssize_t|sys||extattr_list_fd(int fd, \ 713 int attrnamespace, void *data, size_t nbytes); } 714371 STD RUMP { ssize_t|sys||extattr_list_file(const char *path, \ 715 int attrnamespace, void *data, size_t nbytes); } 716372 STD RUMP { ssize_t|sys||extattr_list_link(const char *path, \ 717 int attrnamespace, void *data, size_t nbytes); } 718373 COMPAT_50 MODULAR { int|sys||pselect(int nd, fd_set *in, fd_set *ou, \ 719 fd_set *ex, const struct timespec50 *ts, \ 720 const sigset_t *mask); } 721374 COMPAT_50 MODULAR { int|sys||pollts(struct pollfd *fds, u_int nfds, \ 722 const struct timespec50 *ts, const sigset_t *mask); } 723375 STD RUMP { int|sys||setxattr(const char *path, \ 724 const char *name, void *value, size_t size, \ 725 int flags); } 726376 STD RUMP { int|sys||lsetxattr(const char *path, \ 727 const char *name, void *value, size_t size, \ 728 int flags); } 729377 STD RUMP { int|sys||fsetxattr(int fd, \ 730 const char *name, void *value, size_t size, \ 731 int flags); } 732378 STD RUMP { int|sys||getxattr(const char *path, \ 733 const char *name, void *value, size_t size); } 734379 STD RUMP { int|sys||lgetxattr(const char *path, \ 735 const char *name, void *value, size_t size); } 736380 STD RUMP { int|sys||fgetxattr(int fd, \ 737 const char *name, void *value, size_t size); } 738381 STD RUMP { int|sys||listxattr(const char *path, \ 739 char *list, size_t size); } 740382 STD RUMP { int|sys||llistxattr(const char *path, \ 741 char *list, size_t size); } 742383 STD RUMP { int|sys||flistxattr(int fd, \ 743 char *list, size_t size); } 744384 STD RUMP { int|sys||removexattr(const char *path, \ 745 const char *name); } 746385 STD RUMP { int|sys||lremovexattr(const char *path, \ 747 const char *name); } 748386 STD RUMP { int|sys||fremovexattr(int fd, \ 749 const char *name); } 750387 COMPAT_50 MODULAR { int|sys|30|stat(const char *path, struct stat30 *ub); } 751388 COMPAT_50 MODULAR { int|sys|30|fstat(int fd, struct stat30 *sb); } 752389 COMPAT_50 MODULAR { int|sys|30|lstat(const char *path, struct stat30 *ub); } 753390 STD RUMP { int|sys|30|getdents(int fd, char *buf, size_t count); } 754391 IGNORED old posix_fadvise 755392 COMPAT_30 MODULAR { int|sys|30|fhstat(const struct compat_30_fhandle \ 756 *fhp, struct stat30 *sb); } 757393 COMPAT_50 MODULAR { int|sys|30|ntp_gettime(struct ntptimeval50 *ntvp); } 758394 STD RUMP { int|sys|30|socket(int domain, int type, int protocol); } 759395 STD RUMP { int|sys|30|getfh(const char *fname, void *fhp, \ 760 size_t *fh_size); } 761396 STD { int|sys|40|fhopen(const void *fhp, size_t fh_size,\ 762 int flags); } 763397 STD { int|sys|40|fhstatvfs1(const void *fhp, \ 764 size_t fh_size, struct statvfs *buf, int flags); } 765398 COMPAT_50 MODULAR { int|sys|40|fhstat(const void *fhp, \ 766 size_t fh_size, struct stat30 *sb); } 767 768; Asynchronous I/O system calls 769399 STD MODULAR { int|sys||aio_cancel(int fildes, struct aiocb *aiocbp); } 770400 STD MODULAR { int|sys||aio_error(const struct aiocb *aiocbp); } 771401 STD MODULAR { int|sys||aio_fsync(int op, struct aiocb *aiocbp); } 772402 STD MODULAR { int|sys||aio_read(struct aiocb *aiocbp); } 773403 STD MODULAR { int|sys||aio_return(struct aiocb *aiocbp); } 774404 COMPAT_50 MODULAR { int|sys||aio_suspend(const struct aiocb *const *list, \ 775 int nent, const struct timespec50 *timeout); } 776405 STD MODULAR { int|sys||aio_write(struct aiocb *aiocbp); } 777406 STD MODULAR { int|sys||lio_listio(int mode, struct aiocb *const *list, \ 778 int nent, struct sigevent *sig); } 779 780407 UNIMPL 781408 UNIMPL 782409 UNIMPL 783 784410 STD RUMP { int|sys|50|mount(const char *type, \ 785 const char *path, int flags, void *data, \ 786 size_t data_len); } 787411 STD { void *|sys||mremap(void *old_address, size_t old_size, \ 788 void *new_address, size_t new_size, int flags); } 789 790; Processor-sets system calls 791412 STD { int|sys||pset_create(psetid_t *psid); } 792413 STD { int|sys||pset_destroy(psetid_t psid); } 793414 STD { int|sys||pset_assign(psetid_t psid, cpuid_t cpuid, \ 794 psetid_t *opsid); } 795415 STD { int|sys||_pset_bind(idtype_t idtype, id_t first_id, \ 796 id_t second_id, psetid_t psid, psetid_t *opsid); } 797416 STD { int|sys|50|posix_fadvise(int fd, int pad, \ 798 off_t offset, off_t len, int advice); } 799417 STD RUMP { int|sys|50|select(int nd, fd_set *in, fd_set *ou, \ 800 fd_set *ex, struct timeval *tv); } 801418 STD { int|sys|50|gettimeofday(struct timeval *tp, \ 802 void *tzp); } 803419 STD { int|sys|50|settimeofday(const struct timeval *tv, \ 804 const void *tzp); } 805420 STD RUMP { int|sys|50|utimes(const char *path, \ 806 const struct timeval *tptr); } 807421 STD { int|sys|50|adjtime(const struct timeval *delta, \ 808 struct timeval *olddelta); } 809#if defined(LFS) || !defined(_KERNEL) 810422 STD { int|sys|50|lfs_segwait(fsid_t *fsidp, \ 811 struct timeval *tv); } 812#else 813422 EXCL __lfs_segwait50 814#endif 815423 STD RUMP { int|sys|50|futimes(int fd, \ 816 const struct timeval *tptr); } 817424 STD RUMP { int|sys|50|lutimes(const char *path, \ 818 const struct timeval *tptr); } 819425 STD { int|sys|50|setitimer(int which, \ 820 const struct itimerval *itv, \ 821 struct itimerval *oitv); } 822426 STD { int|sys|50|getitimer(int which, \ 823 struct itimerval *itv); } 824427 STD { int|sys|50|clock_gettime(clockid_t clock_id, \ 825 struct timespec *tp); } 826428 STD { int|sys|50|clock_settime(clockid_t clock_id, \ 827 const struct timespec *tp); } 828429 STD { int|sys|50|clock_getres(clockid_t clock_id, \ 829 struct timespec *tp); } 830430 STD { int|sys|50|nanosleep(const struct timespec *rqtp, \ 831 struct timespec *rmtp); } 832431 STD { int|sys|50|__sigtimedwait(const sigset_t *set, \ 833 siginfo_t *info, \ 834 struct timespec *timeout); } 835432 STD { int|sys|50|mq_timedsend(mqd_t mqdes, \ 836 const char *msg_ptr, size_t msg_len, \ 837 unsigned msg_prio, \ 838 const struct timespec *abs_timeout); } 839433 STD { ssize_t|sys|50|mq_timedreceive(mqd_t mqdes, \ 840 char *msg_ptr, size_t msg_len, unsigned *msg_prio, \ 841 const struct timespec *abs_timeout); } 842434 STD { int|sys|50|_lwp_park(const struct timespec *ts, \ 843 lwpid_t unpark, const void *hint, \ 844 const void *unparkhint); } 845435 STD RUMP { int|sys|50|kevent(int fd, \ 846 const struct kevent *changelist, size_t nchanges, \ 847 struct kevent *eventlist, size_t nevents, \ 848 const struct timespec *timeout); } 849436 STD RUMP { int|sys|50|pselect(int nd, fd_set *in, fd_set *ou, \ 850 fd_set *ex, const struct timespec *ts, \ 851 const sigset_t *mask); } 852437 STD RUMP { int|sys|50|pollts(struct pollfd *fds, u_int nfds, \ 853 const struct timespec *ts, const sigset_t *mask); } 854438 STD MODULAR { int|sys|50|aio_suspend( \ 855 const struct aiocb *const *list, \ 856 int nent, const struct timespec *timeout); } 857439 STD RUMP { int|sys|50|stat(const char *path, struct stat *ub); } 858440 STD RUMP { int|sys|50|fstat(int fd, struct stat *sb); } 859441 STD RUMP { int|sys|50|lstat(const char *path, struct stat *ub); } 860#if defined(SYSVSEM) || !defined(_KERNEL_OPT) 861442 STD { int|sys|50|__semctl(int semid, int semnum, int cmd, \ 862 ... union __semun *arg); } 863#else 864442 EXCL ____semctl50 865#endif 866#if defined(SYSVSHM) || !defined(_KERNEL_OPT) 867443 STD { int|sys|50|shmctl(int shmid, int cmd, \ 868 struct shmid_ds *buf); } 869#else 870443 EXCL ____shmctl50 871#endif 872#if defined(SYSVMSG) || !defined(_KERNEL_OPT) 873444 STD { int|sys|50|msgctl(int msqid, int cmd, \ 874 struct msqid_ds *buf); } 875#else 876444 EXCL ____msgctl50 877#endif 878445 STD { int|sys|50|getrusage(int who, struct rusage *rusage); } 879446 STD { int|sys|50|timer_settime(timer_t timerid, \ 880 int flags, const struct itimerspec *value, \ 881 struct itimerspec *ovalue); } 882447 STD { int|sys|50|timer_gettime(timer_t timerid, struct \ 883 itimerspec *value); } 884#if defined(NTP) || !defined(_KERNEL_OPT) 885448 STD { int|sys|50|ntp_gettime(struct ntptimeval *ntvp); } 886#else 887448 EXCL ___ntp_gettime50 888#endif 889449 STD { int|sys|50|wait4(int pid, int *status, \ 890 int options, struct rusage *rusage); } 891450 STD RUMP { int|sys|50|mknod(const char *path, mode_t mode, \ 892 dev_t dev); } 893451 STD RUMP { int|sys|50|fhstat(const void *fhp, \ 894 size_t fh_size, struct stat *sb); } 895