package/fakeroot: add patch to fix parallel build
When building host-fakeroot on host with large number of CPUs,
compilation can randomly fail. Failures are observed on hosts
with 24 CPUs or more.
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
|
...
This commit fixes the issue by adding a package patch.
Fixes:
- https://gitlab.com/buildroot.org/buildroot/-/jobs/9085451831
- https://gitlab.com/buildroot.org/buildroot/-/jobs/9085451244
- https://gitlab.com/buildroot.org/buildroot/-/jobs/9085451198
- and many more...
Signed-off-by: Julien Olivain <ju.o@free.fr>
Signed-off-by: Peter Korsgaard <peter@korsgaard.com>
(cherry picked from commit 45c13bf2490124f265a2efd6c0c3b8065e4498f6)
Signed-off-by: Peter Korsgaard <peter@korsgaard.com>
This commit is contained in:
parent
f755df596d
commit
614ecffacc
97
package/fakeroot/0001-Makefile.am-fix-parallel-build.patch
Normal file
97
package/fakeroot/0001-Makefile.am-fix-parallel-build.patch
Normal file
@ -0,0 +1,97 @@
|
||||
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
|
||||
|
||||
@ -15,6 +15,8 @@ HOST_FAKEROOT_DEPENDENCIES = host-acl
|
||||
HOST_FAKEROOT_CONF_ENV = \
|
||||
ac_cv_header_sys_capability_h=no \
|
||||
ac_cv_func_capset=no
|
||||
# 0001-Makefile.am-fix-parallel-build.patch
|
||||
HOST_FAKEROOT_AUTORECONF = YES
|
||||
FAKEROOT_LICENSE = GPL-3.0+
|
||||
FAKEROOT_LICENSE_FILES = COPYING
|
||||
|
||||
|
||||
Loading…
Reference in New Issue
Block a user