pkgsrc-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[pkgsrc/trunk]: pkgsrc/lang/ghc90 Built a bootkit for NetBSD/aarch64



details:   https://anonhg.NetBSD.org/pkgsrc/rev/ac5d588c9a06
branches:  trunk
changeset: 452982:ac5d588c9a06
user:      pho <pho%pkgsrc.org@localhost>
date:      Fri May 21 01:45:00 2021 +0000

description:
Built a bootkit for NetBSD/aarch64

Also the package is now more explicit about LLVM. It used to invoke whatever llc(1) and opt(1) found in the $PATH when -fllvm is passed to the compiler, though it's not the default backend. Now LLVM 
is an explicit, optional dependency on platforms where NCG backend is available, and a mandatory dependency on others.

Note that the LLVM backend tends to produce faster code but it runs significantly slower than NCG. AArch64 support of NCG is being worked on, but it hasn't been merged to the 9.0 branch yet (or even 
the master branch).

diffstat:

 lang/ghc90/Makefile                   |   9 ++++--
 lang/ghc90/bootstrap.mk               |  11 ++++++-
 lang/ghc90/distinfo                   |   9 +++++-
 lang/ghc90/options.mk                 |  48 +++++++++++++++++++++++++++++++++++
 lang/ghc90/patches/patch-aclocal.m4   |  26 +++++++++++++++---
 lang/ghc90/patches/patch-llvm-targets |  17 ++++++++++++
 6 files changed, 108 insertions(+), 12 deletions(-)

diffs (209 lines):

diff -r 0a1bac56c08c -r ac5d588c9a06 lang/ghc90/Makefile
--- a/lang/ghc90/Makefile       Thu May 20 23:08:30 2021 +0000
+++ b/lang/ghc90/Makefile       Fri May 21 01:45:00 2021 +0000
@@ -1,9 +1,9 @@
-# $NetBSD: Makefile,v 1.12 2021/05/01 09:04:57 pho Exp $
+# $NetBSD: Makefile,v 1.13 2021/05/21 01:45:00 pho Exp $
 # -----------------------------------------------------------------------------
 # Package metadata
 #
 DISTNAME=      ghc-9.0.1-src
