summaryrefslogtreecommitdiff
path: root/libre/aarch64-linux-gnu-gcc/PKGBUILD
diff options
context:
space:
mode:
authorDavid P <megver83@parabola.nu>2018-04-09 14:43:48 -0300
committerDavid P <megver83@parabola.nu>2018-04-09 14:43:48 -0300
commit2f5136e5f40d69bd0115d898fda48d0ed9159c40 (patch)
tree2c1f3266d1b90a7150e0aee124ecb1223360f4bb /libre/aarch64-linux-gnu-gcc/PKGBUILD
parent14611d71231ab4b751fe634c21cfe8b726ca2612 (diff)
downloadabslibre-2f5136e5f40d69bd0115d898fda48d0ed9159c40.tar.gz
abslibre-2f5136e5f40d69bd0115d898fda48d0ed9159c40.tar.bz2
abslibre-2f5136e5f40d69bd0115d898fda48d0ed9159c40.zip
Add libre/sh-elf-{gcc,binutils,newlib}
Diffstat (limited to 'libre/aarch64-linux-gnu-gcc/PKGBUILD')
-rw-r--r--libre/aarch64-linux-gnu-gcc/PKGBUILD92
1 files changed, 92 insertions, 0 deletions
diff --git a/libre/aarch64-linux-gnu-gcc/PKGBUILD b/libre/aarch64-linux-gnu-gcc/PKGBUILD
new file mode 100644
index 000000000..60c10c9c3
--- /dev/null
+++ b/libre/aarch64-linux-gnu-gcc/PKGBUILD
@@ -0,0 +1,92 @@
+# Maintainer: Anatol Pomozov <anatol.pomozov@gmail.com>
+
+_target=aarch64-linux-gnu
+pkgname=$_target-gcc
+pkgver=7.2.0
+_islver=0.18
+pkgrel=1
+_snapshot=7-20170907
+pkgdesc='The GNU Compiler Collection - cross compiler for ARM64 target'
+arch=(i686 x86_64)
+url='http://gcc.gnu.org/'
+license=(GPL LGPL FDL)
+depends=($_target-binutils $_target-glibc libmpc zlib)
+makedepends=(gmp mpfr)
+options=(!emptydirs !strip)
+source=(#ftp://gcc.gnu.org/pub/gcc/releases/gcc-$pkgver/gcc-$pkgver.tar.bz2
+ ftp://gcc.gnu.org/pub/gcc/snapshots/$_snapshot/gcc-$_snapshot.tar.xz
+ http://isl.gforge.inria.fr/isl-$_islver.tar.bz2)
+sha256sums=('af37950ac7fc4996b4bdf22cbaaf5d1db52ff6490bfe3d83bcae5d5097645bc9'
+ '6b8b0fd7f81d0a957beb3679c81bbb34ccc7568d5682844d8924424a0dadcb1b')
+
+if [ -n "$_snapshot" ]; then
+ _basedir=gcc-$_snapshot
+else
+ _basedir=gcc-$pkgver
+fi
+
+prepare() {
+ cd $_basedir
+
+ # link isl for in-tree builds
+ ln -sf ../isl-$_islver isl
+
+ echo $pkgver > gcc/BASE-VER
+
+ # Do not run fixincludes
+ sed -i 's@\./fixinc\.sh@-c true@' gcc/Makefile.in
+
+ # hack! - some configure tests for header files using "$CPP $CPPFLAGS"
+ sed -i "/ac_cpp=/s/\$CPPFLAGS/\$CPPFLAGS -O2/" "$srcdir"/$_basedir/{libiberty,gcc}/configure
+
+ rm -rf $srcdir/gcc-build
+ mkdir $srcdir/gcc-build
+}
+
+build() {
+ cd gcc-build
+
+ # using -pipe causes spurious test-suite failures
+ # http://gcc.gnu.org/bugzilla/show_bug.cgi?id=48565
+ CFLAGS=${CFLAGS/-pipe/}
+ CXXFLAGS=${CXXFLAGS/-pipe/}
+
+ $srcdir/$_basedir/configure \
+ --prefix=/usr \
+ --program-prefix=$_target- \
+ --with-local-prefix=/usr/$_target \
+ --with-sysroot=/usr/$_target \
+ --with-build-sysroot=/usr/$_target \
+ --libdir=/usr/lib --libexecdir=/usr/lib \
+ --target=$_target --host=$CHOST --build=$CHOST \
+ --disable-nls \
+ --enable-languages=c,c++ \
+ --enable-shared --enable-threads=posix \
+ --with-system-zlib --with-isl --enable-__cxa_atexit \
+ --disable-libunwind-exceptions --enable-clocale=gnu \
+ --disable-libstdcxx-pch --disable-libssp \
+ --enable-gnu-unique-object --enable-linker-build-id \
+ --enable-lto --enable-plugin --enable-install-libiberty \
+ --with-linker-hash-style=gnu --enable-gnu-indirect-function \
+ --disable-multilib --disable-werror \
+ --enable-checking=release
+
+ make
+}
+
+package() {
+ cd gcc-build
+
+ make DESTDIR="$pkgdir" install-gcc install-target-libgcc install-target-libstdc++-v3
+
+ # strip target binaries
+ find "$pkgdir"/usr/lib/gcc/$_target/ "$pkgdir"/usr/$_target/lib -type f -and \( -name \*.a -or -name \*.o \) -exec $_target-objcopy -R .comment -R .note -R .debug_info -R .debug_aranges -R .debug_pubnames -R .debug_pubtypes -R .debug_abbrev -R .debug_line -R .debug_str -R .debug_ranges -R .debug_loc '{}' \;
+
+ # strip host binaries
+ find "$pkgdir"/usr/bin/ "$pkgdir"/usr/lib/gcc/$_target/ -type f -and \( -executable \) -exec strip '{}' \;
+
+ # Remove files that conflict with host gcc package
+ rm -r "$pkgdir"/usr/share/man/man7
+ rm -r "$pkgdir"/usr/share/info
+ rm -r "$pkgdir"/usr/share/gcc-$pkgver
+}