aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStefan Reinauer <stefan.reinauer@coreboot.org>2015-06-05 12:43:28 -0700
committerStefan Reinauer <stefan.reinauer@coreboot.org>2015-06-08 20:00:04 +0200
commit699ac27decfa241854ee6517d7db8d53bb2e8750 (patch)
tree426038643cd4ebda279779fbc5b05cb1eeddf6c0
parent4565aea8fbb114f65ecce7bdaaa538f80c382599 (diff)
buildgcc: refactor package unpacking, patching and building
- keep a list of packages to build in $PACKAGES and only download, patch and build a package if it is in that list (instead of having exceptions for GDB, EXPAT and PYTHON) - unify interface for download() and unpack_and_patch() - consolidate some randomly spread code like creating / removing build directories and calls to searchtool() Change-Id: I2070e3b2fbb84eb18e9220658fb2d5518b8179ee Signed-off-by: Stefan Reinauer <stefan.reinauer@coreboot.org> Reviewed-on: http://review.coreboot.org/10434 Reviewed-by: Patrick Georgi <pgeorgi@google.com> Tested-by: build bot (Jenkins)
-rwxr-xr-xutil/crossgcc/buildgcc133
1 files changed, 65 insertions, 68 deletions
diff --git a/util/crossgcc/buildgcc b/util/crossgcc/buildgcc
index 63e07b0f5d..45ee3c1f8f 100755
--- a/util/crossgcc/buildgcc
+++ b/util/crossgcc/buildgcc
@@ -30,7 +30,7 @@ TARGETDIR=`pwd`/xgcc
TARGETARCH=i386-elf
DESTDIR=
-# version numbers
+# GCC toolchain version numbers
GMP_VERSION=6.0.0
MPFR_VERSION=3.1.2
MPC_VERSION=1.0.3
@@ -43,7 +43,7 @@ IASL_VERSION=20150204
PYTHON_VERSION=3.4.3
EXPAT_VERSION=2.1.0
-# archive locations
+# GCC toolchain archive locations
GMP_ARCHIVE="http://ftpmirror.gnu.org/gmp/gmp-${GMP_VERSION}a.tar.bz2"
MPFR_ARCHIVE="http://ftpmirror.gnu.org/mpfr/mpfr-${MPFR_VERSION}.tar.bz2"
MPC_ARCHIVE="http://ftpmirror.gnu.org/mpc/mpc-${MPC_VERSION}.tar.gz"
@@ -55,6 +55,7 @@ IASL_ARCHIVE="https://acpica.org/sites/acpica/files/acpica-unix-${IASL_VERSION}.
PYTHON_ARCHIVE="http://www.python.org/ftp/python/${PYTHON_VERSION}/Python-${PYTHON_VERSION}.tar.xz"
EXPAT_ARCHIVE="http://downloads.sourceforge.net/sourceforge/expat/expat-${EXPAT_VERSION}.tar.gz"
+# GCC toolchain directories
GMP_DIR="gmp-${GMP_VERSION}"
MPFR_DIR="mpfr-${MPFR_VERSION}"
MPC_DIR="mpc-${MPC_VERSION}"
@@ -153,6 +154,9 @@ searchtool()
TAR=`searchtool tar` || exit $?
PATCH=`searchtool patch` || exit $?
MAKE=`searchtool make` || exit $?
+SHA1SUM=`searchtool sha1sum`
+SHA512SUM=`searchtool sha512sum`
+CHECKSUM=$SHA1SUM
searchtool m4 > /dev/null
searchtool bison > /dev/null
@@ -163,8 +167,11 @@ searchtool wget > /dev/null
searchtool bzip2 "bzip2," > /dev/null
download() {
- ARCHIVE=$1
- FILE=`basename $ARCHIVE`
+ PACKAGE=$1
+ archive=$PACKAGE"_ARCHIVE"
+ archive="`eval echo '$'$archive`"
+
+ FILE=`basename $archive`
printf " * $FILE "
test -f tarballs/$FILE && \
@@ -174,7 +181,7 @@ download() {
printf "(downloading)"
rm -f tarballs/$FILE
cd tarballs
- wget --no-check-certificate -q $ARCHIVE
+ wget --no-check-certificate -q $archive
cd ..
test ! -f sum/$FILE.cksum && test -f tarballs/$FILE && \
(test -z "$CHECKSUM" || $CHECKSUM tarballs/$FILE > sum/$FILE.cksum ) && \
@@ -220,15 +227,23 @@ wait_for_build() {
true
}
-SHA1SUM=`searchtool sha1sum`
-SHA512SUM=`searchtool sha512sum`
-CHECKSUM=$SHA1SUM
-
cleanup()
{
printf "Cleaning up temporary files... "
- rm -rf ${BUILDDIRPREFIX}-* combined gcc-* gmp-* mpfr-* mpc-* libelf-* binutils-*
- rm -rf gdb-* acpica-* python-* expat-*
+ # GCC toolchain
+ rm -rf ${GMP_DIR} ${BUILDDIRPREFIX}-gmp
+ rm -rf ${MPFR_DIR} ${BUILDDIRPREFIX}-mpfr
+ rm -rf ${MPC_DIR} ${BUILDDIRPREFIX}-mpc
+ rm -rf ${LIBELF_DIR} ${BUILDDIRPREFIX}-libelf
+ rm -rf ${BINUTILS_DIR} ${BUILDDIRPREFIX}-binutils
+ rm -rf ${GCC_DIR} ${BUILDDIRPREFIX}-gcc
+
+ # Other tools
+ rm -rf ${GDB_DIR} ${BUILDDIRPREFIX}-gdb
+ rm -rf ${EXPAT_DIR} ${BUILDDIRPREFIX}-expat
+ rm -rf ${PYTHON_DIR} ${BUILDDIRPREFIX}-python
+ rm -rf ${IASL_DIR}
+
printf "${green}ok${NC}\n"
}
@@ -331,29 +346,26 @@ case "$TARGETARCH" in
esac
echo "Target arch is now $TARGETARCH"
+NAME="${TARGETARCH} cross"
+PACKAGES="GMP MPFR MPC LIBELF BINUTILS GCC IASL"
+
BUILDDIRPREFIX=build-${TARGETARCH}
if [ "$clean" = "1" ]; then
cleanup
fi
-GDB_PACKAGE="GDB"
-PYTHON_PACKAGE="PYTHON"
-EXPAT_PACKAGE="EXPAT"
if [ $SKIPGDB -eq 1 ]; then
printf "Will skip GDB ... ${green}ok${NC}\n"
- GDB_ARCHIVE=""
- GDB_PACKAGE=""
if [ $SKIPPYTHON -eq 0 ]; then
printf "Python scripting needs GDB ... disabling ... ${green}ok${NC}\n"
SKIPPYTHON=1
fi
+else
+ PACKAGES="$PACKAGES GDB"
fi
-if [ $SKIPPYTHON -eq 1 ]; then
- PYTHON_ARCHIVE=""
- PYTHON_PACKAGE=""
- EXPAT_ARCHIVE=""
- EXPAT_PACKAGE=""
+if [ $SKIPPYTHON -eq 0 ]; then
+ PACKAGES="$PACKAGES EXPAT PYTHON"
fi
# coreboot does not like the GOLD linker
@@ -363,21 +375,16 @@ GCC_OPTIONS="--enable-lto"
printf "Downloading tar balls ... \n"
mkdir -p tarballs
-for ARCHIVE in $GMP_ARCHIVE $MPFR_ARCHIVE $MPC_ARCHIVE $LIBELF_ARCHIVE \
- $GCC_ARCHIVE $BINUTILS_ARCHIVE $GDB_ARCHIVE \
- $IASL_ARCHIVE $PYTHON_ARCHIVE $EXPAT_ARCHIVE; do
- download $ARCHIVE
+for P in $PACKAGES; do
+ download $P
done
-printf "Downloaded tar balls ... "
-printf "${green}ok${NC}\n"
+printf "Downloaded tar balls ... ${green}ok${NC}\n"
printf "Unpacking and patching ... \n"
-for PACKAGE in GMP MPFR MPC LIBELF GCC BINUTILS $PYTHON_PACKAGE \
- $EXPAT_PACKAGE $GDB_PACKAGE IASL; do
- unpack_and_patch $PACKAGE
+for P in $PACKAGES; do
+ unpack_and_patch $P
done
-printf "Unpacked and patched ... "
-printf "${green}ok${NC}\n"
+printf "Unpacked and patched ... ${green}ok${NC}\n"
CC=cc
if [ $UNAME = "Darwin" ]; then
@@ -407,18 +414,16 @@ if [ "$USECCACHE" = 1 ]; then
fi
mkdir -p ${BUILDDIRPREFIX}-gmp ${BUILDDIRPREFIX}-mpfr ${BUILDDIRPREFIX}-mpc ${BUILDDIRPREFIX}-libelf ${BUILDDIRPREFIX}-binutils \
- ${BUILDDIRPREFIX}-gcc ${BUILDDIRPREFIX}-python ${BUILDDIRPREFIX}-expat
+ ${BUILDDIRPREFIX}-gcc ${BUILDDIRPREFIX}-python ${BUILDDIRPREFIX}-expat ${BUILDDIRPREFIX}-gdb
mkdir -p $DESTDIR$TARGETDIR/bin
export PATH=$DESTDIR$TARGETDIR/bin:$PATH
-if [ $SKIPGDB -eq 0 ]; then
- mkdir -p ${BUILDDIRPREFIX}-gdb
-fi
+[[ "$PACKAGES" == *GMP* ]] && \
if [ -f ${BUILDDIRPREFIX}-gmp/.success ]; then
printf "Skipping GMP as it is already built\n"
else
-printf "Building GMP ${GMP_VERSION} ... "
+ printf "Building GMP ${GMP_VERSION} ... "
(
cd ${BUILDDIRPREFIX}-gmp
rm -f .failed
@@ -431,17 +436,18 @@ printf "Building GMP ${GMP_VERSION} ... "
if [ ! -f .failed ]; then touch .success; fi
) 2>&1 | wait_for_build "${BUILDDIRPREFIX}-gmp" || exit 1
-fi
# Now set CFLAGS to match GMP CFLAGS but strip out -pedantic
# as GCC 4.6.x fails if it's there.
HOSTCFLAGS=`grep __GMP_CFLAGS $DESTDIR$TARGETDIR/include/gmp.h |cut -d\" -f2 |\
sed s,-pedantic,,`
+fi
+[[ "$PACKAGES" == *MPFR* ]] && \
if [ -f ${BUILDDIRPREFIX}-mpfr/.success ]; then
printf "Skipping MPFR as it is already built\n"
else
-printf "Building MPFR ${MPFR_VERSION} ... "
+ printf "Building MPFR ${MPFR_VERSION} ... "
(
test $UNAME = "Darwin" && CFLAGS="$CFLAGS -force_cpusubtype_ALL"
cd ${BUILDDIRPREFIX}-mpfr
@@ -464,10 +470,11 @@ printf "Building MPFR ${MPFR_VERSION} ... "
) 2>&1 | wait_for_build "${BUILDDIRPREFIX}-mpfr" || exit 1
fi
+[[ "$PACKAGES" == *MPC* ]] && \
if [ -f ${BUILDDIRPREFIX}-mpc/.success ]; then
printf "Skipping MPC as it is already built\n"
else
-printf "Building MPC ${MPC_VERSION} ... "
+ printf "Building MPC ${MPC_VERSION} ... "
(
cd ${BUILDDIRPREFIX}-mpc
rm -f .failed
@@ -484,10 +491,11 @@ printf "Building MPC ${MPC_VERSION} ... "
) 2>&1 | wait_for_build "${BUILDDIRPREFIX}-mpc" || exit 1
fi
+[[ "$PACKAGES" == *LIBELF* ]] && \
if [ -f ${BUILDDIRPREFIX}-libelf/.success ]; then
printf "Skipping libelf as it is already built\n"
else
-printf "Building libelf ${LIBELF_VERSION} ... "
+ printf "Building libelf ${LIBELF_VERSION} ... "
(
cd ${BUILDDIRPREFIX}-libelf
rm -f .failed
@@ -504,10 +512,11 @@ printf "Building libelf ${LIBELF_VERSION} ... "
) 2>&1 | wait_for_build "${BUILDDIRPREFIX}-libelf" || exit 1
fi
+[[ "$PACKAGES" == *BINUTILS* ]] && \
if [ -f ${BUILDDIRPREFIX}-binutils/.success ]; then
printf "Skipping binutils as it is already built\n"
else
-printf "Building binutils ${BINUTILS_VERSION} ... "
+ printf "Building binutils ${BINUTILS_VERSION} ... "
(
# What a pain: binutils don't come with configure
# script anymore. Create it:
@@ -526,10 +535,11 @@ printf "Building binutils ${BINUTILS_VERSION} ... "
) 2>&1 | wait_for_build "${BUILDDIRPREFIX}-binutils" || exit 1
fi
+[[ "$PACKAGES" == *GCC* ]] && \
if [ -f ${BUILDDIRPREFIX}-gcc/.success ]; then
printf "Skipping GCC as it is already built\n"
else
-printf "Building GCC ${GCC_VERSION} ... "
+ printf "Building GCC ${GCC_VERSION} ... "
(
# Even worse than binutils: GCC does not come with configure
# script anymore, but also enforces an obsolete autoconf version
@@ -574,12 +584,11 @@ printf "Building GCC ${GCC_VERSION} ... "
) 2>&1 | wait_for_build "${BUILDDIRPREFIX}-gcc" || exit 1
fi
+[[ "$PACKAGES" == *EXPAT* ]] && \
if [ -f ${BUILDDIRPREFIX}-expat/.success ]; then
printf "Skipping Expat as it is already built\n"
-elif [ $SKIPPYTHON -eq 1 ]; then
- printf "Skipping Expat (Python scripting not enabled)\n"
else
-printf "Building Expat ${EXPAT_VERSION} ... "
+ printf "Building Expat ${EXPAT_VERSION} ... "
(
cd ${BUILDDIRPREFIX}-expat
rm -f .failed
@@ -594,13 +603,11 @@ printf "Building Expat ${EXPAT_VERSION} ... "
) 2>&1 | wait_for_build "${BUILDDIRPREFIX}-expat" || exit 1
fi
-
+[[ "$PACKAGES" == *PYTHON* ]] && \
if [ -f ${BUILDDIRPREFIX}-python/.success ]; then
printf "Skipping Python as it is already built\n"
-elif [ $SKIPPYTHON -eq 1 ]; then
- printf "Skipping Python (Python scripting not enabled)\n"
else
-printf "Building Python ${PYTHON_VERSION} ... "
+ printf "Building Python ${PYTHON_VERSION} ... "
(
cd ${BUILDDIRPREFIX}-python
rm -f .failed
@@ -615,13 +622,11 @@ printf "Building Python ${PYTHON_VERSION} ... "
) 2>&1 | wait_for_build "${BUILDDIRPREFIX}-python" || exit 1
fi
-
+[[ "$PACKAGES" == *GDB* ]] && \
if [ -f ${BUILDDIRPREFIX}-gdb/.success ]; then
printf "Skipping GDB as it is already built\n"
-elif [ $SKIPGDB -eq 1 ]; then
- printf "Skipping GDB (GDB support not enabled)\n"
else
-printf "Building GDB ${GDB_VERSION} ... "
+ printf "Building GDB ${GDB_VERSION} ... "
(
cd ${BUILDDIRPREFIX}-gdb
export PYTHONHOME=$DESTDIR$TARGETDIR
@@ -640,10 +645,11 @@ printf "Building GDB ${GDB_VERSION} ... "
) 2>&1 | wait_for_build "${BUILDDIRPREFIX}-gdb" || exit 1
fi
+[[ "$PACKAGES" == *IASL* ]] && \
if [ -f $IASL_DIR/source/compiler/.success ]; then
printf "Skipping IASL as it is already built\n"
else
-printf "Building IASL ${IASL_VERSION} ... "
+ printf "Building IASL ${IASL_VERSION} ... "
(
RDIR=$IASL_DIR/source/compiler
cd $IASL_DIR/generate/unix
@@ -660,25 +666,16 @@ printf "Building IASL ${IASL_VERSION} ... "
) 2>&1 | wait_for_build "$IASL_DIR/source/compiler" || exit 1
fi
+# Adding git information of current tree to target directory
+# for reproducibility
PROGNAME=`basename "$0"`
rm -f "$DESTDIR$TARGETDIR/$PROGNAME".commit.*
cp "$PROGNAME" $DESTDIR$TARGETDIR/"$PROGNAME.commit.`git describe`"
if [ $SAVETEMPS -eq 0 ]; then
- printf "Cleaning up... "
- rm -rf ${GMP_DIR} ${BUILDDIRPREFIX}-gmp
- rm -rf ${MPFR_DIR} ${BUILDDIRPREFIX}-mpfr
- rm -rf ${MPC_DIR} ${BUILDDIRPREFIX}-mpc
- rm -rf ${LIBELF_DIR} ${BUILDDIRPREFIX}-libelf
- rm -rf ${BINUTILS_DIR} ${BUILDDIRPREFIX}-binutils
- rm -rf ${GCC_DIR} ${BUILDDIRPREFIX}-gcc
- rm -rf ${GDB_DIR} ${BUILDDIRPREFIX}-gdb
- rm -rf ${EXPAT_DIR} ${BUILDDIRPREFIX}-expat
- rm -rf ${PYTHON_DIR} ${BUILDDIRPREFIX}-python
- rm -rf ${IASL_DIR}
- printf "${green}ok${NC}\n"
+ cleanup
else
printf "Leaving temporary files around... ${green}ok${NC}\n"
fi
-printf "\n${green}You can now run your $TARGETARCH cross toolchain from $TARGETDIR.${NC}\n"
+printf "\n${green}You can now run your $NAME toolchain from $TARGETDIR.${NC}\n"