3 # Multi-build script for testing compilation of all maintained
6 # Copyright (C) 2002, 2003, 2007, 2008, 2009, 2010
7 # Free Software Foundation, Inc.
9 # Contributed by Richard Earnshaw (rearnsha@arm.com)
11 # This program is free software; you can redistribute it and/or modify
12 # it under the terms of the GNU General Public License as published by
13 # the Free Software Foundation; either version 3 of the License, or
14 # (at your option) any later version.
16 # This program is distributed in the hope that it will be useful,
17 # but WITHOUT ANY WARRANTY; without even the implied warranty of
18 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 # GNU General Public License for more details.
21 # You should have received a copy of the GNU General Public License
22 # along with this program. If not, see <http://www.gnu.org/licenses/>.
24 # Make certain that the script is not running in an internationalized
27 LC_ALL
=c
; export LC_ALL
32 Usage: gdb_mbuild.sh [ <options> ... ] <srcdir> <builddir>
34 -j <makejobs> Run <makejobs> in parallel. Passed to make.
35 On a single cpu machine, 2 is recommended.
36 -k Keep going. Do not stop after the first build fails.
37 --keep Keep builds. Do not remove each build when finished.
38 -e <regexp> Regular expression for selecting the targets to build.
39 -f Force rebuild. Even rebuild previously built directories.
40 -v Be more (and more, and more) verbose.
42 <srcdir> Source code directory.
43 <builddir> Build directory.
44 Environment variables examined (with default if not defined):
49 -b <maxbuilds> Run <maxbuild> builds in parallel.
50 On a single cpu machine, 1 is recommended.
54 ### COMMAND LINE OPTIONS
67 # Number of parallel make jobs.
69 test $# -ge 1 || usage
73 # Number of builds to fire off in parallel.
75 test $# -ge 1 || usage
79 # Should we soldier on after the first build fails?
86 # A regular expression for selecting targets
88 test $# -ge 1 || usage
89 targexp
="${targexp} -e ${1}"
96 # Be more, and more, and more, verbose
97 verbose
=`expr ${verbose} + 1`
106 ### COMMAND LINE PARAMETERS
113 # Convert these to absolute directory paths.
115 # Where the sources live
116 srcdir
=`cd $1 && /bin/pwd` ||
exit 1
118 # Where the builds occur
119 builddir
=`cd $2 && /bin/pwd` ||
exit 1
121 ### ENVIRONMENT PARAMETERS
123 # Version of make to use
129 # Where to look for the list of targets to test
130 maintainers
=${srcdir}/gdb
/MAINTAINERS
131 if [ ! -r ${maintainers} ]
133 echo Maintainers
file ${maintainers} not found
137 # Get the list of targets and the build options
138 alltarg
=`cat ${maintainers} | tr -s '[\t]' '[ ]' | sed -n '
139 /^[ ]*[-a-z0-9\.]*[ ]*[(]*--target=.*/ !d
154 ' | if test "${targexp}" = ""
156 grep -v -e broken -e OBSOLETE
162 # Usage: fail <message> <test-that-should-succeed>. Should the build
163 # fail? If the test is true, and we don't want to keep going, print
164 # the message and shoot everything in sight and abort the build.
171 echo "${target}: ${msg}"
172 if test "${keepgoing}" != ""
184 # Usage: log <level> <logfile>. Write standard input to <logfile> and
185 # stdout (if verbose >= level).
189 if test ${verbose} -ge $1
199 # Warn the user of what is comming, print the list of targets
205 # For each target, configure, build and test it.
207 echo "$alltarg" |
while read target gdbopts simopts
211 dir
=${builddir}/${target}
213 # Should a scratch rebuild be forced, for perhaps the entire
218 echo forcing
${target} ...
228 # Did the previous configure attempt fail? If it did
229 # restart from scratch.
231 if test -d ${dir} -a ! -r ${dir}/Makefile
233 echo ... removing partially configured
${target}
237 echo "${target}: unable to remove directory ${dir}"
242 # From now on, we're in this target's build directory
247 # Configure, if not already. Should this go back to being
248 # separate and done in parallel?
250 if test ! -r Makefile
252 # Default SIMOPTS to GDBOPTS.
253 test -z "${simopts}" && simopts
="${gdbopts}"
255 __target
="--target=${target}"
256 __enable_gdb_build_warnings
=`test -z "${gdbopts}" \
257 || echo "--enable-gdb-build-warnings=${gdbopts}"`
258 __enable_sim_build_warnings
=`test -z "${simopts}" \
259 || echo "--enable-sim-build-warnings=${simopts}"`
260 __configure
="${srcdir}/configure \
262 ${__enable_gdb_build_warnings} \
263 ${__enable_sim_build_warnings}"
264 echo ...
${__configure}
265 trap "echo Removing partially configured ${dir} directory ...; rm -rf ${dir}; exit 1" 1 2 15
266 ${__configure} 2>&1 | log
2 Config.log
269 fail
"configure failed" ! -r Makefile
271 # Build, if not built.
273 if test ! -x gdb
/gdb
-a ! -x gdb
/gdb.exe
275 # Iff the build fails remove the final build target so that
276 # the follow-on code knows things failed. Stops the follow-on
277 # code thinking that a failed rebuild succedded (executable
278 # left around from previous build).
279 echo ...
${make} ${keepgoing} ${makejobs} ${target}
280 ( ${make} ${keepgoing} ${makejobs} all-gdb ||
rm -f gdb
/gdb gdb
/gdb.exe
281 ) 2>&1 | log
1 Build.log
283 fail
"compile failed" ! -x gdb
/gdb
-a ! -x gdb
/gdb.exe
285 # Check that the built GDB can at least print it's architecture.
287 echo ... run
${target}
288 rm -f core gdb.core
${dir}/gdb
/x
290 maint print architecture
293 .
/gdb
/gdb
-batch -nx -x x
2>&1 | log
1 Gdb.log
294 fail
"gdb dumped core" -r core
-o -r gdb.core
295 fail
"gdb printed no output" ! -s Gdb.log
296 grep -e internal-error Gdb.log
&& fail
"gdb panic" 1
298 echo ... cleanup
${target}
300 # Create a sed script that cleans up the output from GDB.
302 touch mbuild.
sed ||
exit 1
303 # Rules to replace <0xNNNN> with the corresponding function's
305 sed -n -e '/<0x0*>/d' -e 's/^.*<0x\([0-9a-f]*\)>.*$/0x\1/p' Gdb.log \
309 func
="`addr2line -f -e ./gdb/gdb -s ${addr} | sed -n -e 1p`"
310 test ${verbose} -gt 0 && echo "${addr} ${func}" 1>&2
311 echo "s
/<${addr}>/<${func}>/g
"
313 # Rules to strip the leading paths off of file names.
314 echo 's/"\
/.
*\
/gdb\
//"gdb\//g' >> mbuild.sed
316 sed -f mbuild.sed Gdb.log > Mbuild.log
318 # Replace the build directory with a file as semaphore that stops
319 # a rebuild. (should the logs be saved?)
328 mv ${target}/Mbuild.log ${target}.tmp
330 mv ${target}.tmp ${target}
334 echo ... ${target} built