Commit 650c9dbd authored by Alexei Starovoitov's avatar Alexei Starovoitov Committed by Andrii Nakryiko

selftests/bpf: Convert map_ptr_kern test to use light skeleton.

To exercise CO-RE in the kernel further convert map_ptr_kern
test to light skeleton.
Signed-off-by: default avatarAlexei Starovoitov <ast@kernel.org>
Signed-off-by: default avatarAndrii Nakryiko <andrii@kernel.org>
Acked-by: default avatarAndrii Nakryiko <andrii@kernel.org>
Link: https://lore.kernel.org/bpf/20211201181040.23337-15-alexei.starovoitov@gmail.com
parent d82fa9b7
...@@ -325,7 +325,8 @@ LINKED_SKELS := test_static_linked.skel.h linked_funcs.skel.h \ ...@@ -325,7 +325,8 @@ 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 \ LSKELS := kfunc_call_test.c fentry_test.c fexit_test.c fexit_sleep.c \
test_ringbuf.c atomics.c trace_printk.c trace_vprintk.c test_ringbuf.c atomics.c trace_printk.c trace_vprintk.c \
map_ptr_kern.c
# Generate both light skeleton and libbpf skeleton for these # Generate both light skeleton and libbpf skeleton for these
LSKELS_EXTRA := test_ksyms_module.c test_ksyms_weak.c kfunc_call_test_subprog.c LSKELS_EXTRA := test_ksyms_module.c test_ksyms_weak.c kfunc_call_test_subprog.c
SKEL_BLACKLIST += $$(LSKELS) SKEL_BLACKLIST += $$(LSKELS)
......
...@@ -4,31 +4,29 @@ ...@@ -4,31 +4,29 @@
#include <test_progs.h> #include <test_progs.h>
#include <network_helpers.h> #include <network_helpers.h>
#include "map_ptr_kern.skel.h" #include "map_ptr_kern.lskel.h"
void test_map_ptr(void) void test_map_ptr(void)
{ {
struct map_ptr_kern *skel; struct map_ptr_kern_lskel *skel;
__u32 duration = 0, retval; __u32 duration = 0, retval;
char buf[128]; char buf[128];
int err; int err;
int page_size = getpagesize(); int page_size = getpagesize();
skel = map_ptr_kern__open(); skel = map_ptr_kern_lskel__open();
if (!ASSERT_OK_PTR(skel, "skel_open")) if (!ASSERT_OK_PTR(skel, "skel_open"))
return; return;
err = bpf_map__set_max_entries(skel->maps.m_ringbuf, page_size); skel->maps.m_ringbuf.max_entries = page_size;
if (!ASSERT_OK(err, "bpf_map__set_max_entries"))
goto cleanup;
err = map_ptr_kern__load(skel); err = map_ptr_kern_lskel__load(skel);
if (!ASSERT_OK(err, "skel_load")) if (!ASSERT_OK(err, "skel_load"))
goto cleanup; goto cleanup;
skel->bss->page_size = page_size; skel->bss->page_size = page_size;
err = bpf_prog_test_run(bpf_program__fd(skel->progs.cg_skb), 1, &pkt_v4, err = bpf_prog_test_run(skel->progs.cg_skb.prog_fd, 1, &pkt_v4,
sizeof(pkt_v4), buf, NULL, &retval, NULL); sizeof(pkt_v4), buf, NULL, &retval, NULL);
if (CHECK(err, "test_run", "err=%d errno=%d\n", err, errno)) if (CHECK(err, "test_run", "err=%d errno=%d\n", err, errno))
...@@ -39,5 +37,5 @@ void test_map_ptr(void) ...@@ -39,5 +37,5 @@ void test_map_ptr(void)
goto cleanup; goto cleanup;
cleanup: cleanup:
map_ptr_kern__destroy(skel); map_ptr_kern_lskel__destroy(skel);
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment