blob: 049d577fd7d469ddd9ba259bb259be0aa971608d [file] [log] [blame]
Victor Hsiehdbb86702020-06-15 09:29:07 -07001# This file is used to populate seccomp's allowlist policy in combination with SYSCALLS.TXT.
Victor Hsieh2f23ced2018-01-17 16:59:12 -08002# Note that the resultant policy is applied only to zygote spawned processes.
3#
Victor Hsiehdbb86702020-06-15 09:29:07 -07004# 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
Victor Hsieh2f23ced2018-01-17 16:59:12 -08006#
Victor Hsieh2f23ced2018-01-17 16:59:12 -08007# This file is processed by a python script named genseccomp.py.
8
Victor Hsiehe15233c2018-03-28 16:30:20 -07009# Note: Some privileged syscalls are still needed in app process after fork before uid change,
Martijn Coenene17fce12019-01-21 14:29:35 +010010# 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.
Victor Hsiehe15233c2018-03-28 16:30:20 -070012
Victor Hsieh2f23ced2018-01-17 16:59:12 -080013# syscalls to modify IDs
Elliott Hughes2b499042020-02-13 14:21:55 -080014int 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
Martijn Coenene17fce12019-01-21 14:29:35 +010024# setresuid is explicitly allowed, see above.
Elliott Hughes8dc9f462023-02-03 23:10:04 +000025int setfsgid:setfsgid32(gid_t) lp32
26int setfsgid:setfsgid(gid_t) lp64
27int setfsuid:setfsuid32(uid_t) lp32
28int setfsuid:setfsuid(uid_t) lp64
Elliott Hughes2b499042020-02-13 14:21:55 -080029int setgroups:setgroups32(int, const gid_t*) lp32
30int setgroups:setgroups(int, const gid_t*) lp64
Victor Hsieh2f23ced2018-01-17 16:59:12 -080031
32# syscalls to modify times
33int adjtimex(struct timex*) all
34int clock_adjtime(clockid_t, struct timex*) all
35int clock_settime(clockid_t, const struct timespec*) all
36int settimeofday(const struct timeval*, const struct timezone*) all
37
38int acct(const char* filepath) all
39int klogctl:syslog(int, char*, int) all
Victor Hsieh2f23ced2018-01-17 16:59:12 -080040int chroot(const char*) all
41
42# syscalls to change machine various configurations
43int init_module(void*, unsigned long, const char*) all
44int delete_module(const char*, unsigned int) all
45int mount(const char*, const char*, const char*, unsigned long, const void*) all
46int umount2(const char*, int) all
47int swapon(const char*, int) all
48int swapoff(const char*) all
49int setdomainname(const char*, size_t) all
50int sethostname(const char*, size_t) all
51int __reboot:reboot(int, int, int, void*) all