diff options
author | Cristian Toader <cristian.matei.toader@gmail.com> | 2013-07-31 12:05:10 +0300 |
---|---|---|
committer | Cristian Toader <cristian.matei.toader@gmail.com> | 2013-07-31 12:05:10 +0300 |
commit | dde3ed385bc9de8bffa52b9b5e525fb7a0aae88b (patch) | |
tree | e2d38ecb90bc76f9a9201d0ba0d35daf7889bce2 | |
parent | 313cbe6e24618c4c5875c8e3aab4cd563c97791f (diff) | |
download | tor-dde3ed385bc9de8bffa52b9b5e525fb7a0aae88b.tar tor-dde3ed385bc9de8bffa52b9b5e525fb7a0aae88b.tar.gz |
removed access, set_robust_list, set_thread_area, set_tid_address, uname; added sb_poll
-rw-r--r-- | src/common/sandbox.c | 31 |
1 files changed, 24 insertions, 7 deletions
diff --git a/src/common/sandbox.c b/src/common/sandbox.c index fe2f457b0..d330cab98 100644 --- a/src/common/sandbox.c +++ b/src/common/sandbox.c @@ -43,6 +43,7 @@ #include <unistd.h> #include <fcntl.h> #include <time.h> +#include <poll.h> sandbox_cfg_t *filter_dynamic = NULL; @@ -50,7 +51,6 @@ sandbox_cfg_t *filter_dynamic = NULL; * stage 1 general Tor sandbox. */ static int filter_nopar_gen[] = { - SCMP_SYS(access), SCMP_SYS(brk), SCMP_SYS(close), SCMP_SYS(clone), @@ -88,25 +88,27 @@ static int filter_nopar_gen[] = { SCMP_SYS(mlockall), SCMP_SYS(mmap), SCMP_SYS(munmap), - SCMP_SYS(poll), SCMP_SYS(read), SCMP_SYS(rename), SCMP_SYS(rt_sigreturn), #ifdef __NR_sigreturn SCMP_SYS(sigreturn), #endif - SCMP_SYS(set_robust_list), - SCMP_SYS(set_thread_area), - SCMP_SYS(set_tid_address), SCMP_SYS(stat), #ifdef __NR_stat64 SCMP_SYS(stat64), #endif - SCMP_SYS(uname), SCMP_SYS(write), SCMP_SYS(exit_group), SCMP_SYS(exit), + // Not needed.. +// SCMP_SYS(access), +// SCMP_SYS(set_robust_list), +// SCMP_SYS(set_thread_area), +// SCMP_SYS(set_tid_address), +// SCMP_SYS(uname), + // socket syscalls SCMP_SYS(bind), SCMP_SYS(connect), @@ -437,6 +439,20 @@ sb_mremap(scmp_filter_ctx ctx) return 0; } +static int +sb_poll(scmp_filter_ctx ctx) +{ + int rc = 0; + + rc = seccomp_rule_add(ctx, SCMP_ACT_ALLOW, SCMP_SYS(poll), 2, + SCMP_CMP(1, SCMP_CMP_EQ, 1), + SCMP_CMP(2, SCMP_CMP_EQ, 10)); + if (rc) + return rc; + + return 0; +} + static sandbox_filter_func_t filter_func[] = { sb_rt_sigaction, sb_rt_sigprocmask, @@ -453,7 +469,8 @@ static sandbox_filter_func_t filter_func[] = { sb_mprotect, sb_flock, sb_futex, - sb_mremap + sb_mremap, + sb_poll }; const char* |