|
@@ -1,97 +0,0 @@
|
|
|
-From 29e9322e6a8238205780107e731a51b48845f9c7 Mon Sep 17 00:00:00 2001
|
|
|
-From: Julien Olivain <ju.o@free.fr>
|
|
|
-Date: Mon, 10 Feb 2025 22:59:04 +0100
|
|
|
-Subject: [PATCH] Makefile.am: fix parallel build
|
|
|
-
|
|
|
-When building fakeroot on host with large number of CPUs, compilation
|
|
|
-can randomly fail. Failures were observed on hosts with 24 CPUs.
|
|
|
-
|
|
|
-Build logs show errors such as:
|
|
|
-
|
|
|
- make -j$(nproc)
|
|
|
- ...
|
|
|
- awk -f ./wrapawk < ./wrapfunc.inp
|
|
|
- awk -f ./wrapawk < ./wrapfunc.inp
|
|
|
- ...
|
|
|
- In file included from libfakeroot.c:265:
|
|
|
- wraptmpf.h:607: error: unterminated #ifdef
|
|
|
- 607 | #ifdef __APPLE__
|
|
|
- |
|
|
|
- wraptmpf.h:601: error: unterminated #ifdef
|
|
|
- 601 | #ifdef HAVE_FTS_CHILDREN
|
|
|
- |
|
|
|
- wraptmpf.h:2: error: unterminated #ifndef
|
|
|
- 2 | #ifndef WRAPTMPF_H
|
|
|
- |
|
|
|
- ...
|
|
|
-
|
|
|
-The issue was observed in the builders of Buildroot Linux [1], which
|
|
|
-is using fakeroot. Examples of build failures are [2], [3], [4].
|
|
|
-
|
|
|
-It is important to note that in all failing cases, there is
|
|
|
-more that one parallel invocation of the "wrapawk" script [5].
|
|
|
-
|
|
|
-This script is meant to generate many output files (wrapped.h,
|
|
|
-wrapdef.h, wrapstruct.h, wraptmpf.h) from a single invocation.
|
|
|
-
|
|
|
-The Makefile.am file is using multiple targets in an attempt to
|
|
|
-reflect that generation of multiple outputs at once. See [6].
|
|
|
-
|
|
|
-This use of multiple targets in this rule is incorrect here. See
|
|
|
-the Make manual [7]. This construct, used in Makefile.am, incorrectly
|
|
|
-assumes all those targets are independant (so they can be executed in
|
|
|
-parallel). They are not. In the current failing case, parallel
|
|
|
-invocations will generates all their respective output files,
|
|
|
-overwriting each other. This could lead to incomplete generated
|
|
|
-files, resulting to the observed compilation failures.
|
|
|
-
|
|
|
-Note that GNU Make 4.3 introduced "Grouped Targets" for that purpose.
|
|
|
-See "Rules with Grouped Targets" section in [7]. But this would add a
|
|
|
-requirement on Make >= 4.3.
|
|
|
-
|
|
|
-For that reason, this commit fixes the issue by using a simpler
|
|
|
-construct, working with all Make versions: the first output file
|
|
|
-"wrapped.h" is kept as a target, and it is devlared as a
|
|
|
-dependency of the three other generated files. This change makes sure
|
|
|
-that only one invocation of "wrapawk" will happen at a time,
|
|
|
-disregarding the number of parallel jobs requiring those generated
|
|
|
-files. This has the effect of completely solving the parallel build
|
|
|
-for all GNU Make versions.
|
|
|
-
|
|
|
-[1] https://buildroot.org/
|
|
|
-[2] https://gitlab.com/buildroot.org/buildroot/-/jobs/9085451831
|
|
|
-[3] https://gitlab.com/buildroot.org/buildroot/-/jobs/9085451244
|
|
|
-[4] https://gitlab.com/buildroot.org/buildroot/-/jobs/9085451198
|
|
|
-[5] https://salsa.debian.org/clint/fakeroot/-/blob/master/wrapawk
|
|
|
-[6] https://salsa.debian.org/clint/fakeroot/-/blob/upstream/1.37/Makefile.am#L54
|
|
|
-[7] https://www.gnu.org/software/make/manual/html_node/Multiple-Targets.html
|
|
|
-
|
|
|
-Upstream: Proposed: https://salsa.debian.org/clint/fakeroot/-/merge_requests/33
|
|
|
-Signed-off-by: Julien Olivain <ju.o@free.fr>
|
|
|
----
|
|
|
- Makefile.am | 5 +++--
|
|
|
- 1 file changed, 3 insertions(+), 2 deletions(-)
|
|
|
-
|
|
|
-diff --git a/Makefile.am b/Makefile.am
|
|
|
-index 46f01eb..ff71a8d 100644
|
|
|
---- a/Makefile.am
|
|
|
-+++ b/Makefile.am
|
|
|
-@@ -48,12 +48,13 @@ EXTRA_DIST=wrapawk wrapawk_macosx wrapfunc.inp \
|
|
|
- CLEAN_FILES=fakerootconfig.h
|
|
|
-
|
|
|
- if MACOSX
|
|
|
--wrapped.h wrapdef.h wrapstruct.h wraptmpf.h:wrapawk_macosx wrapfunc.inp
|
|
|
-+wrapped.h: wrapawk_macosx wrapfunc.inp
|
|
|
- awk -f $(srcdir)/wrapawk_macosx < $(srcdir)/wrapfunc.inp
|
|
|
- else !MACOSX
|
|
|
--wrapped.h wrapdef.h wrapstruct.h wraptmpf.h:wrapawk wrapfunc.inp
|
|
|
-+wrapped.h: wrapawk wrapfunc.inp
|
|
|
- awk -f $(srcdir)/wrapawk < $(srcdir)/wrapfunc.inp
|
|
|
- endif !MACOSX
|
|
|
-+wrapdef.h wrapstruct.h wraptmpf.h: wrapped.h
|
|
|
-
|
|
|
- libfakeroot.lo:libfakeroot.c wrapdef.h wrapstruct.h wraptmpf.h
|
|
|
-
|
|
|
---
|
|
|
-2.48.1
|
|
|
-
|