2 #include <bpf/libbpf.h>
3 #include <util/llvm-utils.h>
4 #include <util/cache.h>
9 static int perf_config_cb(const char *var
, const char *val
,
10 void *arg __maybe_unused
)
12 return perf_default_config(var
, val
, arg
);
15 #ifdef HAVE_LIBBPF_SUPPORT
16 static int test__bpf_parsing(void *obj_buf
, size_t obj_buf_sz
)
18 struct bpf_object
*obj
;
20 obj
= bpf_object__open_buffer(obj_buf
, obj_buf_sz
, NULL
);
23 bpf_object__close(obj
);
27 static int test__bpf_parsing(void *obj_buf __maybe_unused
,
28 size_t obj_buf_sz __maybe_unused
)
30 pr_debug("Skip bpf parsing\n");
38 } bpf_source_table
[__LLVM_TESTCASE_MAX
] = {
39 [LLVM_TESTCASE_BASE
] = {
40 .source
= test_llvm__bpf_base_prog
,
41 .desc
= "Basic BPF llvm compiling test",
43 [LLVM_TESTCASE_KBUILD
] = {
44 .source
= test_llvm__bpf_test_kbuild_prog
,
45 .desc
= "Test kbuild searching",
51 test_llvm__fetch_bpf_obj(void **p_obj_buf
,
53 enum test_llvm__testcase idx
,
58 const char *tmpl_old
, *clang_opt_old
;
59 char *tmpl_new
= NULL
, *clang_opt_new
= NULL
;
60 int err
, old_verbose
, ret
= TEST_FAIL
;
62 if (idx
>= __LLVM_TESTCASE_MAX
)
65 source
= bpf_source_table
[idx
].source
;
66 desc
= bpf_source_table
[idx
].desc
;
68 perf_config(perf_config_cb
, NULL
);
71 * Skip this test if user's .perfconfig doesn't set [llvm] section
72 * and clang is not found in $PATH, and this is not perf test -v
74 if (!force
&& (verbose
== 0 &&
75 !llvm_param
.user_set_param
&&
76 llvm__search_clang())) {
77 pr_debug("No clang and no verbosive, skip this test\n");
82 * llvm is verbosity when error. Suppress all error output if
85 old_verbose
= verbose
;
92 if (!llvm_param
.clang_bpf_cmd_template
)
95 if (!llvm_param
.clang_opt
)
96 llvm_param
.clang_opt
= strdup("");
98 err
= asprintf(&tmpl_new
, "echo '%s' | %s%s", source
,
99 llvm_param
.clang_bpf_cmd_template
,
100 old_verbose
? "" : " 2>/dev/null");
103 err
= asprintf(&clang_opt_new
, "-xc %s", llvm_param
.clang_opt
);
107 tmpl_old
= llvm_param
.clang_bpf_cmd_template
;
108 llvm_param
.clang_bpf_cmd_template
= tmpl_new
;
109 clang_opt_old
= llvm_param
.clang_opt
;
110 llvm_param
.clang_opt
= clang_opt_new
;
112 err
= llvm__compile_bpf("-", p_obj_buf
, p_obj_buf_sz
);
114 llvm_param
.clang_bpf_cmd_template
= tmpl_old
;
115 llvm_param
.clang_opt
= clang_opt_old
;
117 verbose
= old_verbose
;
126 pr_debug("Failed to compile test case: '%s'\n", desc
);
132 enum test_llvm__testcase i
;
134 for (i
= 0; i
< __LLVM_TESTCASE_MAX
; i
++) {
136 void *obj_buf
= NULL
;
137 size_t obj_buf_sz
= 0;
139 ret
= test_llvm__fetch_bpf_obj(&obj_buf
, &obj_buf_sz
,
142 if (ret
== TEST_OK
) {
143 ret
= test__bpf_parsing(obj_buf
, obj_buf_sz
);
145 pr_debug("Failed to parse test case '%s'\n",
146 bpf_source_table
[i
].desc
);
157 * Test 0 is the basic LLVM test. If test 0
158 * fail, the basic LLVM support not functional
159 * so the whole test should fail. If other test
160 * case fail, it can be fixed by adjusting
161 * config so don't report error.