$NetBSD: syscalls.master,v 1.107 2024/09/28 19:35:56 christos Exp $
; @(#)syscalls.master 8.1 (Berkeley) 7/19/93
; NetBSD m68k COMPAT_LINUX 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
; 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 names and switch definition files only.
#if defined(_KERNEL_OPT)
#include "opt_compat_netbsd.h"
#include "opt_compat_43.h"
#endif
#include <sys/param.h>
#include <sys/poll.h>
#include <sys/systm.h>
#include <sys/signal.h>
#include <sys/mount.h>
#include <sys/sched.h>
#include <sys/syscallargs.h>
#include <compat/linux/common/linux_types.h>
#include <compat/linux/common/linux_signal.h>
#include <compat/linux/common/linux_siginfo.h>
#include <compat/linux/common/linux_machdep.h>
#include <compat/linux/common/linux_mmap.h>
#include <compat/linux/common/linux_mqueue.h>
#include <compat/linux/common/linux_sched.h>
#include <compat/linux/linux_syscallargs.h>
%%
0 NOARGS { int|linux_sys||nosys(void); } syscall
1 STD { int|linux_sys||exit(int rval); }
2 NOARGS { int|sys||fork(void); }
3 NOARGS { ssize_t|sys||read(int fd, void *buf, size_t nbyte); }
4 NOARGS { ssize_t|sys||write(int fd, const void *buf, \
size_t nbyte); }
5 STD { int|linux_sys||open(const char *path, int flags, \
linux_umode_t mode); }
6 NOARGS { int|sys||close(int fd); }
7 STD { int|linux_sys||waitpid(int pid, int *status, \
int options);}
8 STD { int|linux_sys||creat(const char *path, linux_umode_t mode); }
9 NOARGS { int|sys||link(const char *path, const char *link); }
10 STD { int|linux_sys||unlink(const char *path); }
11 NOARGS { int|sys||execve(const char *path, char **argp, \
char **envp); }
12 NOARGS { int|sys||chdir(const char *path); }
13 STD { int|linux_sys||time(linux_time_t *t); }
14 STD { int|linux_sys||mknod(const char *path, linux_umode_t mode, \
unsigned dev); }
15 NOARGS { int|sys||chmod(const char *path, int mode); }
;16 lchown on i386; chown on m68k.
16 STD { int|linux_sys||chown16(const char *path, \
linux_uid16_t uid, linux_gid16_t gid); }
17 OBSOL break
18 OBSOL ostat
#if !defined(_KERNEL) || defined(COMPAT_43)
19 NOARGS { long|compat_43_sys||lseek(int fd, long offset, \
int whence); }
#else
19 UNIMPL compat_43_sys_lseek
#endif
20 NOARGS { pid_t|sys||getpid(void); }
21 UNIMPL mount
22 OBSOL umount
23 NOARGS linux_setuid16 { int|sys||setuid(uid_t uid); }
24 NOARGS linux_getuid16 { uid_t|sys||getuid(void); }
25 STD { int|linux_sys||stime(linux_time_t *t); }
26 STD { int|linux_sys||ptrace(int request, int pid, \
int addr, int data); }
27 STD { int|linux_sys||alarm(unsigned int secs); }
28 OBSOL ofstat
29 STD { int|linux_sys||pause(void); }
30 STD { int|linux_sys||utime(const char *path, \
struct linux_utimbuf *times); }
31 OBSOL stty
32 OBSOL gtty
33 NOARGS { int|sys||access(const char *path, int flags); }
34 STD { int|linux_sys||nice(int incr); }
35 OBSOL ftime
36 NOARGS { int|sys||sync(void); }
37 STD { int|linux_sys||kill(int pid, int signum); }
38 NOARGS { int|sys||__posix_rename(const char *from, \
const char *to); }
39 NOARGS { int|sys||mkdir(const char *path, linux_umode_t mode); }
40 NOARGS { int|sys||rmdir(const char *path); }
41 NOARGS { int|sys||dup(int fd); }
42 STD { int|linux_sys||pipe(int *pfds); }
43 STD { int|linux_sys||times(struct times *tms); }
44 OBSOL prof
45 STD { int|linux_sys||brk(char *nsize); }
46 NOARGS linux_setgid16 { int|sys||setgid(gid_t gid); }
47 NOARGS linux_getgid16 { gid_t|sys||getgid(void); }
48 STD { int|linux_sys||signal(int signum, \
linux_handler_t handler); }
49 NOARGS linux_geteuid16 { uid_t|sys||geteuid(void); }
50 NOARGS linux_getegid16 { gid_t|sys||getegid(void); }
51 NOARGS { int|sys||acct(char *path); }
52 UNIMPL umount
53 OBSOL lock
54 STD { int|linux_sys||ioctl(int fd, u_long com, \
void *data); }
55 STD { int|linux_sys||fcntl(int fd, int cmd, void *arg); }
56 OBSOL mpx
57 NOARGS { int|sys||setpgid(int pid, int pgid); }
58 OBSOL ulimit
59 UNIMPL oldolduname
60 NOARGS { int|sys||umask(int newmask); }
61 NOARGS { int|sys||chroot(char *path); }
62 UNIMPL ustat
63 NOARGS { int|sys||dup2(int from, int to); }
64 NOARGS { pid_t|sys||getppid(void); }
65 NOARGS { int|sys||getpgrp(void); }
66 NOARGS { int|sys||setsid(void); }
67 STD { int|linux_sys||sigaction(int signum, \
const struct linux_old_sigaction *nsa, \
struct linux_old_sigaction *osa); }
68 STD { int|linux_sys||siggetmask(void); }
69 STD { int|linux_sys||sigsetmask(linux_old_sigset_t mask); }
70 STD { int|linux_sys||setreuid16(linux_uid16_t ruid, \
linux_uid16_t euid); }
71 STD { int|linux_sys||setregid16(linux_gid16_t rgid, \
linux_gid16_t egid); }
72 STD { int|linux_sys||sigsuspend(void *restart, \
int oldmask, int mask); }
73 STD { int|linux_sys||sigpending(linux_old_sigset_t *set); }
#if !defined(_KERNEL) || defined(COMPAT_43)
74 NOARGS { int|compat_43_sys||sethostname(char *hostname, \
u_int len);}
#else
74 UNIMPL compat_43_sys_sethostname
#endif
75 STD { int|linux_sys||setrlimit(u_int which, \
struct orlimit *rlp); }
76 STD { int|linux_sys||getrlimit(u_int which, \
struct orlimit *rlp); }
77 NOARGS { int|compat_50_sys||getrusage(int who, \
struct rusage50 *rusage); }
78 STD { int|linux_sys||gettimeofday(struct timeval50 *tp, \
struct timezone *tzp); }
79 STD { int|linux_sys||settimeofday(struct timeval50 *tp, \
struct timezone *tzp); }
80 STD { int|linux_sys||getgroups16(int gidsetsize, \
linux_gid16_t *gidset); }
81 STD { int|linux_sys||setgroups16(int gidsetsize, \
linux_gid16_t *gidset); }
82 STD { int|linux_sys||oldselect(struct linux_oldselect *lsp); }
83 NOARGS { int|sys||symlink(const char *path, const char *to); }
#if !defined(_KERNEL) || defined(COMPAT_43)
84 NOARGS { int|compat_43_sys||lstat(const char *path, \
struct stat43 *up); } oolstat
#else
84 UNIMPL compat_43_sys_lstat
#endif
85 NOARGS { ssize_t|sys||readlink(const char *path, char *buf, \
int count); }
#ifdef EXEC_AOUT
86 STD { int|linux_sys||uselib(const char *path); }
#else
86 UNIMPL sys_uselib
#endif
87 STD { int|linux_sys||swapon(char *name); }
88 STD { int|linux_sys||reboot(int magic1, int magic2, \
int cmd, void *arg); }
89 STD { int|linux_sys||readdir(int fd, void *dent, \
unsigned int count); }
90 STD { int|linux_sys||old_mmap(struct linux_oldmmap *lmp); }
91 NOARGS { int|sys||munmap(void *addr, size_t len); }
92 NOARGS { int|compat_43_sys||truncate(const char *path, \
long length); }
#if !defined(_KERNEL) || defined(COMPAT_43)
93 NOARGS { int|compat_43_sys||ftruncate(int fd, long length); }
#else
93 UNIMPL compat_43_sys_ftruncate
#endif
94 NOARGS { int|sys||fchmod(int fd, linux_umode_t mode); }
95 STD { int|linux_sys||fchown16(int fd, linux_uid16_t uid, \
linux_gid16_t gid); }
96 STD { int|linux_sys||getpriority(int which, int who); }
97 NOARGS { int|sys||setpriority(int which, int who, int prio); }
98 NOARGS { int|sys||profil(void *samples, u_int size, \
u_int offset, u_int scale); }
99 STD { int|linux_sys||statfs(const char *path, \
struct linux_statfs *sp); }
100 STD { int|linux_sys||fstatfs(int fd, \
struct linux_statfs *sp); }
101 UNIMPL ioperm
102 STD { int|linux_sys||socketcall(int what, void *args); }
103 UNIMPL syslog
104 NOARGS { int|compat_50_sys||setitimer(int which, \
struct itimerval50 *itv, \
struct itimerval50 *oitv); }
105 NOARGS { int|compat_50_sys||getitimer(int which, \
struct itimerval50 *itv); }
106 STD { int|linux_sys||stat(const char *path, \
struct linux_stat *sp); }
107 STD { int|linux_sys||lstat(const char *path, \
struct linux_stat *sp); }
108 STD { int|linux_sys||fstat(int fd, struct linux_stat *sp); }
109 UNIMPL olduname
110 UNIMPL iopl
111 UNIMPL vhangup
112 UNIMPL idle
113 UNIMPL vm86old
114 STD { int|linux_sys||wait4(int pid, int *status, \
int options, struct rusage50 *rusage); }
115 STD { int|linux_sys||swapoff(const char *path); }
116 STD { int|linux_sys||sysinfo(struct linux_sysinfo *arg); }
117 STD { int|linux_sys||ipc(int what, int a1, int a2, int a3, \
void *ptr); }
118 NOARGS { int|sys||fsync(int fd); }
119 STD { int|linux_sys||sigreturn(void); }
120 STD { int|linux_sys||clone(int flags, void *stack, \
void *parent_tidptr, void *tls, void *child_tidptr); }
121 STD { int|linux_sys||setdomainname(char *domainname, \
int len); }
122 STD { int|linux_sys||uname(struct linux_utsname *up); }
123 STD { int|linux_sys||cacheflush(unsigned long addr, \
int scope, int cache, unsigned long len); }
124 UNIMPL adjtimex
125 STD { int|linux_sys||mprotect(const void *start, \
unsigned long len, int prot); }
126 STD { int|linux_sys||sigprocmask(int how, \
const linux_old_sigset_t *set, \
linux_old_sigset_t *oset); }
127 UNIMPL create_module
128 UNIMPL init_module
129 UNIMPL delete_module
130 UNIMPL get_kernel_syms
131 UNIMPL quotactl
132 NOARGS { pid_t|sys||getpgid(pid_t pid); }
133 NOARGS { int|sys||fchdir(int fd); }
134 UNIMPL bdflush
135 UNIMPL sysfs
136 STD { int|linux_sys||personality(unsigned long per); }
137 UNIMPL afs_syscall
138 NOARGS linux_setfsuid16 { int|linux_sys||setfsuid(uid_t uid); }
139 NOARGS linux_setfsgid16 { int|linux_sys||setfsgid(gid_t gid); }
140 STD { int|linux_sys||llseek(int fd, u_int32_t ohigh, \
u_int32_t olow, void *res, int whence); }
141 STD { int|linux_sys||getdents(int fd, \
struct linux_dirent *dent, unsigned int count); }
142 STD { int|linux_sys||select(int nfds, fd_set *readfds, \
fd_set *writefds, fd_set *exceptfds, \
struct timeval50 *timeout); }
143 NOARGS { int|sys||flock(int fd, int how); }
144 NOARGS { int|sys|13|msync(void *addr, size_t len, int flags); }
145 NOARGS { ssize_t|sys||readv(int fd, \
const struct iovec *iovp, int iovcnt); }
146 NOARGS { ssize_t|sys||writev(int fd, \
const struct iovec *iovp, int iovcnt); }
147 NOARGS { pid_t|sys||getsid(pid_t pid); }
148 STD { int|linux_sys||fdatasync(int fd); }
149 STD { int|linux_sys||__sysctl(struct linux___sysctl *lsp); }
150 NOARGS { int|sys||mlock(void *addr, size_t len); }
151 NOARGS { int|sys||munlock(void *addr, size_t len); }
152 NOARGS { int|sys||mlockall(int flags); }
153 NOARGS { int|sys||munlockall(void); }
154 STD { int|linux_sys||sched_setparam(pid_t pid, \
const struct linux_sched_param *sp); }
155 STD { int|linux_sys||sched_getparam(pid_t pid, \
struct linux_sched_param *sp); }
156 STD { int|linux_sys||sched_setscheduler(pid_t pid, \
int policy, const struct linux_sched_param *sp); }
157 STD { int|linux_sys||sched_getscheduler(pid_t pid); }
158 STD { int|linux_sys||sched_yield(void); }
159 STD { int|linux_sys||sched_get_priority_max(int policy); }
160 STD { int|linux_sys||sched_get_priority_min(int policy); }
161 UNIMPL sched_rr_get_interval
162 STD { int|linux_sys||nanosleep( \
const struct linux_timespec *rqtp, \
struct linux_timespec *rmtp); }
163 STD { void *|linux_sys||mremap(void *old_address, \
size_t old_size, size_t new_size, u_long flags); }
164 STD { int|linux_sys||setresuid16(linux_uid16_t ruid, \
linux_uid16_t euid, linux_uid16_t suid); }
165 STD { int|linux_sys||getresuid16(linux_uid16_t *ruid, \
linux_uid16_t *euid, linux_uid16_t *suid); }
166 UNIMPL vm86
167 UNIMPL query_module
168 NOARGS { int|sys||poll(struct pollfd *fds, u_int nfds, \
int timeout); }
169 UNIMPL nfsservctl
170 STD { int|linux_sys||setresgid16(linux_gid16_t rgid, \
linux_gid16_t egid, linux_gid16_t sgid); }
171 STD { int|linux_sys||getresgid16(linux_gid16_t *rgid, \
linux_gid16_t *egid, linux_gid16_t *sgid); }
172 UNIMPL prctl
173 STD { int|linux_sys||rt_sigreturn(void); }
174 STD { int|linux_sys||rt_sigaction(int signum, \
const struct linux_sigaction *nsa, \
struct linux_sigaction *osa, \
size_t sigsetsize); }
175 STD { int|linux_sys||rt_sigprocmask(int how, \
const linux_sigset_t *set, \
linux_sigset_t *oset, \
size_t sigsetsize); }
176 STD { int|linux_sys||rt_sigpending( \
linux_sigset_t *set, \
size_t sigsetsize); }
177 STD { int|linux_sys||rt_sigtimedwait( \
const linux_sigset_t *set, \
linux_siginfo_t *info, \
const struct linux_timespec *timeout); }
178 STD { int|linux_sys||rt_queueinfo(int pid, int signum, \
linux_siginfo_t *uinfo); }
179 STD { int|linux_sys||rt_sigsuspend(linux_sigset_t *unewset, \
size_t sigsetsize); }
180 STD { int|linux_sys||pread(int fd, char *buf, \
size_t nbyte, off_t offset); }
181 STD { int|linux_sys||pwrite(int fd, char *buf, \
size_t nbyte, off_t offset); }
;182 chown on i386; lchown on m68k.
182 STD { int|linux_sys||lchown16(const char *path, \
linux_uid16_t uid, linux_gid16_t gid); }
183 NOARGS { int|sys||__getcwd(char *bufp, size_t length); }
184 UNIMPL capget
185 UNIMPL capset
186 STD { int|linux_sys||sigaltstack( \
const struct linux_sigaltstack *ss, \
struct linux_sigaltstack *oss); }
187 UNIMPL sendfile
188 UNIMPL getpmsg
189 UNIMPL putpmsg
190 NOARGS { int|sys|14|vfork(void); }
191 STD { int|linux_sys||ugetrlimit(int which, \
struct orlimit *rlp); }
#define linux_sys_mmap2_args linux_sys_mmap_args
192 NOARGS { linux_off_t|linux_sys||mmap2(unsigned long addr, \
size_t len, int prot, int flags, int fd, \
linux_off_t offset); }
193 STD { int|linux_sys||truncate64(const char *path, \
off_t length); }
194 STD { int|linux_sys||ftruncate64(unsigned int fd, \
off_t length); }
195 STD { int|linux_sys||stat64(const char *path, \
struct linux_stat64 *sp); }
196 STD { int|linux_sys||lstat64(const char *path, \
struct linux_stat64 *sp); }
197 STD { int|linux_sys||fstat64(int fd, \
struct linux_stat64 *sp); }
198 NOARGS { int|sys||__posix_chown(const char *path, uid_t uid, \
gid_t gid); }
199 NOARGS { uid_t|sys||getuid(void); }
200 NOARGS { gid_t|sys||getgid(void); }
201 NOARGS { uid_t|sys||geteuid(void); }
202 NOARGS { gid_t|sys||getegid(void); }
203 NOARGS { int|sys||setreuid(uid_t ruid, uid_t euid); }
204 NOARGS { int|sys||setregid(gid_t rgid, gid_t egid); }
205 NOARGS { int|sys||getgroups(int gidsetsize, gid_t *gidset); }
206 NOARGS { int|sys||setgroups(int gidsetsize, gid_t *gidset); }
207 NOARGS { int|sys||__posix_fchown(int fd, uid_t uid, \
gid_t gid); }
208 STD { int|linux_sys||setresuid(uid_t ruid, uid_t euid, \
uid_t suid); }
209 STD { int|linux_sys||getresuid(uid_t *ruid, uid_t *euid, \
uid_t *suid); }
210 STD { int|linux_sys||setresgid(gid_t rgid, gid_t egid, \
gid_t sgid); }
211 STD { int|linux_sys||getresgid(gid_t *rgid, gid_t *egid, \
gid_t *sgid); }
212 NOARGS { int|sys||__posix_lchown(const char *path, uid_t uid, \
gid_t gid); }
213 NOARGS { int|sys||setuid(uid_t uid); }
214 NOARGS { int|sys||setgid(gid_t gid); }
215 STD { int|linux_sys||setfsuid(uid_t uid); }
216 STD { int|linux_sys||setfsgid(gid_t gid); }
217 UNIMPL /* unused */
218 UNIMPL /* unused */
219 UNIMPL /* unused */
220 STD { int|linux_sys||getdents64(int fd, \
struct linux_dirent64 *dent, unsigned int count); }
221 NOARGS { pid_t|linux_sys||gettid(void); }
222 STD { int|linux_sys||tkill(int tid, int sig); }
223 STD { int|linux_sys||setxattr(char *path, char *name, \
void *value, size_t size, int flags); }
224 STD { int|linux_sys||lsetxattr(char *path, char *name, \
void *value, size_t size, int flags); }
225 STD { int|linux_sys||fsetxattr(int fd, char *name, \
void *value, size_t size, int flags); }
226 STD { ssize_t|linux_sys||getxattr(char *path, char *name, \
void *value, size_t size); }
227 STD { ssize_t|linux_sys||lgetxattr(char *path, char *name, \
void *value, size_t size); }
228 STD { ssize_t|linux_sys||fgetxattr(int fd, char *name, \
void *value, size_t size); }
229 STD { ssize_t|linux_sys||listxattr(char *path, char *list, \
size_t size); }
230 STD { ssize_t|linux_sys||llistxattr(char *path, char *list, \
size_t size); }
231 STD { ssize_t|linux_sys||flistxattr(int fd, char *list, \
size_t size); }
232 STD { int|linux_sys||removexattr(char *path, char *name); }
233 STD { int|linux_sys||lremovexattr(char *path, char *name); }
234 STD { int|linux_sys||fremovexattr(int fd, char *name); }
235 STD { int|linux_sys||futex(int *uaddr, int op, int val, \
const struct linux_timespec *timeout, int *uaddr2, \
int val3); }
236 UNIMPL sendfile64
237 NOARGS { int|sys||mincore(void *addr, size_t len, char *vec); }
238 NOARGS { int|sys||madvise(void *addr, size_t len, int behav); }
239 STD { int|linux_sys||fcntl64(int fd, int cmd, void *arg); }
240 STD { ssize_t|linux_sys||readahead(int fd, off_t offset, \
size_t count); }
241 UNIMPL io_setup
242 UNIMPL io_destroy
243 UNIMPL io_getevents
244 UNIMPL io_submit
245 UNIMPL io_cancel
246 STD { int|linux_sys||fadvise64(int fd, off_t offset, \
size_t len, int advice); }
247 UNIMPL exit_group
248 UNIMPL lookup_dcookie
249 STD { int|linux_sys||epoll_create(int size); }
250 STD { int|linux_sys||epoll_ctl(int epfd, int op, int fd, \
struct linux_epoll_event *event); }
251 STD { int|linux_sys||epoll_wait(int epfd, \
struct linux_epoll_event *events, int maxevents, \
int timeout); }
252 UNIMPL remap_file_pages
253 STD { int|linux_sys||set_tid_address(int *tid); }
254 STD { int|linux_sys||timer_create(clockid_t clockid, \
struct linux_sigevent *evp, timer_t *timerid); }
255 STD { int|linux_sys||timer_settime(timer_t timerid, \
int flags, const struct linux_itimerspec *tim, \
struct linux_itimerspec *otim); }
256 STD { int|linux_sys||timer_gettime(timer_t timerid, \
struct linux_itimerspec *tim); }
257 NOARGS { int|sys||timer_getoverrun(timer_t timerid); }
258 NOARGS { int|sys||timer_delete(timer_t timerid); }
259 STD { int|linux_sys||clock_settime(clockid_t which, \
struct linux_timespec *tp); }
260 STD { int|linux_sys||clock_gettime(clockid_t which, \
struct linux_timespec *tp); }
261 STD { int|linux_sys||clock_getres(clockid_t which, \
struct linux_timespec *tp); }
262 STD { int|linux_sys||clock_nanosleep(clockid_t which, \
int flags, struct linux_timespec *rqtp, \
struct linux_timespec *rmtp); }
263 STD { int|linux_sys||statfs64(const char *path, \
size_t sz, struct linux_statfs64 *sp); }
264 STD { int|linux_sys||fstatfs64(int fd, \
size_t sz, struct linux_statfs64 *sp); }
265 STD { int|linux_sys||tgkill(int tgid, int tid, int sig); }
266 NOARGS { int|compat_50_sys||utimes(const char *path, \
const struct timeval50 *tptr); }
267 STD { int|linux_sys||fadvise64_64(int fd, off_t offset, \
off_t len, int advice); }
268 UNIMPL mbind
269 UNIMPL get_mempolicy
270 UNIMPL set_mempolicy
271 STD { linux_mqd_t|linux_sys||mq_open(const char *name, \
int oflag, linux_umode_t mode, \
struct linux_mq_attr *attr); }
272 STD { int|linux_sys||mq_unlink(const char *name); }
273 STD { int|linux_sys||mq_timedsend(linux_mqd_t mqdes, \
const char *msg_ptr, size_t msg_len, \
unsigned int msg_prio, \
const struct linux_timespec *abs_timeout); }
274 STD { ssize_t|linux_sys||mq_timedreceive(linux_mqd_t mqdes, \
char *msg_ptr, size_t msg_len, \
unsigned int *msg_prio, \
const struct linux_timespec *abs_timeout); }
275 STD { int|linux_sys||mq_notify(linux_mqd_t mqdes, \
const struct linux_sigevent *sevp); }
276 STD { int|linux_sys||mq_getsetattr(linux_mqd_t mqdes, \
const struct linux_mq_attr *newattr, \
struct linux_mq_attr *oldattr); }
277 UNIMPL waitid
278 UNIMPL vserver
279 UNIMPL add_key
280 UNIMPL request_key
281 UNIMPL keyctl
282 UNIMPL ioprio_set
283 UNIMPL ioprio_get
284 STD { int|linux_sys||inotify_init(void); }
285 STD { int|linux_sys||inotify_add_watch(int fd, \
const char *pathname, uint32_t mask); }
286 STD { int|linux_sys||inotify_rm_watch(int fd, int wd); }
287 UNIMPL migrate_pages
288 STD { int|linux_sys||openat(int fd, const char *path, \
int flags, ... linux_umode_t mode); }
289 NOARGS { int|sys||mkdirat(int fd, const char *path, \
linux_umode_t mode); }
290 STD { int|linux_sys||mknodat(int fd, const char *path, \
linux_umode_t mode, unsigned dev); }
291 STD { int|linux_sys||fchownat(int fd, const char *path, \
uid_t owner, gid_t group, int flag); }
292 UNIMPL futimesat
293 STD { int|linux_sys||fstatat64(int fd, const char *path, \
struct linux_stat64 *sp, int flag); }
294 STD { int|linux_sys||unlinkat(int fd, const char *path, \
int flag); }
295 NOARGS { int|sys||renameat(int fromfd, const char *from, \
int tofd, const char *to); }
296 STD { int|linux_sys||linkat(int fd1, const char *name1, \
int fd2, const char *name2, int flags); }
297 NOARGS { int|sys||symlinkat(const char *path1, int fd, \
const char *path2); }
298 NOARGS { ssize_t|sys||readlinkat(int fd, const char *path, \
char *buf, size_t bufsize); }
299 STD { int|linux_sys||fchmodat(int fd, const char *path, \
linux_umode_t mode); }
300 STD { int|linux_sys||faccessat(int fd, const char *path, \
int amode); }
301 STD { int|linux_sys||pselect6(int nfds, fd_set *readfds, \
fd_set *writefds, fd_set *exceptfds, \
struct linux_timespec *timeout, \
linux_sized_sigset_t *ss); }
302 STD { int|linux_sys||ppoll(struct pollfd *fds, u_int nfds, \
struct linux_timespec *timeout, \
linux_sigset_t *sigset); }
303 UNIMPL unshare
;
; The NetBSD native robust list calls have different
; argument names / types, but they are ABI-compatible
; with Linux.
;
304 NOARGS { int|sys||__futex_set_robust_list(void *head, \
size_t len); }
305 NOARGS { int|sys||__futex_get_robust_list(lwpid_t lwpid, \
void **headp, size_t *lenp); }
306 UNIMPL splice
307 STD { int|linux_sys||sync_file_range(int fd, \
off_t offset, off_t nbytes, unsigned int flags); }
308 UNIMPL tee
309 UNIMPL vmsplice
310 UNIMPL move_pages
311 STD { int|linux_sys||sched_setaffinity(pid_t pid, \
unsigned int len, unsigned long *mask); }
312 STD { int|linux_sys||sched_getaffinity(pid_t pid, \
unsigned int len, unsigned long *mask); }
313 UNIMPL kexec_load
314 STD { int|linux_sys||getcpu(unsigned int *cpu, \
unsigned int *node, \
struct linux_getcpu_cache *tcache); }
315 STD { int|linux_sys||epoll_pwait(int epfd, \
struct linux_epoll_event *events, int maxevents, \
int timeout, const linux_sigset_t *sigmask); }
316 STD { int|linux_sys||utimensat(int fd, const char *path, \
struct linux_timespec *times, int flag); }
317 UNIMPL signalfd
318 STD { int|linux_sys||timerfd_create(clockid_t clock_id, \
int flags); }
319 STD { int|linux_sys||eventfd(unsigned int initval); }
320 STD { int|linux_sys||fallocate(int fd, int mode, \
off_t offset, off_t len); }
321 STD { int|linux_sys||timerfd_settime(int fd, int flags, \
const struct linux_itimerspec *tim, \
struct linux_itimerspec *otim); }
322 STD { int|linux_sys||timerfd_gettime(int fd, \
struct linux_itimerspec *tim); }
323 UNIMPL signalfd4
324 STD { int|linux_sys||eventfd2(unsigned int initval, \
int flags); }
325 STD { int|linux_sys||epoll_create1(int flags); }
326 STD { int|linux_sys||dup3(int from, int to, int flags); }
327 STD { int|linux_sys||pipe2(int *pfds, int flags); }
328 STD { int|linux_sys||inotify_init1(int flags); }
329 STD { int|linux_sys||preadv(int fd, \
const struct iovec *iovp, int iovcnt, \
unsigned long off_lo, unsigned long off_hi); }
330 STD { int|linux_sys||pwritev(int fd, \
const struct iovcnt *iovp, int iovcnt, \
unsigned long off_lo, unsigned long off_hi); }
331 UNIMPL rt_tgsigqueueinfo
332 UNIMPL perf_counter_open
333 UNIMPL set_thread_area
334 UNIMPL get_thread_area
335 UNIMPL atomic_cmpxchg_32
336 UNIMPL atomic_barrier
337 UNIMPL fanotify_init
338 UNIMPL fanotify_mark
339 STD { int|linux_sys||prlimit64(pid_t pid, int which, \
struct rlimit *new_rlp, struct rlimit *old_rlp); }
340 UNIMPL name_to_handle_at
341 UNIMPL open_by_handle_at
342 UNIMPL clock_adjtime
343 STD { int|linux_sys||syncfs(int fd); }
344 UNIMPL setns
345 UNIMPL process_vm_readv
346 UNIMPL process_vm_writev
347 UNIMPL kcmp
348 UNIMPL finit_module
349 UNIMPL sched_setattr
350 UNIMPL sched_getattr
351 STD { int|linux_sys||renameat2(int fromfd, \
const char *from, int tofd, const char *to, \
unsigned int flags); }
352 NOARGS { ssize_t|sys||getrandom(void *buf, size_t buflen, \
unsigned int flags); }
353 UNIMPL memfd_create
354 UNIMPL bpf
355 UNIMPL execveat
356 UNIMPL socket
357 UNIMPL socketpair
358 UNIMPL bind
359 UNIMPL connect
360 UNIMPL listen
361 STD { int|linux_sys||accept4(int s, \
struct osockaddr *name, \
int *anamelen, int flags); }
362 UNIMPL getsockopt
363 UNIMPL setsockopt
364 UNIMPL getsockname
365 UNIMPL getpeername
366 UNIMPL sendto
367 UNIMPL sendmsg
368 UNIMPL recvfrom
369 UNIMPL recvmsg
370 UNIMPL shutdown
371 STD { int|linux_sys||recvmmsg(int s, \
struct linux_mmsghdr *msgvec, unsigned int vlen, \
unsigned int flags, struct timespec *timeout); }
372 STD { int|linux_sys||sendmmsg(int s, \
struct linux_mmsghdr *msgvec, unsigned int vlen, \
unsigned int flags); }
373 UNIMPL userfaultfd
374 UNIMPL membarrier
375 UNIMPL mlock2
376 STD { ssize_t|linux_sys||copy_file_range(int fd_in, \
off_t * off_in, int fd_out, off_t * off_out, \
size_t len, unsigned int flags); }
377 UNIMPL preadv2
378 UNIMPL pwritev2
379 STD { int|linux_sys||statx(int fd, const char *path, \
int flag, unsigned int mask, \
struct linux_statx *sp); }
380 UNIMPL
381 UNIMPL
382 UNIMPL
383 UNIMPL
384 UNIMPL
385 UNIMPL
386 UNIMPL
387 UNIMPL
388 UNIMPL
389 UNIMPL
390 UNIMPL
391 UNIMPL
392 UNIMPL
393 UNIMPL
394 UNIMPL
395 UNIMPL
396 UNIMPL
397 UNIMPL
398 UNIMPL
399 UNIMPL
400 UNIMPL
401 UNIMPL
402 UNIMPL
403 UNIMPL
404 UNIMPL
405 UNIMPL
406 UNIMPL
407 UNIMPL
408 UNIMPL
409 UNIMPL
410 UNIMPL
411 UNIMPL
412 UNIMPL
413 UNIMPL
414 UNIMPL
415 UNIMPL
416 UNIMPL
417 UNIMPL
418 UNIMPL
419 UNIMPL
420 UNIMPL
421 UNIMPL
422 UNIMPL
423 UNIMPL
424 UNIMPL
425 UNIMPL
426 UNIMPL
427 UNIMPL
428 UNIMPL
429 UNIMPL
430 UNIMPL
431 UNIMPL
432 UNIMPL
433 UNIMPL
434 UNIMPL
435 STD { int|linux_sys||clone3( \
struct linux_user_clone3_args *cl_args, \
size_t size); }
436 STD { int|linux_sys||close_range(unsigned int first, \
unsigned int last, unsigned int flags); }
437 UNIMPL
438 UNIMPL
439 STD { int|linux_sys||faccessat2(int fd, const char *path, \
int amode, int flags); }
440 UNIMPL
441 STD { int|linux_sys||epoll_pwait2(int epfd, \
struct linux_epoll_event *events, int maxevents, \
const struct linux_timespec *timeout, \
const linux_sigset_t *sigmask); }