diff options
author | Treehugger Robot <treehugger-gerrit@google.com> | 2018-03-07 23:14:25 +0000 |
---|---|---|
committer | Gerrit Code Review <noreply-gerritcodereview@google.com> | 2018-03-07 23:14:25 +0000 |
commit | 0a2060c090e8b33045236fa0f836903994210c2b (patch) | |
tree | a78532b7fad77e4f243b2a0776b3b1101f9aeaf0 | |
parent | 832f4907f0bd244aef90955d2b00aac53f1eed6e (diff) | |
parent | ed74abc8dcac82d95b64a550254cb5ba1e9a0b8e (diff) | |
download | bionic-o-mr1-iot-preview-7.tar.gz |
Merge "Move some syscalls in commmon whitelist to app"android-o-mr1-iot-preview-7o-mr1-iot-preview-7
-rw-r--r-- | libc/SECCOMP_WHITELIST_APP.TXT | 57 | ||||
-rw-r--r-- | libc/SECCOMP_WHITELIST_COMMON.TXT | 57 | ||||
-rw-r--r-- | libc/seccomp/arm_system_policy.cpp | 166 | ||||
-rw-r--r-- | libc/seccomp/mips_system_policy.cpp | 172 | ||||
-rw-r--r-- | libc/seccomp/x86_64_system_policy.cpp | 4 | ||||
-rw-r--r-- | libc/seccomp/x86_system_policy.cpp | 178 |
6 files changed, 326 insertions, 308 deletions
diff --git a/libc/SECCOMP_WHITELIST_APP.TXT b/libc/SECCOMP_WHITELIST_APP.TXT index 2f3618c44..cd5359c54 100644 --- a/libc/SECCOMP_WHITELIST_APP.TXT +++ b/libc/SECCOMP_WHITELIST_APP.TXT @@ -24,3 +24,60 @@ # - Each parameter type is assumed to be stored in 32 bits. # # This file is processed by a python script named genseccomp.py. + +# Syscalls needed to run GFXBenchmark +pid_t vfork:vfork() arm,x86,x86_64 + +# Needed for debugging 32-bit Chrome +int pipe:pipe(int pipefd[2]) arm,x86,mips + +# b/34651972 +int access:access(const char *pathname, int mode) arm,x86,mips +int stat64:stat64(const char*, struct stat64*) arm,x86,mips + +# b/34813887 +int open:open(const char *path, int oflag, ... ) arm,x86,mips +int getdents:getdents(unsigned int fd, struct linux_dirent *dirp, unsigned int count) arm,x86,mips + +# b/34719286 +int eventfd:eventfd(unsigned int initval, int flags) arm,x86,mips + +# b/34817266 +int epoll_wait:epoll_wait(int epfd, struct epoll_event *events, int maxevents, int timeout) arm,x86,mips + +# b/34908783 +int epoll_create:epoll_create(int size) arm,x86,mips + +# b/34979910 +int creat:creat(const char *pathname, mode_t mode) arm,x86,mips +int unlink:unlink(const char *pathname) arm,x86,mips + +# b/35059702 +int lstat64:lstat64(const char*, struct stat64*) arm,x86,mips + +# b/35217603 +int fcntl:fcntl(int fd, int cmd, ... /* arg */ ) arm,x86,mips +pid_t fork:fork() arm,x86,mips +int poll:poll(struct pollfd *fds, nfds_t nfds, int timeout) arm,x86,mips + +# b/35906875. Note mips already has getuid from SYSCALLS.TXT +int inotify_init() arm,x86,mips +uid_t getuid() arm,x86 + +# b/36435222 +int remap_file_pages(void *addr, size_t size, int prot, size_t pgoff, int flags) arm,x86,mips + +# b/36449658 +int rename(const char *oldpath, const char *newpath) arm,x86,mips + +# b/36726183. Note arm does not support mmap +void* mmap(void *addr, size_t length, int prot, int flags, int fd, off_t offset) x86,mips + +# b/37769298 +int dup2(int oldfd, int newfd) arm,x86,mips + +# b/62779795 +int compat_select:_newselect(int n, unsigned long* inp, unsigned long* outp, unsigned long* exp, struct timeval* timeout) arm,x86,mips + +# b/62090571 +int mkdir(const char *pathname, mode_t mode) arm,x86,mips diff --git a/libc/SECCOMP_WHITELIST_COMMON.TXT b/libc/SECCOMP_WHITELIST_COMMON.TXT index a620b4444..f4b033e50 100644 --- a/libc/SECCOMP_WHITELIST_COMMON.TXT +++ b/libc/SECCOMP_WHITELIST_COMMON.TXT @@ -51,59 +51,11 @@ int seccomp:seccomp(unsigned int operation, unsigned int flags, void *args) all # syscalls needed to boot android int sigreturn:sigreturn(unsigned long __unused) arm,x86,mips -# Syscalls needed to run GFXBenchmark -pid_t vfork:vfork() arm,x86,x86_64 - -# Needed for debugging 32-bit Chrome -int pipe:pipe(int pipefd[2]) arm,x86,mips - -# b/34651972 -int access:access(const char *pathname, int mode) arm,x86,mips -int stat64:stat64(const char*, struct stat64*) arm,x86,mips - -# b/34813887 -int open:open(const char *path, int oflag, ... ) arm,x86,mips -int getdents:getdents(unsigned int fd, struct linux_dirent *dirp, unsigned int count) arm,x86,mips - -# b/34719286 -int eventfd:eventfd(unsigned int initval, int flags) arm,x86,mips - -# b/34817266 -int epoll_wait:epoll_wait(int epfd, struct epoll_event *events, int maxevents, int timeout) arm,x86,mips - # Needed by sanitizers (b/34606909) # 5 (__NR_open) and 195 (__NR_stat64) are also required, but they are # already allowed. ssize_t readlink:readlink(const char *path, char *buf, size_t bufsiz) arm,x86,mips -# b/34908783 -int epoll_create:epoll_create(int size) arm,x86,mips - -# b/34979910 -int creat:creat(const char *pathname, mode_t mode) arm,x86,mips -int unlink:unlink(const char *pathname) arm,x86,mips - -# b/35059702 -int lstat64:lstat64(const char*, struct stat64*) arm,x86,mips - -# b/35217603 -int fcntl:fcntl(int fd, int cmd, ... /* arg */ ) arm,x86,mips -pid_t fork:fork() arm,x86,mips -int poll:poll(struct pollfd *fds, nfds_t nfds, int timeout) arm,x86,mips - -# b/35906875. Note mips already has getuid from SYSCALLS.TXT -int inotify_init() arm,x86,mips -uid_t getuid() arm,x86 - -# b/36435222 -int remap_file_pages(void *addr, size_t size, int prot, size_t pgoff, int flags) arm,x86,mips - -# b/36449658 -int rename(const char *oldpath, const char *newpath) arm,x86,mips - -# b/36726183. Note arm does not support mmap -void* mmap(void *addr, size_t length, int prot, int flags, int fd, off_t offset) x86,mips - # Useful new syscalls which we don't yet use in bionic. int sched_getattr(pid_t pid, struct sched_attr* attr, unsigned int flags) all int sched_setattr(pid_t pid, struct sched_attr* attr, unsigned int size, unsigned int flags) all @@ -119,12 +71,3 @@ int io_destroy(aio_context_t ctx) all int io_submit(aio_context_t ctx, long nr, struct iocb **iocbpp) all int io_getevents(aio_context_t ctx, long min_nr, long max_nr, struct io_event *events, struct timespec *timeout) all int io_cancel(aio_context_t ctx, struct iocb *, struct io_event *result) all - -# b/37769298 -int dup2(int oldfd, int newfd) arm,x86,mips - -# b/62779795 -int compat_select:_newselect(int n, unsigned long* inp, unsigned long* outp, unsigned long* exp, struct timeval* timeout) arm,x86,mips - -# b/62090571 -int mkdir(const char *pathname, mode_t mode) arm,x86,mips diff --git a/libc/seccomp/arm_system_policy.cpp b/libc/seccomp/arm_system_policy.cpp index 18df03b8f..feb111ea4 100644 --- a/libc/seccomp/arm_system_policy.cpp +++ b/libc/seccomp/arm_system_policy.cpp @@ -5,128 +5,132 @@ #include "seccomp_bpfs.h" const sock_filter arm_system_filter[] = { -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 0, 0, 124), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 138, 61, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 0, 0, 128), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 143, 63, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 74, 31, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 41, 15, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 24, 7, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 10, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 8, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 7, 117, 116), //restart_syscall|exit|fork|read|write|open|close -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 9, 116, 115), //creat -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 19, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 13, 114, 113), //unlink|execve|chdir -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 22, 113, 112), //lseek|getpid|mount -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 33, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 43, 15, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 19, 7, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 6, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 3, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 2, 121, 120), //restart_syscall|exit +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 5, 120, 119), //read|write +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 11, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 7, 118, 117), //close +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 13, 117, 116), //execve|chdir +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 36, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 26, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 25, 110, 109), //getuid -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 27, 109, 108), //ptrace -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 36, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 34, 107, 106), //access -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 40, 106, 105), //sync|kill|rename|mkdir +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 22, 114, 113), //lseek|getpid|mount +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 27, 113, 112), //ptrace +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 41, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 38, 111, 110), //sync|kill +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 42, 110, 109), //dup BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 57, 7, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 51, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 45, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 44, 102, 101), //dup|pipe|times -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 46, 101, 100), //brk +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 44, 106, 105), //times +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 46, 105, 104), //brk BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 54, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 53, 99, 98), //acct|umount2 -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 56, 98, 97), //ioctl|fcntl -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 63, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 53, 103, 102), //acct|umount2 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 55, 102, 101), //ioctl +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 64, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 60, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 58, 95, 94), //setpgid -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 62, 94, 93), //umask|chroot +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 58, 99, 98), //setpgid +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 62, 98, 97), //umask|chroot BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 66, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 65, 92, 91), //dup2|getppid -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 68, 91, 90), //setsid|sigaction +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 65, 96, 95), //getppid +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 68, 95, 94), //setsid|sigaction BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 114, 15, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 91, 7, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 85, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 77, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 76, 86, 85), //sethostname|setrlimit -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 80, 85, 84), //getrusage|gettimeofday|settimeofday +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 76, 90, 89), //sethostname|setrlimit +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 80, 89, 88), //getrusage|gettimeofday|settimeofday BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 88, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 86, 83, 82), //readlink -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 89, 82, 81), //reboot +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 86, 87, 86), //readlink +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 89, 86, 85), //reboot BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 96, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 94, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 93, 79, 78), //munmap|truncate -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 95, 78, 77), //fchmod +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 93, 83, 82), //munmap|truncate +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 95, 82, 81), //fchmod BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 103, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 98, 76, 75), //getpriority|setpriority -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 106, 75, 74), //syslog|setitimer|getitimer +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 98, 80, 79), //getpriority|setpriority +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 106, 79, 78), //syslog|setitimer|getitimer BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 128, 7, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 118, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 116, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 115, 71, 70), //wait4 -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 117, 70, 69), //sysinfo +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 115, 75, 74), //wait4 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 117, 74, 73), //sysinfo BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 124, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 123, 68, 67), //fsync|sigreturn|clone|setdomainname|uname -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 126, 67, 66), //adjtimex|mprotect +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 123, 72, 71), //fsync|sigreturn|clone|setdomainname|uname +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 126, 71, 70), //adjtimex|mprotect BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 136, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 131, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 130, 64, 63), //init_module|delete_module -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 134, 63, 62), //quotactl|getpgid|fchdir -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 137, 62, 61), //personality +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 130, 68, 67), //init_module|delete_module +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 134, 67, 66), //quotactl|getpgid|fchdir +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 138, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 137, 65, 64), //personality +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 141, 64, 63), //setfsuid|setfsgid|_llseek BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 290, 31, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 217, 15, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 183, 7, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 168, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 191, 7, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 172, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 150, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 149, 56, 55), //setfsuid|setfsgid|_llseek|getdents|_newselect|flock|msync|readv|writev|getsid|fdatasync -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 164, 55, 54), //mlock|munlock|mlockall|munlockall|sched_setparam|sched_getparam|sched_setscheduler|sched_getscheduler|sched_yield|sched_get_priority_max|sched_get_priority_min|sched_rr_get_interval|nanosleep|mremap -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 172, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 169, 53, 52), //poll -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 182, 52, 51), //prctl|rt_sigreturn|rt_sigaction|rt_sigprocmask|rt_sigpending|rt_sigtimedwait|rt_sigqueueinfo|rt_sigsuspend|pread64|pwrite64 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 149, 58, 57), //flock|msync|readv|writev|getsid|fdatasync +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 164, 57, 56), //mlock|munlock|mlockall|munlockall|sched_setparam|sched_getparam|sched_setscheduler|sched_getscheduler|sched_yield|sched_get_priority_max|sched_get_priority_min|sched_rr_get_interval|nanosleep|mremap +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 183, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 182, 55, 54), //prctl|rt_sigreturn|rt_sigaction|rt_sigprocmask|rt_sigpending|rt_sigtimedwait|rt_sigqueueinfo|rt_sigsuspend|pread64|pwrite64 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 188, 54, 53), //getcwd|capget|capset|sigaltstack|sendfile BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 199, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 190, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 188, 49, 48), //getcwd|capget|capset|sigaltstack|sendfile -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 198, 48, 47), //vfork|ugetrlimit|mmap2|truncate64|ftruncate64|stat64|lstat64|fstat64 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 197, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 195, 51, 50), //ugetrlimit|mmap2|truncate64|ftruncate64 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 198, 50, 49), //fstat64 BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 213, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 212, 46, 45), //getuid32|getgid32|geteuid32|getegid32|setreuid32|setregid32|getgroups32|setgroups32|fchown32|setresuid32|getresuid32|setresgid32|getresgid32 -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 215, 45, 44), //setuid32|setgid32 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 212, 48, 47), //getuid32|getgid32|geteuid32|getegid32|setreuid32|setregid32|getgroups32|setgroups32|fchown32|setresuid32|getresuid32|setresgid32|getresgid32 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 215, 47, 46), //setuid32|setgid32 BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 256, 7, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 224, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 219, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 218, 41, 40), //getdents64 -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 222, 40, 39), //mincore|madvise|fcntl64 -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 250, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 249, 38, 37), //gettid|readahead|setxattr|lsetxattr|fsetxattr|getxattr|lgetxattr|fgetxattr|listxattr|llistxattr|flistxattr|removexattr|lremovexattr|fremovexattr|tkill|sendfile64|futex|sched_setaffinity|sched_getaffinity|io_setup|io_destroy|io_getevents|io_submit|io_cancel|exit_group -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 254, 37, 36), //epoll_create|epoll_ctl|epoll_wait|remap_file_pages +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 218, 43, 42), //getdents64 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 222, 42, 41), //mincore|madvise|fcntl64 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 251, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 249, 40, 39), //gettid|readahead|setxattr|lsetxattr|fsetxattr|getxattr|lgetxattr|fgetxattr|listxattr|llistxattr|flistxattr|removexattr|lremovexattr|fremovexattr|tkill|sendfile64|futex|sched_setaffinity|sched_getaffinity|io_setup|io_destroy|io_getevents|io_submit|io_cancel|exit_group +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 252, 39, 38), //epoll_ctl BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 280, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 270, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 269, 34, 33), //set_tid_address|timer_create|timer_settime|timer_gettime|timer_getoverrun|timer_delete|clock_settime|clock_gettime|clock_getres|clock_nanosleep|statfs64|fstatfs64|tgkill -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 271, 33, 32), //arm_fadvise64_64 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 269, 36, 35), //set_tid_address|timer_create|timer_settime|timer_gettime|timer_getoverrun|timer_delete|clock_settime|clock_gettime|clock_getres|clock_nanosleep|statfs64|fstatfs64|tgkill +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 271, 35, 34), //arm_fadvise64_64 BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 286, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 285, 31, 30), //waitid|socket|bind|connect|listen -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 289, 30, 29), //getsockname|getpeername|socketpair +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 285, 33, 32), //waitid|socket|bind|connect|listen +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 289, 32, 31), //getsockname|getpeername|socketpair BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 350, 15, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 327, 7, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 316, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 317, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 292, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 291, 25, 24), //sendto -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 298, 24, 23), //recvfrom|shutdown|setsockopt|getsockopt|sendmsg|recvmsg +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 291, 27, 26), //sendto +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 298, 26, 25), //recvfrom|shutdown|setsockopt|getsockopt|sendmsg|recvmsg BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 322, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 319, 22, 21), //inotify_init|inotify_add_watch|inotify_rm_watch -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 326, 21, 20), //openat|mkdirat|mknodat|fchownat +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 319, 24, 23), //inotify_add_watch|inotify_rm_watch +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 326, 23, 22), //openat|mkdirat|mknodat|fchownat BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 345, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 340, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 338, 18, 17), //fstatat64|unlinkat|renameat|linkat|symlinkat|readlinkat|fchmodat|faccessat|pselect6|ppoll|unshare -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 344, 17, 16), //splice|sync_file_range2|tee|vmsplice +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 338, 20, 19), //fstatat64|unlinkat|renameat|linkat|symlinkat|readlinkat|fchmodat|faccessat|pselect6|ppoll|unshare +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 344, 19, 18), //splice|sync_file_range2|tee|vmsplice BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 348, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 347, 15, 14), //getcpu|epoll_pwait -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 349, 14, 13), //utimensat -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 390, 7, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 372, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 369, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 367, 10, 9), //timerfd_create|eventfd|fallocate|timerfd_settime|timerfd_gettime|signalfd4|eventfd2|epoll_create1|dup3|pipe2|inotify_init1|preadv|pwritev|rt_tgsigqueueinfo|perf_event_open|recvmmsg|accept4 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 347, 17, 16), //getcpu|epoll_pwait +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 349, 16, 15), //utimensat +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 380, 7, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 369, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 352, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 351, 12, 11), //timerfd_create +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 367, 11, 10), //fallocate|timerfd_settime|timerfd_gettime|signalfd4|eventfd2|epoll_create1|dup3|pipe2|inotify_init1|preadv|pwritev|rt_tgsigqueueinfo|perf_event_open|recvmmsg|accept4 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 372, 1, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 370, 9, 8), //prlimit64 -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 380, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 378, 7, 6), //clock_adjtime|syncfs|sendmmsg|setns|process_vm_readv|process_vm_writev -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 388, 6, 5), //sched_setattr|sched_getattr|renameat2|seccomp|getrandom|memfd_create|bpf|execveat -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 983045, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 983042, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 394, 3, 2), //mlock2|copy_file_range|preadv2|pwritev2 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 378, 8, 7), //clock_adjtime|syncfs|sendmmsg|setns|process_vm_readv|process_vm_writev +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 983042, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 390, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 388, 5, 4), //sched_setattr|sched_getattr|renameat2|seccomp|getrandom|memfd_create|bpf|execveat +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 394, 4, 3), //mlock2|copy_file_range|preadv2|pwritev2 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 983045, 1, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 983043, 2, 1), //__ARM_NR_cacheflush BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 983046, 1, 0), //__ARM_NR_set_tls BPF_STMT(BPF_RET|BPF_K, SECCOMP_RET_ALLOW), diff --git a/libc/seccomp/mips_system_policy.cpp b/libc/seccomp/mips_system_policy.cpp index a88a6e3d4..32ed56715 100644 --- a/libc/seccomp/mips_system_policy.cpp +++ b/libc/seccomp/mips_system_policy.cpp @@ -5,108 +5,116 @@ #include "seccomp_bpfs.h" const sock_filter mips_system_filter[] = { -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4001, 0, 108), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4128, 53, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4063, 27, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4036, 13, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4023, 7, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4010, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4008, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4007, 101, 100), //exit|fork|read|write|open|close -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4009, 100, 99), //creat -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4019, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4013, 98, 97), //unlink|execve|chdir -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4022, 97, 96), //lseek|getpid|mount -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4033, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4026, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4025, 94, 93), //setuid|getuid -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4027, 93, 92), //ptrace -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4034, 92, 91), //access +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4001, 0, 116), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4131, 57, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4064, 29, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4041, 15, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4019, 7, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4006, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4003, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4002, 109, 108), //exit +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4005, 108, 107), //read|write +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4011, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4007, 106, 105), //close +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4013, 105, 104), //execve|chdir +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4026, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4023, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4022, 102, 101), //lseek|getpid|mount +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4025, 101, 100), //setuid|getuid +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4036, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4027, 99, 98), //ptrace +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4038, 98, 97), //sync|kill BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4054, 7, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4045, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4041, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4040, 88, 87), //sync|kill|rename|mkdir -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4044, 87, 86), //dup|pipe|times +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4043, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4042, 94, 93), //dup +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4044, 93, 92), //times BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4049, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4048, 85, 84), //brk|setgid|getgid -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4053, 84, 83), //geteuid|getegid|acct|umount2 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4048, 91, 90), //brk|setgid|getgid +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4053, 90, 89), //geteuid|getegid|acct|umount2 BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4060, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4057, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4056, 81, 80), //ioctl|fcntl -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4058, 80, 79), //setpgid -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4062, 79, 78), //umask|chroot +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4055, 87, 86), //ioctl +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4058, 86, 85), //setpgid +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4062, 85, 84), //umask|chroot BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4094, 13, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4085, 7, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4070, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4066, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4065, 74, 73), //dup2|getppid -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4068, 73, 72), //setsid|sigaction +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4065, 80, 79), //getppid +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4068, 79, 78), //setsid|sigaction BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4074, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4072, 71, 70), //setreuid|setregid -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4082, 70, 69), //sethostname|setrlimit|getrlimit|getrusage|gettimeofday|settimeofday|getgroups|setgroups -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4090, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4072, 77, 76), //setreuid|setregid +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4082, 76, 75), //sethostname|setrlimit|getrlimit|getrusage|gettimeofday|settimeofday|getgroups|setgroups +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4091, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4088, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4086, 67, 66), //readlink -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4089, 66, 65), //reboot -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4093, 65, 64), //mmap|munmap|truncate -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4116, 5, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4086, 73, 72), //readlink +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4089, 72, 71), //reboot +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4093, 71, 70), //munmap|truncate +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4118, 7, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4114, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4103, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4098, 61, 60), //fchmod|fchown|getpriority|setpriority -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4106, 60, 59), //syslog|setitimer|getitimer -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4115, 59, 58), //wait4 -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4124, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4118, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4117, 56, 55), //sysinfo -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4123, 55, 54), //fsync|sigreturn|clone|setdomainname|uname -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4126, 54, 53), //adjtimex|mprotect -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4222, 27, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4176, 13, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4098, 67, 66), //fchmod|fchown|getpriority|setpriority +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4106, 66, 65), //syslog|setitimer|getitimer +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4116, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4115, 64, 63), //wait4 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4117, 63, 62), //sysinfo +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4128, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4124, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4123, 60, 59), //fsync|sigreturn|clone|setdomainname|uname +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4126, 59, 58), //adjtimex|mprotect +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4130, 58, 57), //init_module|delete_module +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4249, 29, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4179, 15, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4151, 7, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4136, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4131, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4130, 48, 47), //init_module|delete_module -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4134, 47, 46), //quotactl|getpgid|fchdir -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4138, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4137, 45, 44), //personality -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4148, 44, 43), //setfsuid|setfsgid|_llseek|getdents|_newselect|flock|msync|readv|writev|cacheflush +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4138, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4136, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4134, 52, 51), //quotactl|getpgid|fchdir +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4137, 51, 50), //personality +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4143, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4141, 49, 48), //setfsuid|setfsgid|_llseek +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4148, 48, 47), //flock|msync|readv|writev|cacheflush BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4169, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4154, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4153, 41, 40), //getsid|fdatasync -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4168, 40, 39), //mlock|munlock|mlockall|munlockall|sched_setparam|sched_getparam|sched_setscheduler|sched_getscheduler|sched_yield|sched_get_priority_max|sched_get_priority_min|sched_rr_get_interval|nanosleep|mremap -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4175, 39, 38), //bind|connect|getpeername|getsockname|getsockopt|listen -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4203, 7, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4188, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4179, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4178, 35, 34), //recvfrom|recvmsg -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4187, 34, 33), //sendmsg|sendto|setsockopt|shutdown|socket|socketpair|setresuid|getresuid +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4153, 45, 44), //getsid|fdatasync +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4168, 44, 43), //mlock|munlock|mlockall|munlockall|sched_setparam|sched_getparam|sched_setscheduler|sched_getscheduler|sched_yield|sched_get_priority_max|sched_get_priority_min|sched_rr_get_interval|nanosleep|mremap +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4176, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4175, 42, 41), //bind|connect|getpeername|getsockname|getsockopt|listen +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4178, 41, 40), //recvfrom|recvmsg +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4215, 7, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4203, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4190, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4189, 32, 31), //poll -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4202, 31, 30), //setresgid|getresgid|prctl|rt_sigreturn|rt_sigaction|rt_sigprocmask|rt_sigpending|rt_sigtimedwait|rt_sigqueueinfo|rt_sigsuspend|pread64|pwrite64 -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4217, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4187, 37, 36), //sendmsg|sendto|setsockopt|shutdown|socket|socketpair|setresuid|getresuid +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4202, 36, 35), //setresgid|getresgid|prctl|rt_sigreturn|rt_sigaction|rt_sigprocmask|rt_sigpending|rt_sigtimedwait|rt_sigqueueinfo|rt_sigsuspend|pread64|pwrite64 BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4210, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4208, 28, 27), //getcwd|capget|capset|sigaltstack|sendfile -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4216, 27, 26), //mmap2|truncate64|ftruncate64|stat64|lstat64|fstat64 -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4221, 26, 25), //mincore|madvise|getdents64|fcntl64 -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4316, 13, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4288, 7, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4208, 34, 33), //getcwd|capget|capset|sigaltstack|sendfile +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4213, 33, 32), //mmap2|truncate64|ftruncate64 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4222, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4217, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4216, 30, 29), //fstat64 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4221, 29, 28), //mincore|madvise|getdents64|fcntl64 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4247, 28, 27), //gettid|readahead|setxattr|lsetxattr|fsetxattr|getxattr|lgetxattr|fgetxattr|listxattr|llistxattr|flistxattr|removexattr|lremovexattr|fremovexattr|tkill|sendfile64|futex|sched_setaffinity|sched_getaffinity|io_setup|io_destroy|io_getevents|io_submit|io_cancel|exit_group +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4312, 13, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4285, 7, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4278, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4248, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4247, 21, 20), //gettid|readahead|setxattr|lsetxattr|fsetxattr|getxattr|lgetxattr|fgetxattr|listxattr|llistxattr|flistxattr|removexattr|lremovexattr|fremovexattr|tkill|sendfile64|futex|sched_setaffinity|sched_getaffinity|io_setup|io_destroy|io_getevents|io_submit|io_cancel|exit_group -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4267, 20, 19), //epoll_create|epoll_ctl|epoll_wait|remap_file_pages|set_tid_address|restart_syscall|fadvise64|statfs64|fstatfs64|timer_create|timer_settime|timer_gettime|timer_getoverrun|timer_delete|clock_settime|clock_gettime|clock_getres|clock_nanosleep|tgkill +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4252, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4250, 23, 22), //epoll_ctl +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4267, 22, 21), //set_tid_address|restart_syscall|fadvise64|statfs64|fstatfs64|timer_create|timer_settime|timer_gettime|timer_getoverrun|timer_delete|clock_settime|clock_gettime|clock_getres|clock_nanosleep|tgkill BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4283, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4279, 18, 17), //waitid -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4287, 17, 16), //set_thread_area|inotify_init|inotify_add_watch|inotify_rm_watch -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4312, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4293, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4292, 14, 13), //openat|mkdirat|mknodat|fchownat -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4308, 13, 12), //fstatat64|unlinkat|renameat|linkat|symlinkat|readlinkat|fchmodat|faccessat|pselect6|ppoll|unshare|splice|sync_file_range|tee|vmsplice -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4314, 12, 11), //getcpu|epoll_pwait -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4341, 5, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4338, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4319, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4317, 8, 7), //utimensat -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4336, 7, 6), //eventfd|fallocate|timerfd_create|timerfd_gettime|timerfd_settime|signalfd4|eventfd2|epoll_create1|dup3|pipe2|inotify_init1|preadv|pwritev|rt_tgsigqueueinfo|perf_event_open|accept4|recvmmsg +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4279, 20, 19), //waitid +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4284, 19, 18), //set_thread_area +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4293, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4288, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4287, 16, 15), //inotify_add_watch|inotify_rm_watch +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4292, 15, 14), //openat|mkdirat|mknodat|fchownat +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4308, 14, 13), //fstatat64|unlinkat|renameat|linkat|symlinkat|readlinkat|fchmodat|faccessat|pselect6|ppoll|unshare|splice|sync_file_range|tee|vmsplice +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4341, 7, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4320, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4316, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4314, 10, 9), //getcpu|epoll_pwait +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4317, 9, 8), //utimensat +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4338, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4336, 7, 6), //fallocate|timerfd_create|timerfd_gettime|timerfd_settime|signalfd4|eventfd2|epoll_create1|dup3|pipe2|inotify_init1|preadv|pwritev|rt_tgsigqueueinfo|perf_event_open|accept4|recvmmsg BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4339, 6, 5), //prlimit64 BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4359, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 4349, 1, 0), diff --git a/libc/seccomp/x86_64_system_policy.cpp b/libc/seccomp/x86_64_system_policy.cpp index 67859eb90..cef86711a 100644 --- a/libc/seccomp/x86_64_system_policy.cpp +++ b/libc/seccomp/x86_64_system_policy.cpp @@ -20,14 +20,14 @@ BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 24, 1, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 21, 76, 75), //lseek|mmap|mprotect|munmap|brk|rt_sigaction|rt_sigprocmask|rt_sigreturn|ioctl|pread64|pwrite64|readv|writev BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 29, 75, 74), //sched_yield|mremap|msync|mincore|madvise BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 33, 74, 73), //dup -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 58, 5, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 59, 5, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 44, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 38, 1, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 37, 70, 69), //nanosleep|getitimer BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 43, 69, 68), //setitimer|getpid|sendfile|socket|connect BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 57, 68, 67), //sendto|recvfrom|sendmsg|recvmsg|shutdown|bind|listen|getsockname|getpeername|socketpair|setsockopt|getsockopt|clone BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 72, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 64, 66, 65), //vfork|execve|exit|wait4|kill|uname +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 64, 66, 65), //execve|exit|wait4|kill|uname BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 78, 65, 64), //fcntl|flock|fsync|fdatasync|truncate|ftruncate BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 137, 11, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 95, 5, 0), diff --git a/libc/seccomp/x86_system_policy.cpp b/libc/seccomp/x86_system_policy.cpp index 3a34c6983..10a3ba9da 100644 --- a/libc/seccomp/x86_system_policy.cpp +++ b/libc/seccomp/x86_system_policy.cpp @@ -5,112 +5,118 @@ #include "seccomp_bpfs.h" const sock_filter x86_system_filter[] = { -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 0, 0, 114), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 131, 57, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 0, 0, 120), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 136, 59, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 66, 29, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 41, 15, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 24, 7, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 10, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 8, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 7, 107, 106), //restart_syscall|exit|fork|read|write|open|close -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 9, 106, 105), //creat -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 19, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 13, 104, 103), //unlink|execve|chdir -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 22, 103, 102), //lseek|getpid|mount -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 33, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 43, 15, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 19, 7, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 6, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 3, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 2, 113, 112), //restart_syscall|exit +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 5, 112, 111), //read|write +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 11, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 7, 110, 109), //close +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 13, 109, 108), //execve|chdir +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 36, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 26, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 25, 100, 99), //getuid -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 27, 99, 98), //ptrace -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 36, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 34, 97, 96), //access -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 40, 96, 95), //sync|kill|rename|mkdir +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 22, 106, 105), //lseek|getpid|mount +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 27, 105, 104), //ptrace +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 41, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 38, 103, 102), //sync|kill +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 42, 102, 101), //dup BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 57, 7, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 51, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 45, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 44, 92, 91), //dup|pipe|times -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 46, 91, 90), //brk +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 44, 98, 97), //times +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 46, 97, 96), //brk BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 54, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 53, 89, 88), //acct|umount2 -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 56, 88, 87), //ioctl|fcntl -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 63, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 53, 95, 94), //acct|umount2 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 55, 94, 93), //ioctl +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 64, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 60, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 58, 85, 84), //setpgid -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 62, 84, 83), //umask|chroot -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 65, 83, 82), //dup2|getppid -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 96, 13, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 58, 91, 90), //setpgid +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 62, 90, 89), //umask|chroot +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 65, 89, 88), //getppid +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 102, 15, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 88, 7, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 77, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 74, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 68, 78, 77), //setsid|sigaction -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 76, 77, 76), //sethostname|setrlimit +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 68, 84, 83), //setsid|sigaction +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 76, 83, 82), //sethostname|setrlimit BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 85, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 80, 75, 74), //getrusage|gettimeofday|settimeofday -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 86, 74, 73), //readlink +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 80, 81, 80), //getrusage|gettimeofday|settimeofday +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 86, 80, 79), //readlink BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 94, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 90, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 89, 71, 70), //reboot -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 93, 70, 69), //mmap|munmap|truncate -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 95, 69, 68), //fchmod -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 118, 7, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 114, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 102, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 98, 65, 64), //getpriority|setpriority -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 106, 64, 63), //socketcall|syslog|setitimer|getitimer -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 116, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 115, 62, 61), //wait4 -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 117, 61, 60), //sysinfo -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 128, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 124, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 123, 58, 57), //fsync|sigreturn|clone|setdomainname|uname -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 126, 57, 56), //adjtimex|mprotect -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 130, 56, 55), //init_module|delete_module -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 254, 27, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 190, 13, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 168, 7, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 138, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 136, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 134, 50, 49), //quotactl|getpgid|fchdir -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 137, 49, 48), //personality +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 91, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 89, 77, 76), //reboot +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 93, 76, 75), //munmap|truncate +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 96, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 95, 74, 73), //fchmod +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 98, 73, 72), //getpriority|setpriority +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 124, 7, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 116, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 114, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 106, 69, 68), //socketcall|syslog|setitimer|getitimer +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 115, 68, 67), //wait4 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 118, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 117, 66, 65), //sysinfo +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 123, 65, 64), //fsync|sigreturn|clone|setdomainname|uname +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 131, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 128, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 126, 62, 61), //adjtimex|mprotect +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 130, 61, 60), //init_module|delete_module +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 134, 60, 59), //quotactl|getpgid|fchdir +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 258, 29, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 199, 15, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 172, 7, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 143, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 138, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 137, 54, 53), //personality +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 141, 53, 52), //setfsuid|setfsgid|_llseek BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 150, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 149, 47, 46), //setfsuid|setfsgid|_llseek|getdents|_newselect|flock|msync|readv|writev|getsid|fdatasync -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 164, 46, 45), //mlock|munlock|mlockall|munlockall|sched_setparam|sched_getparam|sched_setscheduler|sched_getscheduler|sched_yield|sched_get_priority_max|sched_get_priority_min|sched_rr_get_interval|nanosleep|mremap -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 183, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 172, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 169, 43, 42), //poll -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 182, 42, 41), //prctl|rt_sigreturn|rt_sigaction|rt_sigprocmask|rt_sigpending|rt_sigtimedwait|rt_sigqueueinfo|rt_sigsuspend|pread64|pwrite64 -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 188, 41, 40), //getcwd|capget|capset|sigaltstack|sendfile -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 224, 7, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 213, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 199, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 198, 37, 36), //vfork|ugetrlimit|mmap2|truncate64|ftruncate64|stat64|lstat64|fstat64 -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 212, 36, 35), //getuid32|getgid32|geteuid32|getegid32|setreuid32|setregid32|getgroups32|setgroups32|fchown32|setresuid32|getresuid32|setresgid32|getresgid32 -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 218, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 215, 34, 33), //setuid32|setgid32 -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 222, 33, 32), //mincore|madvise|getdents64|fcntl64 -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 252, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 245, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 244, 30, 29), //gettid|readahead|setxattr|lsetxattr|fsetxattr|getxattr|lgetxattr|fgetxattr|listxattr|llistxattr|flistxattr|removexattr|lremovexattr|fremovexattr|tkill|sendfile64|futex|sched_setaffinity|sched_getaffinity|set_thread_area -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 250, 29, 28), //io_setup|io_destroy|io_getevents|io_submit|io_cancel -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 253, 28, 27), //exit_group -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 318, 13, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 149, 51, 50), //flock|msync|readv|writev|getsid|fdatasync +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 164, 50, 49), //mlock|munlock|mlockall|munlockall|sched_setparam|sched_getparam|sched_setscheduler|sched_getscheduler|sched_yield|sched_get_priority_max|sched_get_priority_min|sched_rr_get_interval|nanosleep|mremap +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 191, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 183, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 182, 47, 46), //prctl|rt_sigreturn|rt_sigaction|rt_sigprocmask|rt_sigpending|rt_sigtimedwait|rt_sigqueueinfo|rt_sigsuspend|pread64|pwrite64 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 188, 46, 45), //getcwd|capget|capset|sigaltstack|sendfile +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 197, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 195, 44, 43), //ugetrlimit|mmap2|truncate64|ftruncate64 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 198, 43, 42), //fstat64 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 245, 7, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 218, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 213, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 212, 39, 38), //getuid32|getgid32|geteuid32|getegid32|setreuid32|setregid32|getgroups32|setgroups32|fchown32|setresuid32|getresuid32|setresgid32|getresgid32 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 215, 38, 37), //setuid32|setgid32 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 224, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 222, 36, 35), //mincore|madvise|getdents64|fcntl64 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 244, 35, 34), //gettid|readahead|setxattr|lsetxattr|fsetxattr|getxattr|lgetxattr|fgetxattr|listxattr|llistxattr|flistxattr|removexattr|lremovexattr|fremovexattr|tkill|sendfile64|futex|sched_setaffinity|sched_getaffinity|set_thread_area +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 255, 3, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 252, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 250, 32, 31), //io_setup|io_destroy|io_getevents|io_submit|io_cancel +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 253, 31, 30), //exit_group +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 256, 30, 29), //epoll_ctl +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 322, 15, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 295, 7, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 284, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 272, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 271, 23, 22), //epoll_create|epoll_ctl|epoll_wait|remap_file_pages|set_tid_address|timer_create|timer_settime|timer_gettime|timer_getoverrun|timer_delete|clock_settime|clock_gettime|clock_getres|clock_nanosleep|statfs64|fstatfs64|tgkill -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 273, 22, 21), //fadvise64_64 -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 291, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 285, 20, 19), //waitid -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 294, 19, 18), //inotify_init|inotify_add_watch|inotify_rm_watch +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 271, 25, 24), //set_tid_address|timer_create|timer_settime|timer_gettime|timer_getoverrun|timer_delete|clock_settime|clock_gettime|clock_getres|clock_nanosleep|statfs64|fstatfs64|tgkill +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 273, 24, 23), //fadvise64_64 +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 292, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 285, 22, 21), //waitid +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 294, 21, 20), //inotify_add_watch|inotify_rm_watch BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 313, 3, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 300, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 299, 16, 15), //openat|mkdirat|mknodat|fchownat -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 311, 15, 14), //fstatat64|unlinkat|renameat|linkat|symlinkat|readlinkat|fchmodat|faccessat|pselect6|ppoll|unshare -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 317, 14, 13), //splice|sync_file_range|tee|vmsplice +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 299, 18, 17), //openat|mkdirat|mknodat|fchownat +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 311, 17, 16), //fstatat64|unlinkat|renameat|linkat|symlinkat|readlinkat|fchmodat|faccessat|pselect6|ppoll|unshare +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 318, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 317, 15, 14), //splice|sync_file_range|tee|vmsplice +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 321, 14, 13), //getcpu|epoll_pwait|utimensat BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 346, 7, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 340, 3, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 322, 1, 0), -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 321, 10, 9), //getcpu|epoll_pwait|utimensat -BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 337, 9, 8), //timerfd_create|eventfd|fallocate|timerfd_settime|timerfd_gettime|signalfd4|eventfd2|epoll_create1|dup3|pipe2|inotify_init1|preadv|pwritev|rt_tgsigqueueinfo|perf_event_open +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 324, 1, 0), +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 323, 10, 9), //timerfd_create +BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 337, 9, 8), //fallocate|timerfd_settime|timerfd_gettime|signalfd4|eventfd2|epoll_create1|dup3|pipe2|inotify_init1|preadv|pwritev|rt_tgsigqueueinfo|perf_event_open BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 343, 1, 0), BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 341, 7, 6), //prlimit64 BPF_JUMP(BPF_JMP|BPF_JGE|BPF_K, 345, 6, 5), //clock_adjtime|syncfs |