// SPDX-License-Identifier: GPL-2.0 #include #include #include "bpf_misc.h" #include "../test_kmods/bpf_testmod.h" #include "../test_kmods/bpf_testmod_kfunc.h" char _license[] SEC("license") = "GPL"; int test_pid; /* Programs associated with st_ops_map_a */ #define MAP_A_MAGIC 1234 int test_err_a; SEC("struct_ops") int BPF_PROG(test_1_a, struct st_ops_args *args) { return MAP_A_MAGIC; } SEC("tp_btf/sys_enter") int BPF_PROG(sys_enter_prog_a, struct pt_regs *regs, long id) { struct st_ops_args args = {}; struct task_struct *task; int ret; task = bpf_get_current_task_btf(); if (!test_pid || task->pid != test_pid) return 0; ret = bpf_kfunc_multi_st_ops_test_1_assoc(&args); if (ret != MAP_A_MAGIC) test_err_a++; return 0; } SEC("syscall") int syscall_prog_a(void *ctx) { struct st_ops_args args = {}; int ret; ret = bpf_kfunc_multi_st_ops_test_1_assoc(&args); if (ret != MAP_A_MAGIC) test_err_a++; return 0; } SEC(".struct_ops.link") struct bpf_testmod_multi_st_ops st_ops_map_a = { .test_1 = (void *)test_1_a, }; /* Programs associated with st_ops_map_b */ #define MAP_B_MAGIC 5678 int test_err_b; SEC("struct_ops") int BPF_PROG(test_1_b, struct st_ops_args *args) { return MAP_B_MAGIC; } SEC("tp_btf/sys_enter") int BPF_PROG(sys_enter_prog_b, struct pt_regs *regs, long id) { struct st_ops_args args = {}; struct task_struct *task; int ret; task = bpf_get_current_task_btf(); if (!test_pid || task->pid != test_pid) return 0; ret = bpf_kfunc_multi_st_ops_test_1_assoc(&args); if (ret != MAP_B_MAGIC) test_err_b++; return 0; } SEC("syscall") int syscall_prog_b(void *ctx) { struct st_ops_args args = {}; int ret; ret = bpf_kfunc_multi_st_ops_test_1_assoc(&args); if (ret != MAP_B_MAGIC) test_err_b++; return 0; } SEC(".struct_ops.link") struct bpf_testmod_multi_st_ops st_ops_map_b = { .test_1 = (void *)test_1_b, };