only check SHA1 sums for files we're using
[summon-arm-toolchain.git] / summon-arm-toolchain
index cbf50c11f6e743b62176080dd8ef471bf7543b80..3cd8aee266295066c4cc0904d367151d8c9641ff 100755 (executable)
@@ -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
 ##############################################################################
@@ -111,7 +121,7 @@ if which fetch > /dev/null; then
 elif which wget > /dev/null; then
     FETCHCMD=wget
 elif which curl > /dev/null; then
-    FETCHCMD="curl -O"
+    FETCHCMD="curl -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