]> www.infradead.org Git - users/jedix/linux-maple.git/commit
kbuild: Require pahole <v1.28 or >v1.29 with GENDWARFKSYMS on X86
authorSami Tolvanen <samitolvanen@google.com>
Mon, 7 Apr 2025 23:08:44 +0000 (23:08 +0000)
committerMasahiro Yamada <masahiroy@kernel.org>
Mon, 12 May 2025 06:03:16 +0000 (15:03 +0900)
commit9520a2b3f0b5e182f73410e45b9b92ea51d9b828
treea9de682b8e0d2df36c82188b5f75682b3557ec7d
parent82f2b0b97b36ee3fcddf0f0780a9a0825d52fec3
kbuild: Require pahole <v1.28 or >v1.29 with GENDWARFKSYMS on X86

With CONFIG_GENDWARFKSYMS, __gendwarfksyms_ptr variables are
added to the kernel in EXPORT_SYMBOL() to ensure DWARF type
information is available for exported symbols in the TUs where
they're actually exported. These symbols are dropped when linking
vmlinux, but dangling references to them remain in DWARF.

With CONFIG_DEBUG_INFO_BTF enabled on X86, pahole versions after
commit 47dcb534e253 ("btf_encoder: Stop indexing symbols for
VARs") and before commit 9810758003ce ("btf_encoder: Verify 0
address DWARF variables are in ELF section") place these symbols
in the .data..percpu section, which results in an "Invalid
offset" error in btf_datasec_check_meta() during boot, as all
the variables are at zero offset and have non-zero size. If
CONFIG_DEBUG_INFO_BTF_MODULES is enabled, this also results in a
failure to load modules with:

  failed to validate module [$module] BTF: -22

As the issue occurs in pahole v1.28 and the fix was merged
after v1.29 was released, require pahole <v1.28 or >v1.29 when
GENDWARFKSYMS is enabled with DEBUG_INFO_BTF on X86.

Reported-by: Paolo Pisati <paolo.pisati@canonical.com>
Signed-off-by: Sami Tolvanen <samitolvanen@google.com>
Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
kernel/module/Kconfig