cosmopolitan/libc/sysv/consts/pr.h
Justine Tunney 5a132f9652 Add seccomp bpf sandboxing to redbean
It's now possible to pass the `-S` or `-SS` flags to sandbox redbean
worker proecsses after they've been forked. The first `-S` flag is
intended to be a permissive builtin policy that limits system calls to
only that which the various parts of redbean serving need. The second
`-SS` flag is intended to be more restrictive, preventing things like
the Lua extensions you download off the web from using the HTTP client
or sockets APIs. In upcoming changes you'll be able to implement your
own Berkeley Packet Filter sandbox programs and load them via Lua.
2022-04-18 08:54:42 -07:00

102 lines
3.4 KiB
C

#ifndef COSMOPOLITAN_LIBC_SYSV_CONSTS_PR_H_
#define COSMOPOLITAN_LIBC_SYSV_CONSTS_PR_H_
#define PR_GET_SECCOMP 21
#define PR_SET_SECCOMP 22
#define SECCOMP_MODE_DISABLED 0
#define SECCOMP_MODE_STRICT 1
#define SECCOMP_MODE_FILTER 2
#define PR_SET_NO_NEW_PRIVS 38
#define PR_GET_NO_NEW_PRIVS 39
#define PR_SET_NAME 15
#define PR_GET_NAME 0x10
#define PR_GET_TSC 25
#define PR_SET_TSC 26
#define PR_TSC_ENABLE 1
#define PR_TSC_SIGSEGV 2
#define PR_GET_FPEXC 11
#define PR_SET_FPEXC 12
#define PR_FP_EXC_SW_ENABLE 0x80
#define PR_FP_EXC_DIV 0x010000
#define PR_FP_EXC_OVF 0x020000
#define PR_FP_EXC_UND 0x040000
#define PR_FP_EXC_RES 0x080000
#define PR_FP_EXC_INV 0x100000
#define PR_FP_EXC_DISABLED 0
#define PR_FP_EXC_NONRECOV 1
#define PR_FP_EXC_ASYNC 2
#define PR_FP_EXC_PRECISE 3
#define PR_MCE_KILL_CLEAR 0
#define PR_MCE_KILL_LATE 0
#define PR_SPEC_NOT_AFFECTED 0
#define PR_SPEC_STORE_BYPASS 0
#define PR_CAP_AMBIENT_IS_SET 1
#define PR_FPEMU_NOPRINT 1
#define PR_MCE_KILL_EARLY 1
#define PR_MCE_KILL_SET 1
#define PR_SET_MM_START_CODE 1
#define PR_SET_PDEATHSIG 1
#define PR_SPEC_PRCTL 1
#define PR_CAP_AMBIENT_RAISE 2
#define PR_FPEMU_SIGFPE 2
#define PR_GET_PDEATHSIG 2
#define PR_MCE_KILL_DEFAULT 2
#define PR_SET_MM_END_CODE 2
#define PR_SPEC_ENABLE 2
#define PR_CAP_AMBIENT_LOWER 3
#define PR_GET_DUMPABLE 3
#define PR_SET_MM_START_DATA 3
#define PR_CAP_AMBIENT_CLEAR_ALL 4
#define PR_SET_DUMPABLE 4
#define PR_SET_MM_END_DATA 4
#define PR_SPEC_DISABLE 4
#define PR_SET_MM_START_STACK 5
#define PR_SET_MM_START_BRK 6
#define PR_GET_KEEPCAPS 7
#define PR_SET_MM_BRK 7
#define PR_SET_KEEPCAPS 8
#define PR_SET_MM_ARG_START 8
#define PR_SPEC_FORCE_DISABLE 8
#define PR_GET_FPEMU 9
#define PR_SET_MM_ARG_END 9
#define PR_SET_FPEMU 10
#define PR_SET_MM_ENV_START 10
#define PR_GET_FPEXC 11
#define PR_SET_MM_ENV_END 11
#define PR_SET_FPEXC 12
#define PR_SET_MM_AUXV 12
#define PR_SET_MM_EXE_FILE 13
#define PR_SET_MM_MAP 14
#define PR_SET_MM_MAP_SIZE 15
#define PR_CAPBSET_READ 23
#define PR_CAPBSET_DROP 24
#define PR_GET_TSC 25
#define PR_SET_TSC 26
#define PR_GET_SECUREBITS 27
#define PR_SET_SECUREBITS 28
#define PR_SET_TIMERSLACK 29
#define PR_GET_TIMERSLACK 30
#define PR_TASK_PERF_EVENTS_DISABLE 31
#define PR_TASK_PERF_EVENTS_ENABLE 0x20
#define PR_MCE_KILL 33
#define PR_MCE_KILL_GET 34
#define PR_SET_MM 35
#define PR_SET_CHILD_SUBREAPER 36
#define PR_GET_CHILD_SUBREAPER 37
#define PR_GET_TID_ADDRESS 40
#define PR_SET_THP_DISABLE 41
#define PR_GET_THP_DISABLE 42
#define PR_MPX_ENABLE_MANAGEMENT 43
#define PR_MPX_DISABLE_MANAGEMENT 44
#define PR_CAP_AMBIENT 47
#define PR_GET_SPECULATION_CTRL 52
#define PR_SET_SPECULATION_CTRL 53
#define PR_SET_PTRACER 0x59616d61
#define PR_SET_PTRACER_ANY -1
#endif /* COSMOPOLITAN_LIBC_SYSV_CONSTS_PR_H_ */