Commit e25f0498 authored by Brendan Gregg's avatar Brendan Gregg Committed by GitHub

Merge pull request #171 from cneira/headers

BPFTRACE_KERNEL_SOURCE  environment variable
parents bfbd2cd7 5892a8cb
...@@ -2,7 +2,14 @@ ...@@ -2,7 +2,14 @@
BPFtrace is a high-level tracing language for Linux enhanced Berkeley Packet Filter (eBPF) available in recent Linux kernels (4.x). BPFtrace uses LLVM as a backend to compile scripts to BPF-bytecode and makes use of [BCC](https://github.com/iovisor/bcc) for interacting with the Linux BPF system, as well as existing Linux tracing capabilities: kernel dynamic tracing (kprobes), user-level dynamic tracing (uprobes), and tracepoints. The BPFtrace language is inspired by awk and C, and predecessor tracers such as DTrace and SystemTap. BPFtrace was created by [Alastair Robertson](https://github.com/ajor). BPFtrace is a high-level tracing language for Linux enhanced Berkeley Packet Filter (eBPF) available in recent Linux kernels (4.x). BPFtrace uses LLVM as a backend to compile scripts to BPF-bytecode and makes use of [BCC](https://github.com/iovisor/bcc) for interacting with the Linux BPF system, as well as existing Linux tracing capabilities: kernel dynamic tracing (kprobes), user-level dynamic tracing (uprobes), and tracepoints. The BPFtrace language is inspired by awk and C, and predecessor tracers such as DTrace and SystemTap. BPFtrace was created by [Alastair Robertson](https://github.com/ajor).
To learn more about BPFtrace, see the [Reference Guide](docs/reference_guide.md) and [One-Liner Tutorial](docs/tutorial_one_liners.md). To learn more about BPFtrace, see the [Reference Guide](docs/reference_guide.md) and [One-Liner Tutorial](docs/tutorial_one_liners.md).
BPFTrace depends on the kernel headers which are searched for by default in:
```bash
/lib/modules/$(uname -r)
```
The default search directory could be overridden using the environment variable BPFTRACE_KERNEL_HEADERS.
## Install ## Install
......
...@@ -159,10 +159,25 @@ void ClangParser::parse(ast::Program *program, StructMap &structs) ...@@ -159,10 +159,25 @@ void ClangParser::parse(ast::Program *program, StructMap &structs)
struct utsname utsname; struct utsname utsname;
uname(&utsname); uname(&utsname);
std::string kernel_modules_dir = std::string("/lib/modules/") + utsname.release; const char* env_kernel_modules_dir = ::getenv("BPFTRACE_KERNEL_HEADERS");
std::string kernel_modules_dir = env_kernel_modules_dir?
std::string(env_kernel_modules_dir):
std::string("/lib/modules/") +
utsname.release;
if (!is_dir(kernel_modules_dir)){
std::cerr << "WARNING: ("
<< kernel_modules_dir << ") is not a valid dir" << std::endl;
std::cerr << "Use environment variable BPFTRACE_KERNEL_HEADERS to setup"
" a valid directory for kernel headers." << std::endl;
exit(EXIT_FAILURE);
}
auto kpath_info = get_kernel_path_info(kernel_modules_dir); auto kpath_info = get_kernel_path_info(kernel_modules_dir);
auto kpath = kernel_modules_dir + "/" + kpath_info.second; auto kpath = env_kernel_modules_dir?
bool has_kpath_source = kpath_info.first; kernel_modules_dir :
kernel_modules_dir + "/" + kpath_info.second;
bool has_kpath_source = env_kernel_modules_dir? true:kpath_info.first;
std::vector<std::string> kflags; std::vector<std::string> kflags;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment