9 # shellcheck source=common.sh
10 . "$(dirname "$0")/common.sh"
14 bparent=$(dirname "$build_dir")
16 line=$(tail -n 1 "$SHA1_FILE")
18 # strip everything after the first tab character
21 if [ "$tree" != "$stree" ]; then
22 printf 'That is not the last tree merged (%s v %s)\n' "$tree" "$stree" 1>&2
28 obdir="$bparent/old/$tree"
31 if [ "$build_host" ]; then
32 cmd="ssh root@$build_host unshare -n su $(id -u -n)"
35 log_regex='/^[[:space:]]+$/d
36 /^[.[:digit:]]+user [.[:digit:]]+system [:.[:digit:]]+elapsed [[:digit:]]+%CPU \([[:digit:]]+avgtext\+[[:digit:]]+avgdata [[:digit:]]+maxresident\)k$/d
37 /^[[:digit:]]+inputs\+[[:digit:]]+outputs \([[:digit:]]+major\+[[:digit:]]+minor\)pagefaults [[:digit:]]+swaps$/d
38 /^Setup is [[:digit:]]+ bytes \(padded to [[:digit:]]+ bytes\)\.$/d
39 /^System is [[:digit:]]+ kB$/d
40 /^CRC [[:xdigit:]]+$/d
41 /^Kernel: arch\/x86\/boot\/bzImage is ready \(#[[:digit:]]+\)$/d
42 /^WARNING: vmlinux\.o\(\.text\+0x[[:xdigit:]]+\): Section mismatch in reference from /d
43 /^WARNING: drivers\/built-in\.o\(\.text\+0x[[:xdigit:]]+\): Section mismatch in reference from /d
44 /^Warning: Kernel ABI header at /d
45 /^[[:space:]]+PERF_VERSION = /d
46 s/^(Parsed description of) [[:digit:]]+ (helper function)/\1 X \2/
47 s/^([[:xdigit:]]+)([[:space:]]+R_PPC64_(ADDR64|REL32)[[:space:]].*)$/XXX\2/'
51 echo Building on \$(hostname)
53 echo \$PATH | grep -q "\$HOME/bin" || export PATH="\$HOME/bin:\$PATH"
56 cd "$build_dir" || exit 1
58 export CCACHE_DIR="$bparent/.ccache"
59 export TMPDIR="$bparent/tmp"
61 git reset --hard next || exit 1
62 touch .scmversion || exit 1
64 [ -d "$obdir" ] || mkdir -p "$obdir" || exit 1
67 sed -E -e '$log_regex' | grep -vxFf $bparent/log-ignore
75 sep='======================================================================'
78 echo " \$arch \$conf build OK - log follows"
83 if [ -f $obdir/\$b ]; then
84 olen=\$(sanitise_log <$obdir/\$b | wc -l)
86 len=\$(sanitise_log <\$log | wc -l)
87 if [ \$len -gt \$olen ]; then
89 echo " log \$b increased number of lines"
91 linux-next-notify "\$arch \$conf log got bigger"
92 if [ -f $obdir/\$b ]; then
93 diff -u $obdir/\$b \$log 2>&1 | less
95 diff -u /dev/null \$log 2>&1 | less
98 if [ \$len -gt 0 ]; then
99 (sanitise_log <\$log; cat $bparent/log-ignore ) |
100 sort -u >$bparent/log-ignore.tmp
101 mv $bparent/log-ignore.tmp $bparent/log-ignore
106 echo Building: x86_64 allmodconfig
107 d="$bparent/x86_64_allmodconfig"
108 [ -d \$d ] || mkdir \$d || exit 1
110 make ARCH=x86_64 CROSS_COMPILE=x86_64-linux-gnu- O=\$d -s allmodconfig || exit 1
111 echo "Forking x86 build ..."
112 /usr/bin/time make ARCH=x86_64 CROSS_COMPILE=x86_64-linux-gnu- O=\$d -j"$j_factor" -O -s > \$log_x86 2>&1 &
115 echo Building: powerpc ppc64_defconfig
116 d="$bparent/powerpc_ppc64_defconfig"
117 [ -d \$d ] || mkdir \$d || exit 1
119 make ARCH=powerpc O=\$d -s ppc64_defconfig || exit 1
120 echo "Forking powerpc build ..."
121 /usr/bin/time make ARCH=powerpc O=\$d -j"$j_factor" -O -s > \$log_ppc 2>&1 &
124 echo Building: arm multi_v7_defconfig
125 d="$bparent/arm_multi_v7_defconfig"
126 [ -d \$d ] || mkdir \$d || exit 1
128 make ARCH=arm CROSS_COMPILE=arm-linux-gnueabi- O=\$d -s multi_v7_defconfig || exit 1
129 echo "Forking arm build ..."
130 /usr/bin/time make ARCH=arm CROSS_COMPILE=arm-linux-gnueabi- O=\$d -j"$j_factor" -O -s > \$log_arm 2>&1 &
135 [ -d \$d ] || mkdir \$d || exit 1
137 echo "Forking perf build ..."
138 /usr/bin/time make -C tools/perf -f Makefile.perf -s -O -j"$j_factor" O=\$d > \$log_perf 2>&1 &
144 if [ \$rc -ne 0 ]; then
145 echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
146 echo "ERROR: perf build failed - log follows"
147 echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
149 kill \$x86_64_pid || true
150 kill \$ppc64_pid || true
151 kill \$arm_pid || true
156 show_log native perf \$log_perf
162 if [ \$rc -ne 0 ]; then
163 echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
164 echo "ERROR: arm multi_v7_defconfig build failed - log follows"
165 echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
167 kill \$x86_64_pid || true
168 kill \$ppc64_pid || true
173 show_log arm multi_v7_defconfig \$log_arm
179 if [ \$rc -ne 0 ]; then
180 echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
181 echo "ERROR: powerpc ppc64_defconfig build failed - log follows"
182 echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
184 kill \$x86_64_pid || true
189 show_log powerpc ppc64_defconfig \$log_ppc
195 if [ \$rc -ne 0 ]; then
196 echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
197 echo "ERROR: x86_64 allmodconfig build failed - log follows"
198 echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
203 show_log x86_64 allmodconfig \$log_x86