mirror of
https://github.com/u-boot/u-boot.git
synced 2025-04-18 10:54:37 +00:00

In case the build system builds a directory with empty Makefile, one which does not contain any obj-y entries, the build fails to link due to missing built-in.o . This happens because of this part of scripts/Makefile.build 81 ifneq ($(strip $(obj-y) $(obj-m) $(obj-) $(subdir-m) $(lib-target)),) 82 builtin-target := $(obj)/built-in.o 83 endif which does not assign builtin-target in case obj-y is empty. The built-in target is then not built at all, and built-in.o is not generated by this part of scripts/Makefile.build 325 ifdef builtin-target 326 quiet_cmd_link_o_target = AR $@ 327 # If the list of objects to link is empty, just create an empty built-in.o ... 335 targets += $(builtin-target) 336 endif # builtin-target This is the correct behavior. The final link however expects the built-in.o to exist in every directory included in the build, even in those where the aforementioned code skipped generation of built-in.o . Make sure the built-in.o does exist for every directory used in final link simply by doing touch on every built-in.o used for the link, which will create empty built-in.o in case any built-in.o is missing. A possible alternative fix is the always define the builtin-target and always generate built-in.o . Signed-off-by: Marek Vasut <marek.vasut+renesas@mailbox.org> Tested-by: Quentin Schulz <quentin.schulz@cherry.de>
75 lines
2.6 KiB
Makefile
75 lines
2.6 KiB
Makefile
# SPDX-License-Identifier: GPL-2.0+
|
|
# Copyright (c) 2011 The Chromium OS Authors.
|
|
|
|
PLATFORM_CPPFLAGS += -D__SANDBOX__ -U_FORTIFY_SOURCE
|
|
PLATFORM_CPPFLAGS += -fPIC -ffunction-sections -fdata-sections
|
|
PLATFORM_LIBS += -lrt
|
|
SDL_CONFIG ?= sdl2-config
|
|
|
|
# Define this to avoid linking with SDL, which requires SDL libraries
|
|
# This can solve 'sdl-config: Command not found' errors
|
|
ifeq ($(CONFIG_SANDBOX_SDL),y)
|
|
PLATFORM_LIBS += $(shell $(SDL_CONFIG) --libs)
|
|
PLATFORM_CPPFLAGS += $(shell $(SDL_CONFIG) --cflags)
|
|
endif
|
|
|
|
SANITIZERS :=
|
|
ifdef CONFIG_ASAN
|
|
SANITIZERS += -fsanitize=address
|
|
endif
|
|
ifdef CONFIG_FUZZ
|
|
SANITIZERS += -fsanitize=fuzzer
|
|
endif
|
|
KBUILD_CFLAGS += $(SANITIZERS)
|
|
|
|
cmd_u-boot__ = \
|
|
touch $(u-boot-main) ; \
|
|
$(CC) -o $@ -Wl,-T u-boot.lds $(u-boot-init) \
|
|
$(KBUILD_LDFLAGS:%=-Wl,%) \
|
|
$(SANITIZERS) \
|
|
$(LTO_FINAL_LDFLAGS) \
|
|
-Wl,--whole-archive \
|
|
$(u-boot-main) \
|
|
$(u-boot-keep-syms-lto) \
|
|
-Wl,--no-whole-archive \
|
|
$(PLATFORM_LIBS) -Wl,-Map -Wl,u-boot.map -Wl,--gc-sections
|
|
|
|
cmd_u-boot-spl = (cd $(obj) && \
|
|
touch $(patsubst $(obj)/%,%,$(u-boot-spl-main)) && \
|
|
$(CC) -o $(SPL_BIN) -Wl,-T u-boot-spl.lds \
|
|
$(KBUILD_LDFLAGS:%=-Wl,%) \
|
|
$(SANITIZERS) \
|
|
$(LTO_FINAL_LDFLAGS) \
|
|
$(patsubst $(obj)/%,%,$(u-boot-spl-init)) \
|
|
-Wl,--whole-archive \
|
|
$(patsubst $(obj)/%,%,$(u-boot-spl-main)) \
|
|
$(patsubst $(obj)/%,%,$(u-boot-spl-platdata)) \
|
|
$(patsubst $(obj)/%,%,$(u-boot-spl-keep-syms-lto)) \
|
|
-Wl,--no-whole-archive \
|
|
$(PLATFORM_LIBS) -Wl,-Map -Wl,u-boot-spl.map -Wl,--gc-sections)
|
|
|
|
ifeq ($(HOST_ARCH),$(HOST_ARCH_X86_64))
|
|
EFI_LDS := ${SRCDIR}/../../../arch/x86/lib/elf_x86_64_efi.lds
|
|
EFI_TARGET := --target=efi-app-x86_64
|
|
else ifeq ($(HOST_ARCH),$(HOST_ARCH_X86))
|
|
EFI_LDS := ${SRCDIR}/../../../arch/x86/lib/elf_ia32_efi.lds
|
|
EFI_TARGET := --target=efi-app-ia32
|
|
else ifeq ($(HOST_ARCH),$(HOST_ARCH_AARCH64))
|
|
EFI_LDS := ${SRCDIR}/../../../arch/arm/lib/elf_aarch64_efi.lds
|
|
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 \
|
|
-j .binman_sym_table -j .text_rest \
|
|
-j .efi_runtime -j .efi_runtime_rel
|
|
else ifeq ($(HOST_ARCH),$(HOST_ARCH_ARM))
|
|
EFI_LDS := ${SRCDIR}/../../../arch/arm/lib/elf_arm_efi.lds
|
|
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 \
|
|
-j .binman_sym_table -j .text_rest \
|
|
-j .efi_runtime -j .efi_runtime_rel
|
|
else ifeq ($(HOST_ARCH),$(HOST_ARCH_RISCV32))
|
|
EFI_LDS := ${SRCDIR}/../../../arch/riscv/lib/elf_riscv32_efi.lds
|
|
else ifeq ($(HOST_ARCH),$(HOST_ARCH_RISCV64))
|
|
EFI_LDS := ${SRCDIR}/../../../arch/riscv/lib/elf_riscv64_efi.lds
|
|
endif
|
|
EFI_CRT0 := crt0_sandbox_efi.o
|
|
EFI_RELOC := reloc_sandbox_efi.o
|