rpi2 V1.1 vs. hard coded max_execution_time figures in /usr/local/share/poudriere/common.sh (package; also: extract, install, deinstall)

Mark Millard markmi at dsl-only.net
Tue Dec 19 21:37:54 UTC 2017


I tied building devel/llvm50 on a rpi2 V1.1 via poudriere
and it got as far as:

. . .
=======================<phase: package        >============================
===>  Building package for llvm50-5.0.0_6
=>> Killing timed out build after 7200 seconds

This was for:

---Begin OPTIONS List---
===> The following configuration options are available for llvm50-5.0.0_6:
     CLANG=on: Build clang
     DOCS=on: Build and/or install documentation
     EXTRAS=on: Extra clang tools
     LIT=on: Install lit and FileCheck test tools
     LLD=on: Install lld, the LLVM linker
     LLDB=on: Install lldb, the LLVM debugger

But I had set in /usr/local/etc/poudriere.conf :

# This defines the max time (in seconds) that a command may run for a build
# before it is killed for taking too long. Default: 86400
#MAX_EXECUTION_TIME=86400
MAX_EXECUTION_TIME=432000
 
# This defines the time (in seconds) before a command is considered to
# be in a runaway state for having no output on stdout. Default: 7200
#NOHANG_TIME=7200
NOHANG_TIME=28800

The magic 7200 is from /usr/local/share/poudriere/common.sh :

                package)
                        max_execution_time=7200
. . .

There is also a lack of control over:

                extract)
                        max_execution_time=3600
. . .
                install)
                        max_execution_time=3600
. . .
                deinstall)
                        max_execution_time=3600
. . .

The rpi2 is now busy constructing a bsdtar when it
could have had a llvm50 package. (I wonder if the
bsdtar takes less time than the package would have
taken.)

As stands the only way to allow such large builds
on the rpi2 is to edit:

/usr/local/share/poudriere/common.sh

after each poudriere installation/update.

The following large things did manage to build
packages:

lang/gcc7
devel/cmake (indirect from selecting devel/llvm50)

(I avoid WITH_DEBUG for devel/llvm50 in all
environments: that build is massive, needing
between 24 GiBytes and 26 GiBytes for RAM+SWAP
on a powerpc64, if I remember right.)



Other than the hard coded max_execution_time
examples I've no found any fundmental problems
with using poudriere when configured as
indicated below. (Being willing to give it
the time it needed.)

For these experiments I've used:

NO_ZFS=yes
USE_TMPFS=no
PARALLEL_JOBS=1
ALLOW_MAKE_JOBS=yes
MAX_EXECUTION_TIME=432000
NOHANG_TIME=28800

For what I tried I've not had to
use MAKE_JOBS_NUMBER_LIMIT?= or
MAKE_JOBS_NUMBER?= . (Say, in
/usr/local/etc/poudriere.d/make.conf
testing the likes of
.if ${.CURDIR:M*/devel/llvm*}
code.)

The rpi2 has world, kernel, and its dtb
file via a USB SSD Stick, not from a
usdcard. The usdcard is very minimal
as far as its UFS / file system goes:

/etc/fstab (redirecting to the USB SSD)
/boot/* (with /boot/kernel/ empty and /boot/dtb/ empty)

The USB SSD stick has:

# df -m
Filesystem  1M-blocks  Used  Avail Capacity  Mounted on
/dev/da0p1     195378 31305 148443    17%    /
devfs               0     0      0   100%    /dev

(/dev/da0p1 has a UFS file system.)

# swapinfo
Device          1K-blocks     Used    Avail Capacity
/dev/da0p2        1572864    16876  1555988     1%


===
Mark Millard
markmi at dsl-only.net



More information about the freebsd-arm mailing list