mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-09-04 20:19:47 +08:00

Also, avoid using CO-RE features, as lskel doesn't support CO-RE, yet.
Include both light and libbpf skeleton in same file to test both of them
together.
In c48e51c8b0
("bpf: selftests: Add selftests for module kfunc support"),
I added support for generating both lskel and libbpf skel for a BPF
object, however the name parameter for bpftool caused collisions when
included in same file together. This meant that every test needed a
separate file for a libbpf/light skeleton separation instead of
subtests.
Change that by appending a "_lskel" suffix to the name for files using
light skeleton, and convert all existing users.
Signed-off-by: Kumar Kartikeya Dwivedi <memxor@gmail.com>
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Acked-by: Andrii Nakryiko <andrii@kernel.org>
Link: https://lore.kernel.org/bpf/20211028063501.2239335-7-memxor@gmail.com
63 lines
1.5 KiB
C
63 lines
1.5 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
/* Copyright (c) 2021 Facebook */
|
|
|
|
#include <test_progs.h>
|
|
#include <network_helpers.h>
|
|
#include "test_ksyms_module.lskel.h"
|
|
#include "test_ksyms_module.skel.h"
|
|
|
|
void test_ksyms_module_lskel(void)
|
|
{
|
|
struct test_ksyms_module_lskel *skel;
|
|
int retval;
|
|
int err;
|
|
|
|
if (!env.has_testmod) {
|
|
test__skip();
|
|
return;
|
|
}
|
|
|
|
skel = test_ksyms_module_lskel__open_and_load();
|
|
if (!ASSERT_OK_PTR(skel, "test_ksyms_module_lskel__open_and_load"))
|
|
return;
|
|
err = bpf_prog_test_run(skel->progs.load.prog_fd, 1, &pkt_v4, sizeof(pkt_v4),
|
|
NULL, NULL, (__u32 *)&retval, NULL);
|
|
if (!ASSERT_OK(err, "bpf_prog_test_run"))
|
|
goto cleanup;
|
|
ASSERT_EQ(retval, 0, "retval");
|
|
ASSERT_EQ(skel->bss->out_bpf_testmod_ksym, 42, "bpf_testmod_ksym");
|
|
cleanup:
|
|
test_ksyms_module_lskel__destroy(skel);
|
|
}
|
|
|
|
void test_ksyms_module_libbpf(void)
|
|
{
|
|
struct test_ksyms_module *skel;
|
|
int retval, err;
|
|
|
|
if (!env.has_testmod) {
|
|
test__skip();
|
|
return;
|
|
}
|
|
|
|
skel = test_ksyms_module__open_and_load();
|
|
if (!ASSERT_OK_PTR(skel, "test_ksyms_module__open"))
|
|
return;
|
|
err = bpf_prog_test_run(bpf_program__fd(skel->progs.load), 1, &pkt_v4,
|
|
sizeof(pkt_v4), NULL, NULL, (__u32 *)&retval, NULL);
|
|
if (!ASSERT_OK(err, "bpf_prog_test_run"))
|
|
goto cleanup;
|
|
ASSERT_EQ(retval, 0, "retval");
|
|
ASSERT_EQ(skel->bss->out_bpf_testmod_ksym, 42, "bpf_testmod_ksym");
|
|
cleanup:
|
|
test_ksyms_module__destroy(skel);
|
|
}
|
|
|
|
void test_ksyms_module(void)
|
|
{
|
|
if (test__start_subtest("lskel"))
|
|
test_ksyms_module_lskel();
|
|
if (test__start_subtest("libbpf"))
|
|
test_ksyms_module_libbpf();
|
|
}
|