0001
0002
0003 #include <test_progs.h>
0004 #include "test_legacy_printk.skel.h"
0005
0006 static int execute_one_variant(bool legacy)
0007 {
0008 struct test_legacy_printk *skel;
0009 int err, zero = 0, my_pid = getpid(), res, map_fd;
0010
0011 skel = test_legacy_printk__open();
0012 if (!ASSERT_OK_PTR(skel, "skel_open"))
0013 return -errno;
0014
0015 bpf_program__set_autoload(skel->progs.handle_legacy, legacy);
0016 bpf_program__set_autoload(skel->progs.handle_modern, !legacy);
0017
0018 err = test_legacy_printk__load(skel);
0019
0020 if (err)
0021 goto err_out;
0022
0023 if (legacy) {
0024 map_fd = bpf_map__fd(skel->maps.my_pid_map);
0025 err = bpf_map_update_elem(map_fd, &zero, &my_pid, BPF_ANY);
0026 if (!ASSERT_OK(err, "my_pid_map_update"))
0027 goto err_out;
0028 err = bpf_map_lookup_elem(map_fd, &zero, &res);
0029 } else {
0030 skel->bss->my_pid_var = my_pid;
0031 }
0032
0033 err = test_legacy_printk__attach(skel);
0034 if (!ASSERT_OK(err, "skel_attach"))
0035 goto err_out;
0036
0037 usleep(1);
0038
0039 if (legacy) {
0040 map_fd = bpf_map__fd(skel->maps.res_map);
0041 err = bpf_map_lookup_elem(map_fd, &zero, &res);
0042 if (!ASSERT_OK(err, "res_map_lookup"))
0043 goto err_out;
0044 } else {
0045 res = skel->bss->res_var;
0046 }
0047
0048 if (!ASSERT_GT(res, 0, "res")) {
0049 err = -EINVAL;
0050 goto err_out;
0051 }
0052
0053 err_out:
0054 test_legacy_printk__destroy(skel);
0055 return err;
0056 }
0057
0058 void test_legacy_printk(void)
0059 {
0060
0061 ASSERT_OK(execute_one_variant(true ), "legacy_case");
0062
0063
0064 execute_one_variant(false);
0065 }