diff mbox series

[RFC,bpf-next,6/6] selftests/bpf: Add test cases for demonstrating runtime acquire/release reference tracking

Message ID AM6PR03MB508078EF9EDA7CAC87E8AC3299FE2@AM6PR03MB5080.eurprd03.prod.outlook.com (mailing list archive)
State RFC
Delegated to: BPF
Headers show
Series bpf: BPF runtime hooks: low-overhead non-intrusive tracking of runtime acquire/release (for watchdog) | expand

Checks

Context Check Description
bpf/vmtest-bpf-next-VM_Test-13 success Logs for s390x-gcc / GCC BPF
bpf/vmtest-bpf-next-VM_Test-19 success Logs for s390x-gcc / veristat-kernel
bpf/vmtest-bpf-next-VM_Test-18 success Logs for s390x-gcc / test (test_verifier, false, 360) / test_verifier on s390x with gcc
bpf/vmtest-bpf-next-VM_Test-20 success Logs for s390x-gcc / veristat-meta
bpf/vmtest-bpf-next-VM_Test-21 success Logs for set-matrix
bpf/vmtest-bpf-next-VM_Test-22 success Logs for x86_64-gcc / GCC BPF / GCC BPF
bpf/vmtest-bpf-next-VM_Test-23 success Logs for x86_64-gcc / build / build for x86_64 with gcc
bpf/vmtest-bpf-next-VM_Test-24 success Logs for x86_64-gcc / build-release
bpf/vmtest-bpf-next-VM_Test-25 success Logs for x86_64-gcc / test (test_maps, false, 360) / test_maps on x86_64 with gcc
bpf/vmtest-bpf-next-VM_Test-27 fail Logs for x86_64-gcc / test (test_progs_no_alu32, false, 360) / test_progs_no_alu32 on x86_64 with gcc
bpf/vmtest-bpf-next-VM_Test-26 fail Logs for x86_64-gcc / test (test_progs, false, 360) / test_progs on x86_64 with gcc
bpf/vmtest-bpf-next-VM_Test-28 success Logs for x86_64-gcc / test (test_progs_no_alu32_parallel, true, 30) / test_progs_no_alu32_parallel on x86_64 with gcc
bpf/vmtest-bpf-next-VM_Test-29 success Logs for x86_64-gcc / test (test_progs_parallel, true, 30) / test_progs_parallel on x86_64 with gcc
bpf/vmtest-bpf-next-VM_Test-30 success Logs for x86_64-gcc / test (test_verifier, false, 360) / test_verifier on x86_64 with gcc
bpf/vmtest-bpf-next-VM_Test-31 success Logs for x86_64-gcc / veristat-kernel / x86_64-gcc veristat_kernel
bpf/vmtest-bpf-next-VM_Test-32 success Logs for x86_64-gcc / veristat-meta / x86_64-gcc veristat_meta
bpf/vmtest-bpf-next-VM_Test-33 success Logs for x86_64-llvm-17 / GCC BPF / GCC BPF
bpf/vmtest-bpf-next-VM_Test-34 success Logs for x86_64-llvm-17 / build / build for x86_64 with llvm-17
bpf/vmtest-bpf-next-VM_Test-35 success Logs for x86_64-llvm-17 / build-release / build for x86_64 with llvm-17-O2
bpf/vmtest-bpf-next-VM_Test-36 success Logs for x86_64-llvm-17 / test (test_maps, false, 360) / test_maps on x86_64 with llvm-17
bpf/vmtest-bpf-next-VM_Test-37 fail Logs for x86_64-llvm-17 / test (test_progs, false, 360) / test_progs on x86_64 with llvm-17
bpf/vmtest-bpf-next-VM_Test-38 fail Logs for x86_64-llvm-17 / test (test_progs_no_alu32, false, 360) / test_progs_no_alu32 on x86_64 with llvm-17
bpf/vmtest-bpf-next-VM_Test-39 success Logs for x86_64-llvm-17 / test (test_verifier, false, 360) / test_verifier on x86_64 with llvm-17
bpf/vmtest-bpf-next-VM_Test-40 success Logs for x86_64-llvm-17 / veristat-kernel
bpf/vmtest-bpf-next-VM_Test-41 success Logs for x86_64-llvm-17 / veristat-meta
bpf/vmtest-bpf-next-VM_Test-42 success Logs for x86_64-llvm-18 / GCC BPF / GCC BPF
bpf/vmtest-bpf-next-VM_Test-43 success Logs for x86_64-llvm-18 / build / build for x86_64 with llvm-18
bpf/vmtest-bpf-next-VM_Test-44 success Logs for x86_64-llvm-18 / build-release / build for x86_64 with llvm-18-O2
bpf/vmtest-bpf-next-VM_Test-45 success Logs for x86_64-llvm-18 / test (test_maps, false, 360) / test_maps on x86_64 with llvm-18
bpf/vmtest-bpf-next-VM_Test-46 fail Logs for x86_64-llvm-18 / test (test_progs, false, 360) / test_progs on x86_64 with llvm-18
bpf/vmtest-bpf-next-VM_Test-47 fail Logs for x86_64-llvm-18 / test (test_progs_cpuv4, false, 360) / test_progs_cpuv4 on x86_64 with llvm-18
bpf/vmtest-bpf-next-VM_Test-48 fail Logs for x86_64-llvm-18 / test (test_progs_no_alu32, false, 360) / test_progs_no_alu32 on x86_64 with llvm-18
bpf/vmtest-bpf-next-VM_Test-49 success Logs for x86_64-llvm-18 / test (test_verifier, false, 360) / test_verifier on x86_64 with llvm-18
bpf/vmtest-bpf-next-VM_Test-50 success Logs for x86_64-llvm-18 / veristat-kernel
bpf/vmtest-bpf-next-VM_Test-51 success Logs for x86_64-llvm-18 / veristat-meta
bpf/vmtest-bpf-next-VM_Test-9 success Logs for aarch64-gcc / test (test_progs_no_alu32, false, 360) / test_progs_no_alu32 on aarch64 with gcc
bpf/vmtest-bpf-next-VM_Test-16 success Logs for s390x-gcc / test (test_progs, false, 360) / test_progs on s390x with gcc
bpf/vmtest-bpf-next-PR success PR summary
bpf/vmtest-bpf-next-VM_Test-0 success Logs for Lint
bpf/vmtest-bpf-next-VM_Test-2 success Logs for Unittests
bpf/vmtest-bpf-next-VM_Test-1 success Logs for ShellCheck
bpf/vmtest-bpf-next-VM_Test-3 success Logs for Validate matrix.py
bpf/vmtest-bpf-next-VM_Test-7 success Logs for s390x-gcc / build-release
bpf/vmtest-bpf-next-VM_Test-8 success Logs for set-matrix
bpf/vmtest-bpf-next-VM_Test-10 success Logs for x86_64-gcc / build-release
bpf/vmtest-bpf-next-VM_Test-4 success Logs for aarch64-gcc / GCC BPF
bpf/vmtest-bpf-next-VM_Test-5 success Logs for aarch64-gcc / build / build for aarch64 with gcc
bpf/vmtest-bpf-next-VM_Test-6 success Logs for aarch64-gcc / build-release
bpf/vmtest-bpf-next-VM_Test-11 success Logs for aarch64-gcc / veristat-kernel
bpf/vmtest-bpf-next-VM_Test-12 success Logs for aarch64-gcc / veristat-meta
bpf/vmtest-bpf-next-VM_Test-14 success Logs for s390x-gcc / build-release
bpf/vmtest-bpf-next-VM_Test-15 success Logs for set-matrix
bpf/vmtest-bpf-next-VM_Test-17 success Logs for x86_64-gcc / build-release
netdev/series_format success Posting correctly formatted
netdev/tree_selection success Clearly marked for bpf-next, async
netdev/ynl success Generated files up to date; no warnings/errors; no diff in generated;
netdev/fixes_present success Fixes tag not required for -next series
netdev/header_inline success No static functions without inline keyword in header files
netdev/build_32bit success Errors and warnings before: 0 this patch: 0
netdev/build_tools success Errors and warnings before: 26 (+1) this patch: 26 (+1)
netdev/cc_maintainers warning 7 maintainers not CCed: ndesaulniers@google.com morbo@google.com shuah@kernel.org linux-kselftest@vger.kernel.org llvm@lists.linux.dev nathan@kernel.org justinstitt@google.com
netdev/build_clang success Errors and warnings before: 47 this patch: 47
netdev/verify_signedoff success Signed-off-by tag matches author and committer
netdev/deprecated_api success None detected
netdev/check_selftest success No net selftest shell script
netdev/verify_fixes success No Fixes tag
netdev/build_allmodconfig_warn success Errors and warnings before: 10 this patch: 10
netdev/checkpatch warning CHECK: No space is necessary after a cast WARNING: added, moved or deleted file(s), does MAINTAINERS need updating?
netdev/build_clang_rust success No Rust files in patch. Skipping build
netdev/kdoc success Errors and warnings before: 0 this patch: 0
netdev/source_inline success Was 0 now: 0

