9 tools_dir=$(cd $(dirname "$0"); pwd)
10 . "$tools_dir/common.sh"
14 bparent=$(dirname "$build_dir")
16 line="$(tail -n 1 $SHA1_FILE)"
18 # strip everything after the first tab character
21 [ "$tree" = "$stree" ] || {
22 echo "That is not the last tree merged ($tree v $stree)" 1>&2
28 obdir="$bparent/old/$tree"
32 cmd="ssh root@$build_host unshare -n su $(id -u -n)"
36 echo Building on \$(hostname)
38 echo \$PATH | grep -q "\$HOME/bin" || export PATH="\$HOME/bin:\$PATH"
41 cd "$build_dir" || exit 1
43 export CCACHE_DIR="$bparent/.ccache"
44 export TMPDIR="$bparent/tmp"
46 git reset --hard next || exit 1
47 touch .scmversion || exit 1
49 [ -d "$obdir" ] || mkdir -p "$obdir" || exit 1
53 /^[.[:digit:]]+user [.[:digit:]]+system [:.[:digit:]]+elapsed [[:digit:]]+%CPU \([[:digit:]]+avgtext\+[[:digit:]]+avgdata [[:digit:]]+maxresident\)k$/d
54 /^[[:digit:]]+inputs\+[[:digit:]]+outputs \([[:digit:]]+major\+[[:digit:]]+minor\)pagefaults [[:digit:]]+swaps$/d
55 /^Setup is [[:digit:]]+ bytes \(padded to [[:digit:]]+ bytes\)\.$/d
56 /^System is [[:digit:]]+ kB$/d
57 /^CRC [[:xdigit:]]+$/d
58 /^Kernel: arch\/x86\/boot\/bzImage is ready \(#[[:digit:]]+\)$/d
59 ' | grep -vxFf $bparent/log-ignore
67 sep='======================================================================'
70 echo " \$arch \$conf build OK - log follows"
74 if [ -f $obdir/\$b ]; then
75 olen=\$(sanitise_log <$obdir/\$b | wc -l)
76 len=\$(sanitise_log <\$log | wc -l)
77 if [ \$olen -lt \$len ]; then
79 echo " log \$b increased number of lines"
81 pushover "linux-next log got bigger"
82 diff -u $obdir/\$b \$log 2>&1 | less
88 echo Building: x86_64 allmodconfig
89 d="$bparent/x86_64_allmodconfig"
90 [ -d \$d ] || mkdir \$d || exit 1
93 echo CONFIG_BUILD_DOCSRC=n >\$e || exit 1
94 echo CONFIG_MODULES=y >>\$e || exit 1
95 KCONFIG_ALLCONFIG=\$e cross -n -N -a x86_64 -c "$gcc_version" O=\$d -s allmodconfig || exit 1
96 echo "Forking x86 build ..."
97 /usr/bin/time cross -n -N -a x86_64 -c "$gcc_version" O=\$d -j"$j_factor" -s > \$log_x86 2>&1 &
100 echo Building: powerpc ppc64_defconfig
101 d="$bparent/powerpc_ppc64_defconfig"
102 [ -d \$d ] || mkdir \$d || exit 1
104 cross -n -N -a powerpc64 -k powerpc -c "$gcc_ppc_version" O=\$d -s ppc64_defconfig || exit 1
105 echo "Forking powerpc build ..."
106 /usr/bin/time cross -n -N -a powerpc64 -k powerpc -c "$gcc_ppc_version" O=\$d -j"$j_factor" -s > \$log_ppc 2>&1 &
109 echo Building: arm multi_v7_defconfig
110 d="$bparent/arm_multi_v7_defconfig"
111 [ -d \$d ] || mkdir \$d || exit 1
113 cross -n -N -a arm -c "$gcc_version" O=\$d -s multi_v7_defconfig || exit 1
114 echo "Forking arm build ..."
115 /usr/bin/time cross -n -N -a arm -c "$gcc_version" O=\$d -j"$j_factor" -s > \$log_arm 2>&1 &
120 [ -d \$d ] || mkdir \$d || exit 1
122 echo "Forking perf build ..."
123 /usr/bin/time make -s -C tools/perf JOBS="$j_factor" O=\$d > \$log_perf 2>&1 &
129 if [ \$rc -ne 0 ]; then
130 echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
131 echo "ERROR: perf build failed - log follows"
132 echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
141 show_log native perf \$log_perf
147 if [ \$rc -ne 0 ]; then
148 echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
149 echo "ERROR: arm multi_v7_defconfig build failed - log follows"
150 echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
158 show_log arm multi_v7_defconfig \$log_arm
164 if [ \$rc -ne 0 ]; then
165 echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
166 echo "ERROR: powerpc ppc64_defconfig build failed - log follows"
167 echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
174 show_log powerpc ppc64_defconfig \$log_ppc
180 if [ \$rc -ne 0 ]; then
181 echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
182 echo "ERROR: x86_64 allmodconfig build failed - log follows"
183 echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
188 show_log x86_64 allmodconfig \$log_x86