]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
kbuild: hdrcheck: fix cross build with clang
authorArnd Bergmann <arnd@arndb.de>
Tue, 25 Feb 2025 10:00:31 +0000 (11:00 +0100)
committerMasahiro Yamada <masahiroy@kernel.org>
Tue, 4 Mar 2025 19:06:45 +0000 (04:06 +0900)
The headercheck tries to call clang with a mix of compiler arguments
that don't include the target architecture. When building e.g. x86
headers on arm64, this produces a warning like

   clang: warning: unknown platform, assuming -mfloat-abi=soft

Add in the KBUILD_CPPFLAGS, which contain the target, in order to make it
build properly.

See also 1b71c2fb04e7 ("kbuild: userprogs: fix bitsize and target
detection on clang").

Reviewed-by: Nathan Chancellor <nathan@kernel.org>
Fixes: feb843a469fb ("kbuild: add $(CLANG_FLAGS) to KBUILD_CPPFLAGS")
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
usr/include/Makefile

index 6c6de1b1622b1a69255b4e9e926cb6efbf3d1d0b..e3d6b03527fecc08e3b24c45502d575d7749be06 100644 (file)
@@ -10,7 +10,7 @@ UAPI_CFLAGS := -std=c90 -Wall -Werror=implicit-function-declaration
 
 # In theory, we do not care -m32 or -m64 for header compile tests.
 # It is here just because CONFIG_CC_CAN_LINK is tested with -m32 or -m64.
-UAPI_CFLAGS += $(filter -m32 -m64 --target=%, $(KBUILD_CFLAGS))
+UAPI_CFLAGS += $(filter -m32 -m64 --target=%, $(KBUILD_CPPFLAGS) $(KBUILD_CFLAGS))
 
 # USERCFLAGS might contain sysroot location for CC.
 UAPI_CFLAGS += $(USERCFLAGS)