mirror of
https://github.com/QingdaoU/Judger.git
synced 2025-01-16 17:25:24 +00:00
add whitelist
This commit is contained in:
parent
fb96e31733
commit
54bd029d93
@ -29,7 +29,9 @@
|
|||||||
#include <unistd.h> // readlink
|
#include <unistd.h> // readlink
|
||||||
#include <seccomp.h>
|
#include <seccomp.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
int syscalls_whitelist[] = {SCMP_SYS(read), SCMP_SYS(write), SCMP_SYS(open), SCMP_SYS(close),
|
||||||
|
SCMP_SYS(fstat), SCMP_SYS(mmap), SCMP_SYS(mprotect), SCMP_SYS(munmap),
|
||||||
|
SCMP_SYS(brk), SCMP_SYS(access), SCMP_SYS(exit_group), SCMP_SYS(arch_prctl)};
|
||||||
typedef int (*main_t)(int, char **, char **);
|
typedef int (*main_t)(int, char **, char **);
|
||||||
|
|
||||||
#ifndef __unbounded
|
#ifndef __unbounded
|
||||||
@ -48,6 +50,7 @@ int __libc_start_main(main_t main, int argc,
|
|||||||
int i;
|
int i;
|
||||||
ssize_t len;
|
ssize_t len;
|
||||||
void *libc;
|
void *libc;
|
||||||
|
int whitelist_length = sizeof(syscalls_whitelist) / sizeof(int);
|
||||||
scmp_filter_ctx ctx = NULL;
|
scmp_filter_ctx ctx = NULL;
|
||||||
int (*libc_start_main)(main_t main,
|
int (*libc_start_main)(main_t main,
|
||||||
int,
|
int,
|
||||||
@ -65,9 +68,10 @@ int __libc_start_main(main_t main, int argc,
|
|||||||
libc_start_main = dlsym(libc, "__libc_start_main");
|
libc_start_main = dlsym(libc, "__libc_start_main");
|
||||||
if (!libc_start_main) exit(-2);
|
if (!libc_start_main) exit(-2);
|
||||||
|
|
||||||
ctx = seccomp_init(SCMP_ACT_ALLOW);
|
ctx = seccomp_init(SCMP_ACT_KILL);
|
||||||
if (!ctx) goto out;
|
if (!ctx) goto out;
|
||||||
if (seccomp_rule_add(ctx, SCMP_ACT_KILL, SCMP_SYS(clone), 0)) goto out;
|
for(i = 0; i < whitelist_length; i++)
|
||||||
|
if (seccomp_rule_add(ctx, SCMP_ACT_ALLOW, syscalls_whitelist[i], 0)) goto out;
|
||||||
if (seccomp_load(ctx)) goto out;
|
if (seccomp_load(ctx)) goto out;
|
||||||
out:
|
out:
|
||||||
if (ctx) seccomp_release(ctx);
|
if (ctx) seccomp_release(ctx);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user