diff options
author | Rafael Silva | 2021-10-25 16:23:51 +0100 |
---|---|---|
committer | Rafael Silva | 2021-10-25 16:23:51 +0100 |
commit | ab0f94ff4ab464ffbccb671e528ae8e0f1bb1b65 (patch) | |
tree | aba9c51e249534a189f026451c61b657fbe240b9 /PKGBUILD | |
download | aur-ab0f94ff4ab464ffbccb671e528ae8e0f1bb1b65.tar.gz |
v11.2.0
Diffstat (limited to 'PKGBUILD')
-rw-r--r-- | PKGBUILD | 107 |
1 files changed, 107 insertions, 0 deletions
diff --git a/PKGBUILD b/PKGBUILD new file mode 100644 index 000000000000..e6fec02fa14d --- /dev/null +++ b/PKGBUILD @@ -0,0 +1,107 @@ +# Maintainer: Rafael Silva (perigoso) <perigoso@riseup.net> + +_target=ft32-elf +pkgname=$_target-gcc +pkgver=11.2.0 +_islver=0.24 +pkgrel=1 +pkgdesc='The GNU Compiler Collection - cross compiler for Bridgetek FT9xx (bare-metal) target - bootstrap version. only used to build initial glibc and compiler' +arch=(x86_64) +url='https://gcc.gnu.org/' +license=(GPL LGPL FDL) +depends=($_target-binutils zlib libmpc) +makedepends=(gmp mpfr $_target-newlib) +optdepends=("$_target-newlib: Standard C library optimized for embedded systems") +options=(!emptydirs !strip) +provides=(${pkgname%-bootstrap}) +conflicts=(${pkgname%-bootstrap}) +source=("https://ftp.gnu.org/gnu/gcc/gcc-$pkgver/gcc-$pkgver.tar.xz"{,.sig} + #"ftp://gcc.gnu.org/pub/gcc/snapshots/$_snapshot/gcc-$_snapshot.tar.xz" + "https://libisl.sourceforge.io/isl-$_islver.tar.xz") +sha512sums=('d53a0a966230895c54f01aea38696f818817b505f1e2bfa65e508753fcd01b2aedb4a61434f41f3a2ddbbd9f41384b96153c684ded3f0fa97c82758d9de5c7cf' + 'SKIP' + 'ff6bdcff839e1cd473f2a0c1e4dd4a3612ec6fee4544ccbc62b530a7248db2cf93b4b99bf493a86ddf2aba00e768927265d5d411f92061ea85fd7929073428e8') +validpgpkeys=('F3691687D867B81B51CE07D9BBE43771487328A9' # Bartlomiej Piotrowski <b@bpiotrowski.pl> + '13975A70E63C361C73AE69EF6EEB81F8981C74C7' # Richard Guenther <richard.guenther@gmail.com> + '33C235A34C46AA3FFB293709A328C3A2C3C45C06') # Jakub Jelinek <jakub@redhat.com> + + +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 -p "$srcdir"/gcc-build +} + +build() { + cd gcc-build + + export CFLAGS_FOR_TARGET='-g -Os -ffunction-sections -fdata-sections' + export CXXFLAGS_FOR_TARGET='-g -Os -ffunction-sections -fdata-sections' + + "$srcdir"/$_basedir/configure \ + --target=$_target \ + --prefix=/usr \ + --libdir=/usr/lib \ + --libexecdir=/usr/lib \ + --program-prefix=$_target- \ + --with-local-prefix=/usr/$_target \ + --with-build-sysroot=/usr/$_target \ + --with-sysroot=/usr/$_target \ + --with-newlib \ + --without-headers \ + --disable-shared \ + --disable-threads \ + --with-system-zlib \ + --enable-tls \ + --enable-languages=c \ + --disable-libatomic \ + --disable-libmudflap \ + --disable-libssp \ + --disable-libquadmath \ + --disable-libgomp \ + --disable-nls \ + --enable-multilib \ + --disable-bootstrap \ + --enable-checking=release + + make inhibit-libc=true +} + +package() { + cd gcc-build + + make DESTDIR="$pkgdir" inhibit-libc=true install + + # strip target binaries + find "$pkgdir"/usr/lib/gcc/$_target/ \ + -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 "$pkgdir"/usr/lib/libcc1.* +} |