tests: check handling of seccomp SECCOMP_RET_TRAP

* tests/seccomp_ret_trap.c: New file.
* tests/seccomp_ret_trap.expected: Likewise.
* tests/Makefile.am (EXTRA_DIST): Add it.
* tests/pure_executables.list (seccomp_ret_trap): New entry.
* tests/.gitignore: Add seccomp_ret_trap.
* tests/gen_tests.in: Likewise.
This commit is contained in:
Дмитрий Левин 2017-11-07 02:27:55 +00:00
parent 8932ac050e
commit 14f8e30813
6 changed files with 117 additions and 0 deletions

1
tests/.gitignore vendored
View File

@ -384,6 +384,7 @@ seccomp-filter
seccomp-filter-v seccomp-filter-v
seccomp-strict seccomp-strict
seccomp_get_action_avail seccomp_get_action_avail
seccomp_ret_trap
select select
select-P select-P
semop semop

View File

@ -374,6 +374,7 @@ EXTRA_DIST = \
run.sh \ run.sh \
sched.in \ sched.in \
scno_tampering.sh \ scno_tampering.sh \
seccomp_ret_trap.expected \
setfsugid.c \ setfsugid.c \
setresugid.c \ setresugid.c \
setreugid.c \ setreugid.c \

View File

@ -335,6 +335,7 @@ sched_yield -a14
seccomp-filter -e trace=seccomp seccomp-filter -e trace=seccomp
seccomp-filter-v -v -e trace=seccomp seccomp-filter-v -v -e trace=seccomp
seccomp_get_action_avail -e trace=seccomp seccomp_get_action_avail -e trace=seccomp
seccomp_ret_trap run_prog; run_strace -a11 -esignal=none -echdir $args; match_diff
select -a36 select -a36
select-P -a36 -e trace=select -P /dev/full 9>>/dev/full select-P -a36 -e trace=select -P /dev/full 9>>/dev/full
semop -a32 -e trace=semop,semtimedop semop -a32 -e trace=semop,semtimedop

View File

@ -315,6 +315,7 @@ sched_xetscheduler
sched_yield sched_yield
seccomp-filter seccomp-filter
seccomp_get_action_avail seccomp_get_action_avail
seccomp_ret_trap
select select
semop semop
sendfile sendfile

110
tests/seccomp_ret_trap.c Normal file
View File

@ -0,0 +1,110 @@
/*
* Check handling of seccomp SECCOMP_RET_TRAP.
*
* Copyright (c) 2015-2017 Dmitry V. Levin <ldv@altlinux.org>
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#include "tests.h"
#include <signal.h>
#include <stddef.h>
#include <stdio.h>
#include <unistd.h>
#include <asm/unistd.h>
#ifdef HAVE_PRCTL
# include <sys/prctl.h>
#endif
#ifdef HAVE_LINUX_SECCOMP_H
# include <linux/seccomp.h>
#endif
#include <linux/filter.h>
#if defined __NR_seccomp \
&& defined PR_SET_NO_NEW_PRIVS \
&& defined SECCOMP_SET_MODE_FILTER \
&& defined SECCOMP_RET_TRAP \
&& defined BPF_JUMP \
&& defined BPF_STMT
static struct sock_filter filter[] = {
/* load syscall number */
BPF_STMT(BPF_LD|BPF_W|BPF_ABS, offsetof(struct seccomp_data, nr)),
/* trap nanosleep syscall */
BPF_JUMP(BPF_JMP|BPF_K|BPF_JEQ, __NR_nanosleep, 0, 1),
BPF_STMT(BPF_RET|BPF_K, SECCOMP_RET_TRAP),
/* continue with the system call */
BPF_STMT(BPF_RET|BPF_K, SECCOMP_RET_ALLOW)
};
static const struct sock_fprog prog = {
.filter = filter, .len = ARRAY_SIZE(filter)
};
static sigset_t mask;
static const struct timespec ts = { 0, 0 };
static void
handler(int sig)
{
}
int
main(void)
{
if (prctl(PR_SET_NO_NEW_PRIVS, 1, 0, 0, 0))
perror_msg_and_skip("PR_SET_NO_NEW_PRIVS");
if (syscall(__NR_seccomp, SECCOMP_SET_MODE_FILTER, 0, &prog))
perror_msg_and_skip("SECCOMP_SET_MODE_FILTER");
if (sigprocmask(SIG_SETMASK, &mask, NULL))
perror_msg_and_fail("sigprocmask");
if (signal(SIGSYS, handler))
perror_msg_and_fail("signal");
if (chdir("."))
perror_msg_and_fail("chdir");
syscall(__NR_nanosleep, &ts, NULL);
if (chdir("./"))
perror_msg_and_fail("chdir");
return 0;
}
#else
SKIP_MAIN_UNDEFINED("__NR_seccomp && PR_SET_NO_NEW_PRIVS"
" && SECCOMP_SET_MODE_FILTER && SECCOMP_RET_TRAP"
" && BPF_JUMP && BPF_STMT")
#endif

View File

@ -0,0 +1,3 @@
chdir(".") = 0
chdir("./") = 0
+++ exited with 0 +++