selftests/bpf: Convert few tests to light skeleton.
authorAlexei Starovoitov <ast@kernel.org>
Fri, 14 May 2021 00:36:20 +0000 (17:36 -0700)
committerDaniel Borkmann <daniel@iogearbox.net>
Tue, 18 May 2021 22:41:44 +0000 (00:41 +0200)
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
tools/testing/selftests/bpf/.gitignore
tools/testing/selftests/bpf/Makefile
tools/testing/selftests/bpf/prog_tests/fentry_fexit.c
tools/testing/selftests/bpf/prog_tests/fentry_test.c
tools/testing/selftests/bpf/prog_tests/fexit_sleep.c
tools/testing/selftests/bpf/prog_tests/fexit_test.c
tools/testing/selftests/bpf/prog_tests/kfunc_call.c
tools/testing/selftests/bpf/prog_tests/ksyms_module.c
tools/testing/selftests/bpf/prog_tests/ringbuf.c
tools/testing/selftests/bpf/progs/test_ringbuf.c

index 4866f6a219018705527c68df189ef4aaa13d8d65..a030aa4a8a9ecdd3f797550093e3af7a7ed63eb8 100644 (file)
@@ -30,6 +30,7 @@ test_sysctl
 xdping
 test_cpp
 *.skel.h
+*.lskel.h
 /no_alu32
 /bpf_gcc
 /tools
index 511259c2c6c5d665ce297c323275156d91602bea..fdc7785ff82d7f8f0162f4d8c54d58b0b6be436a 100644 (file)
@@ -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_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
 linked_funcs.skel.h-deps := linked_funcs1.o linked_funcs2.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,      \
                                 $$(filter-out $(SKEL_BLACKLIST) $(LINKED_BPF_SRCS),\
                                               $$(TRUNNER_BPF_SRCS)))
+TRUNNER_BPF_LSKELS := $$(patsubst %.c,$$(TRUNNER_OUTPUT)/%.lskel.h, $$(LSKELS))
 TRUNNER_BPF_SKELS_LINKED := $$(addprefix $$(TRUNNER_OUTPUT)/,$(LINKED_SKELS))
 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)$$(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)
        $$(call msg,LINK-BPF,$(TRUNNER_BINARY),$$(@:.skel.h=.o))
        $(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_BPF_OBJS)                               \
                      $(TRUNNER_BPF_SKELS)                              \
+                     $(TRUNNER_BPF_LSKELS)                             \
                      $(TRUNNER_BPF_SKELS_LINKED)                       \
                      $$(BPFOBJ) | $(TRUNNER_OUTPUT)
        $$(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) \
        prog_tests/tests.h map_tests/tests.h verifier/tests.h           \
        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
index 109d0345a2be5ae30de270311fbba2c1ade45628..91154c2ba256d6c0852b4178f7c4f13c6d7c493a 100644 (file)
@@ -1,8 +1,8 @@
 // SPDX-License-Identifier: GPL-2.0
 /* Copyright (c) 2019 Facebook */
 #include <test_progs.h>
