-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathbuild.rs
89 lines (76 loc) · 2.63 KB
/
build.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
extern crate bindgen;
use std::env;
use std::path::PathBuf;
use bindgen::callbacks::{DeriveInfo, ParseCallbacks};
use glob::glob;
use libbpf_cargo::SkeletonBuilder;
use std::path::Path;
const PROFILER_BPF_HEADER: &str = "./src/bpf/profiler.h";
const PROFILER_BPF_SOURCE: &str = "./src/bpf/profiler.bpf.c";
const PROFILER_SKELETON: &str = "./src/bpf/profiler_skel.rs";
const TRACERS_BPF_HEADER: &str = "./src/bpf/tracers.h";
const TRACERS_BPF_SOURCE: &str = "./src/bpf/tracers.bpf.c";
const TRACERS_SKELETON: &str = "./src/bpf/tracers_skel.rs";
#[derive(Debug)]
struct CustomParseCallbacks;
impl ParseCallbacks for CustomParseCallbacks {
fn add_derives(&self, derive_info: &DeriveInfo) -> Vec<String> {
if derive_info.name == "native_stack_t" {
vec!["Hash".into(), "Eq".into(), "PartialEq".into()]
} else {
vec![]
}
}
}
fn main() {
// Inform cargo of when to re build
for path in glob("src/bpf/*[hc]").unwrap().flatten() {
println!("cargo:rerun-if-changed={}", path.display());
}
// Main native profiler.
let bindings = bindgen::Builder::default()
.derive_default(true)
.parse_callbacks(Box::new(CustomParseCallbacks))
.header(PROFILER_BPF_HEADER)
.generate()
.expect("Unable to generate bindings");
let out_path = PathBuf::from(env::var("OUT_DIR").unwrap());
let bindings_out_file = out_path.join("profiler_bindings.rs");
bindings
.write_to_file(bindings_out_file)
.expect("Couldn't write bindings!");
// Tracers.
let bindings = bindgen::Builder::default()
.derive_default(true)
.header(TRACERS_BPF_HEADER)
.generate()
.expect("Unable to generate bindings");
let out_path = PathBuf::from(env::var("OUT_DIR").unwrap());
let bindings_out_file = out_path.join("tracers_bindings.rs");
bindings
.write_to_file(bindings_out_file)
.expect("Couldn't write bindings!");
let skel = Path::new(PROFILER_SKELETON);
SkeletonBuilder::new()
.source(PROFILER_BPF_SOURCE)
.clang_args([
"-Wextra",
"-Wall",
"-Werror",
"-Wno-unused-command-line-argument",
])
.build_and_generate(skel)
.expect("run skeleton builder");
let skel = Path::new(TRACERS_SKELETON);
SkeletonBuilder::new()
.source(TRACERS_BPF_SOURCE)
.clang_args([
"-Wextra",
"-Wall",
"-Werror",
"-Wno-unused-command-line-argument",
"-Wno-unused-function",
])
.build_and_generate(skel)
.expect("run skeleton builder");
}