X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=summon-arm-toolchain;h=a20608d906193d4719a20b43bb801784d2d901fc;hb=83c869ef44037bc2e0abec196de05998d5fea5c9;hp=cbf50c11f6e743b62176080dd8ef471bf7543b80;hpb=eba6343c8555a34b9dc4fbaff97d8709d2b4ff62;p=summon-arm-toolchain.git diff --git a/summon-arm-toolchain b/summon-arm-toolchain index cbf50c1..a20608d 100755 --- a/summon-arm-toolchain +++ b/summon-arm-toolchain @@ -58,6 +58,16 @@ GMP=gmp-5.0.2 MPFR=mpfr-3.0.1 MPC=mpc-0.9 +SHA1SUMS="ef93235588eb443e4c4a77f229a8d131bccaecc6 binutils-2.21.tar.bz2 +8bf66f7a71534ba564563a0ba0b2517aead8ac30 gcc-4.6.1.tar.bz2 +9b766705f051ffb7321de58f247688b0ae661b98 gcc-core-4.6.1.tar.bz2 +828d99a63e0578879150f5681d234763cff69313 gcc-linaro-4.6-2011.07.tar.bz2 +fefd90275d6decdca00c5c29c533e2ef3d439664 gdb-7.3.tar.bz2 +2968220e1988eabb61f921d11e5d2db5431e0a35 gmp-5.0.2.tar.bz2 +229722d553030734d49731844abfef7617b64f1a mpc-0.9.tar.gz +fbf402fc196724ae60ef01eb6ca8490b1ea4db69 mpfr-3.0.1.tar.bz2 +b2269d30ce7b93b7c714b90ef2f40221c2df0fcd newlib-1.19.0.tar.gz" + ############################################################################## # Flags section ############################################################################## @@ -109,9 +119,9 @@ STAMPS=${SUMMON_DIR}/stamps if which fetch > /dev/null; then FETCHCMD="fetch -p" elif which wget > /dev/null; then - FETCHCMD=wget + FETCHCMD="wget -c" elif which curl > /dev/null; then - FETCHCMD="curl -O" + FETCHCMD="curl -C - -O -L" else FETCHCMD=ftp # the only HTTP client on some BSD fi @@ -173,7 +183,7 @@ unpack() { } # Install a build -install() { +doinstall() { log $1 ${SUDO} make ${MAKEFLAGS} $2 $3 $4 $5 $6 $7 $8 } @@ -196,6 +206,14 @@ fetch ${GMP} ftp://ftp.gmplib.org/pub/${GMP}/${GMP}.tar.bz2 fetch ${MPFR} http://www.mpfr.org/${MPFR}/${MPFR}.tar.bz2 fetch ${MPC} http://www.multiprecision.org/mpc/download/${MPC}.tar.gz +if which sha1sum > /dev/null; then + for f in ${BINUTILS} ${GCC} ${NEWLIB} ${GDB} ${GMP} ${MPFR} ${MPC}; do + ( echo "$SHA1SUMS" | grep -F $f | sha1sum -c - ) || ( log 'ERROR: Checksum fail!'; exit 1 ) + done +else + log "WARING: skipping checksum checks due to missing sha1sum" +fi + cd ${SUMMON_DIR} if [ ! -e build ]; then @@ -217,7 +235,7 @@ if [ ! -e ${STAMPS}/${BINUTILS}.build ]; then ${BINUTILFLAGS} log "Building ${BINUTILS}" make ${MAKEFLAGS} - install ${BINUTILS} install + doinstall ${BINUTILS} install cd .. log "Cleaning up ${BINUTILS}" touch ${STAMPS}/${BINUTILS}.build @@ -250,7 +268,7 @@ if [ ! -e ${STAMPS}/${GCC}-boot.build ]; then ${GCCFLAGS} log "Building ${GCC}-boot" make ${MAKEFLAGS} all-gcc - install ${GCC}-boot install-gcc + doinstall ${GCC}-boot install-gcc cd .. log "Cleaning up ${GCC}-boot" touch ${STAMPS}/${GCC}-boot.build @@ -279,7 +297,7 @@ if [ ! -e ${STAMPS}/${NEWLIB}.build ]; then log "Building ${NEWLIB}" NEWLIB_FLAGS="-ffunction-sections -fdata-sections -DPREFER_SIZE_OVER_SPEED -D__OPTIMIZE_SIZE__ -Os -fomit-frame-pointer -fno-unroll-loops -D__BUFSIZ__=256 -mabi=aapcs" make ${MAKEFLAGS} CFLAGS_FOR_TARGET="${NEWLIB_FLAGS}" CCASFLAGS="${NEWLIB_FLAGS}" - install ${NEWLIB} install + doinstall ${NEWLIB} install cd .. log "Cleaning up ${NEWLIB}" touch ${STAMPS}/${NEWLIB}.build @@ -312,7 +330,7 @@ if [ ! -e ${STAMPS}/${GCC}.build ]; then ${GCCFLAGS} log "Building ${GCC}" make ${MAKEFLAGS} - install ${GCC} install + doinstall ${GCC} install cd .. log "Cleaning up ${GCC}" touch ${STAMPS}/${GCC}.build @@ -331,7 +349,7 @@ if [ ! -e ${STAMPS}/${GDB}.build ]; then ${GDBFLAGS} log "Building ${GDB}" make ${MAKEFLAGS} - install ${GDB} install + doinstall ${GDB} install cd .. log "Cleaning up ${GDB}" touch ${STAMPS}/${GDB}.build