From: Alexey Brodkin Date: Thu, 11 Oct 2018 20:12:05 +0000 (+0300) Subject: ARC: Don't use COMMON section for global not-initialized variables X-Git-Tag: v2025.01-rc5-pxa1908~3365^2 X-Git-Url: http://git.dujemihanovic.xyz/img/login.html?a=commitdiff_plain;h=6e63314f432d32d2ce12a51dafa78129e81fe9cf;p=u-boot.git ARC: Don't use COMMON section for global not-initialized variables By default GCC puts global non-initialized variables in COMMON section. And we used to ignore existence of COMMON section in our linker scripts though smart LD silently appended it right after .bss. And the problem here is variables from COMMON section even though require zeroing in run-time were not zeroed as they were placed right after __bss_end symbol. It was a pure luck we never faced serious problem due to this, but now it is fixed. Now as for some other architectures we'll just force GCC to put those global variables in normal .bss section. This solution is much nicer than adding COMMON section to each and every linker script. Signed-off-by: Alexey Brodkin --- diff --git a/arch/arc/config.mk b/arch/arc/config.mk index d255c90e35..18005d9993 100644 --- a/arch/arc/config.mk +++ b/arch/arc/config.mk @@ -43,7 +43,7 @@ PLATFORM_CPPFLAGS += -mcpu=archs endif PLATFORM_CPPFLAGS += -ffixed-r25 -D__ARC__ -gdwarf-2 -mno-sdata -PLATFORM_RELFLAGS += -ffunction-sections -fdata-sections +PLATFORM_RELFLAGS += -ffunction-sections -fdata-sections -fno-common # Needed for relocation LDFLAGS_FINAL += -pie --gc-sections