X-Git-Url: https://git.distorted.org.uk/~mdw/termux-packages/blobdiff_plain/5ce2f122de14f5284f6ec5632257b502074642eb..ee7d67ae62662d05b0069eb0c1bcf5a1e66f6c80:/packages/gcc/build.sh diff --git a/packages/gcc/build.sh b/packages/gcc/build.sh index 0e8ebe1d..45ebc2e1 100755 --- a/packages/gcc/build.sh +++ b/packages/gcc/build.sh @@ -1,21 +1,29 @@ TERMUX_PKG_HOMEPAGE=http://gcc.gnu.org/ TERMUX_PKG_DESCRIPTION="GNU C compiler" -TERMUX_PKG_DEPENDS="binutils, libgmp, libmpfr, libmpc, ndk-sysroot" -TERMUX_PKG_VERSION=4.9.3 -TERMUX_PKG_BUILD_REVISION=2 +TERMUX_PKG_DEPENDS="binutils, libgmp, libmpfr, libmpc, ndk-sysroot, libgcc, libisl, libgnustl" +TERMUX_PKG_VERSION=6.1.0 +TERMUX_PKG_BUILD_REVISION=1 TERMUX_PKG_SRCURL=ftp://ftp.fu-berlin.de/unix/languages/gcc/releases/gcc-${TERMUX_PKG_VERSION}/gcc-${TERMUX_PKG_VERSION}.tar.bz2 TERMUX_PKG_EXTRA_CONFIGURE_ARGS="--enable-languages=c,c++ --with-system-zlib --disable-multilib --disable-lto" +TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --target=$TERMUX_HOST_PLATFORM" TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --with-gmp=$TERMUX_PREFIX --with-mpfr=$TERMUX_PREFIX --with-mpc=$TERMUX_PREFIX" # To build gcc as a PIE binary: TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --with-stage1-ldflags=\"-specs=$TERMUX_SCRIPTDIR/termux.spec\"" +TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --with-isl-include=$TERMUX_PREFIX/include --with-isl-lib=$TERMUX_PREFIX/lib" +TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --disable-isl-version-check" +TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --disable-tls" +TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --enable-host-shared" +TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --enable-default-pie" + if [ "$TERMUX_ARCH" = "arm" ]; then TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --with-arch=armv7-a --with-fpu=neon --with-float=hard" +elif [ "$TERMUX_ARCH" = "aarch64" ]; then + TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --with-arch=armv8-a" elif [ "$TERMUX_ARCH" = "i686" ]; then # -mstackrealign -msse3 -m32 TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --with-arch=i686 --with-tune=atom --with-fpmath=sse" fi -TERMUX_PKG_KEEP_STATIC_LIBRARIES="true" -TERMUX_PKG_RM_AFTER_INSTALL="bin/gcc-ar bin/gcc-ranlib bin/c++ bin/gcc-nm lib/gcc/*-linux-*/${TERMUX_PKG_VERSION}/plugin lib/gcc/*-linux-*/${TERMUX_PKG_VERSION}/include-fixed lib/gcc/*-linux-*/$TERMUX_PKG_VERSION/install-tools libexec/gcc/*-linux-*/${TERMUX_PKG_VERSION}/plugin libexec/gcc/*-linux-*/${TERMUX_PKG_VERSION}/install-tools share/man/man7" +TERMUX_PKG_RM_AFTER_INSTALL="bin/gcc-ar bin/gcc-ranlib bin/*c++ bin/gcc-nm lib/gcc/*-linux-*/${TERMUX_PKG_VERSION}/plugin lib/gcc/*-linux-*/${TERMUX_PKG_VERSION}/include-fixed lib/gcc/*-linux-*/$TERMUX_PKG_VERSION/install-tools libexec/gcc/*-linux-*/${TERMUX_PKG_VERSION}/plugin libexec/gcc/*-linux-*/${TERMUX_PKG_VERSION}/install-tools share/man/man7" export AR_FOR_TARGET="$AR" export AS_FOR_TARGET="$AS" @@ -45,21 +53,33 @@ unset RANLIB termux_step_make () { make -j $TERMUX_MAKE_PROCESSES all-gcc - make -j $TERMUX_MAKE_PROCESSES all-target-libgcc } termux_step_make_install () { - make install-gcc - make install-target-libgcc + make install-gcc } termux_step_post_make_install () { - if [ $TERMUX_ARCH = "arm" ]; then - # Note that moving to $TERMUX_PREFIX/lib/gcc/arm-linux-androideabi/${TERMUX_PKG_VERSION}/ - # allows compilation but fails to link at runtime - mv $TERMUX_PREFIX/lib/armv7-a/hard/libgcc_s* $TERMUX_PREFIX/lib/ + # Android 5.0 only supports PIE binaries, so build that by default with a specs file: + local GCC_SPECS=$TERMUX_PREFIX/lib/gcc/$TERMUX_HOST_PLATFORM/$TERMUX_PKG_VERSION/specs + cp $TERMUX_SCRIPTDIR/termux.spec $GCC_SPECS + + if [ $TERMUX_ARCH = "i686" ]; then + # See https://github.com/termux/termux-packages/issues/3 + # and https://github.com/termux/termux-packages/issues/14 + cat >> $GCC_SPECS <