Commit Message

Juntong Deng Feb. 14, 2025, 12:26 a.m. UTC
This patch adds test cases for demonstrating runtime acquire/release
reference tracking.

Test cases include simple, branch, and loop.

Simple test case has no branches or loops.

Branch test case contains if statements.

Loop test case contains the bpf_iter_num iterator.

Signed-off-by: Juntong Deng <juntong.deng@outlook.com>
---
 tools/testing/selftests/runtime/Makefile     | 20 ++++++++++
 tools/testing/selftests/runtime/branch.bpf.c | 42 ++++++++++++++++++++
 tools/testing/selftests/runtime/branch.c     | 19 +++++++++
 tools/testing/selftests/runtime/loop.bpf.c   | 37 +++++++++++++++++
 tools/testing/selftests/runtime/loop.c       | 19 +++++++++
 tools/testing/selftests/runtime/simple.bpf.c | 35 ++++++++++++++++
 tools/testing/selftests/runtime/simple.c     | 19 +++++++++
 7 files changed, 191 insertions(+)
 create mode 100644 tools/testing/selftests/runtime/Makefile
 create mode 100644 tools/testing/selftests/runtime/branch.bpf.c
 create mode 100644 tools/testing/selftests/runtime/branch.c
 create mode 100644 tools/testing/selftests/runtime/loop.bpf.c
 create mode 100644 tools/testing/selftests/runtime/loop.c
 create mode 100644 tools/testing/selftests/runtime/simple.bpf.c
 create mode 100644 tools/testing/selftests/runtime/simple.c
