mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-13 22:14:20 +08:00
selftests/bpf: Convert few tests to light skeleton.
Convert few tests that don't use CO-RE to light skeleton. Signed-off-by: Alexei Starovoitov <ast@kernel.org> Signed-off-by: Daniel Borkmann <daniel@iogearbox.net> Acked-by: Andrii Nakryiko <andrii@kernel.org> Link: https://lore.kernel.org/bpf/20210514003623.28033-19-alexei.starovoitov@gmail.com
This commit is contained in:
parent
d510296d33
commit
4d1b629861
1
tools/testing/selftests/bpf/.gitignore
vendored
1
tools/testing/selftests/bpf/.gitignore
vendored
@ -30,6 +30,7 @@ test_sysctl
|
|||||||
xdping
|
xdping
|
||||||
test_cpp
|
test_cpp
|
||||||
*.skel.h
|
*.skel.h
|
||||||
|
*.lskel.h
|
||||||
/no_alu32
|
/no_alu32
|
||||||
/bpf_gcc
|
/bpf_gcc
|
||||||
/tools
|
/tools
|
||||||
|
@ -312,6 +312,10 @@ SKEL_BLACKLIST := btf__% test_pinning_invalid.c test_sk_assign.c
|
|||||||
LINKED_SKELS := test_static_linked.skel.h linked_funcs.skel.h \
|
LINKED_SKELS := test_static_linked.skel.h linked_funcs.skel.h \
|
||||||
linked_vars.skel.h linked_maps.skel.h
|
linked_vars.skel.h linked_maps.skel.h
|
||||||
|
|
||||||
|
LSKELS := kfunc_call_test.c fentry_test.c fexit_test.c fexit_sleep.c \
|
||||||
|
test_ksyms_module.c test_ringbuf.c
|
||||||
|
SKEL_BLACKLIST += $$(LSKELS)
|
||||||
|
|
||||||
test_static_linked.skel.h-deps := test_static_linked1.o test_static_linked2.o
|
test_static_linked.skel.h-deps := test_static_linked1.o test_static_linked2.o
|
||||||
linked_funcs.skel.h-deps := linked_funcs1.o linked_funcs2.o
|
linked_funcs.skel.h-deps := linked_funcs1.o linked_funcs2.o
|
||||||
linked_vars.skel.h-deps := linked_vars1.o linked_vars2.o
|
linked_vars.skel.h-deps := linked_vars1.o linked_vars2.o
|
||||||
@ -339,6 +343,7 @@ TRUNNER_BPF_OBJS := $$(patsubst %.c,$$(TRUNNER_OUTPUT)/%.o, $$(TRUNNER_BPF_SRCS)
|
|||||||
TRUNNER_BPF_SKELS := $$(patsubst %.c,$$(TRUNNER_OUTPUT)/%.skel.h, \
|
TRUNNER_BPF_SKELS := $$(patsubst %.c,$$(TRUNNER_OUTPUT)/%.skel.h, \
|
||||||
$$(filter-out $(SKEL_BLACKLIST) $(LINKED_BPF_SRCS),\
|
$$(filter-out $(SKEL_BLACKLIST) $(LINKED_BPF_SRCS),\
|
||||||
$$(TRUNNER_BPF_SRCS)))
|
$$(TRUNNER_BPF_SRCS)))
|
||||||
|
TRUNNER_BPF_LSKELS := $$(patsubst %.c,$$(TRUNNER_OUTPUT)/%.lskel.h, $$(LSKELS))
|
||||||
TRUNNER_BPF_SKELS_LINKED := $$(addprefix $$(TRUNNER_OUTPUT)/,$(LINKED_SKELS))
|
TRUNNER_BPF_SKELS_LINKED := $$(addprefix $$(TRUNNER_OUTPUT)/,$(LINKED_SKELS))
|
||||||
TEST_GEN_FILES += $$(TRUNNER_BPF_OBJS)
|
TEST_GEN_FILES += $$(TRUNNER_BPF_OBJS)
|
||||||
|
|
||||||
@ -380,6 +385,14 @@ $(TRUNNER_BPF_SKELS): %.skel.h: %.o $(BPFTOOL) | $(TRUNNER_OUTPUT)
|
|||||||
$(Q)diff $$(<:.o=.linked2.o) $$(<:.o=.linked3.o)
|
$(Q)diff $$(<:.o=.linked2.o) $$(<:.o=.linked3.o)
|
||||||
$(Q)$$(BPFTOOL) gen skeleton $$(<:.o=.linked3.o) name $$(notdir $$(<:.o=)) > $$@
|
$(Q)$$(BPFTOOL) gen skeleton $$(<:.o=.linked3.o) name $$(notdir $$(<:.o=)) > $$@
|
||||||
|
|
||||||
|
$(TRUNNER_BPF_LSKELS): %.lskel.h: %.o $(BPFTOOL) | $(TRUNNER_OUTPUT)
|
||||||
|
$$(call msg,GEN-SKEL,$(TRUNNER_BINARY),$$@)
|
||||||
|
$(Q)$$(BPFTOOL) gen object $$(<:.o=.linked1.o) $$<
|
||||||
|
$(Q)$$(BPFTOOL) gen object $$(<:.o=.linked2.o) $$(<:.o=.linked1.o)
|
||||||
|
$(Q)$$(BPFTOOL) gen object $$(<:.o=.linked3.o) $$(<:.o=.linked2.o)
|
||||||
|
$(Q)diff $$(<:.o=.linked2.o) $$(<:.o=.linked3.o)
|
||||||
|
$(Q)$$(BPFTOOL) gen skeleton -L $$(<:.o=.linked3.o) name $$(notdir $$(<:.o=)) > $$@
|
||||||
|
|
||||||
$(TRUNNER_BPF_SKELS_LINKED): $(TRUNNER_BPF_OBJS) $(BPFTOOL) | $(TRUNNER_OUTPUT)
|
$(TRUNNER_BPF_SKELS_LINKED): $(TRUNNER_BPF_OBJS) $(BPFTOOL) | $(TRUNNER_OUTPUT)
|
||||||
$$(call msg,LINK-BPF,$(TRUNNER_BINARY),$$(@:.skel.h=.o))
|
$$(call msg,LINK-BPF,$(TRUNNER_BINARY),$$(@:.skel.h=.o))
|
||||||
$(Q)$$(BPFTOOL) gen object $$(@:.skel.h=.linked1.o) $$(addprefix $(TRUNNER_OUTPUT)/,$$($$(@F)-deps))
|
$(Q)$$(BPFTOOL) gen object $$(@:.skel.h=.linked1.o) $$(addprefix $(TRUNNER_OUTPUT)/,$$($$(@F)-deps))
|
||||||
@ -409,6 +422,7 @@ $(TRUNNER_TEST_OBJS): $(TRUNNER_OUTPUT)/%.test.o: \
|
|||||||
$(TRUNNER_EXTRA_HDRS) \
|
$(TRUNNER_EXTRA_HDRS) \
|
||||||
$(TRUNNER_BPF_OBJS) \
|
$(TRUNNER_BPF_OBJS) \
|
||||||
$(TRUNNER_BPF_SKELS) \
|
$(TRUNNER_BPF_SKELS) \
|
||||||
|
$(TRUNNER_BPF_LSKELS) \
|
||||||
$(TRUNNER_BPF_SKELS_LINKED) \
|
$(TRUNNER_BPF_SKELS_LINKED) \
|
||||||
$$(BPFOBJ) | $(TRUNNER_OUTPUT)
|
$$(BPFOBJ) | $(TRUNNER_OUTPUT)
|
||||||
$$(call msg,TEST-OBJ,$(TRUNNER_BINARY),$$@)
|
$$(call msg,TEST-OBJ,$(TRUNNER_BINARY),$$@)
|
||||||
@ -516,6 +530,6 @@ $(OUTPUT)/bench: $(OUTPUT)/bench.o $(OUTPUT)/testing_helpers.o \
|
|||||||
EXTRA_CLEAN := $(TEST_CUSTOM_PROGS) $(SCRATCH_DIR) $(HOST_SCRATCH_DIR) \
|
EXTRA_CLEAN := $(TEST_CUSTOM_PROGS) $(SCRATCH_DIR) $(HOST_SCRATCH_DIR) \
|
||||||
prog_tests/tests.h map_tests/tests.h verifier/tests.h \
|
prog_tests/tests.h map_tests/tests.h verifier/tests.h \
|
||||||
feature \
|
feature \
|
||||||
$(addprefix $(OUTPUT)/,*.o *.skel.h no_alu32 bpf_gcc bpf_testmod.ko)
|
$(addprefix $(OUTPUT)/,*.o *.skel.h *.lskel.h no_alu32 bpf_gcc bpf_testmod.ko)
|
||||||
|
|
||||||
.PHONY: docs docs-clean
|
.PHONY: docs docs-clean
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
// SPDX-License-Identifier: GPL-2.0
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/* Copyright (c) 2019 Facebook */
|
/* Copyright (c) 2019 Facebook */
|
||||||
#include <test_progs.h>
|
#include <test_progs.h>
|
||||||
#include "fentry_test.skel.h"
|
#include "fentry_test.lskel.h"
|
||||||
#include "fexit_test.skel.h"
|
#include "fexit_test.lskel.h"
|
||||||
|
|
||||||
void test_fentry_fexit(void)
|
void test_fentry_fexit(void)
|
||||||
{
|
{
|
||||||
@ -26,7 +26,7 @@ void test_fentry_fexit(void)
|
|||||||
if (CHECK(err, "fexit_attach", "fexit attach failed: %d\n", err))
|
if (CHECK(err, "fexit_attach", "fexit attach failed: %d\n", err))
|
||||||
goto close_prog;
|
goto close_prog;
|
||||||
|
|
||||||
prog_fd = bpf_program__fd(fexit_skel->progs.test1);
|
prog_fd = fexit_skel->progs.test1.prog_fd;
|
||||||
err = bpf_prog_test_run(prog_fd, 1, NULL, 0,
|
err = bpf_prog_test_run(prog_fd, 1, NULL, 0,
|
||||||
NULL, NULL, &retval, &duration);
|
NULL, NULL, &retval, &duration);
|
||||||
CHECK(err || retval, "ipv6",
|
CHECK(err || retval, "ipv6",
|
||||||
|
@ -1,13 +1,13 @@
|
|||||||
// SPDX-License-Identifier: GPL-2.0
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/* Copyright (c) 2019 Facebook */
|
/* Copyright (c) 2019 Facebook */
|
||||||
#include <test_progs.h>
|
#include <test_progs.h>
|
||||||
#include "fentry_test.skel.h"
|
#include "fentry_test.lskel.h"
|
||||||
|
|
||||||
static int fentry_test(struct fentry_test *fentry_skel)
|
static int fentry_test(struct fentry_test *fentry_skel)
|
||||||
{
|
{
|
||||||
int err, prog_fd, i;
|
int err, prog_fd, i;
|
||||||
__u32 duration = 0, retval;
|
__u32 duration = 0, retval;
|
||||||
struct bpf_link *link;
|
int link_fd;
|
||||||
__u64 *result;
|
__u64 *result;
|
||||||
|
|
||||||
err = fentry_test__attach(fentry_skel);
|
err = fentry_test__attach(fentry_skel);
|
||||||
@ -15,11 +15,11 @@ static int fentry_test(struct fentry_test *fentry_skel)
|
|||||||
return err;
|
return err;
|
||||||
|
|
||||||
/* Check that already linked program can't be attached again. */
|
/* Check that already linked program can't be attached again. */
|
||||||
link = bpf_program__attach(fentry_skel->progs.test1);
|
link_fd = fentry_test__test1__attach(fentry_skel);
|
||||||
if (!ASSERT_ERR_PTR(link, "fentry_attach_link"))
|
if (!ASSERT_LT(link_fd, 0, "fentry_attach_link"))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
prog_fd = bpf_program__fd(fentry_skel->progs.test1);
|
prog_fd = fentry_skel->progs.test1.prog_fd;
|
||||||
err = bpf_prog_test_run(prog_fd, 1, NULL, 0,
|
err = bpf_prog_test_run(prog_fd, 1, NULL, 0,
|
||||||
NULL, NULL, &retval, &duration);
|
NULL, NULL, &retval, &duration);
|
||||||
ASSERT_OK(err, "test_run");
|
ASSERT_OK(err, "test_run");
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
#include <time.h>
|
#include <time.h>
|
||||||
#include <sys/mman.h>
|
#include <sys/mman.h>
|
||||||
#include <sys/syscall.h>
|
#include <sys/syscall.h>
|
||||||
#include "fexit_sleep.skel.h"
|
#include "fexit_sleep.lskel.h"
|
||||||
|
|
||||||
static int do_sleep(void *skel)
|
static int do_sleep(void *skel)
|
||||||
{
|
{
|
||||||
@ -58,8 +58,8 @@ void test_fexit_sleep(void)
|
|||||||
* waiting for percpu_ref_kill to confirm). The other one
|
* waiting for percpu_ref_kill to confirm). The other one
|
||||||
* will be freed quickly.
|
* will be freed quickly.
|
||||||
*/
|
*/
|
||||||
close(bpf_program__fd(fexit_skel->progs.nanosleep_fentry));
|
close(fexit_skel->progs.nanosleep_fentry.prog_fd);
|
||||||
close(bpf_program__fd(fexit_skel->progs.nanosleep_fexit));
|
close(fexit_skel->progs.nanosleep_fexit.prog_fd);
|
||||||
fexit_sleep__detach(fexit_skel);
|
fexit_sleep__detach(fexit_skel);
|
||||||
|
|
||||||
/* kill the thread to unwind sys_nanosleep stack through the trampoline */
|
/* kill the thread to unwind sys_nanosleep stack through the trampoline */
|
||||||
|
@ -1,13 +1,13 @@
|
|||||||
// SPDX-License-Identifier: GPL-2.0
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/* Copyright (c) 2019 Facebook */
|
/* Copyright (c) 2019 Facebook */
|
||||||
#include <test_progs.h>
|
#include <test_progs.h>
|
||||||
#include "fexit_test.skel.h"
|
#include "fexit_test.lskel.h"
|
||||||
|
|
||||||
static int fexit_test(struct fexit_test *fexit_skel)
|
static int fexit_test(struct fexit_test *fexit_skel)
|
||||||
{
|
{
|
||||||
int err, prog_fd, i;
|
int err, prog_fd, i;
|
||||||
__u32 duration = 0, retval;
|
__u32 duration = 0, retval;
|
||||||
struct bpf_link *link;
|
int link_fd;
|
||||||
__u64 *result;
|
__u64 *result;
|
||||||
|
|
||||||
err = fexit_test__attach(fexit_skel);
|
err = fexit_test__attach(fexit_skel);
|
||||||
@ -15,11 +15,11 @@ static int fexit_test(struct fexit_test *fexit_skel)
|
|||||||
return err;
|
return err;
|
||||||
|
|
||||||
/* Check that already linked program can't be attached again. */
|
/* Check that already linked program can't be attached again. */
|
||||||
link = bpf_program__attach(fexit_skel->progs.test1);
|
link_fd = fexit_test__test1__attach(fexit_skel);
|
||||||
if (!ASSERT_ERR_PTR(link, "fexit_attach_link"))
|
if (!ASSERT_LT(link_fd, 0, "fexit_attach_link"))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
prog_fd = bpf_program__fd(fexit_skel->progs.test1);
|
prog_fd = fexit_skel->progs.test1.prog_fd;
|
||||||
err = bpf_prog_test_run(prog_fd, 1, NULL, 0,
|
err = bpf_prog_test_run(prog_fd, 1, NULL, 0,
|
||||||
NULL, NULL, &retval, &duration);
|
NULL, NULL, &retval, &duration);
|
||||||
ASSERT_OK(err, "test_run");
|
ASSERT_OK(err, "test_run");
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
/* Copyright (c) 2021 Facebook */
|
/* Copyright (c) 2021 Facebook */
|
||||||
#include <test_progs.h>
|
#include <test_progs.h>
|
||||||
#include <network_helpers.h>
|
#include <network_helpers.h>
|
||||||
#include "kfunc_call_test.skel.h"
|
#include "kfunc_call_test.lskel.h"
|
||||||
#include "kfunc_call_test_subprog.skel.h"
|
#include "kfunc_call_test_subprog.skel.h"
|
||||||
|
|
||||||
static void test_main(void)
|
static void test_main(void)
|
||||||
@ -14,13 +14,13 @@ static void test_main(void)
|
|||||||
if (!ASSERT_OK_PTR(skel, "skel"))
|
if (!ASSERT_OK_PTR(skel, "skel"))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
prog_fd = bpf_program__fd(skel->progs.kfunc_call_test1);
|
prog_fd = skel->progs.kfunc_call_test1.prog_fd;
|
||||||
err = bpf_prog_test_run(prog_fd, 1, &pkt_v4, sizeof(pkt_v4),
|
err = bpf_prog_test_run(prog_fd, 1, &pkt_v4, sizeof(pkt_v4),
|
||||||
NULL, NULL, (__u32 *)&retval, NULL);
|
NULL, NULL, (__u32 *)&retval, NULL);
|
||||||
ASSERT_OK(err, "bpf_prog_test_run(test1)");
|
ASSERT_OK(err, "bpf_prog_test_run(test1)");
|
||||||
ASSERT_EQ(retval, 12, "test1-retval");
|
ASSERT_EQ(retval, 12, "test1-retval");
|
||||||
|
|
||||||
prog_fd = bpf_program__fd(skel->progs.kfunc_call_test2);
|
prog_fd = skel->progs.kfunc_call_test2.prog_fd;
|
||||||
err = bpf_prog_test_run(prog_fd, 1, &pkt_v4, sizeof(pkt_v4),
|
err = bpf_prog_test_run(prog_fd, 1, &pkt_v4, sizeof(pkt_v4),
|
||||||
NULL, NULL, (__u32 *)&retval, NULL);
|
NULL, NULL, (__u32 *)&retval, NULL);
|
||||||
ASSERT_OK(err, "bpf_prog_test_run(test2)");
|
ASSERT_OK(err, "bpf_prog_test_run(test2)");
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
#include <test_progs.h>
|
#include <test_progs.h>
|
||||||
#include <bpf/libbpf.h>
|
#include <bpf/libbpf.h>
|
||||||
#include <bpf/btf.h>
|
#include <bpf/btf.h>
|
||||||
#include "test_ksyms_module.skel.h"
|
#include "test_ksyms_module.lskel.h"
|
||||||
|
|
||||||
static int duration;
|
static int duration;
|
||||||
|
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
#include <sys/sysinfo.h>
|
#include <sys/sysinfo.h>
|
||||||
#include <linux/perf_event.h>
|
#include <linux/perf_event.h>
|
||||||
#include <linux/ring_buffer.h>
|
#include <linux/ring_buffer.h>
|
||||||
#include "test_ringbuf.skel.h"
|
#include "test_ringbuf.lskel.h"
|
||||||
|
|
||||||
#define EDONE 7777
|
#define EDONE 7777
|
||||||
|
|
||||||
@ -93,9 +93,7 @@ void test_ringbuf(void)
|
|||||||
if (CHECK(!skel, "skel_open", "skeleton open failed\n"))
|
if (CHECK(!skel, "skel_open", "skeleton open failed\n"))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
err = bpf_map__set_max_entries(skel->maps.ringbuf, page_size);
|
skel->maps.ringbuf.max_entries = page_size;
|
||||||
if (CHECK(err != 0, "bpf_map__set_max_entries", "bpf_map__set_max_entries failed\n"))
|
|
||||||
goto cleanup;
|
|
||||||
|
|
||||||
err = test_ringbuf__load(skel);
|
err = test_ringbuf__load(skel);
|
||||||
if (CHECK(err != 0, "skel_load", "skeleton load failed\n"))
|
if (CHECK(err != 0, "skel_load", "skeleton load failed\n"))
|
||||||
@ -104,7 +102,7 @@ void test_ringbuf(void)
|
|||||||
/* only trigger BPF program for current process */
|
/* only trigger BPF program for current process */
|
||||||
skel->bss->pid = getpid();
|
skel->bss->pid = getpid();
|
||||||
|
|
||||||
ringbuf = ring_buffer__new(bpf_map__fd(skel->maps.ringbuf),
|
ringbuf = ring_buffer__new(skel->maps.ringbuf.map_fd,
|
||||||
process_sample, NULL, NULL);
|
process_sample, NULL, NULL);
|
||||||
if (CHECK(!ringbuf, "ringbuf_create", "failed to create ringbuf\n"))
|
if (CHECK(!ringbuf, "ringbuf_create", "failed to create ringbuf\n"))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
@ -35,7 +35,7 @@ long prod_pos = 0;
|
|||||||
/* inner state */
|
/* inner state */
|
||||||
long seq = 0;
|
long seq = 0;
|
||||||
|
|
||||||
SEC("tp/syscalls/sys_enter_getpgid")
|
SEC("fentry/__x64_sys_getpgid")
|
||||||
int test_ringbuf(void *ctx)
|
int test_ringbuf(void *ctx)
|
||||||
{
|
{
|
||||||
int cur_pid = bpf_get_current_pid_tgid() >> 32;
|
int cur_pid = bpf_get_current_pid_tgid() >> 32;
|
||||||
@ -48,7 +48,7 @@ int test_ringbuf(void *ctx)
|
|||||||
sample = bpf_ringbuf_reserve(&ringbuf, sizeof(*sample), 0);
|
sample = bpf_ringbuf_reserve(&ringbuf, sizeof(*sample), 0);
|
||||||
if (!sample) {
|
if (!sample) {
|
||||||
__sync_fetch_and_add(&dropped, 1);
|
__sync_fetch_and_add(&dropped, 1);
|
||||||
return 1;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
sample->pid = pid;
|
sample->pid = pid;
|
||||||
|
Loading…
Reference in New Issue
Block a user