-#include "fentry_test.skel.h"
-#include "fexit_test.skel.h"
+#include "fentry_test.lskel.h"
+#include "fexit_test.lskel.h"
 
 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))
                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,
                                NULL, NULL, &retval, &duration);
        CHECK(err || retval, "ipv6",
index 7cb111b1199574aab44ebf06dedfb1e21f057372..174c89e7456e5cfcc259e6b726931cb4b7d159e7 100644 (file)
@@ -1,13 +1,13 @@
 // SPDX-License-Identifier: GPL-2.0
 /* Copyright (c) 2019 Facebook */
 #include <test_progs.h>
-#include "fentry_test.skel.h"
+#include "fentry_test.lskel.h"
 
 static int fentry_test(struct fentry_test *fentry_skel)
 {
        int err, prog_fd, i;
        __u32 duration = 0, retval;
-       struct bpf_link *link;
+       int link_fd;
        __u64 *result;
 
        err = fentry_test__attach(fentry_skel);
@@ -15,11 +15,11 @@ static int fentry_test(struct fentry_test *fentry_skel)
                return err;
 
        /* Check that already linked program can't be attached again. */
-       link = bpf_program__attach(fentry_skel->progs.test1);
-       if (!ASSERT_ERR_PTR(link, "fentry_attach_link"))
+       link_fd = fentry_test__test1__attach(fentry_skel);
+       if (!ASSERT_LT(link_fd, 0, "fentry_attach_link"))
                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,
                                NULL, NULL, &retval, &duration);
        ASSERT_OK(err, "test_run");
index ccc7e8a34ab69b8d3720662df6085f0c6cf71858..4e7f4b42ea298d6040605e385546ab2c0d500e4a 100644 (file)
@@ -6,7 +6,7 @@
 #include <time.h>
 #include <sys/mman.h>
 #include <sys/syscall.h>
-#include "fexit_sleep.skel.h"
+#include "fexit_sleep.lskel.h"
 
 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
         * will be freed quickly.
         */
-       close(bpf_program__fd(fexit_skel->progs.nanosleep_fentry));
-       close(bpf_program__fd(fexit_skel->progs.nanosleep_fexit));
+       close(fexit_skel->progs.nanosleep_fentry.prog_fd);
+       close(fexit_skel->progs.nanosleep_fexit.prog_fd);
        fexit_sleep__detach(fexit_skel);
 
        /* kill the thread to unwind sys_nanosleep stack through the trampoline */
index 6792e41f7f697ad275b6dd428aadb6a4bd61921b..af3dba72670178a412144a640341b1ddb7762086 100644 (file)
@@ -1,13 +1,13 @@
 // SPDX-License-Identifier: GPL-2.0
 /* Copyright (c) 2019 Facebook */
 #include <test_progs.h>
-#include "fexit_test.skel.h"
+#include "fexit_test.lskel.h"
 
 static int fexit_test(struct fexit_test *fexit_skel)
 {
        int err, prog_fd, i;
        __u32 duration = 0, retval;
-       struct bpf_link *link;
+       int link_fd;
        __u64 *result;
 
        err = fexit_test__attach(fexit_skel);
@@ -15,11 +15,11 @@ static int fexit_test(struct fexit_test *fexit_skel)
                return err;
 
        /* Check that already linked program can't be attached again. */
-       link = bpf_program__attach(fexit_skel->progs.test1);
-       if (!ASSERT_ERR_PTR(link, "fexit_attach_link"))
+       link_fd = fexit_test__test1__attach(fexit_skel);
+       if (!ASSERT_LT(link_fd, 0, "fexit_attach_link"))
                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,
                                NULL, NULL, &retval, &duration);
        ASSERT_OK(err, "test_run");
index 7fc0951ee75f13a8804bd4dba667e8a93d3788dd..30a7b9b837bf5a28d2a28054391d7059b58bad43 100644 (file)
@@ -2,7 +2,7 @@
 /* Copyright (c) 2021 Facebook */
 #include <test_progs.h>
 #include <network_helpers.h>
-#include "kfunc_call_test.skel.h"
+#include "kfunc_call_test.lskel.h"
 #include "kfunc_call_test_subprog.skel.h"
 
 static void test_main(void)
@@ -14,13 +14,13 @@ static void test_main(void)
        if (!ASSERT_OK_PTR(skel, "skel"))
                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),
                                NULL, NULL, (__u32 *)&retval, NULL);
        ASSERT_OK(err, "bpf_prog_test_run(test1)");
        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),
                                NULL, NULL, (__u32 *)&retval, NULL);
        ASSERT_OK(err, "bpf_prog_test_run(test2)");
index 4c232b456479d458385297a3ece3ba3ab49adaa9..2cd5cded543fa63c69e8c8e694f34debc2ad9d4d 100644 (file)
@@ -4,7 +4,7 @@
 #include <test_progs.h>
 #include <bpf/libbpf.h>
 #include <bpf/btf.h>
-#include "test_ksyms_module.skel.h"
+#include "test_ksyms_module.lskel.h"
 
 static int duration;
 
index de78617f65501f8b4cf7c9ca6c613dfb1f1cdd36..80c11ac0ffb148bc612fa466345c07af78b50f59 100644 (file)
@@ -12,7 +12,7 @@
 #include <sys/sysinfo.h>
 #include <linux/perf_event.h>
 #include <linux/ring_buffer.h>
-#include "test_ringbuf.skel.h"
+#include "test_ringbuf.lskel.h"
 
 #define EDONE 7777
 
@@ -93,9 +93,7 @@ void test_ringbuf(void)
        if (CHECK(!skel, "skel_open", "skeleton open failed\n"))
                return;
 
-       err = bpf_map__set_max_entries(skel->maps.ringbuf, page_size);
-       if (CHECK(err != 0, "bpf_map__set_max_entries", "bpf_map__set_max_entries failed\n"))
-               goto cleanup;
+       skel->maps.ringbuf.max_entries = page_size;
 
        err = test_ringbuf__load(skel);
        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 */
        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);
        if (CHECK(!ringbuf, "ringbuf_create", "failed to create ringbuf\n"))
                goto cleanup;
index 6b3f288b7c63ca54bc714e1cbc98c4ca32afa8d4..eaa7d9dba0befa524a4765890d5160d7a89ca02e 100644 (file)
@@ -35,7 +35,7 @@ long prod_pos = 0;
 /* inner state */
 long seq = 0;
 
-SEC("tp/syscalls/sys_enter_getpgid")
+SEC("fentry/__x64_sys_getpgid")
 int test_ringbuf(void *ctx)
 {
        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);
        if (!sample) {
                __sync_fetch_and_add(&dropped, 1);
-               return 1;
+               return 0;
        }
 
        sample->pid = pid;