1 // SPDX-License-Identifier: GPL-2.0 2 /* Copyright (c) 2024 Benjamin Tissoires */ 3 #include <test_progs.h> 4 #include "wq.skel.h" 5 #include "wq_failures.skel.h" 6 7 void serial_test_wq(void) 8 { 9 struct wq *wq_skel = NULL; 10 int err, prog_fd; 11 12 LIBBPF_OPTS(bpf_test_run_opts, topts); 13 14 RUN_TESTS(wq); 15 16 /* re-run the success test to check if the timer was actually executed */ 17 18 wq_skel = wq__open_and_load(); 19 if (!ASSERT_OK_PTR(wq_skel, "wq_skel_load")) 20 return; 21 22 err = wq__attach(wq_skel); 23 if (!ASSERT_OK(err, "wq_attach")) 24 return; 25 26 prog_fd = bpf_program__fd(wq_skel->progs.test_syscall_array_sleepable); 27 err = bpf_prog_test_run_opts(prog_fd, &topts); 28 ASSERT_OK(err, "test_run"); 29 ASSERT_EQ(topts.retval, 0, "test_run"); 30 31 usleep(50); /* 10 usecs should be enough, but give it extra */ 32 33 ASSERT_EQ(wq_skel->bss->ok_sleepable, (1 << 1), "ok_sleepable"); 34 wq__destroy(wq_skel); 35 } 36 37 void serial_test_failures_wq(void) 38 { 39 RUN_TESTS(wq_failures); 40 } 41 42 static void test_failure_map_no_btf(void) 43 { 44 struct wq *skel = NULL; 45 char log[8192]; 46 const struct bpf_insn *insns; 47 size_t insn_cnt; 48 int ret, err, map_fd; 49 LIBBPF_OPTS(bpf_prog_load_opts, opts, .log_size = sizeof(log), .log_buf = log, 50 .log_level = 2); 51 52 skel = wq__open(); 53 if (!ASSERT_OK_PTR(skel, "skel_open")) 54 return; 55 56 err = bpf_object__prepare(skel->obj); 57 if (!ASSERT_OK(err, "skel__prepare")) 58 goto out; 59 60 map_fd = bpf_map_create(BPF_MAP_TYPE_ARRAY, "map_no_btf", sizeof(__u32), sizeof(__u64), 100, 61 NULL); 62 if (!ASSERT_GT(map_fd, -1, "map create")) 63 goto out; 64 65 err = bpf_map__reuse_fd(skel->maps.array, map_fd); 66 if (!ASSERT_OK(err, "map reuse fd")) { 67 close(map_fd); 68 goto out; 69 } 70 71 insns = bpf_program__insns(skel->progs.test_map_no_btf); 72 if (!ASSERT_OK_PTR(insns, "insns ptr")) 73 goto out; 74 75 insn_cnt = bpf_program__insn_cnt(skel->progs.test_map_no_btf); 76 if (!ASSERT_GT(insn_cnt, 0u, "insn cnt")) 77 goto out; 78 79 ret = bpf_prog_load(BPF_PROG_TYPE_TRACEPOINT, NULL, "GPL", insns, insn_cnt, &opts); 80 if (!ASSERT_LT(ret, 0, "prog load failed")) { 81 if (ret > 0) 82 close(ret); 83 goto out; 84 } 85 86 ASSERT_HAS_SUBSTR(log, "map 'map_no_btf' has to have BTF in order to use bpf_wq", 87 "log complains no map BTF"); 88 out: 89 wq__destroy(skel); 90 } 91 92 void test_wq_custom(void) 93 { 94 if (test__start_subtest("test_failure_map_no_btf")) 95 test_failure_map_no_btf(); 96 } 97