xref: /openbmc/linux/tools/testing/selftests/bpf/prog_tests/fentry_test.c (revision c900529f3d9161bfde5cca0754f83b4d3c3e0220)
111d1e2eeSAlexei Starovoitov // SPDX-License-Identifier: GPL-2.0
211d1e2eeSAlexei Starovoitov /* Copyright (c) 2019 Facebook */
311d1e2eeSAlexei Starovoitov #include <test_progs.h>
44d1b6298SAlexei Starovoitov #include "fentry_test.lskel.h"
5*5e9cf77dSMenglong Dong #include "fentry_many_args.skel.h"
6dde53c1bSAndrii Nakryiko 
fentry_test_common(struct fentry_test_lskel * fentry_skel)7*5e9cf77dSMenglong Dong static int fentry_test_common(struct fentry_test_lskel *fentry_skel)
811d1e2eeSAlexei Starovoitov {
9da00d2f1SKP Singh 	int err, prog_fd, i;
104d1b6298SAlexei Starovoitov 	int link_fd;
11dde53c1bSAndrii Nakryiko 	__u64 *result;
1204fcb5f9SDelyan Kratunov 	LIBBPF_OPTS(bpf_test_run_opts, topts);
1311d1e2eeSAlexei Starovoitov 
14087cba79SKumar Kartikeya Dwivedi 	err = fentry_test_lskel__attach(fentry_skel);
1556dda5a4SJiri Olsa 	if (!ASSERT_OK(err, "fentry_attach"))
1656dda5a4SJiri Olsa 		return err;
1756dda5a4SJiri Olsa 
1856dda5a4SJiri Olsa 	/* Check that already linked program can't be attached again. */
19087cba79SKumar Kartikeya Dwivedi 	link_fd = fentry_test_lskel__test1__attach(fentry_skel);
204d1b6298SAlexei Starovoitov 	if (!ASSERT_LT(link_fd, 0, "fentry_attach_link"))
2156dda5a4SJiri Olsa 		return -1;
2211d1e2eeSAlexei Starovoitov 
234d1b6298SAlexei Starovoitov 	prog_fd = fentry_skel->progs.test1.prog_fd;
2404fcb5f9SDelyan Kratunov 	err = bpf_prog_test_run_opts(prog_fd, &topts);
2556dda5a4SJiri Olsa 	ASSERT_OK(err, "test_run");
2604fcb5f9SDelyan Kratunov 	ASSERT_EQ(topts.retval, 0, "test_run");
2711d1e2eeSAlexei Starovoitov 
28dde53c1bSAndrii Nakryiko 	result = (__u64 *)fentry_skel->bss;
2956dda5a4SJiri Olsa 	for (i = 0; i < sizeof(*fentry_skel->bss) / sizeof(__u64); i++) {
3056dda5a4SJiri Olsa 		if (!ASSERT_EQ(result[i], 1, "fentry_result"))
3156dda5a4SJiri Olsa 			return -1;
32dde53c1bSAndrii Nakryiko 	}
3311d1e2eeSAlexei Starovoitov 
34087cba79SKumar Kartikeya Dwivedi 	fentry_test_lskel__detach(fentry_skel);
3556dda5a4SJiri Olsa 
3656dda5a4SJiri Olsa 	/* zero results for re-attach test */
3756dda5a4SJiri Olsa 	memset(fentry_skel->bss, 0, sizeof(*fentry_skel->bss));
3856dda5a4SJiri Olsa 	return 0;
3956dda5a4SJiri Olsa }
4056dda5a4SJiri Olsa 
fentry_test(void)41*5e9cf77dSMenglong Dong static void fentry_test(void)
4256dda5a4SJiri Olsa {
43087cba79SKumar Kartikeya Dwivedi 	struct fentry_test_lskel *fentry_skel = NULL;
4456dda5a4SJiri Olsa 	int err;
4556dda5a4SJiri Olsa 
46087cba79SKumar Kartikeya Dwivedi 	fentry_skel = fentry_test_lskel__open_and_load();
4756dda5a4SJiri Olsa 	if (!ASSERT_OK_PTR(fentry_skel, "fentry_skel_load"))
4856dda5a4SJiri Olsa 		goto cleanup;
4956dda5a4SJiri Olsa 
50*5e9cf77dSMenglong Dong 	err = fentry_test_common(fentry_skel);
5156dda5a4SJiri Olsa 	if (!ASSERT_OK(err, "fentry_first_attach"))
5256dda5a4SJiri Olsa 		goto cleanup;
5356dda5a4SJiri Olsa 
54*5e9cf77dSMenglong Dong 	err = fentry_test_common(fentry_skel);
5556dda5a4SJiri Olsa 	ASSERT_OK(err, "fentry_second_attach");
5656dda5a4SJiri Olsa 
57dde53c1bSAndrii Nakryiko cleanup:
58087cba79SKumar Kartikeya Dwivedi 	fentry_test_lskel__destroy(fentry_skel);
5911d1e2eeSAlexei Starovoitov }
60*5e9cf77dSMenglong Dong 
fentry_many_args(void)61*5e9cf77dSMenglong Dong static void fentry_many_args(void)
62*5e9cf77dSMenglong Dong {
63*5e9cf77dSMenglong Dong 	struct fentry_many_args *fentry_skel = NULL;
64*5e9cf77dSMenglong Dong 	int err;
65*5e9cf77dSMenglong Dong 
66*5e9cf77dSMenglong Dong 	fentry_skel = fentry_many_args__open_and_load();
67*5e9cf77dSMenglong Dong 	if (!ASSERT_OK_PTR(fentry_skel, "fentry_many_args_skel_load"))
68*5e9cf77dSMenglong Dong 		goto cleanup;
69*5e9cf77dSMenglong Dong 
70*5e9cf77dSMenglong Dong 	err = fentry_many_args__attach(fentry_skel);
71*5e9cf77dSMenglong Dong 	if (!ASSERT_OK(err, "fentry_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(fentry_skel->bss->test1_result, 1,
77*5e9cf77dSMenglong Dong 		  "fentry_many_args_result1");
78*5e9cf77dSMenglong Dong 	ASSERT_EQ(fentry_skel->bss->test2_result, 1,
79*5e9cf77dSMenglong Dong 		  "fentry_many_args_result2");
80*5e9cf77dSMenglong Dong 	ASSERT_EQ(fentry_skel->bss->test3_result, 1,
81*5e9cf77dSMenglong Dong 		  "fentry_many_args_result3");
82*5e9cf77dSMenglong Dong 
83*5e9cf77dSMenglong Dong cleanup:
84*5e9cf77dSMenglong Dong 	fentry_many_args__destroy(fentry_skel);
85*5e9cf77dSMenglong Dong }
86*5e9cf77dSMenglong Dong 
test_fentry_test(void)87*5e9cf77dSMenglong Dong void test_fentry_test(void)
88*5e9cf77dSMenglong Dong {
89*5e9cf77dSMenglong Dong 	if (test__start_subtest("fentry"))
90*5e9cf77dSMenglong Dong 		fentry_test();
91*5e9cf77dSMenglong Dong 	if (test__start_subtest("fentry_many_args"))
92*5e9cf77dSMenglong Dong 		fentry_many_args();
93*5e9cf77dSMenglong Dong }
94