mirror of
https://git.yoctoproject.org/poky
synced 2026-05-31 12:49:46 +00:00
u-boot: Fix build race condition
Backports 2f61b13d6acba787b00598d519c85222e993e4ca (included in the 2018.07 release) which fixes a race condition when building. [YOCTO #12705] (From OE-Core rev: 77586b8e1e50234f34b6c469c41819e36cc8a786) Signed-off-by: Joshua Watt <JPEWhacker@gmail.com> Signed-off-by: Armin Kuster <akuster808@gmail.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
committed by
Richard Purdie
parent
b136c92b29
commit
e4f158a461
@@ -0,0 +1,51 @@
|
|||||||
|
From 5c2e24a9ed54dfee77d1844a080e998b4affe916 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Heinrich Schuchardt <xypron.glpk@gmx.de>
|
||||||
|
Date: Sat, 2 Jun 2018 19:00:41 +0200
|
||||||
|
Subject: [PATCH] efi_loader: avoid make race condition
|
||||||
|
|
||||||
|
When U-Boot is built with 'make -j' there is not guarantee that targets in
|
||||||
|
directory arch/ are built before targets in directory lib/. The current
|
||||||
|
build instruction for EFI binaries in lib/ rely on dependencies in arch/.
|
||||||
|
If $(EFI_CRT0) or $(EFI_RELOC) is not yet built before trying to build
|
||||||
|
%.efi an error
|
||||||
|
*** No rule to make target '%.efi'
|
||||||
|
occurs.
|
||||||
|
|
||||||
|
With the patch separate copies of $(EFI_CRT0) and $(EFI_RELOC) named
|
||||||
|
efi_crt0.o and efi_reloc.o are built in lib/efi_loader and
|
||||||
|
lib/efi_selftest.
|
||||||
|
|
||||||
|
Signed-off-by: Heinrich Schuchardt <xypron.glpk@gmx.de>
|
||||||
|
Signed-off-by: Alexander Graf <agraf@suse.de>
|
||||||
|
|
||||||
|
Upstream-Status: Backport from 2018.07
|
||||||
|
|
||||||
|
Signed-off-by: Joshua Watt <JPEWhacker@gmail.com>
|
||||||
|
---
|
||||||
|
scripts/Makefile.lib | 10 ++++++++--
|
||||||
|
1 file changed, 8 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/scripts/Makefile.lib b/scripts/Makefile.lib
|
||||||
|
index 8f19b2db56..f2f398c935 100644
|
||||||
|
--- a/scripts/Makefile.lib
|
||||||
|
+++ b/scripts/Makefile.lib
|
||||||
|
@@ -404,8 +404,14 @@ cmd_efi_ld = $(LD) -nostdlib -znocombreloc -T $(EFI_LDS_PATH) -shared \
|
||||||
|
|
||||||
|
EFI_LDS_PATH = $(srctree)/arch/$(ARCH)/lib/$(EFI_LDS)
|
||||||
|
|
||||||
|
-$(obj)/%_efi.so: $(obj)/%.o arch/$(ARCH)/lib/$(EFI_CRT0) \
|
||||||
|
- arch/$(ARCH)/lib/$(EFI_RELOC)
|
||||||
|
+$(obj)/efi_crt0.o: $(srctree)/arch/$(ARCH)/lib/$(EFI_CRT0:.o=.S)
|
||||||
|
+ $(call if_changed_dep,as_o_S)
|
||||||
|
+
|
||||||
|
+$(obj)/efi_reloc.o: $(srctree)/arch/$(ARCH)/lib/$(EFI_RELOC:.o=.c) $(recordmcount_source) FORCE
|
||||||
|
+ $(call cmd,force_checksrc)
|
||||||
|
+ $(call if_changed_rule,cc_o_c)
|
||||||
|
+
|
||||||
|
+$(obj)/%_efi.so: $(obj)/%.o $(obj)/efi_crt0.o $(obj)/efi_reloc.o
|
||||||
|
$(call cmd,efi_ld)
|
||||||
|
|
||||||
|
# ACPI
|
||||||
|
--
|
||||||
|
2.17.1
|
||||||
|
|
||||||
@@ -11,6 +11,7 @@ SRCREV = "f3dd87e0b98999a78e500e8c6d2b063ebadf535a"
|
|||||||
|
|
||||||
SRC_URI = "git://git.denx.de/u-boot.git \
|
SRC_URI = "git://git.denx.de/u-boot.git \
|
||||||
file://MPC8315ERDB-enable-DHCP.patch \
|
file://MPC8315ERDB-enable-DHCP.patch \
|
||||||
|
file://0001-efi_loader-avoid-make-race-condition.patch \
|
||||||
"
|
"
|
||||||
|
|
||||||
S = "${WORKDIR}/git"
|
S = "${WORKDIR}/git"
|
||||||
|
|||||||
Reference in New Issue
Block a user