1# This file is used to populate seccomp's allowlist policy in combination with SYSCALLS.TXT. 2# Note that the resultant policy is applied only to zygote spawned processes. 3# 4# The final seccomp allowlist is SYSCALLS.TXT - SECCOMP_BLOCKLIST.TXT + SECCOMP_ALLOWLIST.TXT 5# Any entry in the blocklist must be in the syscalls file and not be in the allowlist file 6# 7# This file is processed by a python script named genseccomp.py. 8 9# Note: Some privileged syscalls are still needed in app process after fork before uid change, 10# including capset and setresuid. This is because the seccomp filter must be installed while 11# the process still has CAP_SYS_ADMIN; changing the uid would remove that capability. 12 13# syscalls to modify IDs 14int setgid:setgid32(gid_t) lp32 15int setgid:setgid(gid_t) lp64 16int setuid:setuid32(uid_t) lp32 17int setuid:setuid(uid_t) lp64 18int setregid:setregid32(gid_t, gid_t) lp32 19int setregid:setregid(gid_t, gid_t) lp64 20int setreuid:setreuid32(uid_t, uid_t) lp32 21int setreuid:setreuid(uid_t, uid_t) lp64 22int setresgid:setresgid32(gid_t, gid_t, gid_t) lp32 23int setresgid:setresgid(gid_t, gid_t, gid_t) lp64 24# setresuid is explicitly allowed, see above. 25int setfsgid(gid_t) all 26int setfsuid(uid_t) all 27int setgroups:setgroups32(int, const gid_t*) lp32 28int setgroups:setgroups(int, const gid_t*) lp64 29 30# syscalls to modify times 31int adjtimex(struct timex*) all 32int clock_adjtime(clockid_t, struct timex*) all 33int clock_settime(clockid_t, const struct timespec*) all 34int settimeofday(const struct timeval*, const struct timezone*) all 35 36int acct(const char* filepath) all 37int klogctl:syslog(int, char*, int) all 38int chroot(const char*) all 39 40# syscalls to change machine various configurations 41int init_module(void*, unsigned long, const char*) all 42int delete_module(const char*, unsigned int) all 43int mount(const char*, const char*, const char*, unsigned long, const void*) all 44int umount2(const char*, int) all 45int swapon(const char*, int) all 46int swapoff(const char*) all 47int setdomainname(const char*, size_t) all 48int sethostname(const char*, size_t) all 49int __reboot:reboot(int, int, int, void*) all 50