xref: /linux/tools/testing/selftests/bpf/progs/struct_ops_module.c (revision 001821b0e79716c4e17c71d8e053a23599a7a508)
1 // SPDX-License-Identifier: GPL-2.0
2 /* Copyright (c) 2024 Meta Platforms, Inc. and affiliates. */
3 #include <vmlinux.h>
4 #include <bpf/bpf_helpers.h>
5 #include <bpf/bpf_tracing.h>
6 #include "../bpf_testmod/bpf_testmod.h"
7 
8 char _license[] SEC("license") = "GPL";
9 
10 int test_1_result = 0;
11 int test_2_result = 0;
12 
13 SEC("struct_ops/test_1")
14 int BPF_PROG(test_1)
15 {
16 	test_1_result = 0xdeadbeef;
17 	return 0;
18 }
19 
20 SEC("struct_ops/test_2")
21 void BPF_PROG(test_2, int a, int b)
22 {
23 	test_2_result = a + b;
24 }
25 
26 SEC("?struct_ops/test_3")
27 int BPF_PROG(test_3, int a, int b)
28 {
29 	test_2_result = a + b + 3;
30 	return a + b + 3;
31 }
32 
33 SEC(".struct_ops.link")
34 struct bpf_testmod_ops testmod_1 = {
35 	.test_1 = (void *)test_1,
36 	.test_2 = (void *)test_2,
37 	.data = 0x1,
38 };
39 
40 SEC("struct_ops/test_2")
41 void BPF_PROG(test_2_v2, int a, int b)
42 {
43 	test_2_result = a * b;
44 }
45 
46 struct bpf_testmod_ops___v2 {
47 	int (*test_1)(void);
48 	void (*test_2)(int a, int b);
49 	int (*test_maybe_null)(int dummy, struct task_struct *task);
50 };
51 
52 SEC(".struct_ops.link")
53 struct bpf_testmod_ops___v2 testmod_2 = {
54 	.test_1 = (void *)test_1,
55 	.test_2 = (void *)test_2_v2,
56 };
57 
58 struct bpf_testmod_ops___zeroed {
59 	int (*test_1)(void);
60 	void (*test_2)(int a, int b);
61 	int (*test_maybe_null)(int dummy, struct task_struct *task);
62 	void (*zeroed_op)(int a, int b);
63 	int zeroed;
64 };
65 
66 SEC("struct_ops/test_3")
67 int BPF_PROG(zeroed_op)
68 {
69 	return 1;
70 }
71 
72 SEC(".struct_ops.link")
73 struct bpf_testmod_ops___zeroed testmod_zeroed = {
74 	.test_1 = (void *)test_1,
75 	.test_2 = (void *)test_2_v2,
76 	.zeroed_op = (void *)zeroed_op,
77 };
78 
79 struct bpf_testmod_ops___incompatible {
80 	int (*test_1)(void);
81 	void (*test_2)(int *a);
82 	int data;
83 };
84 
85 SEC(".struct_ops.link")
86 struct bpf_testmod_ops___incompatible testmod_incompatible = {
87 	.test_1 = (void *)test_1,
88 	.test_2 = (void *)test_2,
89 	.data = 3,
90 };
91