diff mbox series

Patch

diff --git a/tools/testing/selftests/runtime/Makefile b/tools/testing/selftests/runtime/Makefile
new file mode 100644
index 000000000000..d03133786a26
--- /dev/null
+++ b/tools/testing/selftests/runtime/Makefile
@@ -0,0 +1,20 @@ 
+targets = simple branch loop
+
+all: $(targets)
+
+vmlinux.h:
+	bpftool btf dump file /sys/kernel/btf/vmlinux format c > vmlinux.h
+
+%.bpf.o: %.bpf.c vmlinux.h
+	clang -O2 -g -target bpf -c $*.bpf.c -o $*.bpf.o
+
+%.skel.h: %.bpf.o
+	bpftool gen skeleton $*.bpf.o > $*.skel.h
+
+$(targets): %: %.c %.skel.h
+	clang $< -lelf -lbpf -o $@
+
+clean:
+	rm -f *.o *.skel.h vmlinux.h $(targets)
+
+.SECONDARY:
diff --git a/tools/testing/selftests/runtime/branch.bpf.c b/tools/testing/selftests/runtime/branch.bpf.c
new file mode 100644
index 000000000000..87697151299c
--- /dev/null
+++ b/tools/testing/selftests/runtime/branch.bpf.c
@@ -0,0 +1,42 @@ 
+// SPDX-License-Identifier: GPL-2.0
+
+#include "vmlinux.h"
+#include <bpf/bpf_helpers.h>
+#include <bpf/bpf_tracing.h>
+#include <bpf/bpf_core_read.h>
+
+char LICENSE[] SEC("license") = "GPL";
+
+void bpf_task_release(struct task_struct *p) __ksym;
+struct task_struct *bpf_task_from_pid(s32 pid) __ksym;
+
+int test = 5;
+
+SEC("syscall")
+int test_branch(void *arg)
+{
+	struct task_struct *task1;
+
+	task1 = bpf_task_from_pid(1);
+
+	if (test > 2) {
+		struct task_struct *task2;
+
+		task2 = bpf_task_from_pid(2);
+		if (task2)
+			bpf_task_release(task2);
+	}
+
+	if (test < 2) {
+		struct task_struct *task3;
+
+		task3 = bpf_task_from_pid(3);
+		if (task3)
+			bpf_task_release(task3);
+	}
+
+	if (task1)
+		bpf_task_release(task1);
+
+	return 0;
+}
diff --git a/tools/testing/selftests/runtime/branch.c b/tools/testing/selftests/runtime/branch.c
new file mode 100644
index 000000000000..3592e14f1f75
--- /dev/null
+++ b/tools/testing/selftests/runtime/branch.c
@@ -0,0 +1,19 @@ 
+// SPDX-License-Identifier: GPL-2.0
+
+#include <stdio.h>
+#include <bpf/libbpf.h>
+#include <bpf/bpf.h>
+#include "branch.skel.h"
+
+int main(int argc, char **argv)
+{
+	struct branch_bpf *skel;
+	int err, prog_fd;
+
+	skel = branch_bpf__open_and_load();
+	prog_fd = bpf_program__fd(skel->progs.test_branch);
+	err = bpf_prog_test_run_opts(prog_fd, NULL);
+
+	branch_bpf__destroy(skel);
+	return err;
+}
diff --git a/tools/testing/selftests/runtime/loop.bpf.c b/tools/testing/selftests/runtime/loop.bpf.c
new file mode 100644
index 000000000000..2b49ec9e1058
--- /dev/null
+++ b/tools/testing/selftests/runtime/loop.bpf.c
@@ -0,0 +1,37 @@ 
+// SPDX-License-Identifier: GPL-2.0
+
+#include "vmlinux.h"
+#include <bpf/bpf_helpers.h>
+#include <bpf/bpf_tracing.h>
+#include <bpf/bpf_core_read.h>
+
+char LICENSE[] SEC("license") = "GPL";
+
+void bpf_task_release(struct task_struct *p) __ksym;
+struct task_struct *bpf_task_from_pid(s32 pid) __ksym;
+
+SEC("syscall")
+int test_loop(void *arg)
+{
+	struct task_struct *task_loop;
+	struct task_struct *task1;
+	int *v;
+
+	task1 = bpf_task_from_pid(1);
+
+	struct bpf_iter_num it;
+
+	bpf_iter_num_new(&it, 1, 3);
+	while ((v = bpf_iter_num_next(&it))) {
+		task_loop = bpf_task_from_pid(*v);
+		if (task_loop)
+			bpf_task_release(task_loop);
+	}
+
+	bpf_iter_num_destroy(&it);
+
+	if (task1)
+		bpf_task_release(task1);
+
+	return 0;
+}
diff --git a/tools/testing/selftests/runtime/loop.c b/tools/testing/selftests/runtime/loop.c
new file mode 100644
index 000000000000..bde83e5595e4
--- /dev/null
+++ b/tools/testing/selftests/runtime/loop.c
@@ -0,0 +1,19 @@ 
+// SPDX-License-Identifier: GPL-2.0
+
+#include <stdio.h>
+#include <bpf/libbpf.h>
+#include <bpf/bpf.h>
+#include "loop.skel.h"
+
+int main(int argc, char **argv)
+{
+	struct loop_bpf *skel;
+	int err, prog_fd;
+
+	skel = loop_bpf__open_and_load();
+	prog_fd = bpf_program__fd(skel->progs.test_loop);
+	err = bpf_prog_test_run_opts(prog_fd, NULL);
+
+	loop_bpf__destroy(skel);
+	return err;
+}
diff --git a/tools/testing/selftests/runtime/simple.bpf.c b/tools/testing/selftests/runtime/simple.bpf.c
new file mode 100644
index 000000000000..ad7989ebb7d4
--- /dev/null
+++ b/tools/testing/selftests/runtime/simple.bpf.c
@@ -0,0 +1,35 @@ 
+// SPDX-License-Identifier: GPL-2.0
+
+#include "vmlinux.h"
+#include <bpf/bpf_helpers.h>
+#include <bpf/bpf_tracing.h>
+#include <bpf/bpf_core_read.h>
+
+char LICENSE[] SEC("license") = "GPL";
+
+void bpf_task_release(struct task_struct *p) __ksym;
+struct task_struct *bpf_task_from_pid(s32 pid) __ksym;
+
+struct bpf_cpumask *bpf_cpumask_create(void) __ksym;
+void bpf_cpumask_release(struct bpf_cpumask *cpumask) __ksym;
+
+SEC("syscall")
+int test_simple(void *arg)
+{
+	struct task_struct *task;
+	struct bpf_cpumask *cpumask;
+
+	task = bpf_task_from_pid(1);
+	if (!task)
+		return 0;
+
+	cpumask = bpf_cpumask_create();
+	if (!cpumask)
+		goto error_cpumask;
+
+	bpf_cpumask_release(cpumask);
+error_cpumask:
+	bpf_task_release(task);
+
+	return 0;
+}
diff --git a/tools/testing/selftests/runtime/simple.c b/tools/testing/selftests/runtime/simple.c
new file mode 100644
index 000000000000..e65959aac89b
--- /dev/null
+++ b/tools/testing/selftests/runtime/simple.c
@@ -0,0 +1,19 @@ 
+// SPDX-License-Identifier: GPL-2.0
+
+#include <stdio.h>
+#include <bpf/libbpf.h>
+#include <bpf/bpf.h>
+#include "simple.skel.h"
+
+int main(int argc, char **argv)
+{
+	struct simple_bpf *skel;
+	int err, prog_fd;
+
+	skel = simple_bpf__open_and_load();
+	prog_fd = bpf_program__fd(skel->progs.test_simple);
+	err = bpf_prog_test_run_opts(prog_fd, NULL);
+
+	simple_bpf__destroy(skel);
+	return err;
+}