mirror of
https://gitee.com/bianbu-linux/linux-6.6
synced 2025-04-24 14:07:52 -04:00
Add fentry_many_args.c and fexit_many_args.c to test the fentry/fexit with 7/11 arguments. As this feature is not supported by arm64 yet, we disable these testcases for arm64 in DENYLIST.aarch64. We can combine them with fentry_test.c/fexit_test.c when arm64 is supported too. Correspondingly, add bpf_testmod_fentry_test7() and bpf_testmod_fentry_test11() to bpf_testmod.c Meanwhile, add bpf_modify_return_test2() to test_run.c to test the MODIFY_RETURN with 7 arguments. Add bpf_testmod_test_struct_arg_7/bpf_testmod_test_struct_arg_7 in bpf_testmod.c to test the struct in the arguments. And the testcases passed on x86_64: ./test_progs -t fexit Summary: 5/14 PASSED, 0 SKIPPED, 0 FAILED ./test_progs -t fentry Summary: 3/2 PASSED, 0 SKIPPED, 0 FAILED ./test_progs -t modify_return Summary: 1/0 PASSED, 0 SKIPPED, 0 FAILED ./test_progs -t tracing_struct Summary: 1/0 PASSED, 0 SKIPPED, 0 FAILED Signed-off-by: Menglong Dong <imagedong@tencent.com> Acked-by: Yonghong Song <yhs@fb.com> Link: https://lore.kernel.org/r/20230713040738.1789742-4-imagedong@tencent.com Signed-off-by: Alexei Starovoitov <ast@kernel.org>
93 lines
2.3 KiB
C
93 lines
2.3 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
/* Copyright (c) 2019 Facebook */
|
|
#include <test_progs.h>
|
|
#include "fexit_test.lskel.h"
|
|
#include "fexit_many_args.skel.h"
|
|
|
|
static int fexit_test_common(struct fexit_test_lskel *fexit_skel)
|
|
{
|
|
int err, prog_fd, i;
|
|
int link_fd;
|
|
__u64 *result;
|
|
LIBBPF_OPTS(bpf_test_run_opts, topts);
|
|
|
|
err = fexit_test_lskel__attach(fexit_skel);
|
|
if (!ASSERT_OK(err, "fexit_attach"))
|
|
return err;
|
|
|
|
/* Check that already linked program can't be attached again. */
|
|
link_fd = fexit_test_lskel__test1__attach(fexit_skel);
|
|
if (!ASSERT_LT(link_fd, 0, "fexit_attach_link"))
|
|
return -1;
|
|
|
|
prog_fd = fexit_skel->progs.test1.prog_fd;
|
|
err = bpf_prog_test_run_opts(prog_fd, &topts);
|
|
ASSERT_OK(err, "test_run");
|
|
ASSERT_EQ(topts.retval, 0, "test_run");
|
|
|
|
result = (__u64 *)fexit_skel->bss;
|
|
for (i = 0; i < sizeof(*fexit_skel->bss) / sizeof(__u64); i++) {
|
|
if (!ASSERT_EQ(result[i], 1, "fexit_result"))
|
|
return -1;
|
|
}
|
|
|
|
fexit_test_lskel__detach(fexit_skel);
|
|
|
|
/* zero results for re-attach test */
|
|
memset(fexit_skel->bss, 0, sizeof(*fexit_skel->bss));
|
|
return 0;
|
|
}
|
|
|
|
static void fexit_test(void)
|
|
{
|
|
struct fexit_test_lskel *fexit_skel = NULL;
|
|
int err;
|
|
|
|
fexit_skel = fexit_test_lskel__open_and_load();
|
|
if (!ASSERT_OK_PTR(fexit_skel, "fexit_skel_load"))
|
|
goto cleanup;
|
|
|
|
err = fexit_test_common(fexit_skel);
|
|
if (!ASSERT_OK(err, "fexit_first_attach"))
|
|
goto cleanup;
|
|
|
|
err = fexit_test_common(fexit_skel);
|
|
ASSERT_OK(err, "fexit_second_attach");
|
|
|
|
cleanup:
|
|
fexit_test_lskel__destroy(fexit_skel);
|
|
}
|
|
|
|
static void fexit_many_args(void)
|
|
{
|
|
struct fexit_many_args *fexit_skel = NULL;
|
|
int err;
|
|
|
|
fexit_skel = fexit_many_args__open_and_load();
|
|
if (!ASSERT_OK_PTR(fexit_skel, "fexit_many_args_skel_load"))
|
|
goto cleanup;
|
|
|
|
err = fexit_many_args__attach(fexit_skel);
|
|
if (!ASSERT_OK(err, "fexit_many_args_attach"))
|
|
goto cleanup;
|
|
|
|
ASSERT_OK(trigger_module_test_read(1), "trigger_read");
|
|
|
|
ASSERT_EQ(fexit_skel->bss->test1_result, 1,
|
|
"fexit_many_args_result1");
|
|
ASSERT_EQ(fexit_skel->bss->test2_result, 1,
|
|
"fexit_many_args_result2");
|
|
ASSERT_EQ(fexit_skel->bss->test3_result, 1,
|
|
"fexit_many_args_result3");
|
|
|
|
cleanup:
|
|
fexit_many_args__destroy(fexit_skel);
|
|
}
|
|
|
|
void test_fexit_test(void)
|
|
{
|
|
if (test__start_subtest("fexit"))
|
|
fexit_test();
|
|
if (test__start_subtest("fexit_many_args"))
|
|
fexit_many_args();
|
|
}
|