From: Jeroen Hofstee Date: Sat, 24 Aug 2013 11:55:38 +0000 (+0200) Subject: arm: prevent using movt/movw address loads X-Git-Tag: v2025.01-rc5-pxa1908~15863^2~7 X-Git-Url: http://git.dujemihanovic.xyz/%22http:/www.sics.se/static/%7B%7B%20.RelPermalink%20%7D%7D?a=commitdiff_plain;h=373d79839451de08c3dce9231a133178378c4590;p=u-boot.git arm: prevent using movt/movw address loads The movt/movw instruction can be used to hardcode an memory location in the instruction itself. The linker starts complaining about this if the compiler decides to do so: "relocation R_ARM_MOVW_ABS_NC against `a local symbol' can not be used" and it is not support by U-boot as well. Prevent their use by requiring word relocations. This allows u-boot to be build at other optimalization levels then -Os. Signed-off-by: Jeroen Hofstee Cc: TigerLiu@viatech.com.cn Cc: Albert ARIBAUD Acked-by: Simon Glass --- diff --git a/arch/arm/config.mk b/arch/arm/config.mk index ce3903ba9f..19451ba668 100644 --- a/arch/arm/config.mk +++ b/arch/arm/config.mk @@ -94,7 +94,11 @@ PLATFORM_RELFLAGS += -fno-optimize-sibling-calls endif endif -# check that only R_ARM_RELATIVE relocations are generated ifneq ($(CONFIG_SPL_BUILD),y) -ALL-y += checkarmreloc +# Check that only R_ARM_RELATIVE relocations are generated. +ALL-y += checkarmreloc +# The movt / movw can hardcode 16 bit parts of the addresses in the +# instruction. Relocation is not supported for that case, so disable +# such usage by requiring word relocations. +PLATFORM_CPPFLAGS += $(call cc-option, -mword-relocations) endif