1 //===-- sanitizer_syscalls_netbsd.inc ---------------------------*- C++ -*-===//
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //===----------------------------------------------------------------------===//
9 // Common syscalls handlers for tools like AddressSanitizer,
10 // ThreadSanitizer, MemorySanitizer, etc.
12 // This file should be included into the tool's interceptor file,
13 // which has to define it's own macros:
14 // COMMON_SYSCALL_PRE_READ_RANGE
15 // Called in prehook for regions that will be read by the kernel and
16 // must be initialized.
17 // COMMON_SYSCALL_PRE_WRITE_RANGE
18 // Called in prehook for regions that will be written to by the kernel
19 // and must be addressable. The actual write range may be smaller than
20 // reported in the prehook. See POST_WRITE_RANGE.
21 // COMMON_SYSCALL_POST_READ_RANGE
22 // Called in posthook for regions that were read by the kernel. Does
23 // not make much sense.
24 // COMMON_SYSCALL_POST_WRITE_RANGE
25 // Called in posthook for regions that were written to by the kernel
26 // and are now initialized.
27 // COMMON_SYSCALL_ACQUIRE(addr)
28 // Acquire memory visibility from addr.
29 // COMMON_SYSCALL_RELEASE(addr)
30 // Release memory visibility to addr.
31 // COMMON_SYSCALL_FD_CLOSE(fd)
32 // Called before closing file descriptor fd.
33 // COMMON_SYSCALL_FD_ACQUIRE(fd)
34 // Acquire memory visibility from fd.
35 // COMMON_SYSCALL_FD_RELEASE(fd)
36 // Release memory visibility to fd.
37 // COMMON_SYSCALL_PRE_FORK()
38 // Called before fork syscall.
39 // COMMON_SYSCALL_POST_FORK(long long res)
40 // Called after fork syscall.
42 // DO NOT EDIT! THIS FILE HAS BEEN GENERATED!
44 // Generated with: generate_netbsd_syscalls.awk
45 // Generated date: 2019-12-24
46 // Generated from: syscalls.master,v 1.296 2019/09/22 22:59:39 christos Exp
48 //===----------------------------------------------------------------------===//
50 #include "sanitizer_platform.h"
53 #include "sanitizer_libc.h"
55 #define PRE_SYSCALL(name) \
56 SANITIZER_INTERFACE_ATTRIBUTE void __sanitizer_syscall_pre_impl_##name
57 #define PRE_READ(p, s) COMMON_SYSCALL_PRE_READ_RANGE(p, s)
58 #define PRE_WRITE(p, s) COMMON_SYSCALL_PRE_WRITE_RANGE(p, s)
60 #define POST_SYSCALL(name) \
61 SANITIZER_INTERFACE_ATTRIBUTE void __sanitizer_syscall_post_impl_##name
62 #define POST_READ(p, s) COMMON_SYSCALL_POST_READ_RANGE(p, s)
63 #define POST_WRITE(p, s) COMMON_SYSCALL_POST_WRITE_RANGE(p, s)
65 #ifndef COMMON_SYSCALL_ACQUIRE
66 #define COMMON_SYSCALL_ACQUIRE(addr) ((void)(addr))
69 #ifndef COMMON_SYSCALL_RELEASE
70 #define COMMON_SYSCALL_RELEASE(addr) ((void)(addr))
73 #ifndef COMMON_SYSCALL_FD_CLOSE
74 #define COMMON_SYSCALL_FD_CLOSE(fd) ((void)(fd))
77 #ifndef COMMON_SYSCALL_FD_ACQUIRE
78 #define COMMON_SYSCALL_FD_ACQUIRE(fd) ((void)(fd))
81 #ifndef COMMON_SYSCALL_FD_RELEASE
82 #define COMMON_SYSCALL_FD_RELEASE(fd) ((void)(fd))
85 #ifndef COMMON_SYSCALL_PRE_FORK
86 #define COMMON_SYSCALL_PRE_FORK() \
90 #ifndef COMMON_SYSCALL_POST_FORK
91 #define COMMON_SYSCALL_POST_FORK(res) \
95 // FIXME: do some kind of PRE_READ for all syscall arguments (int(s) and such).
98 #define SYS_MAXSYSARGS 8
99 PRE_SYSCALL(syscall)(long long code_, long long args_[SYS_MAXSYSARGS]) {
102 POST_SYSCALL(syscall)
103 (long long res, long long code_, long long args_[SYS_MAXSYSARGS]) {
106 PRE_SYSCALL(exit)(long long rval_) { /* Nothing to do */ }
107 POST_SYSCALL(exit)(long long res, long long rval_) { /* Nothing to do */ }
108 PRE_SYSCALL(fork)(void) { COMMON_SYSCALL_PRE_FORK(); }
109 POST_SYSCALL(fork)(long long res) { COMMON_SYSCALL_POST_FORK(res); }
110 PRE_SYSCALL(read)(long long fd_, void *buf_, long long nbyte_) {
112 PRE_WRITE(buf_, nbyte_);
115 POST_SYSCALL(read)(long long res, long long fd_, void *buf_, long long nbyte_) {
117 POST_WRITE(buf_, res);
120 PRE_SYSCALL(write)(long long fd_, void *buf_, long long nbyte_) {
122 PRE_READ(buf_, nbyte_);
126 (long long res, long long fd_, void *buf_, long long nbyte_) {
128 POST_READ(buf_, res);
131 PRE_SYSCALL(open)(void *path_, long long flags_, long long mode_) {
132 const char *path = (const char *)path_;
134 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
138 (long long res, void *path_, long long flags_, long long mode_) {
140 const char *path = (const char *)path_;
142 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
146 PRE_SYSCALL(close)(long long fd_) { COMMON_SYSCALL_FD_CLOSE((int)fd_); }
147 POST_SYSCALL(close)(long long res, long long fd_) { /* Nothing to do */ }
148 PRE_SYSCALL(compat_50_wait4)
149 (long long pid_, void *status_, long long options_, void *rusage_) {
152 POST_SYSCALL(compat_50_wait4)
153 (long long res, long long pid_, void *status_, long long options_,
157 PRE_SYSCALL(compat_43_ocreat)(void *path_, long long mode_) { /* TODO */ }
158 POST_SYSCALL(compat_43_ocreat)(long long res, void *path_, long long mode_) {
161 PRE_SYSCALL(link)(void *path_, void *link_) {
162 const char *path = (const char *)path_;
163 const char *link = (const char *)link_;
165 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
168 PRE_READ(path, __sanitizer::internal_strlen(link) + 1);
171 POST_SYSCALL(link)(long long res, void *path_, void *link_) {
173 const char *path = (const char *)path_;
174 const char *link = (const char *)link_;
176 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
179 POST_READ(path, __sanitizer::internal_strlen(link) + 1);
183 PRE_SYSCALL(unlink)(void *path_) {
184 const char *path = (const char *)path_;
186 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
189 POST_SYSCALL(unlink)(long long res, void *path_) {
191 const char *path = (const char *)path_;
193 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
197 /* syscall 11 has been skipped */
198 PRE_SYSCALL(chdir)(void *path_) {
199 const char *path = (const char *)path_;
201 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
204 POST_SYSCALL(chdir)(long long res, void *path_) {
206 const char *path = (const char *)path_;
208 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
212 PRE_SYSCALL(fchdir)(long long fd_) { /* Nothing to do */ }
213 POST_SYSCALL(fchdir)(long long res, long long fd_) { /* Nothing to do */ }
214 PRE_SYSCALL(compat_50_mknod)(void *path_, long long mode_, long long dev_) {
217 POST_SYSCALL(compat_50_mknod)
218 (long long res, void *path_, long long mode_, long long dev_) {
221 PRE_SYSCALL(chmod)(void *path_, long long mode_) {
222 const char *path = (const char *)path_;
224 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
227 POST_SYSCALL(chmod)(long long res, void *path_, long long mode_) {
229 const char *path = (const char *)path_;
231 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
235 PRE_SYSCALL(chown)(void *path_, long long uid_, long long gid_) {
236 const char *path = (const char *)path_;
238 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
242 (long long res, void *path_, long long uid_, long long gid_) {
244 const char *path = (const char *)path_;
246 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
250 PRE_SYSCALL(break)(void *nsize_) { /* Nothing to do */ }
251 POST_SYSCALL(break)(long long res, void *nsize_) { /* Nothing to do */ }
252 PRE_SYSCALL(compat_20_getfsstat)
253 (void *buf_, long long bufsize_, long long flags_) {
256 POST_SYSCALL(compat_20_getfsstat)
257 (long long res, void *buf_, long long bufsize_, long long flags_) {
260 PRE_SYSCALL(compat_43_olseek)
261 (long long fd_, long long offset_, long long whence_) {
264 POST_SYSCALL(compat_43_olseek)
265 (long long res, long long fd_, long long offset_, long long whence_) {
268 PRE_SYSCALL(getpid)(void) { /* Nothing to do */ }
269 POST_SYSCALL(getpid)(long long res) { /* Nothing to do */ }
270 PRE_SYSCALL(compat_40_mount)
271 (void *type_, void *path_, long long flags_, void *data_) {
274 POST_SYSCALL(compat_40_mount)
275 (long long res, void *type_, void *path_, long long flags_, void *data_) {
278 PRE_SYSCALL(unmount)(void *path_, long long flags_) {
279 const char *path = (const char *)path_;
281 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
284 POST_SYSCALL(unmount)(long long res, void *path_, long long flags_) {
286 const char *path = (const char *)path_;
288 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
292 PRE_SYSCALL(setuid)(long long uid_) { /* Nothing to do */ }
293 POST_SYSCALL(setuid)(long long res, long long uid_) { /* Nothing to do */ }
294 PRE_SYSCALL(getuid)(void) { /* Nothing to do */ }
295 POST_SYSCALL(getuid)(long long res) { /* Nothing to do */ }
296 PRE_SYSCALL(geteuid)(void) { /* Nothing to do */ }
297 POST_SYSCALL(geteuid)(long long res) { /* Nothing to do */ }
299 (long long req_, long long pid_, void *addr_, long long data_) {
300 if (req_ == ptrace_pt_io) {
301 struct __sanitizer_ptrace_io_desc *addr =
302 (struct __sanitizer_ptrace_io_desc *)addr_;
303 PRE_READ(addr, struct_ptrace_ptrace_io_desc_struct_sz);
304 if (addr->piod_op == ptrace_piod_write_d ||
305 addr->piod_op == ptrace_piod_write_i) {
306 PRE_READ(addr->piod_addr, addr->piod_len);
308 if (addr->piod_op == ptrace_piod_read_d ||
309 addr->piod_op == ptrace_piod_read_i ||
310 addr->piod_op == ptrace_piod_read_auxv) {
311 PRE_WRITE(addr->piod_addr, addr->piod_len);
313 } else if (req_ == ptrace_pt_lwpinfo) {
314 struct __sanitizer_ptrace_lwpinfo *addr =
315 (struct __sanitizer_ptrace_lwpinfo *)addr_;
316 PRE_READ(&addr->pl_lwpid, sizeof(__sanitizer_lwpid_t));
317 PRE_WRITE(addr, struct_ptrace_ptrace_lwpinfo_struct_sz);
318 } else if (req_ == ptrace_pt_set_event_mask) {
319 PRE_READ(addr_, struct_ptrace_ptrace_event_struct_sz);
320 } else if (req_ == ptrace_pt_get_event_mask) {
321 PRE_WRITE(addr_, struct_ptrace_ptrace_event_struct_sz);
322 } else if (req_ == ptrace_pt_set_siginfo) {
323 PRE_READ(addr_, struct_ptrace_ptrace_siginfo_struct_sz);
324 } else if (req_ == ptrace_pt_get_siginfo) {
325 PRE_WRITE(addr_, struct_ptrace_ptrace_siginfo_struct_sz);
326 } else if (req_ == ptrace_pt_lwpstatus) {
327 struct __sanitizer_ptrace_lwpstatus *addr =
328 (struct __sanitizer_ptrace_lwpstatus *)addr_;
329 PRE_READ(&addr->pl_lwpid, sizeof(__sanitizer_lwpid_t));
330 PRE_WRITE(addr, struct_ptrace_ptrace_lwpstatus_struct_sz);
331 } else if (req_ == ptrace_pt_lwpnext) {
332 struct __sanitizer_ptrace_lwpstatus *addr =
333 (struct __sanitizer_ptrace_lwpstatus *)addr_;
334 PRE_READ(&addr->pl_lwpid, sizeof(__sanitizer_lwpid_t));
335 PRE_WRITE(addr, struct_ptrace_ptrace_lwpstatus_struct_sz);
336 } else if (req_ == ptrace_pt_setregs) {
337 PRE_READ(addr_, struct_ptrace_reg_struct_sz);
338 } else if (req_ == ptrace_pt_getregs) {
339 PRE_WRITE(addr_, struct_ptrace_reg_struct_sz);
340 } else if (req_ == ptrace_pt_setfpregs) {
341 PRE_READ(addr_, struct_ptrace_fpreg_struct_sz);
342 } else if (req_ == ptrace_pt_getfpregs) {
343 PRE_WRITE(addr_, struct_ptrace_fpreg_struct_sz);
344 } else if (req_ == ptrace_pt_setdbregs) {
345 PRE_READ(addr_, struct_ptrace_dbreg_struct_sz);
346 } else if (req_ == ptrace_pt_getdbregs) {
347 PRE_WRITE(addr_, struct_ptrace_dbreg_struct_sz);
351 (long long res, long long req_, long long pid_, void *addr_, long long data_) {
353 if (req_ == ptrace_pt_io) {
354 struct __sanitizer_ptrace_io_desc *addr =
355 (struct __sanitizer_ptrace_io_desc *)addr_;
356 POST_READ(addr, struct_ptrace_ptrace_io_desc_struct_sz);
357 if (addr->piod_op == ptrace_piod_write_d ||
358 addr->piod_op == ptrace_piod_write_i) {
359 POST_READ(addr->piod_addr, addr->piod_len);
361 if (addr->piod_op == ptrace_piod_read_d ||
362 addr->piod_op == ptrace_piod_read_i ||
363 addr->piod_op == ptrace_piod_read_auxv) {
364 POST_WRITE(addr->piod_addr, addr->piod_len);
366 } else if (req_ == ptrace_pt_lwpinfo) {
367 struct __sanitizer_ptrace_lwpinfo *addr =
368 (struct __sanitizer_ptrace_lwpinfo *)addr_;
369 POST_READ(&addr->pl_lwpid, sizeof(__sanitizer_lwpid_t));
370 POST_WRITE(addr, struct_ptrace_ptrace_lwpinfo_struct_sz);
371 } else if (req_ == ptrace_pt_set_event_mask) {
372 POST_READ(addr_, struct_ptrace_ptrace_event_struct_sz);
373 } else if (req_ == ptrace_pt_get_event_mask) {
374 POST_WRITE(addr_, struct_ptrace_ptrace_event_struct_sz);
375 } else if (req_ == ptrace_pt_set_siginfo) {
376 POST_READ(addr_, struct_ptrace_ptrace_siginfo_struct_sz);
377 } else if (req_ == ptrace_pt_get_siginfo) {
378 POST_WRITE(addr_, struct_ptrace_ptrace_siginfo_struct_sz);
379 } else if (req_ == ptrace_pt_lwpstatus) {
380 struct __sanitizer_ptrace_lwpstatus *addr =
381 (struct __sanitizer_ptrace_lwpstatus *)addr_;
382 POST_READ(&addr->pl_lwpid, sizeof(__sanitizer_lwpid_t));
383 POST_WRITE(addr, struct_ptrace_ptrace_lwpstatus_struct_sz);
384 } else if (req_ == ptrace_pt_lwpnext) {
385 struct __sanitizer_ptrace_lwpstatus *addr =
386 (struct __sanitizer_ptrace_lwpstatus *)addr_;
387 POST_READ(&addr->pl_lwpid, sizeof(__sanitizer_lwpid_t));
388 POST_WRITE(addr, struct_ptrace_ptrace_lwpstatus_struct_sz);
389 } else if (req_ == ptrace_pt_setregs) {
390 POST_READ(addr_, struct_ptrace_reg_struct_sz);
391 } else if (req_ == ptrace_pt_getregs) {
392 POST_WRITE(addr_, struct_ptrace_reg_struct_sz);
393 } else if (req_ == ptrace_pt_setfpregs) {
394 POST_READ(addr_, struct_ptrace_fpreg_struct_sz);
395 } else if (req_ == ptrace_pt_getfpregs) {
396 POST_WRITE(addr_, struct_ptrace_fpreg_struct_sz);
397 } else if (req_ == ptrace_pt_setdbregs) {
398 POST_READ(addr_, struct_ptrace_dbreg_struct_sz);
399 } else if (req_ == ptrace_pt_getdbregs) {
400 POST_WRITE(addr_, struct_ptrace_dbreg_struct_sz);
404 PRE_SYSCALL(recvmsg)(long long s_, void *msg_, long long flags_) {
405 PRE_WRITE(msg_, sizeof(__sanitizer_msghdr));
407 POST_SYSCALL(recvmsg)
408 (long long res, long long s_, void *msg_, long long flags_) {
410 POST_WRITE(msg_, sizeof(__sanitizer_msghdr));
413 PRE_SYSCALL(sendmsg)(long long s_, void *msg_, long long flags_) {
414 PRE_READ(msg_, sizeof(__sanitizer_msghdr));
416 POST_SYSCALL(sendmsg)
417 (long long res, long long s_, void *msg_, long long flags_) {
419 POST_READ(msg_, sizeof(__sanitizer_msghdr));
422 PRE_SYSCALL(recvfrom)
423 (long long s_, void *buf_, long long len_, long long flags_, void *from_,
424 void *fromlenaddr_) {
425 PRE_WRITE(buf_, len_);
426 PRE_WRITE(from_, struct_sockaddr_sz);
427 PRE_WRITE(fromlenaddr_, sizeof(__sanitizer_socklen_t));
429 POST_SYSCALL(recvfrom)
430 (long long res, long long s_, void *buf_, long long len_, long long flags_,
431 void *from_, void *fromlenaddr_) {
433 POST_WRITE(buf_, res);
434 POST_WRITE(from_, struct_sockaddr_sz);
435 POST_WRITE(fromlenaddr_, sizeof(__sanitizer_socklen_t));
438 PRE_SYSCALL(accept)(long long s_, void *name_, void *anamelen_) {
439 PRE_WRITE(name_, struct_sockaddr_sz);
440 PRE_WRITE(anamelen_, sizeof(__sanitizer_socklen_t));
443 (long long res, long long s_, void *name_, void *anamelen_) {
445 POST_WRITE(name_, struct_sockaddr_sz);
446 POST_WRITE(anamelen_, sizeof(__sanitizer_socklen_t));
449 PRE_SYSCALL(getpeername)(long long fdes_, void *asa_, void *alen_) {
450 PRE_WRITE(asa_, struct_sockaddr_sz);
451 PRE_WRITE(alen_, sizeof(__sanitizer_socklen_t));
453 POST_SYSCALL(getpeername)
454 (long long res, long long fdes_, void *asa_, void *alen_) {
456 POST_WRITE(asa_, struct_sockaddr_sz);
457 POST_WRITE(alen_, sizeof(__sanitizer_socklen_t));
460 PRE_SYSCALL(getsockname)(long long fdes_, void *asa_, void *alen_) {
461 PRE_WRITE(asa_, struct_sockaddr_sz);
462 PRE_WRITE(alen_, sizeof(__sanitizer_socklen_t));
464 POST_SYSCALL(getsockname)
465 (long long res, long long fdes_, void *asa_, void *alen_) {
467 POST_WRITE(asa_, struct_sockaddr_sz);
468 POST_WRITE(alen_, sizeof(__sanitizer_socklen_t));
471 PRE_SYSCALL(access)(void *path_, long long flags_) {
472 const char *path = (const char *)path_;
474 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
477 POST_SYSCALL(access)(long long res, void *path_, long long flags_) {
479 const char *path = (const char *)path_;
481 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
485 PRE_SYSCALL(chflags)(void *path_, long long flags_) {
486 const char *path = (const char *)path_;
488 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
491 POST_SYSCALL(chflags)(long long res, void *path_, long long flags_) {
493 const char *path = (const char *)path_;
495 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
499 PRE_SYSCALL(fchflags)(long long fd_, long long flags_) { /* Nothing to do */ }
500 POST_SYSCALL(fchflags)(long long res, long long fd_, long long flags_) {
503 PRE_SYSCALL(sync)(void) { /* Nothing to do */ }
504 POST_SYSCALL(sync)(long long res) { /* Nothing to do */ }
505 PRE_SYSCALL(kill)(long long pid_, long long signum_) { /* Nothing to do */ }
506 POST_SYSCALL(kill)(long long res, long long pid_, long long signum_) {
509 PRE_SYSCALL(compat_43_stat43)(void *path_, void *ub_) { /* TODO */ }
510 POST_SYSCALL(compat_43_stat43)(long long res, void *path_, void *ub_) {
513 PRE_SYSCALL(getppid)(void) { /* Nothing to do */ }
514 POST_SYSCALL(getppid)(long long res) { /* Nothing to do */ }
515 PRE_SYSCALL(compat_43_lstat43)(void *path_, void *ub_) { /* TODO */ }
516 POST_SYSCALL(compat_43_lstat43)(long long res, void *path_, void *ub_) {
519 PRE_SYSCALL(dup)(long long fd_) { /* Nothing to do */ }
520 POST_SYSCALL(dup)(long long res, long long fd_) { /* Nothing to do */ }
521 PRE_SYSCALL(pipe)(void) {
522 /* pipe returns two descriptors through two returned values */
524 POST_SYSCALL(pipe)(long long res) {
525 /* pipe returns two descriptors through two returned values */
527 PRE_SYSCALL(getegid)(void) { /* Nothing to do */ }
528 POST_SYSCALL(getegid)(long long res) { /* Nothing to do */ }
530 (void *samples_, long long size_, long long offset_, long long scale_) {
532 PRE_WRITE(samples_, size_);
536 (long long res, void *samples_, long long size_, long long offset_,
540 POST_WRITE(samples_, size_);
545 (void *fname_, long long ops_, long long facs_, long long pid_) {
546 const char *fname = (const char *)fname_;
548 PRE_READ(fname, __sanitizer::internal_strlen(fname) + 1);
552 (long long res, void *fname_, long long ops_, long long facs_, long long pid_) {
553 const char *fname = (const char *)fname_;
556 POST_READ(fname, __sanitizer::internal_strlen(fname) + 1);
560 PRE_SYSCALL(compat_13_sigaction13)(long long signum_, void *nsa_, void *osa_) {
563 POST_SYSCALL(compat_13_sigaction13)
564 (long long res, long long signum_, void *nsa_, void *osa_) {
567 PRE_SYSCALL(getgid)(void) { /* Nothing to do */ }
568 POST_SYSCALL(getgid)(long long res) { /* Nothing to do */ }
569 PRE_SYSCALL(compat_13_sigprocmask13)(long long how_, long long mask_) {
572 POST_SYSCALL(compat_13_sigprocmask13)
573 (long long res, long long how_, long long mask_) {
576 PRE_SYSCALL(__getlogin)(void *namebuf_, long long namelen_) {
578 PRE_WRITE(namebuf_, namelen_);
581 POST_SYSCALL(__getlogin)(long long res, void *namebuf_, long long namelen_) {
584 POST_WRITE(namebuf_, namelen_);
588 PRE_SYSCALL(__setlogin)(void *namebuf_) {
589 const char *namebuf = (const char *)namebuf_;
591 PRE_READ(namebuf, __sanitizer::internal_strlen(namebuf) + 1);
594 POST_SYSCALL(__setlogin)(long long res, void *namebuf_) {
596 const char *namebuf = (const char *)namebuf_;
598 POST_READ(namebuf, __sanitizer::internal_strlen(namebuf) + 1);
602 PRE_SYSCALL(acct)(void *path_) {
603 const char *path = (const char *)path_;
605 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
608 POST_SYSCALL(acct)(long long res, void *path_) {
610 const char *path = (const char *)path_;
612 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
616 PRE_SYSCALL(compat_13_sigpending13)(void) { /* TODO */ }
617 POST_SYSCALL(compat_13_sigpending13)(long long res) { /* TODO */ }
618 PRE_SYSCALL(compat_13_sigaltstack13)(void *nss_, void *oss_) { /* TODO */ }
619 POST_SYSCALL(compat_13_sigaltstack13)(long long res, void *nss_, void *oss_) {
622 PRE_SYSCALL(ioctl)(long long fd_, long long com_, void *data_) {
625 POST_SYSCALL(ioctl)(long long res, long long fd_, long long com_, void *data_) {
628 PRE_SYSCALL(compat_12_oreboot)(long long opt_) { /* TODO */ }
629 POST_SYSCALL(compat_12_oreboot)(long long res, long long opt_) { /* TODO */ }
630 PRE_SYSCALL(revoke)(void *path_) {
631 const char *path = (const char *)path_;
633 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
636 POST_SYSCALL(revoke)(long long res, void *path_) {
638 const char *path = (const char *)path_;
640 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
644 PRE_SYSCALL(symlink)(void *path_, void *link_) {
645 const char *path = (const char *)path_;
646 const char *link = (const char *)link_;
648 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
651 PRE_READ(link, __sanitizer::internal_strlen(link) + 1);
654 POST_SYSCALL(symlink)(long long res, void *path_, void *link_) {
656 const char *path = (const char *)path_;
657 const char *link = (const char *)link_;
659 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
662 POST_READ(link, __sanitizer::internal_strlen(link) + 1);
666 PRE_SYSCALL(readlink)(void *path_, void *buf_, long long count_) {
667 const char *path = (const char *)path_;
669 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
672 PRE_WRITE(buf_, count_);
675 POST_SYSCALL(readlink)
676 (long long res, void *path_, void *buf_, long long count_) {
678 const char *path = (const char *)path_;
680 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
683 PRE_WRITE(buf_, res);
687 PRE_SYSCALL(execve)(void *path_, void *argp_, void *envp_) {
688 const char *path = (const char *)path_;
689 char **argp = (char **)argp_;
690 char **envp = (char **)envp_;
692 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
694 if (argp && argp[0]) {
697 PRE_READ(a, __sanitizer::internal_strlen(a) + 1);
700 if (envp && envp[0]) {
703 PRE_READ(e, __sanitizer::internal_strlen(e) + 1);
707 POST_SYSCALL(execve)(long long res, void *path_, void *argp_, void *envp_) {
708 /* If we are here, something went wrong */
709 const char *path = (const char *)path_;
710 char **argp = (char **)argp_;
711 char **envp = (char **)envp_;
713 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
715 if (argp && argp[0]) {
718 POST_READ(a, __sanitizer::internal_strlen(a) + 1);
721 if (envp && envp[0]) {
724 POST_READ(e, __sanitizer::internal_strlen(e) + 1);
728 PRE_SYSCALL(umask)(long long newmask_) { /* Nothing to do */ }
729 POST_SYSCALL(umask)(long long res, long long newmask_) { /* Nothing to do */ }
730 PRE_SYSCALL(chroot)(void *path_) {
731 const char *path = (const char *)path_;
733 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
736 POST_SYSCALL(chroot)(long long res, void *path_) {
738 const char *path = (const char *)path_;
740 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
744 PRE_SYSCALL(compat_43_fstat43)(long long fd_, void *sb_) { /* TODO */ }
745 POST_SYSCALL(compat_43_fstat43)(long long res, long long fd_, void *sb_) {
748 PRE_SYSCALL(compat_43_ogetkerninfo)
749 (long long op_, void *where_, void *size_, long long arg_) {
752 POST_SYSCALL(compat_43_ogetkerninfo)
753 (long long res, long long op_, void *where_, void *size_, long long arg_) {
756 PRE_SYSCALL(compat_43_ogetpagesize)(void) { /* TODO */ }
757 POST_SYSCALL(compat_43_ogetpagesize)(long long res) { /* TODO */ }
758 PRE_SYSCALL(compat_12_msync)(void *addr_, long long len_) { /* TODO */ }
759 POST_SYSCALL(compat_12_msync)(long long res, void *addr_, long long len_) {
762 PRE_SYSCALL(vfork)(void) { /* Nothing to do */ }
763 POST_SYSCALL(vfork)(long long res) { /* Nothing to do */ }
764 /* syscall 67 has been skipped */
765 /* syscall 68 has been skipped */
766 /* syscall 69 has been skipped */
767 /* syscall 70 has been skipped */
768 PRE_SYSCALL(compat_43_ommap)
769 (void *addr_, long long len_, long long prot_, long long flags_, long long fd_,
773 POST_SYSCALL(compat_43_ommap)
774 (long long res, void *addr_, long long len_, long long prot_, long long flags_,
775 long long fd_, long long pos_) {
778 PRE_SYSCALL(vadvise)(long long anom_) { /* Nothing to do */ }
779 POST_SYSCALL(vadvise)(long long res, long long anom_) { /* Nothing to do */ }
780 PRE_SYSCALL(munmap)(void *addr_, long long len_) { /* Nothing to do */ }
781 POST_SYSCALL(munmap)(long long res, void *addr_, long long len_) {
784 PRE_SYSCALL(mprotect)(void *addr_, long long len_, long long prot_) {
787 POST_SYSCALL(mprotect)
788 (long long res, void *addr_, long long len_, long long prot_) {
791 PRE_SYSCALL(madvise)(void *addr_, long long len_, long long behav_) {
794 POST_SYSCALL(madvise)
795 (long long res, void *addr_, long long len_, long long behav_) {
798 /* syscall 76 has been skipped */
799 /* syscall 77 has been skipped */
800 PRE_SYSCALL(mincore)(void *addr_, long long len_, void *vec_) {
803 POST_SYSCALL(mincore)(long long res, void *addr_, long long len_, void *vec_) {
806 PRE_SYSCALL(getgroups)(long long gidsetsize_, void *gidset_) {
807 unsigned int *gidset = (unsigned int *)gidset_;
809 PRE_WRITE(gidset, sizeof(*gidset) * gidsetsize_);
812 POST_SYSCALL(getgroups)(long long res, long long gidsetsize_, void *gidset_) {
814 unsigned int *gidset = (unsigned int *)gidset_;
816 POST_WRITE(gidset, sizeof(*gidset) * gidsetsize_);
820 PRE_SYSCALL(setgroups)(long long gidsetsize_, void *gidset_) {
821 unsigned int *gidset = (unsigned int *)gidset_;
823 PRE_READ(gidset, sizeof(*gidset) * gidsetsize_);
826 POST_SYSCALL(setgroups)(long long res, long long gidsetsize_, void *gidset_) {
828 unsigned int *gidset = (unsigned int *)gidset_;
830 POST_READ(gidset, sizeof(*gidset) * gidsetsize_);
834 PRE_SYSCALL(getpgrp)(void) { /* Nothing to do */ }
835 POST_SYSCALL(getpgrp)(long long res) { /* Nothing to do */ }
836 PRE_SYSCALL(setpgid)(long long pid_, long long pgid_) { /* Nothing to do */ }
837 POST_SYSCALL(setpgid)(long long res, long long pid_, long long pgid_) {
840 PRE_SYSCALL(compat_50_setitimer)(long long which_, void *itv_, void *oitv_) {
843 POST_SYSCALL(compat_50_setitimer)
844 (long long res, long long which_, void *itv_, void *oitv_) {
847 PRE_SYSCALL(compat_43_owait)(void) { /* TODO */ }
848 POST_SYSCALL(compat_43_owait)(long long res) { /* TODO */ }
849 PRE_SYSCALL(compat_12_oswapon)(void *name_) { /* TODO */ }
850 POST_SYSCALL(compat_12_oswapon)(long long res, void *name_) { /* TODO */ }
851 PRE_SYSCALL(compat_50_getitimer)(long long which_, void *itv_) { /* TODO */ }
852 POST_SYSCALL(compat_50_getitimer)(long long res, long long which_, void *itv_) {
855 PRE_SYSCALL(compat_43_ogethostname)(void *hostname_, long long len_) {
858 POST_SYSCALL(compat_43_ogethostname)
859 (long long res, void *hostname_, long long len_) {
862 PRE_SYSCALL(compat_43_osethostname)(void *hostname_, long long len_) {
865 POST_SYSCALL(compat_43_osethostname)
866 (long long res, void *hostname_, long long len_) {
869 PRE_SYSCALL(compat_43_ogetdtablesize)(void) { /* TODO */ }
870 POST_SYSCALL(compat_43_ogetdtablesize)(long long res) { /* TODO */ }
871 PRE_SYSCALL(dup2)(long long from_, long long to_) { /* Nothing to do */ }
872 POST_SYSCALL(dup2)(long long res, long long from_, long long to_) {
875 /* syscall 91 has been skipped */
876 PRE_SYSCALL(fcntl)(long long fd_, long long cmd_, void *arg_) {
879 POST_SYSCALL(fcntl)(long long res, long long fd_, long long cmd_, void *arg_) {
882 PRE_SYSCALL(compat_50_select)
883 (long long nd_, void *in_, void *ou_, void *ex_, void *tv_) {
886 POST_SYSCALL(compat_50_select)
887 (long long res, long long nd_, void *in_, void *ou_, void *ex_, void *tv_) {
890 /* syscall 94 has been skipped */
891 PRE_SYSCALL(fsync)(long long fd_) { /* Nothing to do */ }
892 POST_SYSCALL(fsync)(long long res, long long fd_) { /* Nothing to do */ }
893 PRE_SYSCALL(setpriority)(long long which_, long long who_, long long prio_) {
896 POST_SYSCALL(setpriority)
897 (long long res, long long which_, long long who_, long long prio_) {
900 PRE_SYSCALL(compat_30_socket)
901 (long long domain_, long long type_, long long protocol_) {
904 POST_SYSCALL(compat_30_socket)
905 (long long res, long long domain_, long long type_, long long protocol_) {
908 PRE_SYSCALL(connect)(long long s_, void *name_, long long namelen_) {
909 PRE_READ(name_, namelen_);
911 POST_SYSCALL(connect)
912 (long long res, long long s_, void *name_, long long namelen_) {
914 POST_READ(name_, namelen_);
917 PRE_SYSCALL(compat_43_oaccept)(long long s_, void *name_, void *anamelen_) {
920 POST_SYSCALL(compat_43_oaccept)
921 (long long res, long long s_, void *name_, void *anamelen_) {
924 PRE_SYSCALL(getpriority)(long long which_, long long who_) {
927 POST_SYSCALL(getpriority)(long long res, long long which_, long long who_) {
930 PRE_SYSCALL(compat_43_osend)
931 (long long s_, void *buf_, long long len_, long long flags_) {
934 POST_SYSCALL(compat_43_osend)
935 (long long res, long long s_, void *buf_, long long len_, long long flags_) {
938 PRE_SYSCALL(compat_43_orecv)
939 (long long s_, void *buf_, long long len_, long long flags_) {
942 POST_SYSCALL(compat_43_orecv)
943 (long long res, long long s_, void *buf_, long long len_, long long flags_) {
946 PRE_SYSCALL(compat_13_sigreturn13)(void *sigcntxp_) { /* TODO */ }
947 POST_SYSCALL(compat_13_sigreturn13)(long long res, void *sigcntxp_) {
950 PRE_SYSCALL(bind)(long long s_, void *name_, long long namelen_) {
951 PRE_READ(name_, namelen_);
954 (long long res, long long s_, void *name_, long long namelen_) {
956 PRE_READ(name_, namelen_);
959 PRE_SYSCALL(setsockopt)
960 (long long s_, long long level_, long long name_, void *val_,
961 long long valsize_) {
963 PRE_READ(val_, valsize_);
966 POST_SYSCALL(setsockopt)
967 (long long res, long long s_, long long level_, long long name_, void *val_,
968 long long valsize_) {
971 POST_READ(val_, valsize_);
975 PRE_SYSCALL(listen)(long long s_, long long backlog_) { /* Nothing to do */ }
976 POST_SYSCALL(listen)(long long res, long long s_, long long backlog_) {
979 /* syscall 107 has been skipped */
980 PRE_SYSCALL(compat_43_osigvec)(long long signum_, void *nsv_, void *osv_) {
983 POST_SYSCALL(compat_43_osigvec)
984 (long long res, long long signum_, void *nsv_, void *osv_) {
987 PRE_SYSCALL(compat_43_osigblock)(long long mask_) { /* TODO */ }
988 POST_SYSCALL(compat_43_osigblock)(long long res, long long mask_) { /* TODO */ }
989 PRE_SYSCALL(compat_43_osigsetmask)(long long mask_) { /* TODO */ }
990 POST_SYSCALL(compat_43_osigsetmask)(long long res, long long mask_) {
993 PRE_SYSCALL(compat_13_sigsuspend13)(long long mask_) { /* TODO */ }
994 POST_SYSCALL(compat_13_sigsuspend13)(long long res, long long mask_) {
997 PRE_SYSCALL(compat_43_osigstack)(void *nss_, void *oss_) { /* TODO */ }
998 POST_SYSCALL(compat_43_osigstack)(long long res, void *nss_, void *oss_) {
1001 PRE_SYSCALL(compat_43_orecvmsg)(long long s_, void *msg_, long long flags_) {
1004 POST_SYSCALL(compat_43_orecvmsg)
1005 (long long res, long long s_, void *msg_, long long flags_) {
1008 PRE_SYSCALL(compat_43_osendmsg)(long long s_, void *msg_, long long flags_) {
1011 POST_SYSCALL(compat_43_osendmsg)
1012 (long long res, long long s_, void *msg_, long long flags_) {
1015 /* syscall 115 has been skipped */
1016 PRE_SYSCALL(compat_50_gettimeofday)(void *tp_, void *tzp_) { /* TODO */ }
1017 POST_SYSCALL(compat_50_gettimeofday)(long long res, void *tp_, void *tzp_) {
1020 PRE_SYSCALL(compat_50_getrusage)(long long who_, void *rusage_) { /* TODO */ }
1021 POST_SYSCALL(compat_50_getrusage)
1022 (long long res, long long who_, void *rusage_) {
1025 PRE_SYSCALL(getsockopt)
1026 (long long s_, long long level_, long long name_, void *val_, void *avalsize_) {
1029 POST_SYSCALL(getsockopt)
1030 (long long res, long long s_, long long level_, long long name_, void *val_,
1034 /* syscall 119 has been skipped */
1035 PRE_SYSCALL(readv)(long long fd_, void *iovp_, long long iovcnt_) {
1036 struct __sanitizer_iovec *iovp = (struct __sanitizer_iovec *)iovp_;
1039 PRE_READ(iovp, sizeof(struct __sanitizer_iovec) * iovcnt_);
1040 for (i = 0; i < iovcnt_; i++) {
1041 PRE_WRITE(iovp[i].iov_base, iovp[i].iov_len);
1046 (long long res, long long fd_, void *iovp_, long long iovcnt_) {
1047 struct __sanitizer_iovec *iovp = (struct __sanitizer_iovec *)iovp_;
1052 POST_READ(iovp, sizeof(struct __sanitizer_iovec) * iovcnt_);
1053 for (i = 0; i < iovcnt_ && n > 0; i++) {
1054 m = n > iovp[i].iov_len ? iovp[i].iov_len : n;
1055 POST_WRITE(iovp[i].iov_base, m);
1061 PRE_SYSCALL(writev)(long long fd_, void *iovp_, long long iovcnt_) {
1062 struct __sanitizer_iovec *iovp = (struct __sanitizer_iovec *)iovp_;
1065 PRE_READ(iovp, sizeof(struct __sanitizer_iovec) * iovcnt_);
1066 for (i = 0; i < iovcnt_; i++) {
1067 PRE_READ(iovp[i].iov_base, iovp[i].iov_len);
1071 POST_SYSCALL(writev)
1072 (long long res, long long fd_, void *iovp_, long long iovcnt_) {
1073 struct __sanitizer_iovec *iovp = (struct __sanitizer_iovec *)iovp_;
1078 POST_READ(iovp, sizeof(struct __sanitizer_iovec) * iovcnt_);
1079 for (i = 0; i < iovcnt_ && n > 0; i++) {
1080 m = n > iovp[i].iov_len ? iovp[i].iov_len : n;
1081 POST_READ(iovp[i].iov_base, m);
1087 PRE_SYSCALL(compat_50_settimeofday)(void *tv_, void *tzp_) { /* TODO */ }
1088 POST_SYSCALL(compat_50_settimeofday)(long long res, void *tv_, void *tzp_) {
1091 PRE_SYSCALL(fchown)(long long fd_, long long uid_, long long gid_) {
1094 POST_SYSCALL(fchown)
1095 (long long res, long long fd_, long long uid_, long long gid_) {
1098 PRE_SYSCALL(fchmod)(long long fd_, long long mode_) { /* Nothing to do */ }
1099 POST_SYSCALL(fchmod)(long long res, long long fd_, long long mode_) {
1102 PRE_SYSCALL(compat_43_orecvfrom)
1103 (long long s_, void *buf_, long long len_, long long flags_, void *from_,
1104 void *fromlenaddr_) {
1107 POST_SYSCALL(compat_43_orecvfrom)
1108 (long long res, long long s_, void *buf_, long long len_, long long flags_,
1109 void *from_, void *fromlenaddr_) {
1112 PRE_SYSCALL(setreuid)(long long ruid_, long long euid_) { /* Nothing to do */ }
1113 POST_SYSCALL(setreuid)(long long res, long long ruid_, long long euid_) {
1116 PRE_SYSCALL(setregid)(long long rgid_, long long egid_) { /* Nothing to do */ }
1117 POST_SYSCALL(setregid)(long long res, long long rgid_, long long egid_) {
1120 PRE_SYSCALL(rename)(void *from_, void *to_) {
1121 const char *from = (const char *)from_;
1122 const char *to = (const char *)to_;
1124 PRE_READ(from, __sanitizer::internal_strlen(from) + 1);
1127 PRE_READ(to, __sanitizer::internal_strlen(to) + 1);
1130 POST_SYSCALL(rename)(long long res, void *from_, void *to_) {
1132 const char *from = (const char *)from_;
1133 const char *to = (const char *)to_;
1135 POST_READ(from, __sanitizer::internal_strlen(from) + 1);
1138 POST_READ(to, __sanitizer::internal_strlen(to) + 1);
1142 PRE_SYSCALL(compat_43_otruncate)(void *path_, long long length_) { /* TODO */ }
1143 POST_SYSCALL(compat_43_otruncate)
1144 (long long res, void *path_, long long length_) {
1147 PRE_SYSCALL(compat_43_oftruncate)(long long fd_, long long length_) {
1150 POST_SYSCALL(compat_43_oftruncate)
1151 (long long res, long long fd_, long long length_) {
1154 PRE_SYSCALL(flock)(long long fd_, long long how_) { /* Nothing to do */ }
1155 POST_SYSCALL(flock)(long long res, long long fd_, long long how_) {
1158 PRE_SYSCALL(mkfifo)(void *path_, long long mode_) {
1159 const char *path = (const char *)path_;
1161 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
1164 POST_SYSCALL(mkfifo)(long long res, void *path_, long long mode_) {
1166 const char *path = (const char *)path_;
1168 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
1173 (long long s_, void *buf_, long long len_, long long flags_, void *to_,
1175 PRE_READ(buf_, len_);
1176 PRE_READ(to_, tolen_);
1178 POST_SYSCALL(sendto)
1179 (long long res, long long s_, void *buf_, long long len_, long long flags_,
1180 void *to_, long long tolen_) {
1182 POST_READ(buf_, len_);
1183 POST_READ(to_, tolen_);
1186 PRE_SYSCALL(shutdown)(long long s_, long long how_) { /* Nothing to do */ }
1187 POST_SYSCALL(shutdown)(long long res, long long s_, long long how_) {
1190 PRE_SYSCALL(socketpair)
1191 (long long domain_, long long type_, long long protocol_, void *rsv_) {
1192 PRE_WRITE(rsv_, 2 * sizeof(int));
1194 POST_SYSCALL(socketpair)
1195 (long long res, long long domain_, long long type_, long long protocol_,
1198 POST_WRITE(rsv_, 2 * sizeof(int));
1201 PRE_SYSCALL(mkdir)(void *path_, long long mode_) {
1202 const char *path = (const char *)path_;
1204 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
1207 POST_SYSCALL(mkdir)(long long res, void *path_, long long mode_) {
1209 const char *path = (const char *)path_;
1211 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
1215 PRE_SYSCALL(rmdir)(void *path_) {
1216 const char *path = (const char *)path_;
1218 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
1221 POST_SYSCALL(rmdir)(long long res, void *path_) {
1223 const char *path = (const char *)path_;
1225 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
1229 PRE_SYSCALL(compat_50_utimes)(void *path_, void *tptr_) { /* TODO */ }
1230 POST_SYSCALL(compat_50_utimes)(long long res, void *path_, void *tptr_) {
1233 /* syscall 139 has been skipped */
1234 PRE_SYSCALL(compat_50_adjtime)(void *delta_, void *olddelta_) { /* TODO */ }
1235 POST_SYSCALL(compat_50_adjtime)(long long res, void *delta_, void *olddelta_) {
1238 PRE_SYSCALL(compat_43_ogetpeername)(long long fdes_, void *asa_, void *alen_) {
1241 POST_SYSCALL(compat_43_ogetpeername)
1242 (long long res, long long fdes_, void *asa_, void *alen_) {
1245 PRE_SYSCALL(compat_43_ogethostid)(void) { /* TODO */ }
1246 POST_SYSCALL(compat_43_ogethostid)(long long res) { /* TODO */ }
1247 PRE_SYSCALL(compat_43_osethostid)(long long hostid_) { /* TODO */ }
1248 POST_SYSCALL(compat_43_osethostid)(long long res, long long hostid_) {
1251 PRE_SYSCALL(compat_43_ogetrlimit)(long long which_, void *rlp_) { /* TODO */ }
1252 POST_SYSCALL(compat_43_ogetrlimit)
1253 (long long res, long long which_, void *rlp_) {
1256 PRE_SYSCALL(compat_43_osetrlimit)(long long which_, void *rlp_) { /* TODO */ }
1257 POST_SYSCALL(compat_43_osetrlimit)
1258 (long long res, long long which_, void *rlp_) {
1261 PRE_SYSCALL(compat_43_okillpg)(long long pgid_, long long signum_) {
1264 POST_SYSCALL(compat_43_okillpg)
1265 (long long res, long long pgid_, long long signum_) {
1268 PRE_SYSCALL(setsid)(void) { /* Nothing to do */ }
1269 POST_SYSCALL(setsid)(long long res) { /* Nothing to do */ }
1270 PRE_SYSCALL(compat_50_quotactl)
1271 (void *path_, long long cmd_, long long uid_, void *arg_) {
1274 POST_SYSCALL(compat_50_quotactl)
1275 (long long res, void *path_, long long cmd_, long long uid_, void *arg_) {
1278 PRE_SYSCALL(compat_43_oquota)(void) { /* TODO */ }
1279 POST_SYSCALL(compat_43_oquota)(long long res) { /* TODO */ }
1280 PRE_SYSCALL(compat_43_ogetsockname)(long long fdec_, void *asa_, void *alen_) {
1283 POST_SYSCALL(compat_43_ogetsockname)
1284 (long long res, long long fdec_, void *asa_, void *alen_) {
1287 /* syscall 151 has been skipped */
1288 /* syscall 152 has been skipped */
1289 /* syscall 153 has been skipped */
1290 /* syscall 154 has been skipped */
1291 PRE_SYSCALL(nfssvc)(long long flag_, void *argp_) { /* Nothing to do */ }
1292 POST_SYSCALL(nfssvc)(long long res, long long flag_, void *argp_) {
1295 PRE_SYSCALL(compat_43_ogetdirentries)
1296 (long long fd_, void *buf_, long long count_, void *basep_) {
1299 POST_SYSCALL(compat_43_ogetdirentries)
1300 (long long res, long long fd_, void *buf_, long long count_, void *basep_) {
1303 PRE_SYSCALL(compat_20_statfs)(void *path_, void *buf_) { /* TODO */ }
1304 POST_SYSCALL(compat_20_statfs)(long long res, void *path_, void *buf_) {
1307 PRE_SYSCALL(compat_20_fstatfs)(long long fd_, void *buf_) { /* TODO */ }
1308 POST_SYSCALL(compat_20_fstatfs)(long long res, long long fd_, void *buf_) {
1311 /* syscall 159 has been skipped */
1312 /* syscall 160 has been skipped */
1313 PRE_SYSCALL(compat_30_getfh)(void *fname_, void *fhp_) { /* TODO */ }
1314 POST_SYSCALL(compat_30_getfh)(long long res, void *fname_, void *fhp_) {
1317 PRE_SYSCALL(compat_09_ogetdomainname)(void *domainname_, long long len_) {
1320 POST_SYSCALL(compat_09_ogetdomainname)
1321 (long long res, void *domainname_, long long len_) {
1324 PRE_SYSCALL(compat_09_osetdomainname)(void *domainname_, long long len_) {
1327 POST_SYSCALL(compat_09_osetdomainname)
1328 (long long res, void *domainname_, long long len_) {
1331 PRE_SYSCALL(compat_09_ouname)(void *name_) { /* TODO */ }
1332 POST_SYSCALL(compat_09_ouname)(long long res, void *name_) { /* TODO */ }
1333 PRE_SYSCALL(sysarch)(long long op_, void *parms_) { /* TODO */ }
1334 POST_SYSCALL(sysarch)(long long res, long long op_, void *parms_) { /* TODO */ }
1335 /* syscall 166 has been skipped */
1336 /* syscall 167 has been skipped */
1337 /* syscall 168 has been skipped */
1339 PRE_SYSCALL(compat_10_osemsys)
1340 (long long which_, long long a2_, long long a3_, long long a4_, long long a5_) {
1343 POST_SYSCALL(compat_10_osemsys)
1344 (long long res, long long which_, long long a2_, long long a3_, long long a4_,
1349 /* syscall 169 has been skipped */
1352 PRE_SYSCALL(compat_10_omsgsys)
1353 (long long which_, long long a2_, long long a3_, long long a4_, long long a5_,
1357 POST_SYSCALL(compat_10_omsgsys)
1358 (long long res, long long which_, long long a2_, long long a3_, long long a4_,
1359 long long a5_, long long a6_) {
1363 /* syscall 170 has been skipped */
1366 PRE_SYSCALL(compat_10_oshmsys)
1367 (long long which_, long long a2_, long long a3_, long long a4_) {
1370 POST_SYSCALL(compat_10_oshmsys)
1371 (long long res, long long which_, long long a2_, long long a3_, long long a4_) {
1375 /* syscall 171 has been skipped */
1377 /* syscall 172 has been skipped */
1379 (long long fd_, void *buf_, long long nbyte_, long long PAD_,
1380 long long offset_) {
1382 PRE_WRITE(buf_, nbyte_);
1386 (long long res, long long fd_, void *buf_, long long nbyte_, long long PAD_,
1387 long long offset_) {
1389 POST_WRITE(buf_, res);
1393 (long long fd_, void *buf_, long long nbyte_, long long PAD_,
1394 long long offset_) {
1396 PRE_READ(buf_, nbyte_);
1399 POST_SYSCALL(pwrite)
1400 (long long res, long long fd_, void *buf_, long long nbyte_, long long PAD_,
1401 long long offset_) {
1403 POST_READ(buf_, res);
1406 PRE_SYSCALL(compat_30_ntp_gettime)(void *ntvp_) { /* TODO */ }
1407 POST_SYSCALL(compat_30_ntp_gettime)(long long res, void *ntvp_) { /* TODO */ }
1408 #if defined(NTP) || !defined(_KERNEL_OPT)
1409 PRE_SYSCALL(ntp_adjtime)(void *tp_) { /* Nothing to do */ }
1410 POST_SYSCALL(ntp_adjtime)(long long res, void *tp_) { /* Nothing to do */ }
1412 /* syscall 176 has been skipped */
1414 /* syscall 177 has been skipped */
1415 /* syscall 178 has been skipped */
1416 /* syscall 179 has been skipped */
1417 /* syscall 180 has been skipped */
1418 PRE_SYSCALL(setgid)(long long gid_) { /* Nothing to do */ }
1419 POST_SYSCALL(setgid)(long long res, long long gid_) { /* Nothing to do */ }
1420 PRE_SYSCALL(setegid)(long long egid_) { /* Nothing to do */ }
1421 POST_SYSCALL(setegid)(long long res, long long egid_) { /* Nothing to do */ }
1422 PRE_SYSCALL(seteuid)(long long euid_) { /* Nothing to do */ }
1423 POST_SYSCALL(seteuid)(long long res, long long euid_) { /* Nothing to do */ }
1424 PRE_SYSCALL(lfs_bmapv)(void *fsidp_, void *blkiov_, long long blkcnt_) {
1427 POST_SYSCALL(lfs_bmapv)
1428 (long long res, void *fsidp_, void *blkiov_, long long blkcnt_) {
1431 PRE_SYSCALL(lfs_markv)(void *fsidp_, void *blkiov_, long long blkcnt_) {
1434 POST_SYSCALL(lfs_markv)
1435 (long long res, void *fsidp_, void *blkiov_, long long blkcnt_) {
1438 PRE_SYSCALL(lfs_segclean)(void *fsidp_, long long segment_) { /* TODO */ }
1439 POST_SYSCALL(lfs_segclean)(long long res, void *fsidp_, long long segment_) {
1442 PRE_SYSCALL(compat_50_lfs_segwait)(void *fsidp_, void *tv_) { /* TODO */ }
1443 POST_SYSCALL(compat_50_lfs_segwait)(long long res, void *fsidp_, void *tv_) {
1446 PRE_SYSCALL(compat_12_stat12)(void *path_, void *ub_) { /* TODO */ }
1447 POST_SYSCALL(compat_12_stat12)(long long res, void *path_, void *ub_) {
1450 PRE_SYSCALL(compat_12_fstat12)(long long fd_, void *sb_) { /* TODO */ }
1451 POST_SYSCALL(compat_12_fstat12)(long long res, long long fd_, void *sb_) {
1454 PRE_SYSCALL(compat_12_lstat12)(void *path_, void *ub_) { /* TODO */ }
1455 POST_SYSCALL(compat_12_lstat12)(long long res, void *path_, void *ub_) {
1458 PRE_SYSCALL(pathconf)(void *path_, long long name_) {
1459 const char *path = (const char *)path_;
1461 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
1464 POST_SYSCALL(pathconf)(long long res, void *path_, long long name_) {
1466 const char *path = (const char *)path_;
1468 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
1472 PRE_SYSCALL(fpathconf)(long long fd_, long long name_) { /* Nothing to do */ }
1473 POST_SYSCALL(fpathconf)(long long res, long long fd_, long long name_) {
1476 PRE_SYSCALL(getsockopt2)
1477 (long long s_, long long level_, long long name_, void *val_, void *avalsize_) {
1480 POST_SYSCALL(getsockopt2)
1481 (long long res, long long s_, long long level_, long long name_, void *val_,
1485 PRE_SYSCALL(getrlimit)(long long which_, void *rlp_) {
1486 PRE_WRITE(rlp_, struct_rlimit_sz);
1488 POST_SYSCALL(getrlimit)(long long res, long long which_, void *rlp_) {
1490 POST_WRITE(rlp_, struct_rlimit_sz);
1493 PRE_SYSCALL(setrlimit)(long long which_, void *rlp_) {
1494 PRE_READ(rlp_, struct_rlimit_sz);
1496 POST_SYSCALL(setrlimit)(long long res, long long which_, void *rlp_) {
1498 POST_READ(rlp_, struct_rlimit_sz);
1501 PRE_SYSCALL(compat_12_getdirentries)
1502 (long long fd_, void *buf_, long long count_, void *basep_) {
1505 POST_SYSCALL(compat_12_getdirentries)
1506 (long long res, long long fd_, void *buf_, long long count_, void *basep_) {
1510 (void *addr_, long long len_, long long prot_, long long flags_, long long fd_,
1511 long long PAD_, long long pos_) {
1515 (long long res, void *addr_, long long len_, long long prot_, long long flags_,
1516 long long fd_, long long PAD_, long long pos_) {
1519 PRE_SYSCALL(__syscall)(long long code_, long long args_[SYS_MAXSYSARGS]) {
1522 POST_SYSCALL(__syscall)
1523 (long long res, long long code_, long long args_[SYS_MAXSYSARGS]) {
1527 (long long fd_, long long PAD_, long long offset_, long long whence_) {
1531 (long long res, long long fd_, long long PAD_, long long offset_,
1532 long long whence_) {
1535 PRE_SYSCALL(truncate)(void *path_, long long PAD_, long long length_) {
1536 const char *path = (const char *)path_;
1538 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
1541 POST_SYSCALL(truncate)
1542 (long long res, void *path_, long long PAD_, long long length_) {
1544 const char *path = (const char *)path_;
1546 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
1550 PRE_SYSCALL(ftruncate)(long long fd_, long long PAD_, long long length_) {
1553 POST_SYSCALL(ftruncate)
1554 (long long res, long long fd_, long long PAD_, long long length_) {
1557 PRE_SYSCALL(__sysctl)
1558 (void *name_, long long namelen_, void *oldv_, void *oldlenp_, void *newv_,
1559 long long newlen_) {
1560 const int *name = (const int *)name_;
1562 PRE_READ(name, namelen_ * sizeof(*name));
1565 PRE_READ(name, newlen_);
1568 POST_SYSCALL(__sysctl)
1569 (long long res, void *name_, long long namelen_, void *oldv_, void *oldlenp_,
1570 void *newv_, long long newlen_) {
1572 const int *name = (const int *)name_;
1574 POST_READ(name, namelen_ * sizeof(*name));
1577 POST_READ(name, newlen_);
1581 PRE_SYSCALL(mlock)(void *addr_, long long len_) { /* Nothing to do */ }
1582 POST_SYSCALL(mlock)(long long res, void *addr_, long long len_) {
1585 PRE_SYSCALL(munlock)(void *addr_, long long len_) { /* Nothing to do */ }
1586 POST_SYSCALL(munlock)(long long res, void *addr_, long long len_) {
1589 PRE_SYSCALL(undelete)(void *path_) {
1590 const char *path = (const char *)path_;
1592 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
1595 POST_SYSCALL(undelete)(long long res, void *path_) {
1597 const char *path = (const char *)path_;
1599 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
1603 PRE_SYSCALL(compat_50_futimes)(long long fd_, void *tptr_) { /* TODO */ }
1604 POST_SYSCALL(compat_50_futimes)(long long res, long long fd_, void *tptr_) {
1607 PRE_SYSCALL(getpgid)(long long pid_) { /* Nothing to do */ }
1608 POST_SYSCALL(getpgid)(long long res, long long pid_) { /* Nothing to do */ }
1609 PRE_SYSCALL(reboot)(long long opt_, void *bootstr_) {
1610 const char *bootstr = (const char *)bootstr_;
1612 PRE_READ(bootstr, __sanitizer::internal_strlen(bootstr) + 1);
1615 POST_SYSCALL(reboot)(long long res, long long opt_, void *bootstr_) {
1616 /* This call should never return */
1617 const char *bootstr = (const char *)bootstr_;
1619 POST_READ(bootstr, __sanitizer::internal_strlen(bootstr) + 1);
1622 PRE_SYSCALL(poll)(void *fds_, long long nfds_, long long timeout_) {
1626 (long long res, void *fds_, long long nfds_, long long timeout_) {
1630 (long long id_, long long a1_, long long a2_, long long a3_, long long a4_,
1631 long long a5_, long long a6_) {
1634 POST_SYSCALL(afssys)
1635 (long long res, long long id_, long long a1_, long long a2_, long long a3_,
1636 long long a4_, long long a5_, long long a6_) {
1639 /* syscall 211 has been skipped */
1640 /* syscall 212 has been skipped */
1641 /* syscall 213 has been skipped */
1642 /* syscall 214 has been skipped */
1643 /* syscall 215 has been skipped */
1644 /* syscall 216 has been skipped */
1645 /* syscall 217 has been skipped */
1646 /* syscall 218 has been skipped */
1647 /* syscall 219 has been skipped */
1648 PRE_SYSCALL(compat_14___semctl)
1649 (long long semid_, long long semnum_, long long cmd_, void *arg_) {
1652 POST_SYSCALL(compat_14___semctl)
1653 (long long res, long long semid_, long long semnum_, long long cmd_,
1657 PRE_SYSCALL(semget)(long long key_, long long nsems_, long long semflg_) {
1660 POST_SYSCALL(semget)
1661 (long long res, long long key_, long long nsems_, long long semflg_) {
1664 PRE_SYSCALL(semop)(long long semid_, void *sops_, long long nsops_) {
1666 PRE_READ(sops_, nsops_ * struct_sembuf_sz);
1670 (long long res, long long semid_, void *sops_, long long nsops_) {
1673 POST_READ(sops_, nsops_ * struct_sembuf_sz);
1677 PRE_SYSCALL(semconfig)(long long flag_) { /* Nothing to do */ }
1678 POST_SYSCALL(semconfig)(long long res, long long flag_) { /* Nothing to do */ }
1679 PRE_SYSCALL(compat_14_msgctl)(long long msqid_, long long cmd_, void *buf_) {
1682 POST_SYSCALL(compat_14_msgctl)
1683 (long long res, long long msqid_, long long cmd_, void *buf_) {
1686 PRE_SYSCALL(msgget)(long long key_, long long msgflg_) { /* Nothing to do */ }
1687 POST_SYSCALL(msgget)(long long res, long long key_, long long msgflg_) {
1691 (long long msqid_, void *msgp_, long long msgsz_, long long msgflg_) {
1693 PRE_READ(msgp_, msgsz_);
1696 POST_SYSCALL(msgsnd)
1697 (long long res, long long msqid_, void *msgp_, long long msgsz_,
1698 long long msgflg_) {
1701 POST_READ(msgp_, msgsz_);
1706 (long long msqid_, void *msgp_, long long msgsz_, long long msgtyp_,
1707 long long msgflg_) {
1710 POST_SYSCALL(msgrcv)
1711 (long long res, long long msqid_, void *msgp_, long long msgsz_,
1712 long long msgtyp_, long long msgflg_) {
1715 PRE_SYSCALL(shmat)(long long shmid_, void *shmaddr_, long long shmflg_) {
1719 (long long res, long long shmid_, void *shmaddr_, long long shmflg_) {
1722 PRE_SYSCALL(compat_14_shmctl)(long long shmid_, long long cmd_, void *buf_) {
1725 POST_SYSCALL(compat_14_shmctl)
1726 (long long res, long long shmid_, long long cmd_, void *buf_) {
1729 PRE_SYSCALL(shmdt)(void *shmaddr_) { /* Nothing to do */ }
1730 POST_SYSCALL(shmdt)(long long res, void *shmaddr_) { /* Nothing to do */ }
1731 PRE_SYSCALL(shmget)(long long key_, long long size_, long long shmflg_) {
1734 POST_SYSCALL(shmget)
1735 (long long res, long long key_, long long size_, long long shmflg_) {
1738 PRE_SYSCALL(compat_50_clock_gettime)(long long clock_id_, void *tp_) {
1741 POST_SYSCALL(compat_50_clock_gettime)
1742 (long long res, long long clock_id_, void *tp_) {
1745 PRE_SYSCALL(compat_50_clock_settime)(long long clock_id_, void *tp_) {
1748 POST_SYSCALL(compat_50_clock_settime)
1749 (long long res, long long clock_id_, void *tp_) {
1752 PRE_SYSCALL(compat_50_clock_getres)(long long clock_id_, void *tp_) {
1755 POST_SYSCALL(compat_50_clock_getres)
1756 (long long res, long long clock_id_, void *tp_) {
1759 PRE_SYSCALL(timer_create)(long long clock_id_, void *evp_, void *timerid_) {
1762 POST_SYSCALL(timer_create)
1763 (long long res, long long clock_id_, void *evp_, void *timerid_) {
1766 PRE_SYSCALL(timer_delete)(long long timerid_) { /* Nothing to do */ }
1767 POST_SYSCALL(timer_delete)(long long res, long long timerid_) {
1770 PRE_SYSCALL(compat_50_timer_settime)
1771 (long long timerid_, long long flags_, void *value_, void *ovalue_) {
1774 POST_SYSCALL(compat_50_timer_settime)
1775 (long long res, long long timerid_, long long flags_, void *value_,
1779 PRE_SYSCALL(compat_50_timer_gettime)(long long timerid_, void *value_) {
1782 POST_SYSCALL(compat_50_timer_gettime)
1783 (long long res, long long timerid_, void *value_) {
1786 PRE_SYSCALL(timer_getoverrun)(long long timerid_) { /* Nothing to do */ }
1787 POST_SYSCALL(timer_getoverrun)(long long res, long long timerid_) {
1790 PRE_SYSCALL(compat_50_nanosleep)(void *rqtp_, void *rmtp_) { /* TODO */ }
1791 POST_SYSCALL(compat_50_nanosleep)(long long res, void *rqtp_, void *rmtp_) {
1794 PRE_SYSCALL(fdatasync)(long long fd_) { /* Nothing to do */ }
1795 POST_SYSCALL(fdatasync)(long long res, long long fd_) { /* Nothing to do */ }
1796 PRE_SYSCALL(mlockall)(long long flags_) { /* Nothing to do */ }
1797 POST_SYSCALL(mlockall)(long long res, long long flags_) { /* Nothing to do */ }
1798 PRE_SYSCALL(munlockall)(void) { /* Nothing to do */ }
1799 POST_SYSCALL(munlockall)(long long res) { /* Nothing to do */ }
1800 PRE_SYSCALL(compat_50___sigtimedwait)(void *set_, void *info_, void *timeout_) {
1803 POST_SYSCALL(compat_50___sigtimedwait)
1804 (long long res, void *set_, void *info_, void *timeout_) {
1807 PRE_SYSCALL(sigqueueinfo)(long long pid_, void *info_) {
1809 PRE_READ(info_, siginfo_t_sz);
1812 POST_SYSCALL(sigqueueinfo)(long long res, long long pid_, void *info_) {}
1813 PRE_SYSCALL(modctl)(long long cmd_, void *arg_) { /* TODO */ }
1814 POST_SYSCALL(modctl)(long long res, long long cmd_, void *arg_) { /* TODO */ }
1815 PRE_SYSCALL(_ksem_init)(long long value_, void *idp_) { /* Nothing to do */ }
1816 POST_SYSCALL(_ksem_init)(long long res, long long value_, void *idp_) {
1819 PRE_SYSCALL(_ksem_open)
1820 (void *name_, long long oflag_, long long mode_, long long value_, void *idp_) {
1821 const char *name = (const char *)name_;
1823 PRE_READ(name, __sanitizer::internal_strlen(name) + 1);
1826 POST_SYSCALL(_ksem_open)
1827 (long long res, void *name_, long long oflag_, long long mode_,
1828 long long value_, void *idp_) {
1829 const char *name = (const char *)name_;
1831 POST_READ(name, __sanitizer::internal_strlen(name) + 1);
1834 PRE_SYSCALL(_ksem_unlink)(void *name_) {
1835 const char *name = (const char *)name_;
1837 PRE_READ(name, __sanitizer::internal_strlen(name) + 1);
1840 POST_SYSCALL(_ksem_unlink)(long long res, void *name_) {
1841 const char *name = (const char *)name_;
1843 POST_READ(name, __sanitizer::internal_strlen(name) + 1);
1846 PRE_SYSCALL(_ksem_close)(long long id_) { /* Nothing to do */ }
1847 POST_SYSCALL(_ksem_close)(long long res, long long id_) { /* Nothing to do */ }
1848 PRE_SYSCALL(_ksem_post)(long long id_) { /* Nothing to do */ }
1849 POST_SYSCALL(_ksem_post)(long long res, long long id_) { /* Nothing to do */ }
1850 PRE_SYSCALL(_ksem_wait)(long long id_) { /* Nothing to do */ }
1851 POST_SYSCALL(_ksem_wait)(long long res, long long id_) { /* Nothing to do */ }
1852 PRE_SYSCALL(_ksem_trywait)(long long id_) { /* Nothing to do */ }
1853 POST_SYSCALL(_ksem_trywait)(long long res, long long id_) {
1856 PRE_SYSCALL(_ksem_getvalue)(long long id_, void *value_) { /* Nothing to do */ }
1857 POST_SYSCALL(_ksem_getvalue)(long long res, long long id_, void *value_) {
1860 PRE_SYSCALL(_ksem_destroy)(long long id_) { /* Nothing to do */ }
1861 POST_SYSCALL(_ksem_destroy)(long long res, long long id_) {
1864 PRE_SYSCALL(_ksem_timedwait)(long long id_, void *abstime_) {
1866 PRE_READ(abstime_, struct_timespec_sz);
1869 POST_SYSCALL(_ksem_timedwait)(long long res, long long id_, void *abstime_) {}
1870 PRE_SYSCALL(mq_open)
1871 (void *name_, long long oflag_, long long mode_, void *attr_) {
1872 const char *name = (const char *)name_;
1874 PRE_READ(name, __sanitizer::internal_strlen(name) + 1);
1877 POST_SYSCALL(mq_open)
1878 (long long res, void *name_, long long oflag_, long long mode_, void *attr_) {
1879 const char *name = (const char *)name_;
1881 POST_READ(name, __sanitizer::internal_strlen(name) + 1);
1884 PRE_SYSCALL(mq_close)(long long mqdes_) { /* Nothing to do */ }
1885 POST_SYSCALL(mq_close)(long long res, long long mqdes_) { /* Nothing to do */ }
1886 PRE_SYSCALL(mq_unlink)(void *name_) {
1887 const char *name = (const char *)name_;
1889 PRE_READ(name, __sanitizer::internal_strlen(name) + 1);
1892 POST_SYSCALL(mq_unlink)(long long res, void *name_) {
1893 const char *name = (const char *)name_;
1895 POST_READ(name, __sanitizer::internal_strlen(name) + 1);
1898 PRE_SYSCALL(mq_getattr)(long long mqdes_, void *mqstat_) { /* Nothing to do */ }
1899 POST_SYSCALL(mq_getattr)(long long res, long long mqdes_, void *mqstat_) {
1902 PRE_SYSCALL(mq_setattr)(long long mqdes_, void *mqstat_, void *omqstat_) {
1904 PRE_READ(mqstat_, struct_mq_attr_sz);
1907 POST_SYSCALL(mq_setattr)
1908 (long long res, long long mqdes_, void *mqstat_, void *omqstat_) {}
1909 PRE_SYSCALL(mq_notify)(long long mqdes_, void *notification_) {
1910 if (notification_) {
1911 PRE_READ(notification_, struct_sigevent_sz);
1914 POST_SYSCALL(mq_notify)(long long res, long long mqdes_, void *notification_) {}
1915 PRE_SYSCALL(mq_send)
1916 (long long mqdes_, void *msg_ptr_, long long msg_len_, long long msg_prio_) {
1918 PRE_READ(msg_ptr_, msg_len_);
1921 POST_SYSCALL(mq_send)
1922 (long long res, long long mqdes_, void *msg_ptr_, long long msg_len_,
1923 long long msg_prio_) {}
1924 PRE_SYSCALL(mq_receive)
1925 (long long mqdes_, void *msg_ptr_, long long msg_len_, void *msg_prio_) {
1928 POST_SYSCALL(mq_receive)
1929 (long long res, long long mqdes_, void *msg_ptr_, long long msg_len_,
1933 PRE_SYSCALL(compat_50_mq_timedsend)
1934 (long long mqdes_, void *msg_ptr_, long long msg_len_, long long msg_prio_,
1935 void *abs_timeout_) {
1938 POST_SYSCALL(compat_50_mq_timedsend)
1939 (long long res, long long mqdes_, void *msg_ptr_, long long msg_len_,
1940 long long msg_prio_, void *abs_timeout_) {
1943 PRE_SYSCALL(compat_50_mq_timedreceive)
1944 (long long mqdes_, void *msg_ptr_, long long msg_len_, void *msg_prio_,
1945 void *abs_timeout_) {
1948 POST_SYSCALL(compat_50_mq_timedreceive)
1949 (long long res, long long mqdes_, void *msg_ptr_, long long msg_len_,
1950 void *msg_prio_, void *abs_timeout_) {
1953 /* syscall 267 has been skipped */
1954 /* syscall 268 has been skipped */
1955 /* syscall 269 has been skipped */
1956 PRE_SYSCALL(__posix_rename)(void *from_, void *to_) {
1957 const char *from = (const char *)from_;
1958 const char *to = (const char *)to_;
1960 PRE_READ(from, __sanitizer::internal_strlen(from) + 1);
1963 PRE_READ(to, __sanitizer::internal_strlen(to) + 1);
1966 POST_SYSCALL(__posix_rename)(long long res, void *from_, void *to_) {
1967 const char *from = (const char *)from_;
1968 const char *to = (const char *)to_;
1970 POST_READ(from, __sanitizer::internal_strlen(from) + 1);
1973 POST_READ(to, __sanitizer::internal_strlen(to) + 1);
1976 PRE_SYSCALL(swapctl)(long long cmd_, void *arg_, long long misc_) { /* TODO */ }
1977 POST_SYSCALL(swapctl)
1978 (long long res, long long cmd_, void *arg_, long long misc_) {
1981 PRE_SYSCALL(compat_30_getdents)(long long fd_, void *buf_, long long count_) {
1984 POST_SYSCALL(compat_30_getdents)
1985 (long long res, long long fd_, void *buf_, long long count_) {
1988 PRE_SYSCALL(minherit)(void *addr_, long long len_, long long inherit_) {
1991 POST_SYSCALL(minherit)
1992 (long long res, void *addr_, long long len_, long long inherit_) {
1995 PRE_SYSCALL(lchmod)(void *path_, long long mode_) {
1996 const char *path = (const char *)path_;
1998 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2001 POST_SYSCALL(lchmod)(long long res, void *path_, long long mode_) {
2002 const char *path = (const char *)path_;
2004 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2007 PRE_SYSCALL(lchown)(void *path_, long long uid_, long long gid_) {
2008 const char *path = (const char *)path_;
2010 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2013 POST_SYSCALL(lchown)
2014 (long long res, void *path_, long long uid_, long long gid_) {
2015 const char *path = (const char *)path_;
2017 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2020 PRE_SYSCALL(compat_50_lutimes)(void *path_, void *tptr_) { /* TODO */ }
2021 POST_SYSCALL(compat_50_lutimes)(long long res, void *path_, void *tptr_) {
2024 PRE_SYSCALL(__msync13)(void *addr_, long long len_, long long flags_) {
2027 POST_SYSCALL(__msync13)
2028 (long long res, void *addr_, long long len_, long long flags_) {
2031 PRE_SYSCALL(compat_30___stat13)(void *path_, void *ub_) { /* TODO */ }
2032 POST_SYSCALL(compat_30___stat13)(long long res, void *path_, void *ub_) {
2035 PRE_SYSCALL(compat_30___fstat13)(long long fd_, void *sb_) { /* TODO */ }
2036 POST_SYSCALL(compat_30___fstat13)(long long res, long long fd_, void *sb_) {
2039 PRE_SYSCALL(compat_30___lstat13)(void *path_, void *ub_) { /* TODO */ }
2040 POST_SYSCALL(compat_30___lstat13)(long long res, void *path_, void *ub_) {
2043 PRE_SYSCALL(__sigaltstack14)(void *nss_, void *oss_) {
2045 PRE_READ(nss_, struct_sigaltstack_sz);
2048 PRE_READ(oss_, struct_sigaltstack_sz);
2051 POST_SYSCALL(__sigaltstack14)(long long res, void *nss_, void *oss_) {}
2052 PRE_SYSCALL(__vfork14)(void) { /* Nothing to do */ }
2053 POST_SYSCALL(__vfork14)(long long res) { /* Nothing to do */ }
2054 PRE_SYSCALL(__posix_chown)(void *path_, long long uid_, long long gid_) {
2055 const char *path = (const char *)path_;
2057 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2060 POST_SYSCALL(__posix_chown)
2061 (long long res, void *path_, long long uid_, long long gid_) {
2062 const char *path = (const char *)path_;
2064 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2067 PRE_SYSCALL(__posix_fchown)(long long fd_, long long uid_, long long gid_) {
2070 POST_SYSCALL(__posix_fchown)
2071 (long long res, long long fd_, long long uid_, long long gid_) {
2074 PRE_SYSCALL(__posix_lchown)(void *path_, long long uid_, long long gid_) {
2075 const char *path = (const char *)path_;
2077 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2080 POST_SYSCALL(__posix_lchown)
2081 (long long res, void *path_, long long uid_, long long gid_) {
2082 const char *path = (const char *)path_;
2084 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2087 PRE_SYSCALL(getsid)(long long pid_) { /* Nothing to do */ }
2088 POST_SYSCALL(getsid)(long long res, long long pid_) { /* Nothing to do */ }
2089 PRE_SYSCALL(__clone)(long long flags_, void *stack_) { /* Nothing to do */ }
2090 POST_SYSCALL(__clone)(long long res, long long flags_, void *stack_) {
2093 PRE_SYSCALL(fktrace)
2094 (long long fd_, long long ops_, long long facs_, long long pid_) {
2097 POST_SYSCALL(fktrace)
2098 (long long res, long long fd_, long long ops_, long long facs_,
2103 (long long fd_, void *iovp_, long long iovcnt_, long long PAD_,
2104 long long offset_) {
2107 POST_SYSCALL(preadv)
2108 (long long res, long long fd_, void *iovp_, long long iovcnt_, long long PAD_,
2109 long long offset_) {
2112 PRE_SYSCALL(pwritev)
2113 (long long fd_, void *iovp_, long long iovcnt_, long long PAD_,
2114 long long offset_) {
2117 POST_SYSCALL(pwritev)
2118 (long long res, long long fd_, void *iovp_, long long iovcnt_, long long PAD_,
2119 long long offset_) {
2122 PRE_SYSCALL(compat_16___sigaction14)
2123 (long long signum_, void *nsa_, void *osa_) {
2126 POST_SYSCALL(compat_16___sigaction14)
2127 (long long res, long long signum_, void *nsa_, void *osa_) {
2130 PRE_SYSCALL(__sigpending14)(void *set_) { /* Nothing to do */ }
2131 POST_SYSCALL(__sigpending14)(long long res, void *set_) { /* Nothing to do */ }
2132 PRE_SYSCALL(__sigprocmask14)(long long how_, void *set_, void *oset_) {
2135 POST_SYSCALL(__sigprocmask14)
2136 (long long res, long long how_, void *set_, void *oset_) {
2139 PRE_SYSCALL(__sigsuspend14)(void *set_) {
2141 PRE_READ(set_, sizeof(__sanitizer_sigset_t));
2144 POST_SYSCALL(__sigsuspend14)(long long res, void *set_) {
2146 PRE_READ(set_, sizeof(__sanitizer_sigset_t));
2149 PRE_SYSCALL(compat_16___sigreturn14)(void *sigcntxp_) { /* TODO */ }
2150 POST_SYSCALL(compat_16___sigreturn14)(long long res, void *sigcntxp_) {
2153 PRE_SYSCALL(__getcwd)(void *bufp_, long long length_) { /* Nothing to do */ }
2154 POST_SYSCALL(__getcwd)(long long res, void *bufp_, long long length_) {
2157 PRE_SYSCALL(fchroot)(long long fd_) { /* Nothing to do */ }
2158 POST_SYSCALL(fchroot)(long long res, long long fd_) { /* Nothing to do */ }
2159 PRE_SYSCALL(compat_30_fhopen)(void *fhp_, long long flags_) { /* TODO */ }
2160 POST_SYSCALL(compat_30_fhopen)(long long res, void *fhp_, long long flags_) {
2163 PRE_SYSCALL(compat_30_fhstat)(void *fhp_, void *sb_) { /* TODO */ }
2164 POST_SYSCALL(compat_30_fhstat)(long long res, void *fhp_, void *sb_) {
2167 PRE_SYSCALL(compat_20_fhstatfs)(void *fhp_, void *buf_) { /* TODO */ }
2168 POST_SYSCALL(compat_20_fhstatfs)(long long res, void *fhp_, void *buf_) {
2171 PRE_SYSCALL(compat_50_____semctl13)
2172 (long long semid_, long long semnum_, long long cmd_, void *arg_) {
2175 POST_SYSCALL(compat_50_____semctl13)
2176 (long long res, long long semid_, long long semnum_, long long cmd_,
2180 PRE_SYSCALL(compat_50___msgctl13)
2181 (long long msqid_, long long cmd_, void *buf_) {
2184 POST_SYSCALL(compat_50___msgctl13)
2185 (long long res, long long msqid_, long long cmd_, void *buf_) {
2188 PRE_SYSCALL(compat_50___shmctl13)
2189 (long long shmid_, long long cmd_, void *buf_) {
2192 POST_SYSCALL(compat_50___shmctl13)
2193 (long long res, long long shmid_, long long cmd_, void *buf_) {
2196 PRE_SYSCALL(lchflags)(void *path_, long long flags_) {
2197 const char *path = (const char *)path_;
2199 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2202 POST_SYSCALL(lchflags)(long long res, void *path_, long long flags_) {
2203 const char *path = (const char *)path_;
2205 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2208 PRE_SYSCALL(issetugid)(void) { /* Nothing to do */ }
2209 POST_SYSCALL(issetugid)(long long res) { /* Nothing to do */ }
2210 PRE_SYSCALL(utrace)(void *label_, void *addr_, long long len_) {
2211 const char *label = (const char *)label_;
2213 PRE_READ(label, __sanitizer::internal_strlen(label) + 1);
2216 PRE_READ(addr_, len_);
2219 POST_SYSCALL(utrace)(long long res, void *label_, void *addr_, long long len_) {
2220 const char *label = (const char *)label_;
2222 POST_READ(label, __sanitizer::internal_strlen(label) + 1);
2225 POST_READ(addr_, len_);
2228 PRE_SYSCALL(getcontext)(void *ucp_) { /* Nothing to do */ }
2229 POST_SYSCALL(getcontext)(long long res, void *ucp_) { /* Nothing to do */ }
2230 PRE_SYSCALL(setcontext)(void *ucp_) {
2232 PRE_READ(ucp_, ucontext_t_sz);
2235 POST_SYSCALL(setcontext)(long long res, void *ucp_) {}
2236 PRE_SYSCALL(_lwp_create)(void *ucp_, long long flags_, void *new_lwp_) {
2238 PRE_READ(ucp_, ucontext_t_sz);
2241 POST_SYSCALL(_lwp_create)
2242 (long long res, void *ucp_, long long flags_, void *new_lwp_) {}
2243 PRE_SYSCALL(_lwp_exit)(void) { /* Nothing to do */ }
2244 POST_SYSCALL(_lwp_exit)(long long res) { /* Nothing to do */ }
2245 PRE_SYSCALL(_lwp_self)(void) { /* Nothing to do */ }
2246 POST_SYSCALL(_lwp_self)(long long res) { /* Nothing to do */ }
2247 PRE_SYSCALL(_lwp_wait)(long long wait_for_, void *departed_) {
2250 POST_SYSCALL(_lwp_wait)(long long res, long long wait_for_, void *departed_) {
2253 PRE_SYSCALL(_lwp_suspend)(long long target_) { /* Nothing to do */ }
2254 POST_SYSCALL(_lwp_suspend)(long long res, long long target_) {
2257 PRE_SYSCALL(_lwp_continue)(long long target_) { /* Nothing to do */ }
2258 POST_SYSCALL(_lwp_continue)(long long res, long long target_) {
2261 PRE_SYSCALL(_lwp_wakeup)(long long target_) { /* Nothing to do */ }
2262 POST_SYSCALL(_lwp_wakeup)(long long res, long long target_) {
2265 PRE_SYSCALL(_lwp_getprivate)(void) { /* Nothing to do */ }
2266 POST_SYSCALL(_lwp_getprivate)(long long res) { /* Nothing to do */ }
2267 PRE_SYSCALL(_lwp_setprivate)(void *ptr_) { /* Nothing to do */ }
2268 POST_SYSCALL(_lwp_setprivate)(long long res, void *ptr_) { /* Nothing to do */ }
2269 PRE_SYSCALL(_lwp_kill)(long long target_, long long signo_) {
2272 POST_SYSCALL(_lwp_kill)(long long res, long long target_, long long signo_) {
2275 PRE_SYSCALL(_lwp_detach)(long long target_) { /* Nothing to do */ }
2276 POST_SYSCALL(_lwp_detach)(long long res, long long target_) {
2279 PRE_SYSCALL(compat_50__lwp_park)
2280 (void *ts_, long long unpark_, void *hint_, void *unparkhint_) {
2283 POST_SYSCALL(compat_50__lwp_park)
2284 (long long res, void *ts_, long long unpark_, void *hint_, void *unparkhint_) {
2287 PRE_SYSCALL(_lwp_unpark)(long long target_, void *hint_) { /* Nothing to do */ }
2288 POST_SYSCALL(_lwp_unpark)(long long res, long long target_, void *hint_) {
2291 PRE_SYSCALL(_lwp_unpark_all)(void *targets_, long long ntargets_, void *hint_) {
2293 PRE_READ(targets_, ntargets_ * sizeof(__sanitizer_lwpid_t));
2296 POST_SYSCALL(_lwp_unpark_all)
2297 (long long res, void *targets_, long long ntargets_, void *hint_) {}
2298 PRE_SYSCALL(_lwp_setname)(long long target_, void *name_) {
2299 const char *name = (const char *)name_;
2301 PRE_READ(name, __sanitizer::internal_strlen(name) + 1);
2304 POST_SYSCALL(_lwp_setname)(long long res, long long target_, void *name_) {
2305 const char *name = (const char *)name_;
2307 POST_READ(name, __sanitizer::internal_strlen(name) + 1);
2310 PRE_SYSCALL(_lwp_getname)(long long target_, void *name_, long long len_) {
2313 POST_SYSCALL(_lwp_getname)
2314 (long long res, long long target_, void *name_, long long len_) {
2317 PRE_SYSCALL(_lwp_ctl)(long long features_, void **address_) {
2320 POST_SYSCALL(_lwp_ctl)(long long res, long long features_, void **address_) {
2323 /* syscall 326 has been skipped */
2324 /* syscall 327 has been skipped */
2325 /* syscall 328 has been skipped */
2326 /* syscall 329 has been skipped */
2327 PRE_SYSCALL(compat_60_sa_register)
2328 (void *newv_, void **oldv_, long long flags_, long long stackinfo_offset_) {
2331 POST_SYSCALL(compat_60_sa_register)
2332 (long long res, void *newv_, void **oldv_, long long flags_,
2333 long long stackinfo_offset_) {
2336 PRE_SYSCALL(compat_60_sa_stacks)(long long num_, void *stacks_) { /* TODO */ }
2337 POST_SYSCALL(compat_60_sa_stacks)
2338 (long long res, long long num_, void *stacks_) {
2341 PRE_SYSCALL(compat_60_sa_enable)(void) { /* TODO */ }
2342 POST_SYSCALL(compat_60_sa_enable)(long long res) { /* TODO */ }
2343 PRE_SYSCALL(compat_60_sa_setconcurrency)(long long concurrency_) { /* TODO */ }
2344 POST_SYSCALL(compat_60_sa_setconcurrency)
2345 (long long res, long long concurrency_) {
2348 PRE_SYSCALL(compat_60_sa_yield)(void) { /* TODO */ }
2349 POST_SYSCALL(compat_60_sa_yield)(long long res) { /* TODO */ }
2350 PRE_SYSCALL(compat_60_sa_preempt)(long long sa_id_) { /* TODO */ }
2351 POST_SYSCALL(compat_60_sa_preempt)(long long res, long long sa_id_) {
2354 /* syscall 336 has been skipped */
2355 /* syscall 337 has been skipped */
2356 /* syscall 338 has been skipped */
2357 /* syscall 339 has been skipped */
2358 PRE_SYSCALL(__sigaction_sigtramp)
2359 (long long signum_, void *nsa_, void *osa_, void *tramp_, long long vers_) {
2361 PRE_READ(nsa_, sizeof(__sanitizer_sigaction));
2364 POST_SYSCALL(__sigaction_sigtramp)
2365 (long long res, long long signum_, void *nsa_, void *osa_, void *tramp_,
2368 PRE_READ(nsa_, sizeof(__sanitizer_sigaction));
2371 /* syscall 341 has been skipped */
2372 /* syscall 342 has been skipped */
2373 PRE_SYSCALL(rasctl)(void *addr_, long long len_, long long op_) {
2376 POST_SYSCALL(rasctl)
2377 (long long res, void *addr_, long long len_, long long op_) {
2380 PRE_SYSCALL(kqueue)(void) { /* Nothing to do */ }
2381 POST_SYSCALL(kqueue)(long long res) { /* Nothing to do */ }
2382 PRE_SYSCALL(compat_50_kevent)
2383 (long long fd_, void *changelist_, long long nchanges_, void *eventlist_,
2384 long long nevents_, void *timeout_) {
2387 POST_SYSCALL(compat_50_kevent)
2388 (long long res, long long fd_, void *changelist_, long long nchanges_,
2389 void *eventlist_, long long nevents_, void *timeout_) {
2392 PRE_SYSCALL(_sched_setparam)
2393 (long long pid_, long long lid_, long long policy_, void *params_) {
2395 PRE_READ(params_, struct_sched_param_sz);
2398 POST_SYSCALL(_sched_setparam)
2399 (long long res, long long pid_, long long lid_, long long policy_,
2402 PRE_READ(params_, struct_sched_param_sz);
2405 PRE_SYSCALL(_sched_getparam)
2406 (long long pid_, long long lid_, void *policy_, void *params_) {
2409 POST_SYSCALL(_sched_getparam)
2410 (long long res, long long pid_, long long lid_, void *policy_, void *params_) {
2413 PRE_SYSCALL(_sched_setaffinity)
2414 (long long pid_, long long lid_, long long size_, void *cpuset_) {
2416 PRE_READ(cpuset_, size_);
2419 POST_SYSCALL(_sched_setaffinity)
2420 (long long res, long long pid_, long long lid_, long long size_,
2423 PRE_READ(cpuset_, size_);
2426 PRE_SYSCALL(_sched_getaffinity)
2427 (long long pid_, long long lid_, long long size_, void *cpuset_) {
2430 POST_SYSCALL(_sched_getaffinity)
2431 (long long res, long long pid_, long long lid_, long long size_,
2435 PRE_SYSCALL(sched_yield)(void) { /* Nothing to do */ }
2436 POST_SYSCALL(sched_yield)(long long res) { /* Nothing to do */ }
2437 PRE_SYSCALL(_sched_protect)(long long priority_) { /* Nothing to do */ }
2438 POST_SYSCALL(_sched_protect)(long long res, long long priority_) {
2441 /* syscall 352 has been skipped */
2442 /* syscall 353 has been skipped */
2443 PRE_SYSCALL(fsync_range)
2444 (long long fd_, long long flags_, long long start_, long long length_) {
2447 POST_SYSCALL(fsync_range)
2448 (long long res, long long fd_, long long flags_, long long start_,
2449 long long length_) {
2452 PRE_SYSCALL(uuidgen)(void *store_, long long count_) { /* Nothing to do */ }
2453 POST_SYSCALL(uuidgen)(long long res, void *store_, long long count_) {
2456 PRE_SYSCALL(compat_90_getvfsstat)
2457 (void *buf_, long long bufsize_, long long flags_) {
2460 POST_SYSCALL(compat_90_getvfsstat)
2461 (long long res, void *buf_, long long bufsize_, long long flags_) {
2464 PRE_SYSCALL(compat_90_statvfs1)(void *path_, void *buf_, long long flags_) {
2465 const char *path = (const char *)path_;
2467 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2470 POST_SYSCALL(compat_90_statvfs1)
2471 (long long res, void *path_, void *buf_, long long flags_) {
2472 const char *path = (const char *)path_;
2474 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2477 PRE_SYSCALL(compat_90_fstatvfs1)(long long fd_, void *buf_, long long flags_) {
2480 POST_SYSCALL(compat_90_fstatvfs1)
2481 (long long res, long long fd_, void *buf_, long long flags_) {
2484 PRE_SYSCALL(compat_30_fhstatvfs1)(void *fhp_, void *buf_, long long flags_) {
2487 POST_SYSCALL(compat_30_fhstatvfs1)
2488 (long long res, void *fhp_, void *buf_, long long flags_) {
2491 PRE_SYSCALL(extattrctl)
2492 (void *path_, long long cmd_, void *filename_, long long attrnamespace_,
2494 const char *path = (const char *)path_;
2496 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2499 POST_SYSCALL(extattrctl)
2500 (long long res, void *path_, long long cmd_, void *filename_,
2501 long long attrnamespace_, void *attrname_) {
2502 const char *path = (const char *)path_;
2504 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2507 PRE_SYSCALL(extattr_set_file)
2508 (void *path_, long long attrnamespace_, void *attrname_, void *data_,
2509 long long nbytes_) {
2510 const char *path = (const char *)path_;
2512 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2515 POST_SYSCALL(extattr_set_file)
2516 (long long res, void *path_, long long attrnamespace_, void *attrname_,
2517 void *data_, long long nbytes_) {
2518 const char *path = (const char *)path_;
2520 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2523 PRE_SYSCALL(extattr_get_file)
2524 (void *path_, long long attrnamespace_, void *attrname_, void *data_,
2525 long long nbytes_) {
2526 const char *path = (const char *)path_;
2528 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2531 POST_SYSCALL(extattr_get_file)
2532 (long long res, void *path_, long long attrnamespace_, void *attrname_,
2533 void *data_, long long nbytes_) {
2534 const char *path = (const char *)path_;
2536 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2539 PRE_SYSCALL(extattr_delete_file)
2540 (void *path_, long long attrnamespace_, void *attrname_) {
2541 const char *path = (const char *)path_;
2543 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2546 POST_SYSCALL(extattr_delete_file)
2547 (long long res, void *path_, long long attrnamespace_, void *attrname_) {
2548 const char *path = (const char *)path_;
2550 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2553 PRE_SYSCALL(extattr_set_fd)
2554 (long long fd_, long long attrnamespace_, void *attrname_, void *data_,
2555 long long nbytes_) {
2558 POST_SYSCALL(extattr_set_fd)
2559 (long long res, long long fd_, long long attrnamespace_, void *attrname_,
2560 void *data_, long long nbytes_) {
2563 PRE_SYSCALL(extattr_get_fd)
2564 (long long fd_, long long attrnamespace_, void *attrname_, void *data_,
2565 long long nbytes_) {
2568 POST_SYSCALL(extattr_get_fd)
2569 (long long res, long long fd_, long long attrnamespace_, void *attrname_,
2570 void *data_, long long nbytes_) {
2573 PRE_SYSCALL(extattr_delete_fd)
2574 (long long fd_, long long attrnamespace_, void *attrname_) {
2577 POST_SYSCALL(extattr_delete_fd)
2578 (long long res, long long fd_, long long attrnamespace_, void *attrname_) {
2581 PRE_SYSCALL(extattr_set_link)
2582 (void *path_, long long attrnamespace_, void *attrname_, void *data_,
2583 long long nbytes_) {
2584 const char *path = (const char *)path_;
2586 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2589 POST_SYSCALL(extattr_set_link)
2590 (long long res, void *path_, long long attrnamespace_, void *attrname_,
2591 void *data_, long long nbytes_) {
2592 const char *path = (const char *)path_;
2594 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2597 PRE_SYSCALL(extattr_get_link)
2598 (void *path_, long long attrnamespace_, void *attrname_, void *data_,
2599 long long nbytes_) {
2600 const char *path = (const char *)path_;
2602 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2605 POST_SYSCALL(extattr_get_link)
2606 (long long res, void *path_, long long attrnamespace_, void *attrname_,
2607 void *data_, long long nbytes_) {
2608 const char *path = (const char *)path_;
2610 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2613 PRE_SYSCALL(extattr_delete_link)
2614 (void *path_, long long attrnamespace_, void *attrname_) {
2615 const char *path = (const char *)path_;
2617 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2620 POST_SYSCALL(extattr_delete_link)
2621 (long long res, void *path_, long long attrnamespace_, void *attrname_) {
2622 const char *path = (const char *)path_;
2624 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2627 PRE_SYSCALL(extattr_list_fd)
2628 (long long fd_, long long attrnamespace_, void *data_, long long nbytes_) {
2631 POST_SYSCALL(extattr_list_fd)
2632 (long long res, long long fd_, long long attrnamespace_, void *data_,
2633 long long nbytes_) {
2636 PRE_SYSCALL(extattr_list_file)
2637 (void *path_, long long attrnamespace_, void *data_, long long nbytes_) {
2638 const char *path = (const char *)path_;
2640 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2643 POST_SYSCALL(extattr_list_file)
2644 (long long res, void *path_, long long attrnamespace_, void *data_,
2645 long long nbytes_) {
2646 const char *path = (const char *)path_;
2648 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2651 PRE_SYSCALL(extattr_list_link)
2652 (void *path_, long long attrnamespace_, void *data_, long long nbytes_) {
2653 const char *path = (const char *)path_;
2655 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2658 POST_SYSCALL(extattr_list_link)
2659 (long long res, void *path_, long long attrnamespace_, void *data_,
2660 long long nbytes_) {
2661 const char *path = (const char *)path_;
2663 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2666 PRE_SYSCALL(compat_50_pselect)
2667 (long long nd_, void *in_, void *ou_, void *ex_, void *ts_, void *mask_) {
2670 POST_SYSCALL(compat_50_pselect)
2671 (long long res, long long nd_, void *in_, void *ou_, void *ex_, void *ts_,
2675 PRE_SYSCALL(compat_50_pollts)
2676 (void *fds_, long long nfds_, void *ts_, void *mask_) {
2679 POST_SYSCALL(compat_50_pollts)
2680 (long long res, void *fds_, long long nfds_, void *ts_, void *mask_) {
2683 PRE_SYSCALL(setxattr)
2684 (void *path_, void *name_, void *value_, long long size_, long long flags_) {
2685 const char *path = (const char *)path_;
2687 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2690 POST_SYSCALL(setxattr)
2691 (long long res, void *path_, void *name_, void *value_, long long size_,
2693 const char *path = (const char *)path_;
2695 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2698 PRE_SYSCALL(lsetxattr)
2699 (void *path_, void *name_, void *value_, long long size_, long long flags_) {
2700 const char *path = (const char *)path_;
2702 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2705 POST_SYSCALL(lsetxattr)
2706 (long long res, void *path_, void *name_, void *value_, long long size_,
2708 const char *path = (const char *)path_;
2710 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2713 PRE_SYSCALL(fsetxattr)
2714 (long long fd_, void *name_, void *value_, long long size_, long long flags_) {
2717 POST_SYSCALL(fsetxattr)
2718 (long long res, long long fd_, void *name_, void *value_, long long size_,
2722 PRE_SYSCALL(getxattr)(void *path_, void *name_, void *value_, long long size_) {
2723 const char *path = (const char *)path_;
2725 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2728 POST_SYSCALL(getxattr)
2729 (long long res, void *path_, void *name_, void *value_, long long size_) {
2730 const char *path = (const char *)path_;
2732 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2735 PRE_SYSCALL(lgetxattr)
2736 (void *path_, void *name_, void *value_, long long size_) {
2737 const char *path = (const char *)path_;
2739 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2742 POST_SYSCALL(lgetxattr)
2743 (long long res, void *path_, void *name_, void *value_, long long size_) {
2744 const char *path = (const char *)path_;
2746 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2749 PRE_SYSCALL(fgetxattr)
2750 (long long fd_, void *name_, void *value_, long long size_) {
2753 POST_SYSCALL(fgetxattr)
2754 (long long res, long long fd_, void *name_, void *value_, long long size_) {
2757 PRE_SYSCALL(listxattr)(void *path_, void *list_, long long size_) {
2758 const char *path = (const char *)path_;
2760 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2763 POST_SYSCALL(listxattr)
2764 (long long res, void *path_, void *list_, long long size_) {
2765 const char *path = (const char *)path_;
2767 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2770 PRE_SYSCALL(llistxattr)(void *path_, void *list_, long long size_) {
2771 const char *path = (const char *)path_;
2773 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2776 POST_SYSCALL(llistxattr)
2777 (long long res, void *path_, void *list_, long long size_) {
2778 const char *path = (const char *)path_;
2780 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2783 PRE_SYSCALL(flistxattr)(long long fd_, void *list_, long long size_) {
2786 POST_SYSCALL(flistxattr)
2787 (long long res, long long fd_, void *list_, long long size_) {
2790 PRE_SYSCALL(removexattr)(void *path_, void *name_) {
2791 const char *path = (const char *)path_;
2793 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2796 POST_SYSCALL(removexattr)(long long res, void *path_, void *name_) {
2797 const char *path = (const char *)path_;
2799 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2802 PRE_SYSCALL(lremovexattr)(void *path_, void *name_) {
2803 const char *path = (const char *)path_;
2805 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2808 POST_SYSCALL(lremovexattr)(long long res, void *path_, void *name_) {
2809 const char *path = (const char *)path_;
2811 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2814 PRE_SYSCALL(fremovexattr)(long long fd_, void *name_) { /* TODO */ }
2815 POST_SYSCALL(fremovexattr)(long long res, long long fd_, void *name_) {
2818 PRE_SYSCALL(compat_50___stat30)(void *path_, void *ub_) { /* TODO */ }
2819 POST_SYSCALL(compat_50___stat30)(long long res, void *path_, void *ub_) {
2822 PRE_SYSCALL(compat_50___fstat30)(long long fd_, void *sb_) { /* TODO */ }
2823 POST_SYSCALL(compat_50___fstat30)(long long res, long long fd_, void *sb_) {
2826 PRE_SYSCALL(compat_50___lstat30)(void *path_, void *ub_) { /* TODO */ }
2827 POST_SYSCALL(compat_50___lstat30)(long long res, void *path_, void *ub_) {
2830 PRE_SYSCALL(__getdents30)(long long fd_, void *buf_, long long count_) {
2833 POST_SYSCALL(__getdents30)
2834 (long long res, long long fd_, void *buf_, long long count_) {
2837 PRE_SYSCALL(posix_fadvise)(long long) { /* Nothing to do */ }
2838 POST_SYSCALL(posix_fadvise)(long long res, long long) { /* Nothing to do */ }
2839 PRE_SYSCALL(compat_30___fhstat30)(void *fhp_, void *sb_) { /* TODO */ }
2840 POST_SYSCALL(compat_30___fhstat30)(long long res, void *fhp_, void *sb_) {
2843 PRE_SYSCALL(compat_50___ntp_gettime30)(void *ntvp_) { /* TODO */ }
2844 POST_SYSCALL(compat_50___ntp_gettime30)(long long res, void *ntvp_) {
2847 PRE_SYSCALL(__socket30)
2848 (long long domain_, long long type_, long long protocol_) {
2851 POST_SYSCALL(__socket30)
2852 (long long res, long long domain_, long long type_, long long protocol_) {
2855 PRE_SYSCALL(__getfh30)(void *fname_, void *fhp_, void *fh_size_) {
2856 const char *fname = (const char *)fname_;
2858 PRE_READ(fname, __sanitizer::internal_strlen(fname) + 1);
2861 POST_SYSCALL(__getfh30)
2862 (long long res, void *fname_, void *fhp_, void *fh_size_) {
2863 const char *fname = (const char *)fname_;
2866 POST_READ(fname, __sanitizer::internal_strlen(fname) + 1);
2870 PRE_SYSCALL(__fhopen40)(void *fhp_, long long fh_size_, long long flags_) {
2872 PRE_READ(fhp_, fh_size_);
2875 POST_SYSCALL(__fhopen40)
2876 (long long res, void *fhp_, long long fh_size_, long long flags_) {}
2877 PRE_SYSCALL(compat_90_fhstatvfs1)
2878 (void *fhp_, long long fh_size_, void *buf_, long long flags_) {
2880 PRE_READ(fhp_, fh_size_);
2883 POST_SYSCALL(compat_90_fhstatvfs1)
2884 (long long res, void *fhp_, long long fh_size_, void *buf_, long long flags_) {}
2885 PRE_SYSCALL(compat_50___fhstat40)(void *fhp_, long long fh_size_, void *sb_) {
2887 PRE_READ(fhp_, fh_size_);
2890 POST_SYSCALL(compat_50___fhstat40)
2891 (long long res, void *fhp_, long long fh_size_, void *sb_) {}
2892 PRE_SYSCALL(aio_cancel)(long long fildes_, void *aiocbp_) {
2894 PRE_READ(aiocbp_, sizeof(struct __sanitizer_aiocb));
2897 POST_SYSCALL(aio_cancel)(long long res, long long fildes_, void *aiocbp_) {}
2898 PRE_SYSCALL(aio_error)(void *aiocbp_) {
2900 PRE_READ(aiocbp_, sizeof(struct __sanitizer_aiocb));
2903 POST_SYSCALL(aio_error)(long long res, void *aiocbp_) {}
2904 PRE_SYSCALL(aio_fsync)(long long op_, void *aiocbp_) {
2906 PRE_READ(aiocbp_, sizeof(struct __sanitizer_aiocb));
2909 POST_SYSCALL(aio_fsync)(long long res, long long op_, void *aiocbp_) {}
2910 PRE_SYSCALL(aio_read)(void *aiocbp_) {
2912 PRE_READ(aiocbp_, sizeof(struct __sanitizer_aiocb));
2915 POST_SYSCALL(aio_read)(long long res, void *aiocbp_) {}
2916 PRE_SYSCALL(aio_return)(void *aiocbp_) {
2918 PRE_READ(aiocbp_, sizeof(struct __sanitizer_aiocb));
2921 POST_SYSCALL(aio_return)(long long res, void *aiocbp_) {}
2922 PRE_SYSCALL(compat_50_aio_suspend)
2923 (void *list_, long long nent_, void *timeout_) {
2926 POST_SYSCALL(compat_50_aio_suspend)
2927 (long long res, void *list_, long long nent_, void *timeout_) {
2930 PRE_SYSCALL(aio_write)(void *aiocbp_) {
2932 PRE_READ(aiocbp_, sizeof(struct __sanitizer_aiocb));
2935 POST_SYSCALL(aio_write)(long long res, void *aiocbp_) {}
2936 PRE_SYSCALL(lio_listio)
2937 (long long mode_, void *list_, long long nent_, void *sig_) {
2940 POST_SYSCALL(lio_listio)
2941 (long long res, long long mode_, void *list_, long long nent_, void *sig_) {
2944 /* syscall 407 has been skipped */
2945 /* syscall 408 has been skipped */
2946 /* syscall 409 has been skipped */
2947 PRE_SYSCALL(__mount50)
2948 (void *type_, void *path_, long long flags_, void *data_, long long data_len_) {
2949 const char *type = (const char *)type_;
2950 const char *path = (const char *)path_;
2952 PRE_READ(type, __sanitizer::internal_strlen(type) + 1);
2955 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
2958 PRE_READ(data_, data_len_);
2961 POST_SYSCALL(__mount50)
2962 (long long res, void *type_, void *path_, long long flags_, void *data_,
2963 long long data_len_) {
2964 const char *type = (const char *)type_;
2965 const char *path = (const char *)path_;
2967 POST_READ(type, __sanitizer::internal_strlen(type) + 1);
2970 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
2973 POST_READ(data_, data_len_);
2977 (void *old_address_, long long old_size_, void *new_address_,
2978 long long new_size_, long long flags_) {
2981 POST_SYSCALL(mremap)
2982 (long long res, void *old_address_, long long old_size_, void *new_address_,
2983 long long new_size_, long long flags_) {
2986 PRE_SYSCALL(pset_create)(void *psid_) { /* Nothing to do */ }
2987 POST_SYSCALL(pset_create)(long long res, void *psid_) { /* Nothing to do */ }
2988 PRE_SYSCALL(pset_destroy)(long long psid_) { /* Nothing to do */ }
2989 POST_SYSCALL(pset_destroy)(long long res, long long psid_) {
2992 PRE_SYSCALL(pset_assign)(long long psid_, long long cpuid_, void *opsid_) {
2995 POST_SYSCALL(pset_assign)
2996 (long long res, long long psid_, long long cpuid_, void *opsid_) {
2999 PRE_SYSCALL(_pset_bind)
3000 (long long idtype_, long long first_id_, long long second_id_, long long psid_,
3004 POST_SYSCALL(_pset_bind)
3005 (long long res, long long idtype_, long long first_id_, long long second_id_,
3006 long long psid_, void *opsid_) {
3009 PRE_SYSCALL(__posix_fadvise50)
3010 (long long fd_, long long PAD_, long long offset_, long long len_,
3011 long long advice_) {
3014 POST_SYSCALL(__posix_fadvise50)
3015 (long long res, long long fd_, long long PAD_, long long offset_,
3016 long long len_, long long advice_) {
3019 PRE_SYSCALL(__select50)
3020 (long long nd_, void *in_, void *ou_, void *ex_, void *tv_) {
3023 POST_SYSCALL(__select50)
3024 (long long res, long long nd_, void *in_, void *ou_, void *ex_, void *tv_) {
3027 PRE_SYSCALL(__gettimeofday50)(void *tp_, void *tzp_) { /* Nothing to do */ }
3028 POST_SYSCALL(__gettimeofday50)(long long res, void *tp_, void *tzp_) {
3031 PRE_SYSCALL(__settimeofday50)(void *tv_, void *tzp_) {
3033 PRE_READ(tv_, timeval_sz);
3036 PRE_READ(tzp_, struct_timezone_sz);
3039 POST_SYSCALL(__settimeofday50)(long long res, void *tv_, void *tzp_) {}
3040 PRE_SYSCALL(__utimes50)(void *path_, void *tptr_) {
3041 struct __sanitizer_timespec **tptr = (struct __sanitizer_timespec **)tptr_;
3042 const char *path = (const char *)path_;
3044 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
3047 PRE_READ(tptr[0], struct_timespec_sz);
3048 PRE_READ(tptr[1], struct_timespec_sz);
3051 POST_SYSCALL(__utimes50)(long long res, void *path_, void *tptr_) {}
3052 PRE_SYSCALL(__adjtime50)(void *delta_, void *olddelta_) {
3054 PRE_READ(delta_, timeval_sz);
3057 POST_SYSCALL(__adjtime50)(long long res, void *delta_, void *olddelta_) {}
3058 PRE_SYSCALL(__lfs_segwait50)(void *fsidp_, void *tv_) { /* TODO */ }
3059 POST_SYSCALL(__lfs_segwait50)(long long res, void *fsidp_, void *tv_) {
3062 PRE_SYSCALL(__futimes50)(long long fd_, void *tptr_) {
3063 struct __sanitizer_timespec **tptr = (struct __sanitizer_timespec **)tptr_;
3065 PRE_READ(tptr[0], struct_timespec_sz);
3066 PRE_READ(tptr[1], struct_timespec_sz);
3069 POST_SYSCALL(__futimes50)(long long res, long long fd_, void *tptr_) {}
3070 PRE_SYSCALL(__lutimes50)(void *path_, void *tptr_) {
3071 struct __sanitizer_timespec **tptr = (struct __sanitizer_timespec **)tptr_;
3072 const char *path = (const char *)path_;
3074 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
3077 PRE_READ(tptr[0], struct_timespec_sz);
3078 PRE_READ(tptr[1], struct_timespec_sz);
3081 POST_SYSCALL(__lutimes50)(long long res, void *path_, void *tptr_) {
3082 struct __sanitizer_timespec **tptr = (struct __sanitizer_timespec **)tptr_;
3083 const char *path = (const char *)path_;
3085 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
3088 POST_READ(tptr[0], struct_timespec_sz);
3089 POST_READ(tptr[1], struct_timespec_sz);
3092 PRE_SYSCALL(__setitimer50)(long long which_, void *itv_, void *oitv_) {
3093 struct __sanitizer_itimerval *itv = (struct __sanitizer_itimerval *)itv_;
3095 PRE_READ(&itv->it_interval.tv_sec, sizeof(__sanitizer_time_t));
3096 PRE_READ(&itv->it_interval.tv_usec, sizeof(__sanitizer_suseconds_t));
3097 PRE_READ(&itv->it_value.tv_sec, sizeof(__sanitizer_time_t));
3098 PRE_READ(&itv->it_value.tv_usec, sizeof(__sanitizer_suseconds_t));
3101 POST_SYSCALL(__setitimer50)
3102 (long long res, long long which_, void *itv_, void *oitv_) {}
3103 PRE_SYSCALL(__getitimer50)(long long which_, void *itv_) { /* Nothing to do */ }
3104 POST_SYSCALL(__getitimer50)(long long res, long long which_, void *itv_) {
3107 PRE_SYSCALL(__clock_gettime50)(long long clock_id_, void *tp_) {
3110 POST_SYSCALL(__clock_gettime50)(long long res, long long clock_id_, void *tp_) {
3113 PRE_SYSCALL(__clock_settime50)(long long clock_id_, void *tp_) {
3115 PRE_READ(tp_, struct_timespec_sz);
3118 POST_SYSCALL(__clock_settime50)
3119 (long long res, long long clock_id_, void *tp_) {}
3120 PRE_SYSCALL(__clock_getres50)(long long clock_id_, void *tp_) {
3123 POST_SYSCALL(__clock_getres50)(long long res, long long clock_id_, void *tp_) {
3126 PRE_SYSCALL(__nanosleep50)(void *rqtp_, void *rmtp_) {
3128 PRE_READ(rqtp_, struct_timespec_sz);
3131 POST_SYSCALL(__nanosleep50)(long long res, void *rqtp_, void *rmtp_) {}
3132 PRE_SYSCALL(____sigtimedwait50)(void *set_, void *info_, void *timeout_) {
3134 PRE_READ(set_, sizeof(__sanitizer_sigset_t));
3137 PRE_READ(timeout_, struct_timespec_sz);
3140 POST_SYSCALL(____sigtimedwait50)
3141 (long long res, void *set_, void *info_, void *timeout_) {}
3142 PRE_SYSCALL(__mq_timedsend50)
3143 (long long mqdes_, void *msg_ptr_, long long msg_len_, long long msg_prio_,
3144 void *abs_timeout_) {
3146 PRE_READ(msg_ptr_, msg_len_);
3149 PRE_READ(abs_timeout_, struct_timespec_sz);
3152 POST_SYSCALL(__mq_timedsend50)
3153 (long long res, long long mqdes_, void *msg_ptr_, long long msg_len_,
3154 long long msg_prio_, void *abs_timeout_) {}
3155 PRE_SYSCALL(__mq_timedreceive50)
3156 (long long mqdes_, void *msg_ptr_, long long msg_len_, void *msg_prio_,
3157 void *abs_timeout_) {
3159 PRE_READ(msg_ptr_, msg_len_);
3162 PRE_READ(abs_timeout_, struct_timespec_sz);
3165 POST_SYSCALL(__mq_timedreceive50)
3166 (long long res, long long mqdes_, void *msg_ptr_, long long msg_len_,
3167 void *msg_prio_, void *abs_timeout_) {}
3168 PRE_SYSCALL(compat_60__lwp_park)
3169 (void *ts_, long long unpark_, void *hint_, void *unparkhint_) {
3172 POST_SYSCALL(compat_60__lwp_park)
3173 (long long res, void *ts_, long long unpark_, void *hint_, void *unparkhint_) {
3176 PRE_SYSCALL(__kevent50)
3177 (long long fd_, void *changelist_, long long nchanges_, void *eventlist_,
3178 long long nevents_, void *timeout_) {
3180 PRE_READ(changelist_, nchanges_ * struct_kevent_sz);
3183 PRE_READ(timeout_, struct_timespec_sz);
3186 POST_SYSCALL(__kevent50)
3187 (long long res, long long fd_, void *changelist_, long long nchanges_,
3188 void *eventlist_, long long nevents_, void *timeout_) {}
3189 PRE_SYSCALL(__pselect50)
3190 (long long nd_, void *in_, void *ou_, void *ex_, void *ts_, void *mask_) {
3192 PRE_READ(ts_, struct_timespec_sz);
3195 PRE_READ(mask_, sizeof(struct __sanitizer_sigset_t));
3198 POST_SYSCALL(__pselect50)
3199 (long long res, long long nd_, void *in_, void *ou_, void *ex_, void *ts_,
3201 PRE_SYSCALL(__pollts50)(void *fds_, long long nfds_, void *ts_, void *mask_) {
3203 PRE_READ(ts_, struct_timespec_sz);
3206 PRE_READ(mask_, sizeof(struct __sanitizer_sigset_t));
3209 POST_SYSCALL(__pollts50)
3210 (long long res, void *fds_, long long nfds_, void *ts_, void *mask_) {}
3211 PRE_SYSCALL(__aio_suspend50)(void *list_, long long nent_, void *timeout_) {
3213 const struct aiocb *const *list = (const struct aiocb *const *)list_;
3215 for (i = 0; i < nent_; i++) {
3217 PRE_READ(list[i], sizeof(struct __sanitizer_aiocb));
3222 PRE_READ(timeout_, struct_timespec_sz);
3225 POST_SYSCALL(__aio_suspend50)
3226 (long long res, void *list_, long long nent_, void *timeout_) {}
3227 PRE_SYSCALL(__stat50)(void *path_, void *ub_) {
3228 const char *path = (const char *)path_;
3230 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
3233 POST_SYSCALL(__stat50)(long long res, void *path_, void *ub_) {
3234 const char *path = (const char *)path_;
3237 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
3241 PRE_SYSCALL(__fstat50)(long long fd_, void *sb_) { /* Nothing to do */ }
3242 POST_SYSCALL(__fstat50)(long long res, long long fd_, void *sb_) {
3245 PRE_SYSCALL(__lstat50)(void *path_, void *ub_) {
3246 const char *path = (const char *)path_;
3248 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
3251 POST_SYSCALL(__lstat50)(long long res, void *path_, void *ub_) {
3252 const char *path = (const char *)path_;
3255 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
3259 PRE_SYSCALL(____semctl50)
3260 (long long semid_, long long semnum_, long long cmd_, void *arg_) {
3263 POST_SYSCALL(____semctl50)
3264 (long long res, long long semid_, long long semnum_, long long cmd_,
3268 PRE_SYSCALL(__shmctl50)(long long shmid_, long long cmd_, void *buf_) {
3271 POST_SYSCALL(__shmctl50)
3272 (long long res, long long shmid_, long long cmd_, void *buf_) {
3275 PRE_SYSCALL(__msgctl50)(long long msqid_, long long cmd_, void *buf_) {
3278 POST_SYSCALL(__msgctl50)
3279 (long long res, long long msqid_, long long cmd_, void *buf_) {
3282 PRE_SYSCALL(__getrusage50)(long long who_, void *rusage_) {
3285 POST_SYSCALL(__getrusage50)(long long res, long long who_, void *rusage_) {
3288 PRE_SYSCALL(__timer_settime50)
3289 (long long timerid_, long long flags_, void *value_, void *ovalue_) {
3290 struct __sanitizer_itimerval *value = (struct __sanitizer_itimerval *)value_;
3292 PRE_READ(&value->it_interval.tv_sec, sizeof(__sanitizer_time_t));
3293 PRE_READ(&value->it_interval.tv_usec, sizeof(__sanitizer_suseconds_t));
3294 PRE_READ(&value->it_value.tv_sec, sizeof(__sanitizer_time_t));
3295 PRE_READ(&value->it_value.tv_usec, sizeof(__sanitizer_suseconds_t));
3298 POST_SYSCALL(__timer_settime50)
3299 (long long res, long long timerid_, long long flags_, void *value_,
3301 struct __sanitizer_itimerval *value = (struct __sanitizer_itimerval *)value_;
3304 POST_READ(&value->it_interval.tv_sec, sizeof(__sanitizer_time_t));
3305 POST_READ(&value->it_interval.tv_usec, sizeof(__sanitizer_suseconds_t));
3306 POST_READ(&value->it_value.tv_sec, sizeof(__sanitizer_time_t));
3307 POST_READ(&value->it_value.tv_usec, sizeof(__sanitizer_suseconds_t));
3311 PRE_SYSCALL(__timer_gettime50)(long long timerid_, void *value_) {
3314 POST_SYSCALL(__timer_gettime50)
3315 (long long res, long long timerid_, void *value_) {
3318 #if defined(NTP) || !defined(_KERNEL_OPT)
3319 PRE_SYSCALL(__ntp_gettime50)(void *ntvp_) { /* Nothing to do */ }
3320 POST_SYSCALL(__ntp_gettime50)(long long res, void *ntvp_) {
3324 /* syscall 448 has been skipped */
3326 PRE_SYSCALL(__wait450)
3327 (long long pid_, void *status_, long long options_, void *rusage_) {
3330 POST_SYSCALL(__wait450)
3331 (long long res, long long pid_, void *status_, long long options_,
3335 PRE_SYSCALL(__mknod50)(void *path_, long long mode_, long long dev_) {
3336 const char *path = (const char *)path_;
3338 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
3341 POST_SYSCALL(__mknod50)
3342 (long long res, void *path_, long long mode_, long long dev_) {
3343 const char *path = (const char *)path_;
3346 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
3350 PRE_SYSCALL(__fhstat50)(void *fhp_, long long fh_size_, void *sb_) {
3352 PRE_READ(fhp_, fh_size_);
3355 POST_SYSCALL(__fhstat50)
3356 (long long res, void *fhp_, long long fh_size_, void *sb_) {
3359 POST_READ(fhp_, fh_size_);
3363 /* syscall 452 has been skipped */
3364 PRE_SYSCALL(pipe2)(void *fildes_, long long flags_) { /* Nothing to do */ }
3365 POST_SYSCALL(pipe2)(long long res, void *fildes_, long long flags_) {
3368 PRE_SYSCALL(dup3)(long long from_, long long to_, long long flags_) {
3372 (long long res, long long from_, long long to_, long long flags_) {
3375 PRE_SYSCALL(kqueue1)(long long flags_) { /* Nothing to do */ }
3376 POST_SYSCALL(kqueue1)(long long res, long long flags_) { /* Nothing to do */ }
3377 PRE_SYSCALL(paccept)
3378 (long long s_, void *name_, void *anamelen_, void *mask_, long long flags_) {
3380 PRE_READ(mask_, sizeof(__sanitizer_sigset_t));
3383 POST_SYSCALL(paccept)
3384 (long long res, long long s_, void *name_, void *anamelen_, void *mask_,
3388 PRE_READ(mask_, sizeof(__sanitizer_sigset_t));
3393 (long long fd1_, void *name1_, long long fd2_, void *name2_, long long flags_) {
3394 const char *name1 = (const char *)name1_;
3395 const char *name2 = (const char *)name2_;
3397 PRE_READ(name1, __sanitizer::internal_strlen(name1) + 1);
3400 PRE_READ(name2, __sanitizer::internal_strlen(name2) + 1);
3403 POST_SYSCALL(linkat)
3404 (long long res, long long fd1_, void *name1_, long long fd2_, void *name2_,
3406 const char *name1 = (const char *)name1_;
3407 const char *name2 = (const char *)name2_;
3410 POST_READ(name1, __sanitizer::internal_strlen(name1) + 1);
3413 POST_READ(name2, __sanitizer::internal_strlen(name2) + 1);
3417 PRE_SYSCALL(renameat)
3418 (long long fromfd_, void *from_, long long tofd_, void *to_) {
3419 const char *from = (const char *)from_;
3420 const char *to = (const char *)to_;
3422 PRE_READ(from, __sanitizer::internal_strlen(from) + 1);
3425 PRE_READ(to, __sanitizer::internal_strlen(to) + 1);
3428 POST_SYSCALL(renameat)
3429 (long long res, long long fromfd_, void *from_, long long tofd_, void *to_) {
3430 const char *from = (const char *)from_;
3431 const char *to = (const char *)to_;
3434 POST_READ(from, __sanitizer::internal_strlen(from) + 1);
3437 POST_READ(to, __sanitizer::internal_strlen(to) + 1);
3441 PRE_SYSCALL(mkfifoat)(long long fd_, void *path_, long long mode_) {
3442 const char *path = (const char *)path_;
3444 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
3447 POST_SYSCALL(mkfifoat)
3448 (long long res, long long fd_, void *path_, long long mode_) {
3449 const char *path = (const char *)path_;
3452 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
3456 PRE_SYSCALL(mknodat)
3457 (long long fd_, void *path_, long long mode_, long long PAD_, long long dev_) {
3458 const char *path = (const char *)path_;
3460 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
3463 POST_SYSCALL(mknodat)
3464 (long long res, long long fd_, void *path_, long long mode_, long long PAD_,
3466 const char *path = (const char *)path_;
3469 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
3473 PRE_SYSCALL(mkdirat)(long long fd_, void *path_, long long mode_) {
3474 const char *path = (const char *)path_;
3476 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
3479 POST_SYSCALL(mkdirat)
3480 (long long res, long long fd_, void *path_, long long mode_) {
3481 const char *path = (const char *)path_;
3484 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
3488 PRE_SYSCALL(faccessat)
3489 (long long fd_, void *path_, long long amode_, long long flag_) {
3490 const char *path = (const char *)path_;
3492 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
3495 POST_SYSCALL(faccessat)
3496 (long long res, long long fd_, void *path_, long long amode_, long long flag_) {
3497 const char *path = (const char *)path_;
3500 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
3504 PRE_SYSCALL(fchmodat)
3505 (long long fd_, void *path_, long long mode_, long long flag_) {
3506 const char *path = (const char *)path_;
3508 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
3511 POST_SYSCALL(fchmodat)
3512 (long long res, long long fd_, void *path_, long long mode_, long long flag_) {
3513 const char *path = (const char *)path_;
3516 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
3520 PRE_SYSCALL(fchownat)
3521 (long long fd_, void *path_, long long owner_, long long group_,
3523 const char *path = (const char *)path_;
3525 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
3528 POST_SYSCALL(fchownat)
3529 (long long res, long long fd_, void *path_, long long owner_, long long group_,
3531 const char *path = (const char *)path_;
3534 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
3538 PRE_SYSCALL(fexecve)(long long fd_, void *argp_, void *envp_) { /* TODO */ }
3539 POST_SYSCALL(fexecve)(long long res, long long fd_, void *argp_, void *envp_) {
3542 PRE_SYSCALL(fstatat)(long long fd_, void *path_, void *buf_, long long flag_) {
3543 const char *path = (const char *)path_;
3545 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
3548 POST_SYSCALL(fstatat)
3549 (long long res, long long fd_, void *path_, void *buf_, long long flag_) {
3550 const char *path = (const char *)path_;
3552 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
3555 PRE_SYSCALL(utimensat)
3556 (long long fd_, void *path_, void *tptr_, long long flag_) {
3557 const char *path = (const char *)path_;
3559 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
3562 PRE_READ(tptr_, struct_timespec_sz);
3565 POST_SYSCALL(utimensat)
3566 (long long res, long long fd_, void *path_, void *tptr_, long long flag_) {
3567 const char *path = (const char *)path_;
3570 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
3573 POST_READ(tptr_, struct_timespec_sz);
3578 (long long fd_, void *path_, long long oflags_, long long mode_) {
3579 const char *path = (const char *)path_;
3581 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
3584 POST_SYSCALL(openat)
3585 (long long res, long long fd_, void *path_, long long oflags_,
3587 const char *path = (const char *)path_;
3590 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
3594 PRE_SYSCALL(readlinkat)
3595 (long long fd_, void *path_, void *buf_, long long bufsize_) {
3596 const char *path = (const char *)path_;
3598 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
3601 POST_SYSCALL(readlinkat)
3602 (long long res, long long fd_, void *path_, void *buf_, long long bufsize_) {
3603 const char *path = (const char *)path_;
3606 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
3610 PRE_SYSCALL(symlinkat)(void *path1_, long long fd_, void *path2_) {
3611 const char *path1 = (const char *)path1_;
3612 const char *path2 = (const char *)path2_;
3614 PRE_READ(path1, __sanitizer::internal_strlen(path1) + 1);
3617 PRE_READ(path2, __sanitizer::internal_strlen(path2) + 1);
3620 POST_SYSCALL(symlinkat)
3621 (long long res, void *path1_, long long fd_, void *path2_) {
3622 const char *path1 = (const char *)path1_;
3623 const char *path2 = (const char *)path2_;
3626 POST_READ(path1, __sanitizer::internal_strlen(path1) + 1);
3629 POST_READ(path2, __sanitizer::internal_strlen(path2) + 1);
3633 PRE_SYSCALL(unlinkat)(long long fd_, void *path_, long long flag_) {
3634 const char *path = (const char *)path_;
3636 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
3639 POST_SYSCALL(unlinkat)
3640 (long long res, long long fd_, void *path_, long long flag_) {
3641 const char *path = (const char *)path_;
3644 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
3648 PRE_SYSCALL(futimens)(long long fd_, void *tptr_) {
3649 struct __sanitizer_timespec **tptr = (struct __sanitizer_timespec **)tptr_;
3651 PRE_READ(tptr[0], struct_timespec_sz);
3652 PRE_READ(tptr[1], struct_timespec_sz);
3655 POST_SYSCALL(futimens)(long long res, long long fd_, void *tptr_) {
3656 struct __sanitizer_timespec **tptr = (struct __sanitizer_timespec **)tptr_;
3659 POST_READ(tptr[0], struct_timespec_sz);
3660 POST_READ(tptr[1], struct_timespec_sz);
3664 PRE_SYSCALL(__quotactl)(void *path_, void *args_) {
3665 const char *path = (const char *)path_;
3667 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
3670 POST_SYSCALL(__quotactl)(long long res, void *path_, void *args_) {
3671 const char *path = (const char *)path_;
3674 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
3678 PRE_SYSCALL(posix_spawn)
3679 (void *pid_, void *path_, void *file_actions_, void *attrp_, void *argv_,
3681 const char *path = (const char *)path_;
3683 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
3686 POST_SYSCALL(posix_spawn)
3687 (long long res, void *pid_, void *path_, void *file_actions_, void *attrp_,
3688 void *argv_, void *envp_) {
3689 const char *path = (const char *)path_;
3692 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
3696 PRE_SYSCALL(recvmmsg)
3697 (long long s_, void *mmsg_, long long vlen_, long long flags_, void *timeout_) {
3699 PRE_READ(timeout_, struct_timespec_sz);
3702 POST_SYSCALL(recvmmsg)
3703 (long long res, long long s_, void *mmsg_, long long vlen_, long long flags_,
3707 POST_READ(timeout_, struct_timespec_sz);
3711 PRE_SYSCALL(sendmmsg)
3712 (long long s_, void *mmsg_, long long vlen_, long long flags_) {
3713 struct __sanitizer_mmsghdr *mmsg = (struct __sanitizer_mmsghdr *)mmsg_;
3715 PRE_READ(mmsg, sizeof(struct __sanitizer_mmsghdr) *
3716 (vlen_ > 1024 ? 1024 : vlen_));
3719 POST_SYSCALL(sendmmsg)
3720 (long long res, long long s_, void *mmsg_, long long vlen_, long long flags_) {
3721 struct __sanitizer_mmsghdr *mmsg = (struct __sanitizer_mmsghdr *)mmsg_;
3724 POST_READ(mmsg, sizeof(struct __sanitizer_mmsghdr) *
3725 (vlen_ > 1024 ? 1024 : vlen_));
3729 PRE_SYSCALL(clock_nanosleep)
3730 (long long clock_id_, long long flags_, void *rqtp_, void *rmtp_) {
3732 PRE_READ(rqtp_, struct_timespec_sz);
3735 POST_SYSCALL(clock_nanosleep)
3736 (long long res, long long clock_id_, long long flags_, void *rqtp_,
3739 POST_READ(rqtp_, struct_timespec_sz);
3742 PRE_SYSCALL(___lwp_park60)
3743 (long long clock_id_, long long flags_, void *ts_, long long unpark_,
3744 void *hint_, void *unparkhint_) {
3746 PRE_READ(ts_, struct_timespec_sz);
3749 POST_SYSCALL(___lwp_park60)
3750 (long long res, long long clock_id_, long long flags_, void *ts_,
3751 long long unpark_, void *hint_, void *unparkhint_) {
3754 POST_READ(ts_, struct_timespec_sz);
3758 PRE_SYSCALL(posix_fallocate)
3759 (long long fd_, long long PAD_, long long pos_, long long len_) {
3762 POST_SYSCALL(posix_fallocate)
3763 (long long res, long long fd_, long long PAD_, long long pos_, long long len_) {
3766 PRE_SYSCALL(fdiscard)
3767 (long long fd_, long long PAD_, long long pos_, long long len_) {
3770 POST_SYSCALL(fdiscard)
3771 (long long res, long long fd_, long long PAD_, long long pos_, long long len_) {
3775 (long long idtype_, long long id_, void *status_, long long options_,
3776 void *wru_, void *info_) {
3780 (long long res, long long idtype_, long long id_, void *status_,
3781 long long options_, void *wru_, void *info_) {
3784 PRE_SYSCALL(clock_getcpuclockid2)
3785 (long long idtype_, long long id_, void *clock_id_) {
3788 POST_SYSCALL(clock_getcpuclockid2)
3789 (long long res, long long idtype_, long long id_, void *clock_id_) {
3792 PRE_SYSCALL(__getvfsstat90)(void *buf_, long long bufsize_, long long flags_) {
3795 POST_SYSCALL(__getvfsstat90)
3796 (long long res, void *buf_, long long bufsize_, long long flags_) {
3799 PRE_SYSCALL(__statvfs190)(void *path_, void *buf_, long long flags_) {
3800 const char *path = (const char *)path_;
3802 PRE_READ(path, __sanitizer::internal_strlen(path) + 1);
3805 POST_SYSCALL(__statvfs190)
3806 (long long res, void *path_, void *buf_, long long flags_) {
3807 const char *path = (const char *)path_;
3809 POST_READ(path, __sanitizer::internal_strlen(path) + 1);
3812 PRE_SYSCALL(__fstatvfs190)(long long fd_, void *buf_, long long flags_) {
3815 POST_SYSCALL(__fstatvfs190)
3816 (long long res, long long fd_, void *buf_, long long flags_) {
3819 PRE_SYSCALL(__fhstatvfs190)
3820 (void *fhp_, long long fh_size_, void *buf_, long long flags_) {
3822 PRE_READ(fhp_, fh_size_);
3825 POST_SYSCALL(__fhstatvfs190)
3826 (long long res, void *fhp_, long long fh_size_, void *buf_, long long flags_) {}
3827 #undef SYS_MAXSYSARGS
3837 #endif // SANITIZER_NETBSD