-PKGREVISION=   4
+PKGREVISION=   5
 PKGNAME=       ${DISTNAME:S/-src$//}
 CATEGORIES=    lang
 MASTER_SITES=  https://downloads.haskell.org/~ghc/${PKGVERSION_NOREV}/
@@ -26,9 +26,12 @@
 BROKEN_EXCEPT_ON_PLATFORM+=    Darwin-*-x86_64
 BROKEN_EXCEPT_ON_PLATFORM+=    FreeBSD-*-i386
 BROKEN_EXCEPT_ON_PLATFORM+=    FreeBSD-*-x86_64
+BROKEN_EXCEPT_ON_PLATFORM+=    NetBSD-*-aarch64
 BROKEN_EXCEPT_ON_PLATFORM+=    NetBSD-*-x86_64
 BROKEN_EXCEPT_ON_PLATFORM+=    SunOS-*-x86_64
 
+.include "options.mk"
+
 
 # -----------------------------------------------------------------------------
 # Distfiles
@@ -205,7 +208,7 @@
 # NetBSD 9.x have libcurses with a newer major version than the
 # bootstrap kit is linked against. For now, work around this with
 # compat80.
-.if ${OPSYS} == "NetBSD" && empty(OS_VERSION:M[0-8].*)
+.if !empty(MACHINE_PLATFORM:MNetBSD-*-x86_64) && empty(OS_VERSION:M[0-8].*)
 BUILD_DEPENDS+=        compat80-[0-9]*:../../emulators/compat80
 # In a sandboxed build environment, we have to reach over to the
 # installed libraries themselves, since the symlinks compat80 adds
diff -r 0a1bac56c08c -r ac5d588c9a06 lang/ghc90/bootstrap.mk
--- a/lang/ghc90/bootstrap.mk   Thu May 20 23:08:30 2021 +0000
+++ b/lang/ghc90/bootstrap.mk   Fri May 21 01:45:00 2021 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: bootstrap.mk,v 1.9 2021/04/30 03:05:30 pho Exp $
+# $NetBSD: bootstrap.mk,v 1.10 2021/05/21 01:45:00 pho Exp $
 # -----------------------------------------------------------------------------
 # Select a bindist of bootstrapping compiler on a per-platform basis.
 #
@@ -37,7 +37,14 @@
 DISTFILES:=    ${DISTFILES} ${BOOT_ARCHIVE} # Available in LOCAL_PORTS
 .endif
 
-.if !empty(MACHINE_PLATFORM:MNetBSD-*-x86_64) || make(distinfo) || make (makesum) || make(mdi)
+.if !empty(MACHINE_PLATFORM:MNetBSD-*-aarch64) || make(distinfo) || make(makesum) || make(mdi)
+# Cross-compiled from x86_64 on a QEMU guest. It took days to compile...
+BOOT_VERSION:= 9.0.1
+BOOT_ARCHIVE:= ghc-${BOOT_VERSION}-boot-aarch64-unknown-netbsd.tar.xz
+DISTFILES:=    ${DISTFILES} ${BOOT_ARCHIVE} # Available in LOCAL_PORTS
+.endif
+
+.if !empty(MACHINE_PLATFORM:MNetBSD-*-x86_64) || make(distinfo) || make(makesum) || make(mdi)
 BOOT_VERSION:= 8.10.4
 BOOT_ARCHIVE:= ghc-${BOOT_VERSION}-boot-x86_64-unknown-netbsd.tar.xz
 DISTFILES:=    ${DISTFILES} ${BOOT_ARCHIVE} # Available in LOCAL_PORTS
diff -r 0a1bac56c08c -r ac5d588c9a06 lang/ghc90/distinfo
--- a/lang/ghc90/distinfo       Thu May 20 23:08:30 2021 +0000
+++ b/lang/ghc90/distinfo       Fri May 21 01:45:00 2021 +0000
@@ -1,9 +1,13 @@
-$NetBSD: distinfo,v 1.13 2021/05/05 09:18:52 pho Exp $
+$NetBSD: distinfo,v 1.14 2021/05/21 01:45:00 pho Exp $
 
 SHA1 (ghc-8.10.4-boot-x86_64-unknown-netbsd.tar.xz) = 3ff01d768393b3866e7a7543f9f55646aaffce7a
 RMD160 (ghc-8.10.4-boot-x86_64-unknown-netbsd.tar.xz) = 39bf10b13054a6316c8477609fb98abe4277fa6c
 SHA512 (ghc-8.10.4-boot-x86_64-unknown-netbsd.tar.xz) = 730347bb5eaac4efac8ec487fafd2da6fe2932db45f59e324c83698eb0b0e8a6a4b4fd513de17fb9c152ccee328660cfe1638cad631ce5e35b2dbfddda0d8850
 Size (ghc-8.10.4-boot-x86_64-unknown-netbsd.tar.xz) = 49500236 bytes
+SHA1 (ghc-9.0.1-boot-aarch64-unknown-netbsd.tar.xz) = db416c1e32a0b65e964aa80db3ecd4492a9e62d0
+RMD160 (ghc-9.0.1-boot-aarch64-unknown-netbsd.tar.xz) = 29250c03e4d29a04f2904508cd0d87d47a0e4340
+SHA512 (ghc-9.0.1-boot-aarch64-unknown-netbsd.tar.xz) = 6ae93b63ecaacc9740f88b0c78095ea660cdf3d7d30bf02b66da3d1a31ceaaf3fd33053b7863ced70ef8b4b844257e6bd856d44648e21876f802e395d265c4d6
+Size (ghc-9.0.1-boot-aarch64-unknown-netbsd.tar.xz) = 83725368 bytes
 SHA1 (ghc-9.0.1-boot-i386-unknown-freebsd.tar.xz) = 7b33f71d9ec9951934137703eef61c106f261808
 RMD160 (ghc-9.0.1-boot-i386-unknown-freebsd.tar.xz) = 98ba27e49e84738a9db92daf669ca7839dd5c0d9
 SHA512 (ghc-9.0.1-boot-i386-unknown-freebsd.tar.xz) = 4fcf2eaa25b33ca77ad4ce465258ca6f9487995219d69416933a84b3d70b7908a09004f3279b4368f81ebb4fdd14465859147ebe683ac7f538307ce5dd74241d
@@ -28,7 +32,7 @@
 RMD160 (netbsd-9.0-amd64-libterminfo.tar.gz) = 5a246633c90ee85f71efcc02d8280bd0c50ab5a7
 SHA512 (netbsd-9.0-amd64-libterminfo.tar.gz) = 79288d44b84df8848afc2cdfee628cc4fd1ec0334159403ef8ba994d617bc56a7114af3031198afb5f3b8f45c0463a848099431e32bc6725042908576b6f95b8
 Size (netbsd-9.0-amd64-libterminfo.tar.gz) = 27744 bytes
-SHA1 (patch-aclocal.m4) = 5de0a62459cddff19973b27e1f2a7dfac7a51dab
+SHA1 (patch-aclocal.m4) = 65f53d7ae4d2124d7191cd0e184b415749a488fb
 SHA1 (patch-compiler_GHC_Driver_Pipeline.hs) = cc2c53f14420b8b75bd70b73e2c95bb52a10cd0c
 SHA1 (patch-compiler_GHC_SysTools_Process.hs) = 36d7171e571d56c4e6ae1ed99d2851c0b0dac084
 SHA1 (patch-configure.ac) = a67c57f39c152a9fc8af830045cf001e957590e2
@@ -45,6 +49,7 @@
 SHA1 (patch-libraries_unix_System_Posix_Files_Common.hsc) = 6efef280832d376915a8987e4e8aac283408f607
 SHA1 (patch-libraries_unix_System_Posix_Signals.hsc) = 49215dce493a6bbc440f91a3959e592f86fc779b
 SHA1 (patch-libraries_unix_include_execvpe.h) = 560c6e9b644687fad62e380f73f08359c48639a2
+SHA1 (patch-llvm-targets) = ff9311421ce0e4c6f666d4f753c8f3b4b7ca1058
 SHA1 (patch-rts_ProfHeap.c) = bc1492578eac7b194caaf1221586cd6c13aa9583
 SHA1 (patch-rts_ghc.mk) = 6e3daf71fb7e656131aa2aeeb0346c651520216a
 SHA1 (patch-rts_posix_GetTime.c) = 036e09510c893ab8677a2b4add0193e7f811bb82
diff -r 0a1bac56c08c -r ac5d588c9a06 lang/ghc90/options.mk
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/lang/ghc90/options.mk     Fri May 21 01:45:00 2021 +0000
@@ -0,0 +1,48 @@
+# $NetBSD: options.mk,v 1.1 2021/05/21 01:45:00 pho Exp $
+
+PKG_OPTIONS_VAR=       PKG_OPTIONS.ghc
+
+# GHC has a native implementation of codegen for some platforms. On
+# those platforms LLVM is optional. It's a requirement anywhere else.
+# See compiler/GHC/Driver/Backend.hs
+
+GHC_NCG_SUPPORTED=     i386 x86_64 powerpc powerpc64 sparc
+.if !empty(GHC_NCG_SUPPORTED:M${MACHINE_ARCH})
+PKG_SUPPORTED_OPTIONS+=        llvm
+PKG_SUGGESTED_OPTIONS+=        llvm
+GHC_LLVM_REQUIRED=     no
+.else
+GHC_LLVM_REQUIRED=     yes
+.endif
+
+.if !empty(PKG_SUPPORTED_OPTIONS)
+.  include "../../mk/bsd.options.mk"
+.endif
+
+.if !empty(PKG_OPTIONS:Mllvm) || ${GHC_LLVM_REQUIRED} == "yes"
+.  include "../../lang/llvm/buildlink3.mk"
+.  include "../../lang/llvm/version.mk"
+CONFIGURE_ENV+=        LLC=${PREFIX:Q}/bin/llc
+CONFIGURE_ENV+=        OPT=${PREFIX:Q}/bin/opt
+
+# Maybe GHC doesn't like this but it's the only option available to us.
+SUBST_CLASSES+=                llvm
+SUBST_STAGE.llvm=      post-extract
+SUBST_MESSAGE.llvm=    Accept whichever version of LLVM installed via pkgsrc
+SUBST_FILES.llvm=      configure.ac
+SUBST_SED.llvm=                -e 's/LlvmVersion=[0-9]*/LlvmVersion=${LLVM_VERSION:C/^([0-9]*)\..*/\1/}/'
+
+# Clang is also required on Darwin.
+# See compiler/GHC/SysTools/Tasks.hs (runClang).
+.  if ${OPSYS} == "Darwin"
+.    include "../../lang/clang/buildlink3.mk"
+CONFIGURE_ENV+=        CLANG=${PREFIX:Q}/bin/clang
+.  else
+CONFIGURE_ENV+=        CLANG=${FALSE}
+.  endif
+
+.else
+CONFIGURE_ENV+=        LLC=${FALSE:Q}
+CONFIGURE_ENV+=        OPT=${FALSE:Q}
+CONFIGURE_ENV+=        CLANG=${FALSE:Q}
+.endif
diff -r 0a1bac56c08c -r ac5d588c9a06 lang/ghc90/patches/patch-aclocal.m4
--- a/lang/ghc90/patches/patch-aclocal.m4       Thu May 20 23:08:30 2021 +0000
+++ b/lang/ghc90/patches/patch-aclocal.m4       Fri May 21 01:45:00 2021 +0000
@@ -1,10 +1,15 @@
-$NetBSD: patch-aclocal.m4,v 1.3 2021/05/05 09:18:52 pho Exp $
+$NetBSD: patch-aclocal.m4,v 1.4 2021/05/21 01:45:00 pho Exp $
+
+Hunk #0:
+  Remove _AC_PROG_CC_C99 macro that is removed in autoconf-2.71 to fix
+  build failure.
 
-Remove _AC_PROG_CC_C99 macro that is removed in autoconf-2.71 to fix
-build failure.
+  Already fixed in the upstream:
+  https://gitlab.haskell.org/ghc/ghc/-/merge_requests/4987
 
-Already fixed in the upstream:
-https://gitlab.haskell.org/ghc/ghc/-/merge_requests/4987
+Hunk #1:
+  Mark the stack as non-executable on NetBSD/aarch64.
+  TODO: Send this to the upstream.
 
 --- aclocal.m4.orig    2021-01-26 14:49:54.000000000 +0000
 +++ aclocal.m4
@@ -26,3 +31,14 @@
      dnl restore saved state
      FP_COPY_SHELLVAR([fp_save_CC],[CC])
      FP_COPY_SHELLVAR([fp_save_CFLAGS],[CFLAGS])
+@@ -759,6 +748,10 @@ AC_DEFUN([FPTOOLS_SET_C_LD_FLAGS],
+         $3="$$3 -Wl,-z,noexecstack"
+         $4="$$4 -z noexecstack"
+         ;;
++    aarch64*netbsd*)
++        $3="$$3 -Wl,-z,noexecstack"
++      $4="$$4 -z noexecstack"
++      ;;
+ 
+     powerpc-ibm-aix*)
+         # We need `-D_THREAD_SAFE` to unlock the thread-local `errno`.
diff -r 0a1bac56c08c -r ac5d588c9a06 lang/ghc90/patches/patch-llvm-targets
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/lang/ghc90/patches/patch-llvm-targets     Fri May 21 01:45:00 2021 +0000
@@ -0,0 +1,17 @@
+$NetBSD: patch-llvm-targets,v 1.1 2021/05/21 01:45:00 pho Exp $
+
+Define the LLVM target for NetBSD/aarch64. This file is generated with
+utils/llvm-targets/gen-data-layout.sh
+
+TODO: Send this to the upstream.
+
+--- llvm-targets.orig  2020-12-21 18:11:39.000000000 +0000
++++ llvm-targets
+@@ -48,6 +48,7 @@
+ ,("amd64-portbld-freebsd", ("e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128", "x86-64", ""))
+ ,("x86_64-unknown-freebsd", ("e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128", "x86-64", ""))
+ ,("aarch64-unknown-freebsd", ("e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128", "generic", "+neon"))
++,("aarch64-unknown-netbsd", ("e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128", "generic", "+neon"))
+ ,("armv6-unknown-freebsd-gnueabihf", ("e-m:e-p:32:32-Fi8-i64:64-v128:64:128-a:0:32-n32-S64", "arm1176jzf-s", "+strict-align"))
+ ,("armv7-unknown-freebsd-gnueabihf", ("e-m:e-p:32:32-Fi8-i64:64-v128:64:128-a:0:32-n32-S64", "generic", "+strict-align"))
+ ,("arm-unknown-nto-qnx-eabi", ("e-m:e-p:32:32-Fi8-i64:64-v128:64:128-a:0:32-n32-S64", "arm7tdmi", "+strict-align"))



Home | Main Index | Thread Index | Old Index