提交 fe27eb66 编写于 作者: A Alexei Starovoitov 提交者: Zheng Zengkai

selftests/bpf: Convert few tests to light skeleton.

mainline inclusion
from mainline-5.14-rc1
commit 4d1b6298
category: feature
bugzilla: https://gitee.com/openeuler/kernel/issues/I5EUVD
CVE: NA

Reference: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=4d1b62986125b6de596c98310543652a7892e097

-------------------------------------------------

Convert few tests that don't use CO-RE to light skeleton.
Signed-off-by: NAlexei Starovoitov <ast@kernel.org>
Signed-off-by: NDaniel Borkmann <daniel@iogearbox.net>
Acked-by: NAndrii Nakryiko <andrii@kernel.org>
Link: https://lore.kernel.org/bpf/20210514003623.28033-19-alexei.starovoitov@gmail.com
(cherry picked from commit 4d1b6298)
Signed-off-by: NWang Yufen <wangyufen@huawei.com>

Conflicts:
	tools/testing/selftests/bpf/Makefile
	tools/testing/selftests/bpf/prog_tests/fexit_sleep.c
Signed-off-by: NWang Yufen <wangyufen@huawei.com>
上级 a58478e2
...@@ -32,6 +32,7 @@ test_current_pid_tgid_new_ns ...@@ -32,6 +32,7 @@ test_current_pid_tgid_new_ns
xdping xdping
test_cpp test_cpp
*.skel.h *.skel.h
*.lskel.h
/no_alu32 /no_alu32
/bpf_gcc /bpf_gcc
/tools /tools
......
...@@ -297,6 +297,10 @@ SKEL_BLACKLIST := btf__% test_pinning_invalid.c test_sk_assign.c ...@@ -297,6 +297,10 @@ SKEL_BLACKLIST := btf__% test_pinning_invalid.c test_sk_assign.c
LINKED_SKELS := test_static_linked.skel.h LINKED_SKELS := test_static_linked.skel.h
LSKELS := kfunc_call_test.c fentry_test.c fexit_test.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
# Set up extra TRUNNER_XXX "temporary" variables in the environment (relies on # Set up extra TRUNNER_XXX "temporary" variables in the environment (relies on
...@@ -319,6 +323,7 @@ TRUNNER_BPF_OBJS := $$(patsubst %.c,$$(TRUNNER_OUTPUT)/%.o, $$(TRUNNER_BPF_SRCS) ...@@ -319,6 +323,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), \ $$(filter-out $(SKEL_BLACKLIST), \
$$(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)
...@@ -361,6 +366,14 @@ $(TRUNNER_BPF_SKELS): %.skel.h: %.o $(BPFTOOL) | $(TRUNNER_OUTPUT) ...@@ -361,6 +366,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))
...@@ -390,6 +403,7 @@ $(TRUNNER_TEST_OBJS): $(TRUNNER_OUTPUT)/%.test.o: \ ...@@ -390,6 +403,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),$$@)
...@@ -496,4 +510,4 @@ $(OUTPUT)/bench: $(OUTPUT)/bench.o $(OUTPUT)/testing_helpers.o \ ...@@ -496,4 +510,4 @@ $(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)
// 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) ...@@ -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",
......
// 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) ...@@ -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");
......
// 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) ...@@ -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 @@ ...@@ -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) ...@@ -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 @@ ...@@ -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 @@ ...@@ -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) ...@@ -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) ...@@ -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; ...@@ -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) ...@@ -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;
......
...@@ -153,6 +153,17 @@ extern int test__join_cgroup(const char *path); ...@@ -153,6 +153,17 @@ extern int test__join_cgroup(const char *path);
___ok; \ ___ok; \
}) })
#define ASSERT_LT(actual, expected, name) ({ \
static int duration = 0; \
typeof(actual) ___act = (actual); \
typeof(expected) ___exp = (expected); \
bool ___ok = ___act < ___exp; \
CHECK(!___ok, (name), \
"unexpected %s: actual %lld >= expected %lld\n", \
(name), (long long)(___act), (long long)(___exp)); \
___ok; \
})
#define ASSERT_STREQ(actual, expected, name) ({ \ #define ASSERT_STREQ(actual, expected, name) ({ \
static int duration = 0; \ static int duration = 0; \
const char *___act = actual; \ const char *___act = actual; \
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册