4b0d506ed3
Recent Linux distributions (e.g. Debian 9) include cross-compilers for AArch64, but only for the aarch64-linux-gnu triplet only. It can thus be expected that users will attempt to use the system cross-compiler (instead of an aarch64-elf variant) to compile U-Boot for their ARMv8 target systems. One key differences between an aarch64-linux-gnu and an aarch64-elf compiler are the default settings regarding position-independent: with the aarch64-linux-gnu compiler, the default will create and use the global offset table. This change-set adjusts the list of sections copied on ARMv8 to include the GOT sections. With this added, the list matches the previous setup for AArch32 closely. Note that this is not an 'academic' issue, but was in fact encountered by our QA during testing of the RK3399-Q7 BSP and resulted in an early failure of the SPL stage during FDT setup. Signed-off-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com> Tested-by: Klaus Goger <klaus.goger@theobroma-systems.com> Reviewed-by: Simon Glass <sjg@chromium.org> Reviewed-by: Tom Rini <trini@konsulko.com>
157 lines
4.3 KiB
Makefile
157 lines
4.3 KiB
Makefile
#
|
|
# (C) Copyright 2000-2002
|
|
# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
|
|
#
|
|
# SPDX-License-Identifier: GPL-2.0+
|
|
#
|
|
|
|
ifndef CONFIG_STANDALONE_LOAD_ADDR
|
|
ifneq ($(CONFIG_ARCH_OMAP2),)
|
|
CONFIG_STANDALONE_LOAD_ADDR = 0x80300000
|
|
else
|
|
CONFIG_STANDALONE_LOAD_ADDR = 0xc100000
|
|
endif
|
|
endif
|
|
|
|
CFLAGS_NON_EFI := -fno-pic -ffixed-r9 -ffunction-sections -fdata-sections
|
|
CFLAGS_EFI := -fpic -fshort-wchar
|
|
|
|
LDFLAGS_FINAL += --gc-sections
|
|
PLATFORM_RELFLAGS += -ffunction-sections -fdata-sections \
|
|
-fno-common -ffixed-r9
|
|
PLATFORM_RELFLAGS += $(call cc-option, -msoft-float) \
|
|
$(call cc-option,-mshort-load-bytes,$(call cc-option,-malignment-traps,))
|
|
|
|
# LLVM support
|
|
LLVMS_RELFLAGS := $(call cc-option,-mllvm,) \
|
|
$(call cc-option,-target arm-none-eabi,) \
|
|
$(call cc-option,-arm-use-movt=0,)
|
|
PLATFORM_RELFLAGS += $(LLVM_RELFLAGS)
|
|
|
|
PLATFORM_CPPFLAGS += -D__ARM__
|
|
|
|
# Choose between ARM/Thumb instruction sets
|
|
ifeq ($(CONFIG_$(SPL_)SYS_THUMB_BUILD),y)
|
|
AFLAGS_IMPLICIT_IT := $(call as-option,-Wa$(comma)-mimplicit-it=always)
|
|
PF_CPPFLAGS_ARM := $(AFLAGS_IMPLICIT_IT) \
|
|
$(call cc-option, -mthumb -mthumb-interwork,\
|
|
$(call cc-option,-marm,)\
|
|
$(call cc-option,-mno-thumb-interwork,)\
|
|
)
|
|
else
|
|
PF_CPPFLAGS_ARM := $(call cc-option,-marm,) \
|
|
$(call cc-option,-mno-thumb-interwork,)
|
|
endif
|
|
|
|
# Only test once
|
|
ifeq ($(CONFIG_$(SPL_)SYS_THUMB_BUILD),y)
|
|
archprepare: checkthumb
|
|
|
|
checkthumb:
|
|
@if test "$(call cc-name)" = "gcc" -a \
|
|
"$(call cc-version)" -lt "0404"; then \
|
|
echo -n '*** Your GCC does not produce working '; \
|
|
echo 'binaries in THUMB mode.'; \
|
|
echo '*** Your board is configured for THUMB mode.'; \
|
|
false; \
|
|
fi
|
|
endif
|
|
|
|
# Try if EABI is supported, else fall back to old API,
|
|
# i. e. for example:
|
|
# - with ELDK 4.2 (EABI supported), use:
|
|
# -mabi=aapcs-linux
|
|
# - with ELDK 4.1 (gcc 4.x, no EABI), use:
|
|
# -mabi=apcs-gnu
|
|
# - with ELDK 3.1 (gcc 3.x), use:
|
|
# -mapcs-32
|
|
PF_CPPFLAGS_ABI := $(call cc-option,\
|
|
-mabi=aapcs-linux,\
|
|
$(call cc-option,\
|
|
-mapcs-32,\
|
|
$(call cc-option,\
|
|
-mabi=apcs-gnu,\
|
|
)\
|
|
)\
|
|
)
|
|
PLATFORM_CPPFLAGS += $(PF_CPPFLAGS_ARM) $(PF_CPPFLAGS_ABI)
|
|
|
|
# For EABI, make sure to provide raise()
|
|
ifneq (,$(findstring -mabi=aapcs-linux,$(PLATFORM_CPPFLAGS)))
|
|
# This file is parsed many times, so the string may get added multiple
|
|
# times. Also, the prefix needs to be different based on whether
|
|
# CONFIG_SPL_BUILD is defined or not. 'filter-out' the existing entry
|
|
# before adding the correct one.
|
|
PLATFORM_LIBS := arch/arm/lib/eabi_compat.o \
|
|
$(filter-out arch/arm/lib/eabi_compat.o, $(PLATFORM_LIBS))
|
|
endif
|
|
|
|
# needed for relocation
|
|
LDFLAGS_u-boot += -pie
|
|
|
|
#
|
|
# FIXME: binutils versions < 2.22 have a bug in the assembler where
|
|
# branches to weak symbols can be incorrectly optimized in thumb mode
|
|
# to a short branch (b.n instruction) that won't reach when the symbol
|
|
# gets preempted
|
|
#
|
|
# http://sourceware.org/bugzilla/show_bug.cgi?id=12532
|
|
#
|
|
ifeq ($(CONFIG_$(SPL_)SYS_THUMB_BUILD),y)
|
|
ifeq ($(GAS_BUG_12532),)
|
|
export GAS_BUG_12532:=$(shell if [ $(call binutils-version) -lt 0222 ] ; \
|
|
then echo y; else echo n; fi)
|
|
endif
|
|
ifeq ($(GAS_BUG_12532),y)
|
|
PLATFORM_RELFLAGS += -fno-optimize-sibling-calls
|
|
endif
|
|
endif
|
|
|
|
ifneq ($(CONFIG_SPL_BUILD),y)
|
|
# 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)
|
|
PLATFORM_CPPFLAGS += $(call cc-option, -fno-pic)
|
|
endif
|
|
|
|
# limit ourselves to the sections we want in the .bin.
|
|
ifdef CONFIG_ARM64
|
|
OBJCOPYFLAGS += -j .text -j .secure_text -j .secure_data -j .rodata -j .data \
|
|
-j .u_boot_list -j .rela.dyn -j .got -j .got.plt
|
|
else
|
|
OBJCOPYFLAGS += -j .text -j .secure_text -j .secure_data -j .rodata -j .hash \
|
|
-j .data -j .got -j .got.plt -j .u_boot_list -j .rel.dyn
|
|
endif
|
|
|
|
ifdef CONFIG_OF_EMBED
|
|
OBJCOPYFLAGS += -j .dtb.init.rodata
|
|
endif
|
|
|
|
ifdef CONFIG_EFI_LOADER
|
|
OBJCOPYFLAGS += -j .efi_runtime -j .efi_runtime_rel
|
|
endif
|
|
|
|
ifneq ($(CONFIG_IMX_CONFIG),)
|
|
ifdef CONFIG_SPL
|
|
ifndef CONFIG_SPL_BUILD
|
|
ALL-y += SPL
|
|
endif
|
|
else
|
|
ifeq ($(CONFIG_OF_SEPARATE),y)
|
|
ALL-y += u-boot-dtb.imx
|
|
else
|
|
ALL-y += u-boot.imx
|
|
endif
|
|
endif
|
|
ifneq ($(CONFIG_VF610),)
|
|
ALL-y += u-boot.vyb
|
|
endif
|
|
endif
|
|
|
|
EFI_LDS := elf_arm_efi.lds
|
|
EFI_CRT0 := crt0_arm_efi.o
|
|
EFI_RELOC := reloc_arm_efi.o
|