X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=summon-arm-toolchain;h=9577702c3e5e41a91fd46c362282a3f859ac28e3;hb=f5a61bf5bc3b29a02cf695873f189a25b7a285fa;hp=f6826da7ac599c6bff11b6c194b078017927c517;hpb=441a9af2309a5d643b3eef41168b75560f261d62;p=summon-arm-toolchain.git diff --git a/summon-arm-toolchain b/summon-arm-toolchain index f6826da..9577702 100755 --- a/summon-arm-toolchain +++ b/summon-arm-toolchain @@ -58,12 +58,24 @@ 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 ############################################################################## -if which getconf > /dev/null; then +if which getconf > /dev/null && getconf _NPROCESSORS_ONLN > /dev/null; then CPUS=$(getconf _NPROCESSORS_ONLN) +elif which sysctl > /dev/null && sysctl hw.ncpu > /dev/null; then + CPUS=$(sysctl hw.ncpu | sed -E -e 's/^hw\.ncpu(: | = )//') else CPUS=1 fi @@ -85,12 +97,13 @@ if [ -f local.sh ]; then . ./local.sh fi -MAKEFLAGS=${PARALLEL} +MAKEFLAGS=${PARALLEL} ${MAKESILENT} TARFLAGS=v +MAKESILENT= if [ ${QUIET} != 0 ]; then TARFLAGS= - MAKEFLAGS="${MAKEFLAGS} -s" + MAKESILENT="-s" fi export PATH="${PREFIX}/bin:${PATH}" @@ -105,9 +118,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 -c" +elif which curl > /dev/null; then + FETCHCMD="curl -C - -O -L" +else + FETCHCMD=ftp # the only HTTP client on some BSD fi if [ USE_LINARO = 1 ]; then @@ -131,7 +150,7 @@ fi fetch() { if [ ! -e ${STAMPS}/$1.fetch ]; then log "Downloading $1 sources..." - wget -c $2 + ${FETCHCMD} $2 touch ${STAMPS}/$1.fetch fi } @@ -167,9 +186,9 @@ unpack() { } # Install a build -install() { +doinstall() { log $1 - ${SUDO} make ${MAKEFLAGS} $2 $3 $4 $5 $6 $7 $8 + ${SUDO} make ${MAKESILENT} $2 $3 $4 $5 $6 $7 $8 } if [ ! -d $SUMMON_DIR ]; then @@ -190,6 +209,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 +238,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 +271,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 +300,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 +333,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 +352,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