2023-10-18 11:19:48 -04:00
|
|
|
# SPDX-License-Identifier: GPL-2.0
|
|
|
|
|
|
|
|
pahole-ver := $(CONFIG_PAHOLE_VERSION)
|
|
|
|
pahole-flags-y :=
|
|
|
|
|
kbuild,bpf: Pass make jobs' value to pahole
Pass the value of make's -j/--jobs argument to pahole, to avoid out of
memory errors and make pahole respect the "jobs" value of make.
On systems with little memory but many cores, invoking pahole using -j
without argument potentially creates too many pahole instances,
causing an out-of-memory situation. Instead, we should pass make's
"jobs" value as an argument to pahole's -j, which is likely configured
to be (much) lower than the actual core count on such systems.
If make was invoked without -j, either via cmdline or MAKEFLAGS, then
JOBS will be simply empty, resulting in the existing behavior, as
expected.
Signed-off-by: Florian Schmaus <flo@geekplace.eu>
Signed-off-by: Andrii Nakryiko <andrii@kernel.org>
Tested-by: Holger Hoffstätte <holger@applied-asynchrony.com>
Link: https://lore.kernel.org/bpf/20241102100452.793970-1-flo@geekplace.eu
2024-11-02 06:04:51 -04:00
|
|
|
JOBS := $(patsubst -j%,%,$(filter -j%,$(MAKEFLAGS)))
|
|
|
|
|
2024-05-07 09:55:14 -04:00
|
|
|
ifeq ($(call test-le, $(pahole-ver), 125),y)
|
|
|
|
|
2023-10-18 11:19:48 -04:00
|
|
|
# pahole 1.18 through 1.21 can't handle zero-sized per-CPU vars
|
|
|
|
ifeq ($(call test-le, $(pahole-ver), 121),y)
|
|
|
|
pahole-flags-$(call test-ge, $(pahole-ver), 118) += --skip_encoding_btf_vars
|
|
|
|
endif
|
|
|
|
|
|
|
|
pahole-flags-$(call test-ge, $(pahole-ver), 121) += --btf_gen_floats
|
|
|
|
|
kbuild,bpf: Pass make jobs' value to pahole
Pass the value of make's -j/--jobs argument to pahole, to avoid out of
memory errors and make pahole respect the "jobs" value of make.
On systems with little memory but many cores, invoking pahole using -j
without argument potentially creates too many pahole instances,
causing an out-of-memory situation. Instead, we should pass make's
"jobs" value as an argument to pahole's -j, which is likely configured
to be (much) lower than the actual core count on such systems.
If make was invoked without -j, either via cmdline or MAKEFLAGS, then
JOBS will be simply empty, resulting in the existing behavior, as
expected.
Signed-off-by: Florian Schmaus <flo@geekplace.eu>
Signed-off-by: Andrii Nakryiko <andrii@kernel.org>
Tested-by: Holger Hoffstätte <holger@applied-asynchrony.com>
Link: https://lore.kernel.org/bpf/20241102100452.793970-1-flo@geekplace.eu
2024-11-02 06:04:51 -04:00
|
|
|
pahole-flags-$(call test-ge, $(pahole-ver), 122) += -j$(JOBS)
|
2023-10-18 11:19:48 -04:00
|
|
|
|
2024-05-14 12:27:16 -04:00
|
|
|
pahole-flags-$(call test-ge, $(pahole-ver), 125) += --skip_encoding_btf_inconsistent_proto --btf_gen_optimized
|
2024-05-07 09:55:14 -04:00
|
|
|
|
|
|
|
else
|
2023-10-18 11:19:48 -04:00
|
|
|
|
2024-05-07 09:55:14 -04:00
|
|
|
# Switch to using --btf_features for v1.26 and later.
|
kbuild,bpf: Pass make jobs' value to pahole
Pass the value of make's -j/--jobs argument to pahole, to avoid out of
memory errors and make pahole respect the "jobs" value of make.
On systems with little memory but many cores, invoking pahole using -j
without argument potentially creates too many pahole instances,
causing an out-of-memory situation. Instead, we should pass make's
"jobs" value as an argument to pahole's -j, which is likely configured
to be (much) lower than the actual core count on such systems.
If make was invoked without -j, either via cmdline or MAKEFLAGS, then
JOBS will be simply empty, resulting in the existing behavior, as
expected.
Signed-off-by: Florian Schmaus <flo@geekplace.eu>
Signed-off-by: Andrii Nakryiko <andrii@kernel.org>
Tested-by: Holger Hoffstätte <holger@applied-asynchrony.com>
Link: https://lore.kernel.org/bpf/20241102100452.793970-1-flo@geekplace.eu
2024-11-02 06:04:51 -04:00
|
|
|
pahole-flags-$(call test-ge, $(pahole-ver), 126) = -j$(JOBS) --btf_features=encode_force,var,float,enum64,decl_tag,type_tag,optimized_func,consistent_func,decl_tag_kfuncs
|
2024-05-07 09:55:14 -04:00
|
|
|
|
2024-06-20 05:17:32 -04:00
|
|
|
ifneq ($(KBUILD_EXTMOD),)
|
|
|
|
module-pahole-flags-$(call test-ge, $(pahole-ver), 126) += --btf_features=distilled_base
|
|
|
|
endif
|
|
|
|
|
2024-05-07 09:55:14 -04:00
|
|
|
endif
|
|
|
|
|
|
|
|
pahole-flags-$(CONFIG_PAHOLE_HAS_LANG_EXCLUDE) += --lang_exclude=rust
|
2023-10-18 11:19:48 -04:00
|
|
|
|
|
|
|
export PAHOLE_FLAGS := $(pahole-flags-y)
|
2024-06-20 05:17:32 -04:00
|
|
|
export MODULE_PAHOLE_FLAGS := $(module-pahole-flags-y)
|