arm64: vdso32: require CROSS_COMPILE_COMPAT for gcc+bfd
commit 3e6f8d1fa18457d54b20917bd9174d27daf09ab9 upstream.
Similar to
commit 231ad7f409f1 ("Makefile: infer --target from ARCH for CC=clang")
There really is no point in setting --target based on
$CROSS_COMPILE_COMPAT for clang when the integrated assembler is being
used, since
commit ef94340583ee ("arm64: vdso32: drop -no-integrated-as flag").
Allows COMPAT_VDSO to be selected without setting $CROSS_COMPILE_COMPAT
when using clang and lld together.
Before:
$ ARCH=arm64 CROSS_COMPILE_COMPAT=arm-linux-gnueabi- make -j72 LLVM=1 defconfig
$ grep CONFIG_COMPAT_VDSO .config
CONFIG_COMPAT_VDSO=y
$ ARCH=arm64 make -j72 LLVM=1 defconfig
$ grep CONFIG_COMPAT_VDSO .config
$
After:
$ ARCH=arm64 CROSS_COMPILE_COMPAT=arm-linux-gnueabi- make -j72 LLVM=1 defconfig
$ grep CONFIG_COMPAT_VDSO .config
CONFIG_COMPAT_VDSO=y
$ ARCH=arm64 make -j72 LLVM=1 defconfig
$ grep CONFIG_COMPAT_VDSO .config
CONFIG_COMPAT_VDSO=y
Reviewed-by: Nathan Chancellor <nathan@kernel.org>
Suggested-by: Nathan Chancellor <nathan@kernel.org>
Tested-by: Nathan Chancellor <nathan@kernel.org>
Signed-off-by: Nick Desaulniers <ndesaulniers@google.com>
Reviewed-by: Vincenzo Frascino <vincenzo.frascino@arm.com>
Link: https://lore.kernel.org/r/20211019223646.1146945-5-ndesaulniers@google.com
Signed-off-by: Will Deacon <will@kernel.org>
Signed-off-by: Nauval Rizky <enuma.alrizky@gmail.com>
Signed-off-by: Fiqri Ardyansyah <fiqri0927936@gmail.com>
Signed-off-by: Cyber Knight <cyberknight755@gmail.com>
This commit is contained in:
committed by
Debayan Kar
parent
05f84a7909
commit
1c525446f9
@@ -71,12 +71,11 @@ ifeq ($(CONFIG_COMPAT_VDSO), y)
|
||||
# should be ignored. If the error is triggered and you set
|
||||
# CONFIG_CROSS_COMPILE_COMPAT, set CROSS_COMPILE_COMPAT to an appropriate value
|
||||
# when invoking make and fix CONFIG_CROSS_COMPILE_COMPAT.
|
||||
ifeq ($(CROSS_COMPILE_COMPAT),)
|
||||
$(error CROSS_COMPILE_COMPAT not defined or empty, the compat vDSO will not be built)
|
||||
else ifeq ($(cc-name),clang)
|
||||
export CROSS_COMPILE_COMPAT
|
||||
ifeq ($(cc-name),clang)
|
||||
export CONFIG_VDSO32 := y
|
||||
vdso32 := -DCONFIG_VDSO32=1
|
||||
else ifeq ($(CROSS_COMPILE_COMPAT),)
|
||||
$(error CROSS_COMPILE_COMPAT not defined or empty, the compat vDSO will not be built)
|
||||
else ifeq ($(shell which $(CROSS_COMPILE_COMPAT)$(cc-name) 2> /dev/null),)
|
||||
$(error $(CROSS_COMPILE_COMPAT)$(cc-name) not found, check CROSS_COMPILE_COMPAT)
|
||||
else
|
||||
|
||||
@@ -5,7 +5,7 @@
|
||||
# A mix between the arm64 and arm vDSO Makefiles.
|
||||
|
||||
ifeq ($(cc-name),clang)
|
||||
CC_ARM32 := $(CC) --target=$(notdir $(CROSS_COMPILE_COMPAT:%-=%))
|
||||
CC_ARM32 := $(CC) --target=arm-linux-gnueabi
|
||||
else
|
||||
CC_ARM32 := $(CROSS_COMPILE_COMPAT)$(cc-name)
|
||||
endif
|
||||
|
||||
Reference in New Issue
Block a user