Fix linking with new ld, based on u-boot
This commit is contained in:
parent
e918d9035f
commit
1d8bdd6f22
3
Makefile
3
Makefile
|
@ -306,6 +306,9 @@ AFLAGS := -D__ASSEMBLY__
|
|||
|
||||
LDFLAGS_barebox := -Map barebox.map
|
||||
|
||||
# Avoid 'Not enough room for program headers' error on binutils 2.28 onwards.
|
||||
LDFLAGS_barebox += $(call ld-option, --no-dynamic-linker)
|
||||
|
||||
# Read KERNELRELEASE from include/config/kernel.release (if it exists)
|
||||
KERNELRELEASE = $(shell cat include/config/kernel.release 2> /dev/null)
|
||||
KERNELVERSION = $(VERSION).$(PATCHLEVEL).$(SUBLEVEL)$(EXTRAVERSION)
|
||||
|
|
|
@ -53,6 +53,9 @@ extra-y += $(pbl-lds)
|
|||
$(pbl-lds): $(obj)/../arch/$(ARCH)/lib/pbl.lds.S FORCE
|
||||
$(call if_changed_dep,cpp_lds_S)
|
||||
|
||||
# Avoid 'Not enough room for program headers' error on binutils 2.28 onwards.
|
||||
LDFLAGS += $(call ld-option, --no-dynamic-linker)
|
||||
|
||||
quiet_cmd_elf__ ?= LD $@
|
||||
cmd_elf__ ?= $(LD) $(LDFLAGS) --gc-sections -pie \
|
||||
-e $(2) -Map $@.map $(LDFLAGS_$(@F)) -o $@ \
|
||||
|
|
|
@ -148,7 +148,7 @@ cc-ldoption = $(call try-run,\
|
|||
# ld-option
|
||||
# Usage: LDFLAGS += $(call ld-option, -X)
|
||||
ld-option = $(call try-run,\
|
||||
$(CC) /dev/null -c -o "$$TMPO" ; $(LD) $(1) "$$TMPO" -o "$$TMP",$(1),$(2))
|
||||
$(CC) -x c /dev/null -c -o "$$TMPO" ; $(LD) $(1) "$$TMPO" -o "$$TMP",$(1),$(2))
|
||||
|
||||
# ar-option
|
||||
# Usage: KBUILD_ARFLAGS := $(call ar-option,D)
|
||||
|
|
Loading…
Reference in New Issue