edd695b032
After this patch, perf utilizes builtin clang support to build BPF script, no longer depend on external clang, but fallbacking to it if for some reason the builtin compiling framework fails. Test: $ type clang -bash: type: clang: not found $ cat ~/.perfconfig $ echo '#define LINUX_VERSION_CODE 0x040700' > ./test.c $ cat ./tools/perf/tests/bpf-script-example.c >> ./test.c $ ./perf record -v --dry-run -e ./test.c 2>&1 | grep builtin bpf: successfull builtin compilation $ Can't pass cflags so unable to include kernel headers now. Will be fixed by following commits. Committer notes: Make sure '-v' comes before the '-e ./test.c' in the command line otherwise the 'verbose' variable will not be set when the bpf event is parsed and thus the pr_debug indicating a 'successfull builtin compilation' will not be output, as the debug level (1) will be less than what 'verbose' has at that point (0). Signed-off-by: Wang Nan <wangnan0@huawei.com> Tested-by: Arnaldo Carvalho de Melo <acme@redhat.com> Cc: Alexei Starovoitov <ast@fb.com> Cc: He Kuang <hekuang@huawei.com> Cc: Jiri Olsa <jolsa@kernel.org> Cc: Joe Stringer <joe@ovn.org> Cc: Zefan Li <lizefan@huawei.com> Cc: pi3orama@163.com Link: http://lkml.kernel.org/r/20161126070354.141764-16-wangnan0@huawei.com [ Spell check/reflow successfull pr_debug string ] Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
44 lines
917 B
C
44 lines
917 B
C
#ifndef PERF_UTIL_CLANG_C_H
|
|
#define PERF_UTIL_CLANG_C_H
|
|
|
|
#include <stddef.h> /* for size_t */
|
|
#include <util-cxx.h> /* for __maybe_unused */
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#ifdef HAVE_LIBCLANGLLVM_SUPPORT
|
|
extern void perf_clang__init(void);
|
|
extern void perf_clang__cleanup(void);
|
|
|
|
extern int test__clang_to_IR(void);
|
|
extern int test__clang_to_obj(void);
|
|
|
|
extern int perf_clang__compile_bpf(const char *filename,
|
|
void **p_obj_buf,
|
|
size_t *p_obj_buf_sz);
|
|
#else
|
|
|
|
|
|
static inline void perf_clang__init(void) { }
|
|
static inline void perf_clang__cleanup(void) { }
|
|
|
|
static inline int test__clang_to_IR(void) { return -1; }
|
|
static inline int test__clang_to_obj(void) { return -1;}
|
|
|
|
static inline int
|
|
perf_clang__compile_bpf(const char *filename __maybe_unused,
|
|
void **p_obj_buf __maybe_unused,
|
|
size_t *p_obj_buf_sz __maybe_unused)
|
|
{
|
|
return -ENOTSUP;
|
|
}
|
|
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
#endif
|