mirror of
https://github.com/torvalds/linux.git
synced 2026-05-31 10:33:41 +02:00
selftests/bpf: Add verifier tests for bpf lsm
Add verifier tests to check bpf lsm return values and disabled hooks. Signed-off-by: Xu Kuohai <xukuohai@huawei.com> Link: https://lore.kernel.org/r/20240719110059.797546-10-xukuohai@huaweicloud.com Signed-off-by: Alexei Starovoitov <ast@kernel.org> Signed-off-by: Andrii Nakryiko <andrii@kernel.org>
This commit is contained in:
parent
d463dd9c9a
commit
04d8243b1f
|
|
@ -88,6 +88,7 @@
|
|||
#include "verifier_xdp.skel.h"
|
||||
#include "verifier_xdp_direct_packet_access.skel.h"
|
||||
#include "verifier_bits_iter.skel.h"
|
||||
#include "verifier_lsm.skel.h"
|
||||
|
||||
#define MAX_ENTRIES 11
|
||||
|
||||
|
|
@ -206,6 +207,7 @@ void test_verifier_xadd(void) { RUN(verifier_xadd); }
|
|||
void test_verifier_xdp(void) { RUN(verifier_xdp); }
|
||||
void test_verifier_xdp_direct_packet_access(void) { RUN(verifier_xdp_direct_packet_access); }
|
||||
void test_verifier_bits_iter(void) { RUN(verifier_bits_iter); }
|
||||
void test_verifier_lsm(void) { RUN(verifier_lsm); }
|
||||
|
||||
static int init_test_val_map(struct bpf_object *obj, char *map_name)
|
||||
{
|
||||
|
|
|
|||
162
tools/testing/selftests/bpf/progs/verifier_lsm.c
Normal file
162
tools/testing/selftests/bpf/progs/verifier_lsm.c
Normal file
|
|
@ -0,0 +1,162 @@
|
|||
// SPDX-License-Identifier: GPL-2.0
|
||||
|
||||
#include <linux/bpf.h>
|
||||
#include <bpf/bpf_helpers.h>
|
||||
#include "bpf_misc.h"
|
||||
|
||||
SEC("lsm/file_alloc_security")
|
||||
__description("lsm bpf prog with -4095~0 retval. test 1")
|
||||
__success
|
||||
__naked int errno_zero_retval_test1(void *ctx)
|
||||
{
|
||||
asm volatile (
|
||||
"r0 = 0;"
|
||||
"exit;"
|
||||
::: __clobber_all);
|
||||
}
|
||||
|
||||
SEC("lsm/file_alloc_security")
|
||||
__description("lsm bpf prog with -4095~0 retval. test 2")
|
||||
__success
|
||||
__naked int errno_zero_retval_test2(void *ctx)
|
||||
{
|
||||
asm volatile (
|
||||
"r0 = -4095;"
|
||||
"exit;"
|
||||
::: __clobber_all);
|
||||
}
|
||||
|
||||
SEC("lsm/file_mprotect")
|
||||
__description("lsm bpf prog with -4095~0 retval. test 4")
|
||||
__failure __msg("R0 has smin=-4096 smax=-4096 should have been in [-4095, 0]")
|
||||
__naked int errno_zero_retval_test4(void *ctx)
|
||||
{
|
||||
asm volatile (
|
||||
"r0 = -4096;"
|
||||
"exit;"
|
||||
::: __clobber_all);
|
||||
}
|
||||
|
||||
SEC("lsm/file_mprotect")
|
||||
__description("lsm bpf prog with -4095~0 retval. test 5")
|
||||
__failure __msg("R0 has smin=4096 smax=4096 should have been in [-4095, 0]")
|
||||
__naked int errno_zero_retval_test5(void *ctx)
|
||||
{
|
||||
asm volatile (
|
||||
"r0 = 4096;"
|
||||
"exit;"
|
||||
::: __clobber_all);
|
||||
}
|
||||
|
||||
SEC("lsm/file_mprotect")
|
||||
__description("lsm bpf prog with -4095~0 retval. test 6")
|
||||
__failure __msg("R0 has smin=1 smax=1 should have been in [-4095, 0]")
|
||||
__naked int errno_zero_retval_test6(void *ctx)
|
||||
{
|
||||
asm volatile (
|
||||
"r0 = 1;"
|
||||
"exit;"
|
||||
::: __clobber_all);
|
||||
}
|
||||
|
||||
SEC("lsm/audit_rule_known")
|
||||
__description("lsm bpf prog with bool retval. test 1")
|
||||
__success
|
||||
__naked int bool_retval_test1(void *ctx)
|
||||
{
|
||||
asm volatile (
|
||||
"r0 = 1;"
|
||||
"exit;"
|
||||
::: __clobber_all);
|
||||
}
|
||||
|
||||
SEC("lsm/audit_rule_known")
|
||||
__description("lsm bpf prog with bool retval. test 2")
|
||||
__success
|
||||
__success
|
||||
__naked int bool_retval_test2(void *ctx)
|
||||
{
|
||||
asm volatile (
|
||||
"r0 = 0;"
|
||||
"exit;"
|
||||
::: __clobber_all);
|
||||
}
|
||||
|
||||
SEC("lsm/audit_rule_known")
|
||||
__description("lsm bpf prog with bool retval. test 3")
|
||||
__failure __msg("R0 has smin=-1 smax=-1 should have been in [0, 1]")
|
||||
__naked int bool_retval_test3(void *ctx)
|
||||
{
|
||||
asm volatile (
|
||||
"r0 = -1;"
|
||||
"exit;"
|
||||
::: __clobber_all);
|
||||
}
|
||||
|
||||
SEC("lsm/audit_rule_known")
|
||||
__description("lsm bpf prog with bool retval. test 4")
|
||||
__failure __msg("R0 has smin=2 smax=2 should have been in [0, 1]")
|
||||
__naked int bool_retval_test4(void *ctx)
|
||||
{
|
||||
asm volatile (
|
||||
"r0 = 2;"
|
||||
"exit;"
|
||||
::: __clobber_all);
|
||||
}
|
||||
|
||||
SEC("lsm/file_free_security")
|
||||
__success
|
||||
__description("lsm bpf prog with void retval. test 1")
|
||||
__naked int void_retval_test1(void *ctx)
|
||||
{
|
||||
asm volatile (
|
||||
"r0 = -4096;"
|
||||
"exit;"
|
||||
::: __clobber_all);
|
||||
}
|
||||
|
||||
SEC("lsm/file_free_security")
|
||||
__success
|
||||
__description("lsm bpf prog with void retval. test 2")
|
||||
__naked int void_retval_test2(void *ctx)
|
||||
{
|
||||
asm volatile (
|
||||
"r0 = 4096;"
|
||||
"exit;"
|
||||
::: __clobber_all);
|
||||
}
|
||||
|
||||
SEC("lsm/getprocattr")
|
||||
__description("lsm disabled hook: getprocattr")
|
||||
__failure __msg("points to disabled hook")
|
||||
__naked int disabled_hook_test1(void *ctx)
|
||||
{
|
||||
asm volatile (
|
||||
"r0 = 0;"
|
||||
"exit;"
|
||||
::: __clobber_all);
|
||||
}
|
||||
|
||||
SEC("lsm/setprocattr")
|
||||
__description("lsm disabled hook: setprocattr")
|
||||
__failure __msg("points to disabled hook")
|
||||
__naked int disabled_hook_test2(void *ctx)
|
||||
{
|
||||
asm volatile (
|
||||
"r0 = 0;"
|
||||
"exit;"
|
||||
::: __clobber_all);
|
||||
}
|
||||
|
||||
SEC("lsm/ismaclabel")
|
||||
__description("lsm disabled hook: ismaclabel")
|
||||
__failure __msg("points to disabled hook")
|
||||
__naked int disabled_hook_test3(void *ctx)
|
||||
{
|
||||
asm volatile (
|
||||
"r0 = 0;"
|
||||
"exit;"
|
||||
::: __clobber_all);
|
||||
}
|
||||
|
||||
char _license[] SEC("license") = "GPL";
|
||||
Loading…
Reference in New Issue
Block a user