Date: Monday, August 14, 2017 @ 17:43:19 Author: felixonmars Revision: 250403
upgpkg: ghc 8.2.1-1 Modified: ghc/trunk/PKGBUILD ghc/trunk/ghc-rebuild-doc-index.hook ghc/trunk/ghc-register.hook ghc/trunk/ghc-unregister.hook Deleted: ghc/trunk/MADV_FREE.patch ----------------------------+ MADV_FREE.patch | 63 -------------------- PKGBUILD | 133 +++++++++++++++++++++++++------------------ ghc-rebuild-doc-index.hook | 2 ghc-register.hook | 2 ghc-unregister.hook | 2 5 files changed, 83 insertions(+), 119 deletions(-) Deleted: MADV_FREE.patch =================================================================== --- MADV_FREE.patch 2017-08-14 16:04:49 UTC (rev 250402) +++ MADV_FREE.patch 2017-08-14 17:43:19 UTC (rev 250403) @@ -1,63 +0,0 @@ -From 6576bf83cdf4eac05eb88a24aa934a736c91e3da Mon Sep 17 00:00:00 2001 -From: Ben Gamari <bgamari.f...@gmail.com> -Date: Thu, 1 Dec 2016 12:55:23 -0500 -Subject: [PATCH] rts: Ensure we always give MADV_DONTNEED a chance in - osDecommitMemory - -As described in #12865, newer Linux kernels support both MADV_FREE and -MADV_DONTNEED. Previously a runtime would fail to try MADV_DONTNEED if -MADV_FREE failed (e.g. since the kernel which the image is running on -doesn't support the latter). Now we try MADV_DONTNEED if MADV_FREE -failed to ensure that binaries compiled on a kernel supporting MADV_FREE -don't fail on decommit. - -Test Plan: Validate - -Reviewers: austin, erikd, simonmar - -Reviewed By: simonmar - -Subscribers: thomie - -Differential Revision: https://phabricator.haskell.org/D2780 - -GHC Trac Issues: #12865 ---- - rts/posix/OSMem.c | 19 ++++++++++++++++--- - 1 file changed, 16 insertions(+), 3 deletions(-) - -diff --git a/rts/posix/OSMem.c b/rts/posix/OSMem.c -index 5291745..beffeda 100644 ---- a/rts/posix/OSMem.c -+++ b/rts/posix/OSMem.c -@@ -541,11 +541,24 @@ void osDecommitMemory(void *at, W_ size) - - #ifdef MADV_FREE - // Try MADV_FREE first, FreeBSD has both and MADV_DONTNEED -- // just swaps memory out -+ // just swaps memory out. Linux >= 4.5 has both DONTNEED and FREE; either -+ // will work as they both allow the system to free anonymous pages. -+ // It is important that we try both methods as the kernel which we were -+ // built on may differ from the kernel we are now running on. - r = madvise(at, size, MADV_FREE); --#else -- r = madvise(at, size, MADV_DONTNEED); -+ if(r < 0) { -+ if (errno == EINVAL) { -+ // Perhaps the system doesn't support MADV_FREE; fall-through and -+ // try MADV_DONTNEED. -+ } else { -+ sysErrorBelch("unable to decommit memory"); -+ } -+ } else { -+ return; -+ } - #endif -+ -+ r = madvise(at, size, MADV_DONTNEED); - if(r < 0) - sysErrorBelch("unable to decommit memory"); - } --- -1.9.1 - Modified: PKGBUILD =================================================================== --- PKGBUILD 2017-08-14 16:04:49 UTC (rev 250402) +++ PKGBUILD 2017-08-14 17:43:19 UTC (rev 250403) @@ -8,13 +8,12 @@ # Libraries depend on versions specified by those hashes. # This implies that all libraries need to be rebuilt when ghc is rebuilt. -# use the following command to print out packages that need to get rebuilt -# grep -r ghc /var/abs/ | awk -F '/' '{ print $5; }' | sort -u +shopt -s extglob pkgbase=ghc -pkgname=(ghc ghc-static) -pkgver=8.0.2 -pkgrel=3 +pkgname=(ghc-libs ghc ghc-static) +pkgver=8.2.1 +pkgrel=1 pkgdesc='The Glasgow Haskell Compiler' arch=('i686' 'x86_64') url='http://www.haskell.org/ghc/' @@ -21,24 +20,21 @@ license=('custom') makedepends=('ghc-static' 'perl' 'libxslt' 'docbook-xsl' 'python-sphinx' 'haskell-hscolour' 'texlive-bin' 'texlive-latexextra' 'ttf-dejavu') -source=("https://downloads.haskell.org/~ghc/$pkgver/$pkgname-${pkgver}-src.tar.xz" - ghc-rebuild-doc-index.hook ghc-register.hook ghc-unregister.hook MADV_FREE.patch) -noextract=("$pkgname-${pkgver}-src.tar.xz") -md5sums=('d0afb5ec441b14527a53d2445cc26ec3' - 'cc9aa11fddde15d8e5e15e99748874a1' - '3b1949e77038b0276ebd5590ab89e1af' - '587efb0cb73a6b336cd9333fc5697de4' - '3bf341c04e2e501a5ace07127de23e8f') +source=("https://downloads.haskell.org/~ghc/$pkgver/$pkgbase-${pkgver}-src.tar.xz" + ghc-rebuild-doc-index.hook ghc-register.hook ghc-unregister.hook) +noextract=("$pkgbase-${pkgver}-src.tar.xz") +md5sums=('8942b6fb393984aeb8304d09bc326851' + '4966d798a2868b289022aea8b655bf17' + '700bcd96afd059d668e50b51c19650d5' + '2355771881c91cb46e6249a81352aea2') prepare() { # Need to extract this tarball with a UTF-8 locale instead of a chroot's "C" # locale; otherwise we get: # bsdtar: Pathname can't be converted from UTF-8 to current locale. - LANG=en_US.UTF-8 bsdtar xf $pkgname-${pkgver}-src.tar.xz + LANG=en_US.UTF-8 bsdtar xf $pkgbase-${pkgver}-src.tar.xz cd ghc-$pkgver - # FS#54823 - patch -p1 -i ../MADV_FREE.patch cp mk/build.mk{.sample,} sed -i '1iBuildFlavour = perf' mk/build.mk @@ -56,48 +52,76 @@ } package_ghc-static() { - pkgdesc='The Glasgow Haskell Compiler - Static Libraries' + pkgdesc='The Glasgow Haskell Compiler - Static Libraries and Documentation' depends=('ghc') cd ghc-$pkgver - make DESTDIR="$pkgdir" -j1 install + make DESTDIR="$pkgdir" install mv "$pkgdir"/usr/lib/ghc-$pkgver/package.conf.d "$srcdir"/static-package.conf.d find "$pkgdir"/usr/lib ! \( -name "*.a" -o -name "*.p_hi" \) -type f -delete find "$pkgdir"/usr/lib -type d -empty -delete mv "$srcdir"/static-package.conf.d "$pkgdir"/usr/lib/ghc-$pkgver/ - rm -r "$pkgdir"/usr/share "$pkgdir"/usr/bin + rm -r "$pkgdir"/usr/bin "$pkgdir"/usr/share/man + + install -Dm644 "$srcdir"/ghc-rebuild-doc-index.hook "$pkgdir"/usr/share/libalpm/hooks/ghc-rebuild-doc-index.hook } package_ghc() { pkgdesc='The Glasgow Haskell Compiler' + provides=("haskell-ghc=$pkgver") + replaces=("haskell-ghc") + depends=('ghc-libs') + + cd ghc-$pkgver + make DESTDIR="$pkgdir" install + + # Remove static libs + find "$pkgdir"/usr/lib \( -name "*.a" -o -name "*.p_hi" \) -delete + + # ghc-pkg is in ghc-libs + rm "$pkgdir"/usr/lib/ghc-$pkgver/bin/ghc-pkg* + rm "$pkgdir"/usr/bin/ghc-pkg* + (cd "$pkgdir"/usr/lib/ghc-$pkgver; rm -r !(bin|ghc-$pkgver)) + + # docs moved to ghc-static + rm -r "$pkgdir"/usr/share/doc + + install -Dm644 utils/completion/ghc.bash \ + "$pkgdir/usr/share/bash-completion/completions/ghc" +} + +package_ghc-libs() { + pkgdesc='The Glasgow Haskell Compiler - Dynamic Libraries' install='ghc.install' depends=('gcc' 'gmp' 'libffi' 'perl') - provides=('haskell-array=0.5.1.1' - 'haskell-base=4.9.1.0' - 'haskell-binary=0.8.3.0' - 'haskell-bytestring=0.10.8.1' - 'haskell-containers=0.5.7.1' - 'haskell-deepseq=1.4.2.0' - 'haskell-directory=1.3.0.0' - 'haskell-filepath=1.4.1.1' - 'haskell-ghc-boot=8.0.2' - 'haskell-ghc-boot-th=8.0.2' - 'haskell-ghc-prim=0.5.0.0' - 'haskell-haskeline=0.7.3.0' - 'haskell-hoopl=3.10.2.1' + provides=('haskell-array=0.5.2.0' + 'haskell-base=4.10.0.0' + 'haskell-binary=0.8.5.1' + 'haskell-bytestring=0.10.8.2' + 'haskell-containers=0.5.10.2' + 'haskell-deepseq=1.4.3.0' + 'haskell-directory=1.3.0.2' + 'haskell-filepath=1.4.1.2' + 'haskell-ghc-boot=8.2.1' + 'haskell-ghc-boot-th=8.2.1' + 'haskell-ghc-compact=0.1.0.0' + 'haskell-ghci=8.2.1' + 'haskell-ghc-prim=0.5.1.0' + 'haskell-haskeline=0.7.4.0' + 'haskell-hoopl=3.10.2.2' 'haskell-hpc=0.6.0.3' - 'haskell-integer-gmp=1.0.0.1' + 'haskell-integer-gmp=1.0.1.0' 'haskell-pretty=1.1.3.3' - 'haskell-process=1.4.3.0' - 'haskell-template-haskell=2.11.1.0' - 'haskell-terminfo=0.4.0.2' - 'haskell-time=1.6.0.1' + 'haskell-process=1.6.1.0' + 'haskell-template-haskell=2.12.0.0' + 'haskell-terminfo=0.4.1.0' + 'haskell-time=1.8.0.2' 'haskell-transformers=0.5.2.0' - 'haskell-unix=2.7.2.1' - 'haskell-xhtml=3000.2.1' - 'haskell-cabal=1.24.2.0') + 'haskell-unix=2.7.2.2' + 'haskell-xhtml=3000.2.2' + 'haskell-cabal=2.0.0.2') replaces=('haskell-array' 'haskell-base' 'haskell-binary' @@ -108,6 +132,8 @@ 'haskell-filepath' 'haskell-ghc-boot' 'haskell-ghc-boot-th' + 'haskell-ghc-compact' + 'haskell-ghci' 'haskell-ghc-prim' 'haskell-haskeline' 'haskell-hoopl' @@ -122,25 +148,26 @@ 'haskell-unix' 'haskell-xhtml' 'haskell-cabal') - provides+=("haskell-ghc=$pkgver") - replaces+=("haskell-ghc") cd ghc-$pkgver - make DESTDIR="$pkgdir" -j1 install + make DESTDIR="$pkgdir" install - for _hook in ghc-rebuild-doc-index.hook ghc-register.hook ghc-unregister.hook; do - install -D -m644 "$srcdir/$_hook" \ - "$pkgdir/usr/share/libalpm/hooks/$_hook" - done + # Remove static libs + find "$pkgdir"/usr/lib \( -name "*.a" -o -name "*.p_hi" \) -delete - install -d -m755 "${pkgdir}"/usr/share/haskell/{register,unregister} + # ghc library and other exes are in the ghc package + rm -r "$pkgdir"/usr/lib/ghc-$pkgver/ghc-$pkgver + (cd "$pkgdir"/usr/lib/ghc-$pkgver/bin; rm !(ghc-pkg*)) + (cd "$pkgdir"/usr/bin; rm !(ghc-pkg*)) - install -Dm644 LICENSE "$pkgdir/usr/share/licenses/$pkgname/LICENSE" + # docs moved to ghc-static + rm -r "$pkgdir"/usr/share/{man,doc} - # Remove static libs - find "$pkgdir"/usr/lib \( -name "*.a" -o -name "*.p_hi" \) -delete + install -Dm644 "$srcdir"/ghc-register.hook "$pkgdir"/usr/share/libalpm/hooks/ghc-register.hook + install -Dm644 "$srcdir"/ghc-unregister.hook "$pkgdir"/usr/share/libalpm/hooks/ghc-unregister.hook - install -Dm644 utils/completion/ghc.bash \ - "$pkgdir/usr/share/bash-completion/completions/ghc" + install -dm755 "$pkgdir"/usr/share/haskell/{register,unregister} + + install -Dm644 LICENSE "$pkgdir"/usr/share/licenses/$pkgname/LICENSE } Modified: ghc-rebuild-doc-index.hook =================================================================== --- ghc-rebuild-doc-index.hook 2017-08-14 16:04:49 UTC (rev 250402) +++ ghc-rebuild-doc-index.hook 2017-08-14 17:43:19 UTC (rev 250403) @@ -10,5 +10,5 @@ Description = Rebuilding Haskell doc index... When = PostTransaction Exec = /bin/bash -c "cd /usr/share/doc/ghc/html/libraries && ./gen_contents_index" -Depends = ghc +Depends = ghc-static Depends = bash Modified: ghc-register.hook =================================================================== --- ghc-register.hook 2017-08-14 16:04:49 UTC (rev 250402) +++ ghc-register.hook 2017-08-14 17:43:19 UTC (rev 250403) @@ -8,5 +8,5 @@ Description = Registering Haskell modules... When = PostTransaction Exec = /bin/sh -c 'while read -r f; do /bin/sh "/$f" 2>&1 >/dev/null ; done' -Depends = ghc +Depends = ghc-libs NeedsTargets Modified: ghc-unregister.hook =================================================================== --- ghc-unregister.hook 2017-08-14 16:04:49 UTC (rev 250402) +++ ghc-unregister.hook 2017-08-14 17:43:19 UTC (rev 250403) @@ -8,5 +8,5 @@ Description = Unregistering Haskell modules... When = PreTransaction Exec = /bin/sh -c 'while read -r f; do /bin/sh "/$f" 2>&1 >/dev/null ; done' -Depends = ghc +Depends = ghc-libs NeedsTargets