1d3b0856eSAlexei Starovoitov // SPDX-License-Identifier: GPL-2.0
2d3b0856eSAlexei Starovoitov /* Copyright (c) 2019 Facebook */
3d3b0856eSAlexei Starovoitov #include <test_progs.h>
44d1b6298SAlexei Starovoitov #include "fexit_test.lskel.h"
5*5e9cf77dSMenglong Dong #include "fexit_many_args.skel.h"
6d3b0856eSAlexei Starovoitov
fexit_test_common(struct fexit_test_lskel * fexit_skel)7*5e9cf77dSMenglong Dong static int fexit_test_common(struct fexit_test_lskel *fexit_skel)
8d3b0856eSAlexei Starovoitov {
9da00d2f1SKP Singh int err, prog_fd, i;
104d1b6298SAlexei Starovoitov int link_fd;
11da00d2f1SKP Singh __u64 *result;
1204fcb5f9SDelyan Kratunov LIBBPF_OPTS(bpf_test_run_opts, topts);
13d3b0856eSAlexei Starovoitov
14087cba79SKumar Kartikeya Dwivedi err = fexit_test_lskel__attach(fexit_skel);
158caadc43SJiri Olsa if (!ASSERT_OK(err, "fexit_attach"))
168caadc43SJiri Olsa return err;
178caadc43SJiri Olsa
188caadc43SJiri Olsa /* Check that already linked program can't be attached again. */
19087cba79SKumar Kartikeya Dwivedi link_fd = fexit_test_lskel__test1__attach(fexit_skel);
204d1b6298SAlexei Starovoitov if (!ASSERT_LT(link_fd, 0, "fexit_attach_link"))
218caadc43SJiri Olsa return -1;
22d3b0856eSAlexei Starovoitov
234d1b6298SAlexei Starovoitov prog_fd = fexit_skel->progs.test1.prog_fd;
2404fcb5f9SDelyan Kratunov err = bpf_prog_test_run_opts(prog_fd, &topts);
258caadc43SJiri Olsa ASSERT_OK(err, "test_run");
2604fcb5f9SDelyan Kratunov ASSERT_EQ(topts.retval, 0, "test_run");
27d3b0856eSAlexei Starovoitov
28da00d2f1SKP Singh result = (__u64 *)fexit_skel->bss;
298caadc43SJiri Olsa for (i = 0; i < sizeof(*fexit_skel->bss) / sizeof(__u64); i++) {
308caadc43SJiri Olsa if (!ASSERT_EQ(result[i], 1, "fexit_result"))
318caadc43SJiri Olsa return -1;
32da00d2f1SKP Singh }
33d3b0856eSAlexei Starovoitov
34087cba79SKumar Kartikeya Dwivedi fexit_test_lskel__detach(fexit_skel);
358caadc43SJiri Olsa
368caadc43SJiri Olsa /* zero results for re-attach test */
378caadc43SJiri Olsa memset(fexit_skel->bss, 0, sizeof(*fexit_skel->bss));
388caadc43SJiri Olsa return 0;
398caadc43SJiri Olsa }
408caadc43SJiri Olsa
fexit_test(void)41*5e9cf77dSMenglong Dong static void fexit_test(void)
428caadc43SJiri Olsa {
43087cba79SKumar Kartikeya Dwivedi struct fexit_test_lskel *fexit_skel = NULL;
448caadc43SJiri Olsa int err;
458caadc43SJiri Olsa
46087cba79SKumar Kartikeya Dwivedi fexit_skel = fexit_test_lskel__open_and_load();
478caadc43SJiri Olsa if (!ASSERT_OK_PTR(fexit_skel, "fexit_skel_load"))
488caadc43SJiri Olsa goto cleanup;
498caadc43SJiri Olsa
50*5e9cf77dSMenglong Dong err = fexit_test_common(fexit_skel);
518caadc43SJiri Olsa if (!ASSERT_OK(err, "fexit_first_attach"))
528caadc43SJiri Olsa goto cleanup;
538caadc43SJiri Olsa
54*5e9cf77dSMenglong Dong err = fexit_test_common(fexit_skel);
558caadc43SJiri Olsa ASSERT_OK(err, "fexit_second_attach");
568caadc43SJiri Olsa
57da00d2f1SKP Singh cleanup:
58087cba79SKumar Kartikeya Dwivedi fexit_test_lskel__destroy(fexit_skel);
59d3b0856eSAlexei Starovoitov }
60*5e9cf77dSMenglong Dong
fexit_many_args(void)61*5e9cf77dSMenglong Dong static void fexit_many_args(void)
62*5e9cf77dSMenglong Dong {
63*5e9cf77dSMenglong Dong struct fexit_many_args *fexit_skel = NULL;
64*5e9cf77dSMenglong Dong int err;
65*5e9cf77dSMenglong Dong
66*5e9cf77dSMenglong Dong fexit_skel = fexit_many_args__open_and_load();
67*5e9cf77dSMenglong Dong if (!ASSERT_OK_PTR(fexit_skel, "fexit_many_args_skel_load"))
68*5e9cf77dSMenglong Dong goto cleanup;
69*5e9cf77dSMenglong Dong
70*5e9cf77dSMenglong Dong err = fexit_many_args__attach(fexit_skel);
71*5e9cf77dSMenglong Dong if (!ASSERT_OK(err, "fexit_many_args_attach"))
72*5e9cf77dSMenglong Dong goto cleanup;
73*5e9cf77dSMenglong Dong
74*5e9cf77dSMenglong Dong ASSERT_OK(trigger_module_test_read(1), "trigger_read");
75*5e9cf77dSMenglong Dong
76*5e9cf77dSMenglong Dong ASSERT_EQ(fexit_skel->bss->test1_result, 1,
77*5e9cf77dSMenglong Dong "fexit_many_args_result1");
78*5e9cf77dSMenglong Dong ASSERT_EQ(fexit_skel->bss->test2_result, 1,
79*5e9cf77dSMenglong Dong "fexit_many_args_result2");
80*5e9cf77dSMenglong Dong ASSERT_EQ(fexit_skel->bss->test3_result, 1,
81*5e9cf77dSMenglong Dong "fexit_many_args_result3");
82*5e9cf77dSMenglong Dong
83*5e9cf77dSMenglong Dong cleanup:
84*5e9cf77dSMenglong Dong fexit_many_args__destroy(fexit_skel);
85*5e9cf77dSMenglong Dong }
86*5e9cf77dSMenglong Dong
test_fexit_test(void)87*5e9cf77dSMenglong Dong void test_fexit_test(void)
88*5e9cf77dSMenglong Dong {
89*5e9cf77dSMenglong Dong if (test__start_subtest("fexit"))
90*5e9cf77dSMenglong Dong fexit_test();
91*5e9cf77dSMenglong Dong if (test__start_subtest("fexit_many_args"))
92*5e9cf77dSMenglong Dong fexit_many_args();
93*5e9cf77dSMenglong Dong }
94