X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=summon-arm-toolchain;h=3cd8aee266295066c4cc0904d367151d8c9641ff;hb=3824a554ef65530578be2e195a84cc7020e46e60;hp=f6826da7ac599c6bff11b6c194b078017927c517;hpb=441a9af2309a5d643b3eef41168b75560f261d62;p=summon-arm-toolchain.git diff --git a/summon-arm-toolchain b/summon-arm-toolchain index f6826da..3cd8aee 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 ############################################################################## @@ -105,9 +115,15 @@ STAMPS=${SUMMON_DIR}/stamps # Detects which tools and flags to use ############################################################################## -if ! which wget > /dev/null; then - echo "Please install wget" - exit 1 +# normalized fetching with whatever we can find +if which fetch > /dev/null; then + FETCHCMD="fetch -p" +elif which wget > /dev/null; then + FETCHCMD=wget +elif which curl > /dev/null; then + FETCHCMD="curl -O -L" +else + FETCHCMD=ftp # the only HTTP client on some BSD fi if [ USE_LINARO = 1 ]; then @@ -131,7 +147,7 @@ fi fetch() { if [ ! -e ${STAMPS}/$1.fetch ]; then log "Downloading $1 sources..." - wget -c $2 + ${FETCHCMD} $2 touch ${STAMPS}/$1.fetch fi } @@ -167,7 +183,7 @@ unpack() { } # Install a build -install() { +doinstall() { log $1 ${SUDO} make ${MAKEFLAGS} $2 $3 $4 $5 $6 $7 $8 } @@ -190,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 @@ -211,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 @@ -244,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 @@ -273,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 @@ -306,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 @@ -325,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