$NetBSD: syscalls.master,v 1.75 2024/09/28 19:35:55 christos Exp $
; @(#)syscalls.master 8.1 (Berkeley) 7/19/93
; NetBSD amd64 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_sysv.h"
#include "opt_compat_43.h"
#include "opt_compat_netbsd.h"
#endif
#include <sys/param.h>
#include <sys/poll.h>
#include <sys/systm.h>
#include <sys/signal.h>
#include <sys/mount.h>
#include <sys/syscallargs.h>
#include <sys/time.h>
#include <compat/sys/time.h>
#include <compat/linux/common/linux_types.h>
#include <compat/linux/common/linux_misc.h>
#include <compat/linux/common/linux_mmap.h>
#include <compat/linux/common/linux_ipc.h>
#include <compat/linux/common/linux_msg.h>
#include <compat/linux/common/linux_sched.h>
#include <compat/linux/common/linux_sem.h>
#include <compat/linux/common/linux_shm.h>
#include <compat/linux/common/linux_signal.h>
#include <compat/linux/common/linux_siginfo.h>
#include <compat/linux/common/linux_mqueue.h>
#include <compat/linux/common/linux_machdep.h>
#include <compat/linux/common/linux_sched.h>
#include <compat/linux/linux_syscallargs.h>
%%
0 NOARGS { ssize_t|sys||read(int fd, void *buf, size_t nbyte); }
1 NOARGS { ssize_t|sys||write(int fd, const void *buf, \
size_t nbyte); }
2 STD { int|linux_sys||open(const char *path, int flags, \
linux_umode_t mode); }
3 NOARGS { int|sys||close(int fd); }
4 STD { int|linux_sys||stat64(const char *path, \
struct linux_stat64 *sp); }
5 STD { int|linux_sys||fstat64(int fd, \
struct linux_stat64 *sp); }
6 STD { int|linux_sys||lstat64(const char *path, \
struct linux_stat64 *sp); }
7 NOARGS { int|sys||poll(struct pollfd *fds, u_int nfds, \
int timeout); }
8 NOARGS { long|compat_43_sys||lseek(int fd, long offset, \
int whence); }
9 NOARGS { linux_off_t|linux_sys||mmap(unsigned long addr, \
size_t len, int prot, int flags, int fd, \
linux_off_t offset); }
10 STD { int|linux_sys||mprotect(const void *start, \
unsigned long len, int prot); }
11 NOARGS { int|sys||munmap(void *addr, size_t len); }
12 STD { int|linux_sys||brk(char *nsize); }
13 STD { int|linux_sys||rt_sigaction(int signum, \
const struct linux_sigaction *nsa, \
struct linux_sigaction *osa, \
size_t sigsetsize); }
14 STD { int|linux_sys||rt_sigprocmask(int how, \
const linux_sigset_t *set, \
linux_sigset_t *oset, \
size_t sigsetsize); }
15 NOARGS { int|linux_sys||rt_sigreturn(void); }
16 STD { int|linux_sys||ioctl(int fd, u_long com, \
void *data); }
17 STD { int|linux_sys||pread(int fd, char *buf, \
size_t nbyte, off_t offset); }
18 STD { int|linux_sys||pwrite(int fd, char *buf, \
size_t nbyte, off_t offset); }
19 NOARGS { ssize_t|sys||readv(int fd, \
const struct iovec *iovp, int iovcnt); }
20 NOARGS { ssize_t|sys||writev(int fd, \
const struct iovec *iovp, int iovcnt); }
21 NOARGS { int|sys||access(const char *path, int flags); }
22 STD { int|linux_sys||pipe(int *pfds); }
23 STD { int|linux_sys||select(int nfds, fd_set *readfds, \
fd_set *writefds, fd_set *exceptfds, \
struct timeval50 *timeout); }
24 STD { int|linux_sys||sched_yield(void); }
25 STD { void *|linux_sys||mremap(void *old_address, \
size_t old_size, size_t new_size, u_long flags); }
26 NOARGS { int|sys|13|msync(void *addr, size_t len, int flags); }
27 NOARGS { int|sys||mincore(void *addr, size_t len, char *vec); }
28 NOARGS { int|sys||madvise(void *addr, size_t len, int behav); }
#ifdef SYSVSHM
29 NOARGS { int|linux_sys||shmget(key_t key, size_t size, \
int shmflg); }
30 NOARGS { int|sys||shmat(int shmid, void *shmaddr, int shmflg); }
31 NOARGS { int|linux_sys||shmctl(int shmid, int cmd, \
struct linux_shmid_ds *buf); }
#else
29 UNIMPL shmget
30 UNIMPL shmat
31 UNIMPL shmctl
#endif
32 NOARGS { int|sys||dup(int fd); }
33 NOARGS { int|sys||dup2(int from, int to); }
34 STD { int|linux_sys||pause(void); }
35 STD { int|linux_sys||nanosleep( \
const struct linux_timespec *rqtp, \
struct linux_timespec *rmtp); }
36 NOARGS { int|compat_50_sys||getitimer(int which, \
struct itimerval50 *itv); }
37 STD { int|linux_sys||alarm(unsigned int secs); }
38 NOARGS { int|compat_50_sys||setitimer(int which, \
struct itimerval50 *itv, \
struct itimerval50 *oitv); }
39 STD { pid_t|sys||getpid(void); }
40 UNIMPL sendfile
41 STD { int|linux_sys||socket(int domain, \
int type, int protocol); }
42 STD { int|linux_sys||connect(int s, \
const struct osockaddr *name, \
unsigned int namelen); }
43 STD { int|linux_sys||accept(int s, struct osockaddr *name, \
int *anamelen); } oaccept
44 STD { ssize_t|linux_sys||sendto(int s, void *msg, int len, \
int flags, struct osockaddr *to, int tolen); }
45 STD { ssize_t|linux_sys||recvfrom(int s, void *buf, \
size_t len, int flags, struct osockaddr *from, \
unsigned int *fromlenaddr); }
46 STD { int|linux_sys||sendmsg(int s, \
const struct linux_msghdr *msg, int flags); }
47 STD { ssize_t|linux_sys||recvmsg(int s, \
struct linux_msghdr *msg, int flags); }
48 NOARGS { int|sys||shutdown(int s, int how); }
49 STD { int|linux_sys||bind(int s, \
const struct osockaddr *name, \
unsigned int namelen); }
50 NOARGS { int|sys||listen(int s, int backlog); }
51 STD { int|linux_sys||getsockname(int fdec, void *asa, \
int *alen); }
52 STD { int|linux_sys||getpeername(int fdes, \
struct sockaddr *asa, unsigned int *alen); }
53 STD { int|linux_sys||socketpair(int domain, int type, \
int protocol, int *rsv); }
54 STD { int|linux_sys||setsockopt(int s, int level, \
int optname, void *optval, int optlen); }
55 STD { int|linux_sys||getsockopt(int s, int level, \
int optname, void *optval, int *optlen); }
56 STD { int|linux_sys||clone(int flags, void *stack, \
void *parent_tidptr, void *child_tidptr, void *tls); }
57 NOARGS { int|sys||fork(void); }
58 NOARGS { int|sys|14|vfork(void); }
59 NOARGS { int|sys||execve(const char *path, char **argp, \
char **envp); }
60 STD { int|linux_sys||exit(int rval); }
61 STD { int|linux_sys||wait4(int pid, int *status, \
int options, struct rusage50 *rusage); }
62 STD { int|linux_sys||kill(int pid, int signum); }
63 STD { int|linux_sys||uname(struct linux_utsname *up); }
#ifdef SYSVSEM
64 NOARGS { int|sys||semget(key_t key, int nsems, int semflg); }
65 NOARGS { int|sys||semop(int semid, struct sembuf *sops, \
size_t nsops); }
66 STD { int|linux_sys||semctl(int semid, int semnum, \
int cmd, union linux_semun arg); }
#else
64 UNIMPL semget
65 UNIMPL semop
66 UNIMPL semctl
#endif
#ifdef SYSVSHM
67 NOARGS { int|sys||shmdt(const void *shmaddr); }
#else
67 UNIMPL shmdt
#endif
#ifdef SYSVMSG
68 NOARGS { int|sys||msgget(key_t key, int msgflg); }
69 NOARGS { int|sys||msgsnd(int msqid, void *msgp, size_t msgsz, \
int msgflg); }
70 NOARGS { ssize_t|sys||msgrcv(int msqid, void *msgp, \
size_t msgsz, long msgtyp, int msgflg); }
71 NOARGS { int|linux_sys||msgctl(int msqid, int cmd, \
struct linux_msqid_ds *buf); }
#else
68 UNIMPL msgget
69 UNIMPL msgsnd
70 UNIMPL msgrcv
71 UNIMPL msgctl
#endif
72 STD { int|linux_sys||fcntl(int fd, int cmd, void *arg); }
73 NOARGS { int|sys||flock(int fd, int how); }
74 NOARGS { int|sys||fsync(int fd); }
75 STD { int|linux_sys||fdatasync(int fd); }
76 STD { int|linux_sys||truncate64(const char *path, \
off_t length); }
77 STD { int|linux_sys||ftruncate64(unsigned int fd, \
off_t length); }
78 STD { int|linux_sys||getdents(int fd, \
struct linux_dirent *dent, unsigned int count); }
79 NOARGS { int|sys||__getcwd(char *bufp, size_t length); }
80 NOARGS { int|sys||chdir(const char *path); }
81 NOARGS { int|sys||fchdir(int fd); }
82 NOARGS { int|sys||__posix_rename(const char *from, \
const char *to); }
83 NOARGS { int|sys||mkdir(const char *path, linux_umode_t mode); }
84 NOARGS { int|sys||rmdir(const char *path); }
85 STD { int|linux_sys||creat(const char *path, linux_umode_t mode); }
86 NOARGS { int|sys||link(const char *path, const char *link); }
87 STD { int|linux_sys||unlink(const char *path); }
88 NOARGS { int|sys||symlink(const char *path, const char *link); }
89 NOARGS { ssize_t|sys||readlink(const char *path, char *buf, \
int count); }
90 NOARGS { int|sys||chmod(const char *path, linux_umode_t mode); }
91 NOARGS { int|sys||fchmod(int fd, linux_umode_t mode); }
92 NOARGS { int|sys||__posix_chown(const char *path, uid_t uid, \
gid_t gid); }
93 NOARGS { int|sys||__posix_fchown(int fd, uid_t uid, \
gid_t gid); }
94 NOARGS { int|sys||__posix_lchown(const char *path, uid_t uid, \
gid_t gid); }
95 NOARGS { int|sys||umask(int newmask); }
96 STD { int|linux_sys||gettimeofday(struct timeval50 *tp, \
struct timezone *tzp); }
97 STD { int|linux_sys||getrlimit(int which, \
struct rlimit *rlp); }
98 NOARGS { int|compat_50_sys||getrusage(int who, \
struct rusage50 *rusage); }
99 STD { int|linux_sys||sysinfo(struct linux_sysinfo *arg); }
100 STD { int|linux_sys||times(struct times *tms); }
101 STD { int|linux_sys||ptrace(long request, long pid, \
long addr, long data); }
102 NOARGS { uid_t|sys||getuid(void); }
103 UNIMPL syslog
104 NOARGS { gid_t|sys||getgid(void); }
105 NOARGS { int|sys||setuid(uid_t uid); }
106 NOARGS { int|sys||setgid(gid_t gid); }
107 NOARGS { uid_t|sys||geteuid(void); }
108 NOARGS { gid_t|sys||getegid(void); }
109 NOARGS { int|sys||setpgid(int pid, int pgid); }
110 STD { pid_t|sys||getppid(void); }
111 NOARGS { int|sys||getpgrp(void); }
112 NOARGS { int|sys||setsid(void); }
113 NOARGS { int|sys||setreuid(uid_t ruid, uid_t euid); }
114 NOARGS { int|sys||setregid(gid_t rgid, gid_t egid); }
115 NOARGS { int|sys||getgroups(int gidsetsize, gid_t *gidset); }
116 NOARGS { int|sys||setgroups(int gidsetsize, gid_t *gidset); }
117 STD { int|linux_sys||setresuid(uid_t ruid, uid_t euid, \
uid_t suid); }
118 STD { int|linux_sys||getresuid(uid_t *ruid, uid_t *euid, \
uid_t *suid); }
119 STD { int|linux_sys||setresgid(gid_t rgid, gid_t egid, \
gid_t sgid); }
120 STD { int|linux_sys||getresgid(gid_t *rgid, gid_t *egid, \
gid_t *sgid); }
121 NOARGS { pid_t|sys||getpgid(pid_t pid); }
122 STD { int|linux_sys||setfsuid(uid_t uid); }
123 STD { int|linux_sys||setfsgid(gid_t gid); }
124 NOARGS { pid_t|sys||getsid(pid_t pid); }
125 UNIMPL capget
126 UNIMPL capset
127 STD { int|linux_sys||rt_sigpending( \
linux_sigset_t *set, \
size_t sigsetsize); }
128 STD { int|linux_sys||rt_sigtimedwait( \
const linux_sigset_t *set, \
linux_siginfo_t *info, \
const struct linux_timespec *timeout); }
129 STD { int|linux_sys||rt_queueinfo(int pid, int signum, \
linux_siginfo_t *uinfo); }
130 STD { int|linux_sys||rt_sigsuspend(linux_sigset_t *unewset, \
size_t sigsetsize); }
131 STD { int|linux_sys||sigaltstack( \
const struct linux_sigaltstack *ss, \
struct linux_sigaltstack *oss); }
132 STD { int|linux_sys||utime(const char *path, \
struct linux_utimbuf *times); }
133 STD { int|linux_sys||mknod(const char *path, linux_umode_t mode, \
unsigned dev); }
#ifdef EXEC_AOUT
134 STD { int|linux_sys||uselib(const char *path); }
#else
134 UNIMPL sys_uselib
#endif
135 STD { int|linux_sys||personality(unsigned long per); }
136 UNIMPL ustat
137 STD { int|linux_sys||statfs(const char *path, \
struct linux_statfs *sp); }
138 STD { int|linux_sys||fstatfs(int fd, \
struct linux_statfs *sp); }
139 UNIMPL sysfs
140 STD { int|linux_sys||getpriority(int which, int who); }
141 NOARGS { int|sys||setpriority(int which, int who, int prio); }
142 STD { int|linux_sys||sched_setparam(pid_t pid, \
const struct linux_sched_param *sp); }
143 STD { int|linux_sys||sched_getparam(pid_t pid, \
struct linux_sched_param *sp); }
144 STD { int|linux_sys||sched_setscheduler(pid_t pid, \
int policy, const struct linux_sched_param *sp); }
145 STD { int|linux_sys||sched_getscheduler(pid_t pid); }
146 STD { int|linux_sys||sched_get_priority_max(int policy); }
147 STD { int|linux_sys||sched_get_priority_min(int policy); }
148 UNIMPL sys_sched_rr_get_interval
149 NOARGS { int|sys||mlock(void *addr, size_t len); }
150 NOARGS { int|sys||munlock(void *addr, size_t len); }
151 NOARGS { int|sys||mlockall(int flags); }
152 NOARGS { int|sys||munlockall(void); }
153 UNIMPL vhangup
154 STD { int|linux_sys||modify_ldt(int func, void *ptr, \
size_t bytecount); }
155 UNIMPL pivot_root
156 STD { int|linux_sys||__sysctl(struct linux___sysctl *lsp); }
157 UNIMPL prctl
158 STD { int|linux_sys||arch_prctl(int code, \
unsigned long addr); }
159 UNIMPL adjtimex
160 STD { int|linux_sys||setrlimit(u_int which, \
struct rlimit *rlp); }
161 NOARGS { int|sys||chroot(char *path); }
162 NOARGS { int|sys||sync(void); }
163 NOARGS { int|sys||acct(char *path); }
164 STD { int|linux_sys||settimeofday(struct timeval50 *tp, \
struct timezone *tzp); }
165 UNIMPL mount
166 UNIMPL umount2
167 STD { int|linux_sys||swapon(char *name); }
168 STD { int|linux_sys||swapoff(const char *path); }
169 STD { int|linux_sys||reboot(int magic1, int magic2, \
int cmd, void *arg); }
170 NOARGS { int|compat_43_sys||sethostname(char *hostname, \
u_int len);}
171 STD { int|linux_sys||setdomainname(char *domainname, \
int len); }
172 STD { int|linux_sys||iopl(int level); }
173 STD { int|linux_sys||ioperm(unsigned int lo, \
unsigned int hi, int val); }
174 UNIMPL create_module
175 UNIMPL init_module
176 UNIMPL delete_module
177 UNIMPL get_kernel_syms
178 UNIMPL query_module
179 UNIMPL quotactl
180 UNIMPL nfsservctl
181 UNIMPL getpmsg
182 UNIMPL putpmsg
183 UNIMPL afs_syscall
184 UNIMPL tuxcall
185 UNIMPL security
186 STD { pid_t|linux_sys||gettid(void); }
187 STD { ssize_t|linux_sys||readahead(int fd, off_t offset, \
size_t count); }
188 STD { int|linux_sys||setxattr(char *path, char *name, \
void *value, size_t size, int flags); }
189 STD { int|linux_sys||lsetxattr(char *path, char *name, \
void *value, size_t size, int flags); }
190 STD { int|linux_sys||fsetxattr(int fd, char *name, \
void *value, size_t size, int flags); }
191 STD { ssize_t|linux_sys||getxattr(char *path, char *name, \
void *value, size_t size); }
192 STD { ssize_t|linux_sys||lgetxattr(char *path, char *name, \
void *value, size_t size); }
193 STD { ssize_t|linux_sys||fgetxattr(int fd, char *name, \
void *value, size_t size); }
194 STD { ssize_t|linux_sys||listxattr(char *path, char *list, \
size_t size); }
195 STD { ssize_t|linux_sys||llistxattr(char *path, char *list, \
size_t size); }
196 STD { ssize_t|linux_sys||flistxattr(int fd, char *list, \
size_t size); }
197 STD { int|linux_sys||removexattr(char *path, char *name); }
198 STD { int|linux_sys||lremovexattr(char *path, char *name); }
199 STD { int|linux_sys||fremovexattr(int fd, char *name); }
200 STD { int|linux_sys||tkill(int tid, int sig); }
201 STD { int|linux_sys||time(linux_time_t *t); }
202 STD { int|linux_sys||futex(int *uaddr, int op, int val, \
const struct linux_timespec *timeout, int *uaddr2, \
int val3); }
203 STD { int|linux_sys||sched_setaffinity(pid_t pid, \
unsigned int len, unsigned long *mask); }
204 STD { int|linux_sys||sched_getaffinity(pid_t pid, \
unsigned int len, unsigned long *mask); }
205 UNIMPL set_thread_area
206 UNIMPL io_setup
207 UNIMPL io_destroy
208 UNIMPL io_getevents
209 UNIMPL io_submit
210 UNIMPL io_cancel
211 UNIMPL get_thread_area
212 UNIMPL lookup_dcookie
213 STD { int|linux_sys||epoll_create(int size); }
214 UNIMPL epoll_ctl_old
215 UNIMPL epoll_wait_old
216 UNIMPL remap_file_pages
217 STD { int|linux_sys||getdents64(int fd, \
struct linux_dirent64 *dent, unsigned int count); }
218 STD { int|linux_sys||set_tid_address(int *tid); }
219 UNIMPL restart_syscall
220 UNIMPL semtimedop
221 STD { int|linux_sys||fadvise64(int fd, off_t offset, \
size_t len, int advice); }
222 STD { int|linux_sys||timer_create(clockid_t clockid, \
struct linux_sigevent *evp, timer_t *timerid); }
223 STD { int|linux_sys||timer_settime(timer_t timerid, \
int flags, const struct linux_itimerspec *tim, \
struct linux_itimerspec *otim); }
224 STD { int|linux_sys||timer_gettime(timer_t timerid, \
struct linux_itimerspec *tim); }
225 NOARGS { int|sys||timer_getoverrun(timer_t timerid); }
226 NOARGS { int|sys||timer_delete(timer_t timerid); }
227 STD { int|linux_sys||clock_settime(clockid_t which, \
struct linux_timespec *tp); }
228 STD { int|linux_sys||clock_gettime(clockid_t which, \
struct linux_timespec *tp); }
229 STD { int|linux_sys||clock_getres(clockid_t which, \
struct linux_timespec *tp); }
230 STD { int|linux_sys||clock_nanosleep(clockid_t which, \
int flags, struct linux_timespec *rqtp, \
struct linux_timespec *rmtp); }
231 STD { int|linux_sys||exit_group(int error_code); }
232 STD { int|linux_sys||epoll_wait(int epfd, \
struct linux_epoll_event *events, int maxevents, \
int timeout); }
233 STD { int|linux_sys||epoll_ctl(int epfd, int op, int fd, \
struct linux_epoll_event *event); }
234 STD { int|linux_sys||tgkill(int tgid, int tid, int sig); }
235 NOARGS { int|compat_50_sys||utimes(const char *path, \
const struct timeval50 *tptr); }
236 UNIMPL vserver
237 UNIMPL mbind
238 UNIMPL set_mempolicy
239 UNIMPL get_mempolicy
240 STD { linux_mqd_t|linux_sys||mq_open(const char *name, \
int oflag, linux_umode_t mode, \
struct linux_mq_attr *attr); }
241 STD { int|linux_sys||mq_unlink(const char *name); }
242 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); }
243 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); }
244 STD { int|linux_sys||mq_notify(linux_mqd_t mqdes, \
const struct linux_sigevent *sevp); }
245 STD { int|linux_sys||mq_getsetattr(linux_mqd_t mqdes, \
const struct linux_mq_attr *newattr, \
struct linux_mq_attr *oldattr); }
246 UNIMPL kexec_load
247 STD { int|linux_sys||waitid(int idtype, id_t id, \
linux_siginfo_t *infop, int options, \
struct rusage50 *rusage); }
248 UNIMPL add_key
249 UNIMPL request_key
250 UNIMPL keyctl
251 UNIMPL ioprio_set
252 UNIMPL ioprio_get
253 STD { int|linux_sys||inotify_init(void); }
254 STD { int|linux_sys||inotify_add_watch(int fd, \
const char *pathname, uint32_t mask); }
255 STD { int|linux_sys||inotify_rm_watch(int fd, int wd); }
256 UNIMPL migrate_pages
257 STD { int|linux_sys||openat(int fd, const char *path, \
int flags, ... linux_umode_t mode); }
258 NOARGS { int|sys||mkdirat(int fd, const char *path, \
linux_umode_t mode); }
259 STD { int|linux_sys||mknodat(int fd, const char *path, \
linux_umode_t mode, unsigned dev); }
260 STD { int|linux_sys||fchownat(int fd, const char *path, \
uid_t owner, gid_t group, int flag); }
261 UNIMPL futimesat
262 STD { int|linux_sys||fstatat64(int fd, const char *path, \
struct linux_stat *sp, int flag); }
263 STD { int|linux_sys||unlinkat(int fd, const char *path, \
int flag); }
264 NOARGS { int|sys||renameat(int fromfd, const char *from, \
int tofd, const char *to); }
265 STD { int|linux_sys||linkat(int fd1, const char *name1, \
int fd2, const char *name2, int flags); }
266 NOARGS { int|sys||symlinkat(const char *path1, int fd, \
const char *path2); }
267 NOARGS { ssize_t|sys||readlinkat(int fd, const char *path, \
char *buf, size_t bufsize); }
268 STD { int|linux_sys||fchmodat(int fd, const char *path, \
linux_umode_t mode); }
269 STD { int|linux_sys||faccessat(int fd, const char *path, \
int amode); }
270 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); }
271 STD { int|linux_sys||ppoll(struct pollfd *fds, u_int nfds, \
struct linux_timespec *timeout, \
linux_sigset_t *sigset); }
272 UNIMPL unshare
;
; The NetBSD native robust list calls have different
; argument names / types, but they are ABI-compatible
; with Linux.
;
273 NOARGS { int|sys||__futex_set_robust_list(void *head, \
size_t len); }
274 NOARGS { int|sys||__futex_get_robust_list(lwpid_t lwpid, \
void **headp, size_t *lenp); }
275 UNIMPL splice
276 UNIMPL tee
277 STD { int|linux_sys||sync_file_range(int fd, \
off_t offset, off_t nbytes, unsigned int flags); }
278 UNIMPL vmsplice
279 UNIMPL move_pages
280 STD { int|linux_sys||utimensat(int fd, const char *path, \
struct linux_timespec *times, int flag); }
281 STD { int|linux_sys||epoll_pwait(int epfd, \
struct linux_epoll_event *events, int maxevents, \
int timeout, const linux_sigset_t *sigmask); }
282 UNIMPL signalfd
283 STD { int|linux_sys||timerfd_create(clockid_t clock_id, \
int flags); }
284 STD { int|linux_sys||eventfd(unsigned int initval); }
285 STD { int|linux_sys||fallocate(int fd, int mode, \
off_t offset, off_t len); }
286 STD { int|linux_sys||timerfd_settime(int fd, int flags, \
const struct linux_itimerspec *tim, \
struct linux_itimerspec *otim); }
287 STD { int|linux_sys||timerfd_gettime(int fd, \
struct linux_itimerspec *tim); }
288 STD { int|linux_sys||accept4(int s, \
struct osockaddr *name, \
int *anamelen, int flags); }
289 UNIMPL signalfd4
290 STD { int|linux_sys||eventfd2(unsigned int initval, \
int flags); }
291 STD { int|linux_sys||epoll_create1(int flags); }
292 STD { int|linux_sys||dup3(int from, int to, int flags); }
293 STD { int|linux_sys||pipe2(int *pfds, int flags); }
294 STD { int|linux_sys||inotify_init1(int flags); }
295 STD { int|linux_sys||preadv(int fd, \
const struct iovec *iovp, int iovcnt, \
unsigned long off_lo, unsigned long off_hi); }
296 STD { int|linux_sys||pwritev(int fd, \
const struct iovcnt *iovp, int iovcnt, \
unsigned long off_lo, unsigned long off_hi); }
297 UNIMPL rt_tgsigqueueinfo
298 UNIMPL perf_counter_open
299 STD { int|linux_sys||recvmmsg(int s, \
struct linux_mmsghdr *msgvec, unsigned int vlen, \
unsigned int flags, struct timespec *timeout); }
300 UNIMPL fanotify_init
301 UNIMPL fanotify_mark
302 STD { int|linux_sys||prlimit64(pid_t pid, int which, \
struct rlimit *new_rlp, struct rlimit *old_rlp); }
303 UNIMPL name_to_handle_at
304 UNIMPL open_by_handle_at
305 UNIMPL clock_adjtime
306 STD { int|linux_sys||syncfs(int fd); }
307 STD { int|linux_sys||sendmmsg(int s, \
struct linux_mmsghdr *msgvec, unsigned int vlen, \
unsigned int flags); }
308 UNIMPL setns
309 STD { int|linux_sys||getcpu(unsigned int *cpu, \
unsigned int *node, \
struct linux_getcpu_cache *tcache); }
310 UNIMPL process_vm_readv
311 UNIMPL process_vm_writev
312 UNIMPL kcmp
313 UNIMPL finit_module
314 UNIMPL sched_setattr
315 UNIMPL sched_getattr
316 STD { int|linux_sys||renameat2(int fromfd, \
const char *from, int tofd, const char *to, \
unsigned int flags); }
317 UNIMPL seccomp
318 NOARGS { ssize_t|sys||getrandom(void *buf, size_t buflen, \
unsigned int flags); }
319 STD { int|linux_sys||memfd_create(const char *name, \
unsigned int flags); }
320 UNIMPL kexec_file_load
321 UNIMPL bpf
322 UNIMPL execveat
323 UNIMPL userfaultfd
324 UNIMPL membarrier
325 UNIMPL mlock2
326 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); }
327 UNIMPL preadv2
328 UNIMPL pwritev2
329 UNIMPL pkey_mprotect
330 UNIMPL pkey_alloc
331 UNIMPL pkey_free
332 STD { int|linux_sys||statx(int fd, const char *path, \
int flag, unsigned int mask, \
struct linux_statx *sp); }
333 UNIMPL io_pgetevents
334 UNIMPL rseq
335 UNIMPL
336 UNIMPL
337 UNIMPL
338 UNIMPL
339 UNIMPL
340 UNIMPL
341 UNIMPL
342 UNIMPL
343 UNIMPL
344 UNIMPL
345 UNIMPL
346 UNIMPL
347 UNIMPL
348 UNIMPL
349 UNIMPL
350 UNIMPL
351 UNIMPL
352 UNIMPL
353 UNIMPL
354 UNIMPL
355 UNIMPL
356 UNIMPL
357 UNIMPL
358 UNIMPL
359 UNIMPL
360 UNIMPL
361 UNIMPL
362 UNIMPL
363 UNIMPL
364 UNIMPL
365 UNIMPL
366 UNIMPL
367 UNIMPL
368 UNIMPL
369 UNIMPL
370 UNIMPL
371 UNIMPL
372 UNIMPL
373 UNIMPL
374 UNIMPL
375 UNIMPL
376 UNIMPL
377 UNIMPL
378 UNIMPL
379 UNIMPL
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 pidfd_send_signal
425 UNIMPL io_uring_setup
426 UNIMPL io_uring_enter
427 UNIMPL io_uring_register
428 UNIMPL open_tree
429 UNIMPL move_mount
430 UNIMPL fsopen
431 UNIMPL fsconfig
432 UNIMPL fsmount
433 UNIMPL fspick
434 UNIMPL pidfd_open
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 openat2
438 UNIMPL pidfd_getfd
439 STD { int|linux_sys||faccessat2(int fd, const char *path, \
int amode, int flags); }
440 UNIMPL process_madvise
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); }
442 UNIMPL mount_setattr
443 UNIMPL quotactl_fd
444 UNIMPL landlock_create_ruleset
445 UNIMPL landlock_add_rule
446 UNIMPL landlock_restrict_self
447 UNIMPL memfd_secret
448 UNIMPL process_mrelease
449 UNIMPL futex_waitv
450 UNIMPL set_mempolicy_home_node
; we want a "nosys" syscall, we'll just add an extra entry for it.
451 STD { int|linux_sys||nosys(void); }