diff options
author | Andrii Nakryiko <andrii@kernel.org> | 2024-03-29 20:04:10 +0100 |
---|---|---|
committer | Alexei Starovoitov <ast@kernel.org> | 2024-03-30 01:18:30 +0100 |
commit | 623bdd58be3727318d374f0052f9dfff1e87b854 (patch) | |
tree | 4fa897fca4d3678d7fe97924daa9a2c7d1f3ff73 /tools/bpf/bpftool/Documentation/bpftool-perf.rst | |
parent | bpf: Avoid kfree_rcu() under lock in bpf_lpm_trie. (diff) | |
download | linux-623bdd58be3727318d374f0052f9dfff1e87b854.tar.xz linux-623bdd58be3727318d374f0052f9dfff1e87b854.zip |
selftests/bpf: make multi-uprobe tests work in RELEASE=1 mode
When BPF selftests are built in RELEASE=1 mode with -O2 optimization
level, uprobe_multi binary, called from multi-uprobe tests is optimized
to the point that all the thousands of target uprobe_multi_func_XXX
functions are eliminated, breaking tests.
So ensure they are preserved by using weak attribute.
But, actually, compiling uprobe_multi binary with -O2 takes a really
long time, and is quite useless (it's not a benchmark). So in addition
to ensuring that uprobe_multi_func_XXX functions are preserved, opt-out
of -O2 explicitly in Makefile and stick to -O0. This saves a lot of
compilation time.
With -O2, just recompiling uprobe_multi:
$ touch uprobe_multi.c
$ time make RELEASE=1 -j90
make RELEASE=1 -j90 291.66s user 2.54s system 99% cpu 4:55.52 total
With -O0:
$ touch uprobe_multi.c
$ time make RELEASE=1 -j90
make RELEASE=1 -j90 22.40s user 1.91s system 99% cpu 24.355 total
5 minutes vs (still slow, but...) 24 seconds.
Signed-off-by: Andrii Nakryiko <andrii@kernel.org>
Link: https://lore.kernel.org/r/20240329190410.4191353-1-andrii@kernel.org
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Diffstat (limited to 'tools/bpf/bpftool/Documentation/bpftool-perf.rst')
0 files changed, 0 insertions, 0 deletions