mirror of
https://github.com/torvalds/linux.git
synced 2026-04-18 06:44:00 -04:00
The added fsession does not prevent running on those architectures, that
haven't added fsession support.
For example, try to run fsession tests on arm64:
test_fsession_basic:PASS:fsession_test__open_and_load 0 nsec
test_fsession_basic:PASS:fsession_attach 0 nsec
check_result:FAIL:test_run_opts err unexpected error: -14 (errno 14)
In order to prevent such errors, add bpf_jit_supports_fsession() to guard
those architectures.
Fixes: 2d419c4465 ("bpf: add fsession support")
Acked-by: Puranjay Mohan <puranjay@kernel.org>
Tested-by: Puranjay Mohan <puranjay@kernel.org>
Signed-off-by: Leon Hwang <leon.hwang@linux.dev>
Link: https://lore.kernel.org/r/20260131144950.16294-2-leon.hwang@linux.dev
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
141 lines
3.0 KiB
C
141 lines
3.0 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
/* Copyright (c) 2025 ChinaTelecom */
|
|
#include <test_progs.h>
|
|
#include "fsession_test.skel.h"
|
|
|
|
static int check_result(struct fsession_test *skel)
|
|
{
|
|
LIBBPF_OPTS(bpf_test_run_opts, topts);
|
|
int err, prog_fd;
|
|
|
|
/* Trigger test function calls */
|
|
prog_fd = bpf_program__fd(skel->progs.test1);
|
|
err = bpf_prog_test_run_opts(prog_fd, &topts);
|
|
if (!ASSERT_OK(err, "test_run_opts err"))
|
|
return err;
|
|
if (!ASSERT_OK(topts.retval, "test_run_opts retval"))
|
|
return topts.retval;
|
|
|
|
for (int i = 0; i < sizeof(*skel->bss) / sizeof(__u64); i++) {
|
|
if (!ASSERT_EQ(((__u64 *)skel->bss)[i], 1, "test_result"))
|
|
return -EINVAL;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
static void test_fsession_basic(void)
|
|
{
|
|
struct fsession_test *skel = NULL;
|
|
int err;
|
|
|
|
skel = fsession_test__open();
|
|
if (!ASSERT_OK_PTR(skel, "fsession_test__open"))
|
|
return;
|
|
|
|
err = fsession_test__load(skel);
|
|
if (err == -EOPNOTSUPP) {
|
|
test__skip();
|
|
goto cleanup;
|
|
}
|
|
if (!ASSERT_OK(err, "fsession_test__load"))
|
|
goto cleanup;
|
|
|
|
err = fsession_test__attach(skel);
|
|
if (!ASSERT_OK(err, "fsession_attach"))
|
|
goto cleanup;
|
|
|
|
check_result(skel);
|
|
cleanup:
|
|
fsession_test__destroy(skel);
|
|
}
|
|
|
|
static void test_fsession_reattach(void)
|
|
{
|
|
struct fsession_test *skel = NULL;
|
|
int err;
|
|
|
|
skel = fsession_test__open();
|
|
if (!ASSERT_OK_PTR(skel, "fsession_test__open"))
|
|
return;
|
|
|
|
err = fsession_test__load(skel);
|
|
if (err == -EOPNOTSUPP) {
|
|
test__skip();
|
|
goto cleanup;
|
|
}
|
|
if (!ASSERT_OK(err, "fsession_test__load"))
|
|
goto cleanup;
|
|
|
|
/* first attach */
|
|
err = fsession_test__attach(skel);
|
|
if (!ASSERT_OK(err, "fsession_first_attach"))
|
|
goto cleanup;
|
|
|
|
if (check_result(skel))
|
|
goto cleanup;
|
|
|
|
/* detach */
|
|
fsession_test__detach(skel);
|
|
|
|
/* reset counters */
|
|
memset(skel->bss, 0, sizeof(*skel->bss));
|
|
|
|
/* second attach */
|
|
err = fsession_test__attach(skel);
|
|
if (!ASSERT_OK(err, "fsession_second_attach"))
|
|
goto cleanup;
|
|
|
|
if (check_result(skel))
|
|
goto cleanup;
|
|
|
|
cleanup:
|
|
fsession_test__destroy(skel);
|
|
}
|
|
|
|
static void test_fsession_cookie(void)
|
|
{
|
|
struct fsession_test *skel = NULL;
|
|
int err;
|
|
|
|
skel = fsession_test__open();
|
|
if (!ASSERT_OK_PTR(skel, "fsession_test__open"))
|
|
goto cleanup;
|
|
|
|
/*
|
|
* The test_fsession_basic() will test the session cookie with
|
|
* bpf_get_func_ip() case, so we need only check
|
|
* the cookie without bpf_get_func_ip() case here
|
|
*/
|
|
bpf_program__set_autoload(skel->progs.test6, false);
|
|
|
|
err = fsession_test__load(skel);
|
|
if (err == -EOPNOTSUPP) {
|
|
test__skip();
|
|
goto cleanup;
|
|
}
|
|
if (!ASSERT_OK(err, "fsession_test__load"))
|
|
goto cleanup;
|
|
|
|
err = fsession_test__attach(skel);
|
|
if (!ASSERT_OK(err, "fsession_attach"))
|
|
goto cleanup;
|
|
|
|
skel->bss->test6_entry_result = 1;
|
|
skel->bss->test6_exit_result = 1;
|
|
|
|
check_result(skel);
|
|
cleanup:
|
|
fsession_test__destroy(skel);
|
|
}
|
|
|
|
void test_fsession_test(void)
|
|
{
|
|
if (test__start_subtest("fsession_test"))
|
|
test_fsession_basic();
|
|
if (test__start_subtest("fsession_reattach"))
|
|
test_fsession_reattach();
|
|
if (test__start_subtest("fsession_cookie"))
|
|
test_fsession_cookie();
|
|
}
|