diff options
Diffstat (limited to 'libre')
-rw-r--r-- | libre/xtensa-unknown-elf-binutils/PKGBUILD | 75 | ||||
-rw-r--r-- | libre/xtensa-unknown-elf-gcc/PKGBUILD | 159 |
2 files changed, 234 insertions, 0 deletions
diff --git a/libre/xtensa-unknown-elf-binutils/PKGBUILD b/libre/xtensa-unknown-elf-binutils/PKGBUILD new file mode 100644 index 000000000..e50dc2fe8 --- /dev/null +++ b/libre/xtensa-unknown-elf-binutils/PKGBUILD @@ -0,0 +1,75 @@ +# Maintainer (Arch): Allan McRae <allan@archlinux.org> +# Maintainer: André Silva <emulatorman@hyperbola.info> +# Maintainer: Márcio Silva <coadde@hyperbola.info> +# Maintainer: Luke R. <g4jc@openmailbox.org> + +pkgname=xtensa-unknown-elf-binutils +pkgver=2.27 +_pkgverpatch=$pkgver +pkgrel=1.92 +pkgdesc="A set of programs to assemble and manipulate binary and object files" +arch=('i686' 'x86_64' 'armv7h') +url="https://www.gnu.org/software/binutils/" +license=('GPL') +groups=('cross-devel') +depends=('glibc>=2.24-2' 'zlib') +checkdepends=('dejagnu' 'bc') +options=('staticlibs' '!distcc' '!ccache') +source=(https://ftp.gnu.org/gnu/binutils/binutils-$pkgver.tar.bz2{,.sig} + https://repo.parabola.nu/other/binutils/$_pkgverpatch/binutils-xtensa.patch) +validpgpkeys=('EAF1C276A747E9ED86210CBAC3126D3B4AE55E93') # Tristan Gingold <gingold@adacore.com> +sha512sums=('cf276f84935312361a2ca077e04d0b469d23a3aed979d8ba5d92ea590904ffb2c2e7ed12cc842822bfc402836be86f479660cef3791aa62f3753d8a1a6f564cb' + 'SKIP' + 'e10ed358794d7aa32ac25087afd804dc4c3028c4664d7608eb86147f041561d16209afa6501bc8a19e02386674011d567640175f6b8bf89275c243dc3b3a9980') + +prepare() { + cd binutils-$pkgver + + # hack! - libiberty configure tests for header files using "$CPP $CPPFLAGS" + sed -i "/ac_cpp=/s/\$CPPFLAGS/\$CPPFLAGS -O2/" libiberty/configure + + # open-ath9k-htc-firmware patch + patch -p1 -i ${srcdir}/binutils-xtensa.patch + + mkdir ${srcdir}/binutils-build +} + +build() { + cd binutils-build + + ../binutils-$pkgver/configure \ + --prefix=/usr \ + --with-lib-path=/usr/lib:/usr/local/lib \ + --with-bugurl=https://labs.parabola.nu/ \ + --enable-threads \ + --with-pic \ + --enable-ld=default \ + --enable-gold \ + --enable-plugins \ + --enable-deterministic-archives \ + --disable-werror \ + --disable-gdb \ + --disable-nls \ + --target=xtensa-unknown-elf --with-sysroot=/usr/xtensa-unknown-elf + + # check the host environment and makes sure all the necessary tools are available + make configure-host + + make tooldir=/usr +} + +check() { + cd binutils-build + + # unset LDFLAGS as testsuite makes assumptions about which ones are active + # ignore failures in gold testsuite... + make -k LDFLAGS="" check || true +} + +package() { + cd binutils-build + make prefix=${pkgdir}/usr install + + # Remove info documents that conflict with host version + rm -rf ${pkgdir}/usr/share/info +} diff --git a/libre/xtensa-unknown-elf-gcc/PKGBUILD b/libre/xtensa-unknown-elf-gcc/PKGBUILD new file mode 100644 index 000000000..49094e4af --- /dev/null +++ b/libre/xtensa-unknown-elf-gcc/PKGBUILD @@ -0,0 +1,159 @@ +# Maintainer (Arch): Allan McRae <allan@archlinux.org> +# Maintainer: André Silva <emulatorman@hyperbola.info> +# Maintainer: Márcio Silva <coadde@hyperbola.info> +# Maintainer: Luke R. <g4jc@openmailbox.org> + +pkgname=xtensa-unknown-elf-gcc +pkgver=6.3.1 +gccver=6.3.0 +_pkgverpatch=6.2.1 +_pkgver=6 +_islver=0.16 +pkgrel=1.92 +_commit=c2103c17 +pkgdesc="The GNU Compiler Collection" +arch=('i686' 'x86_64' 'armv7h') +license=('GPL' 'LGPL' 'FDL' 'custom') +url="http://gcc.gnu.org" +makedepends=('binutils>=2.27' 'libmpc' 'doxygen') +checkdepends=('dejagnu' 'inetutils') +options=('!emptydirs') +source=(https://ftp.gnu.org/gnu/gcc/gcc-$gccver/gcc-$gccver.tar.bz2{,.sig} + http://isl.gforge.inria.fr/isl-${_islver}.tar.bz2 + https://repo.parabola.nu/other/gcc/$_pkgverpatch/gcc-xtensa.patch) +validpgpkeys=('33C235A34C46AA3FFB293709A328C3A2C3C45C06') # Jakub Jelinek <jakub@redhat.com> # Note: (Weak DSA) :( +sha512sums=('234dd9b1bdc9a9c6e352216a7ef4ccadc6c07f156006a59759c5e0e6a69f0abcdc14630eff11e3826dd6ba5933a8faa43043f3d1d62df6bd5ab1e82862f9bf78' + 'SKIP' + '680da559a37e377c494d9688577159c5c6552c38bf60986c982df8144f3ef60785d530f7223a553c8446bac0c05fd52398e946b1419fbcf511e06316a8fd2d18' + '7637408259cef4b14a2f41690bbc769ad0dc6cf4d1c782405526aeb58f68193269af6882b23fb57c3521174e45709ed2d54f0af1f835646e70a3bfd9f626aad9') + +# gcc-6.0 forces a changed triplet - need to address in pacman/devtools +[[ $CARCH == "x86_64" ]] && CHOST=x86_64-pc-linux-gnu + +_libdir="usr/lib/gcc/xtensa-unknown-elf/$gccver" + +prepare() { + cd ${srcdir}/gcc-$gccver + + # link isl for in-tree build + ln -s ../isl-${_islver} isl + + # Do not run fixincludes + sed -i 's@\./fixinc\.sh@-c true@' gcc/Makefile.in + + # Parabola installs x86_64 libraries /lib + [[ $CARCH == "x86_64" ]] && sed -i '/m64=/s/lib64/lib/' gcc/config/i386/t-linux64 + + # hack! - some configure tests for header files using "$CPP $CPPFLAGS" + sed -i "/ac_cpp=/s/\$CPPFLAGS/\$CPPFLAGS -O2/" {libiberty,gcc}/configure + + # open-ath9k-htc-firmware patch + patch -p1 -i ${srcdir}/gcc-xtensa.patch + + mkdir ${srcdir}/gcc-build +} + +build() { + cd ${srcdir}/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/} + + # --disable-linker-build-id: https://bugs.archlinux.org/task/34902 + + ${srcdir}/gcc-$gccver/configure --prefix=/usr \ + --libdir=/usr/lib \ + --libexecdir=/usr/lib \ + --mandir=/usr/share/man \ + --with-bugurl=https://labs.parabola.nu/ \ + --enable-languages=c,c++,lto \ + --enable-shared \ + --enable-threads=posix \ + --enable-libmpx \ + --with-system-zlib \ + --with-isl \ + --enable-__cxa_atexit \ + --disable-libunwind-exceptions \ + --enable-clocale=gnu \ + --disable-libstdcxx-pch \ + --disable-libssp \ + --enable-gnu-unique-object \ + --disable-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 \ + --disable-nls \ + --target=xtensa-unknown-elf + make all-gcc +} + +package() { + pkgdesc="The GNU Compiler Collection - C and C++ frontends" + depends=("xtensa-unknown-elf-binutils>=2.26" 'libmpc') + groups=('cross-devel') + options=('staticlibs') + + cd ${srcdir}/gcc-build + + make -C gcc DESTDIR=${pkgdir} install-driver install-cpp install-gcc-ar \ + c++.install-common install-headers install-plugin install-lto-wrapper + + install -m755 gcc/gcov $pkgdir/usr/bin/xtensa-unknown-elf-gcov + install -m755 -t $pkgdir/${_libdir}/ gcc/{cc1,cc1plus,collect2,lto1} + + make DESTDIR=${pkgdir} install-fixincludes + make -C gcc DESTDIR=${pkgdir} install-mkheaders + make -C lto-plugin DESTDIR=${pkgdir} install + + make -C gcc DESTDIR=${pkgdir} install-man + + make -C libcpp DESTDIR=${pkgdir} install + make -C gcc DESTDIR=${pkgdir} install-po + + # many packages expect this symlink + ln -s xtensa-unknown-elf-gcc ${pkgdir}/usr/bin/xtensa-unknown-elf-cc + + # POSIX conformance launcher scripts for c89 and c99 + cat > $pkgdir/usr/bin/xtensa-unknown-elf-c89 <<"EOF" +#!/bin/sh +fl="-std=c89" +for opt; do + case "$opt" in + -ansi|-std=c89|-std=iso9899:1990) fl="";; + -std=*) echo "`basename $0` called with non ANSI/ISO C option $opt" >&2 + exit 1;; + esac +done +exec gcc $fl ${1+"$@"} +EOF +sed -i "s|exec gcc|exec xtensa-unknown-elf-gcc|" $pkgdir/usr/bin/xtensa-unknown-elf-c89 + + cat > $pkgdir/usr/bin/xtensa-unknown-elf-c99 <<"EOF" +#!/bin/sh +fl="-std=c99" +for opt; do + case "$opt" in + -std=c99|-std=iso9899:1999) fl="";; + -std=*) echo "`basename $0` called with non ISO C99 option $opt" >&2 + exit 1;; + esac +done +exec gcc $fl ${1+"$@"} +EOF +sed -i "s|exec gcc|exec xtensa-unknown-elf-gcc|" $pkgdir/usr/bin/xtensa-unknown-elf-c99 + + chmod 755 $pkgdir/usr/bin/xtensa-unknown-elf-c{8,9}9 + + # Remove man documents that conflict with host version + rm -rf ${pkgdir}/usr/share/man/man7 + + # Remove unused dirs + rmdir ${pkgdir}/usr/{include,share/info} +} |