pkgsrc-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[pkgsrc/trunk]: pkgsrc/lang/ghc92 Import GHC 9.2.1
details: https://anonhg.NetBSD.org/pkgsrc/rev/ef5453633797
branches: trunk
changeset: 373088:ef5453633797
user: pho <pho%pkgsrc.org@localhost>
date: Sun Feb 06 05:36:15 2022 +0000
description:
Import GHC 9.2.1
The compiler now has a native codegen on aarch64. LLVM backend is now
optional, and is disabled by default.
The full release note is too long to paste here. See:
https://downloads.haskell.org/~ghc/9.2.1/docs/html/users_guide/9.2.1-notes.html
diffstat:
lang/ghc92/BOOTSTRAP.txt | 20 +
lang/ghc92/DEINSTALL | 9 +
lang/ghc92/DESCR | 12 +
lang/ghc92/INSTALL | 8 +
lang/ghc92/Makefile | 255 ++++++++
lang/ghc92/bootstrap.mk | 293 ++++++++++
lang/ghc92/buildlink3.mk | 18 +
lang/ghc92/distinfo | 56 +
lang/ghc92/files/bootstrap.build.mk | 42 +
lang/ghc92/options.mk | 65 ++
lang/ghc92/patches/patch-compiler_GHC_Driver_Pipeline.hs | 19 +
lang/ghc92/patches/patch-compiler_GHC_SysTools_Process.hs | 35 +
lang/ghc92/patches/patch-configure.ac | 82 ++
lang/ghc92/patches/patch-ghc.mk | 16 +
lang/ghc92/patches/patch-ghc_ghc-bin.cabal.in | 30 +
lang/ghc92/patches/patch-ghc_ghc.mk | 19 +
lang/ghc92/patches/patch-libraries_Cabal_Cabal_src_Distribution_Simple_GHC.hs | 33 +
lang/ghc92/patches/patch-libraries_base_GHC_Event_KQueue.hsc | 16 +
lang/ghc92/patches/patch-libraries_base_System_CPUTime_Posix_Times.hsc | 16 +
lang/ghc92/patches/patch-libraries_base_System_Environment.hs | 23 +
lang/ghc92/patches/patch-libraries_base_configure | 18 +
lang/ghc92/patches/patch-libraries_time_lib_Data_Time_Clock_Internal_CTimespec.hsc | 23 +
lang/ghc92/patches/patch-libraries_time_lib_Data_Time_Clock_Internal_CTimeval.hs | 33 +
lang/ghc92/patches/patch-libraries_unix_System_Posix_Env.hsc | 16 +
lang/ghc92/patches/patch-libraries_unix_System_Posix_Env_ByteString.hsc | 16 +
lang/ghc92/patches/patch-libraries_unix_System_Posix_Files_Common.hsc | 33 +
lang/ghc92/patches/patch-libraries_unix_System_Posix_Signals.hsc | 22 +
lang/ghc92/patches/patch-libraries_unix_include_execvpe.h | 19 +
lang/ghc92/patches/patch-llvm-targets | 17 +
lang/ghc92/patches/patch-m4_find__llvm__prog.m4 | 15 +
lang/ghc92/patches/patch-m4_fptools__set__c__ld__flags.m4 | 18 +
lang/ghc92/patches/patch-mk_config.mk.in | 17 +
lang/ghc92/patches/patch-rts_ProfHeap.c | 46 +
lang/ghc92/patches/patch-rts_ghc.mk | 14 +
lang/ghc92/patches/patch-rts_posix_GetTime.c | 31 +
lang/ghc92/patches/patch-rts_posix_OSThreads.c | 44 +
lang/ghc92/patches/patch-rules_build-package-way.mk | 14 +
lang/ghc92/patches/patch-rules_distdir-way-opts.mk | 27 +
lang/ghc92/patches/patch-utils_ghc-cabal_ghc.mk | 15 +
lang/ghc92/patches/patch-utils_haddock_driver_Main.hs | 19 +
40 files changed, 1524 insertions(+), 0 deletions(-)
diffs (truncated from 1684 to 300 lines):
diff -r 99b29f007782 -r ef5453633797 lang/ghc92/BOOTSTRAP.txt
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/lang/ghc92/BOOTSTRAP.txt Sun Feb 06 05:36:15 2022 +0000
@@ -0,0 +1,20 @@
+GHC requires itself to build, and unfortunately the only way to get a
+working GHC for a foreign target is to do a cross-compilation.
+
+In order to build a bootkit for a new platform, you need to manually
+set up a cross-building C compiler and binutils, libc, libterminfo,
+and libiconv for the target. Then you can follow instructions in
+https://gitlab.haskell.org/ghc/ghc/wikis/building/cross-compiling
+
+Once you get a working GHC for the target platform, install it
+somewhere in your PATH, run "cd lang/ghc88; make clean; make bootstrap"
+on the target platform and you'll have a bootkit for the target.
+
+--
+
+GHC in fact has never supported bootstrapping only with a C compiler.
+Prior to GHC 7, it had a thing called "HC source", which was a set of
+C source files compiled from Haskell source, but it wasn't actually
+cross-platform. It was because HC files were generated with many
+assumptions about the platform, such as the layout of libc structs,
+the size of off_t and time_t, byte-order, word size, etc.
diff -r 99b29f007782 -r ef5453633797 lang/ghc92/DEINSTALL
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/lang/ghc92/DEINSTALL Sun Feb 06 05:36:15 2022 +0000
@@ -0,0 +1,9 @@
+#!/bin/sh
+#
+GHC_VERSION="@GHC_VERSION@"
+
+case ${STAGE} in
+ DEINSTALL)
+ ${RM} -f ${PKG_PREFIX}/lib/${PKGBASE}-${GHC_VERSION}/package.conf.d/package.cache
+ ;;
+esac
diff -r 99b29f007782 -r ef5453633797 lang/ghc92/DESCR
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/lang/ghc92/DESCR Sun Feb 06 05:36:15 2022 +0000
@@ -0,0 +1,12 @@
+GHC: The Glasgow Haskell Compiler.
+
+The Glasgow Haskell Compiler is a robust, fully-featured, optimising
+compiler for the functional programming language Haskell 98
+(http://www.haskell.org). GHC compiles Haskell to either native code
+or C. It implements numerous experimental language extensions to
+Haskell, including concurrency, a foreign language interface, several
+type-system extensions, exceptions, and so on. GHC comes with a
+generational garbage collector, a space and time profiler, and a
+comprehensive set of libraries.
+
+This package provides the 9.2.x release series.
diff -r 99b29f007782 -r ef5453633797 lang/ghc92/INSTALL
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/lang/ghc92/INSTALL Sun Feb 06 05:36:15 2022 +0000
@@ -0,0 +1,8 @@
+#!/bin/sh
+#
+
+case ${STAGE} in
+ POST-INSTALL)
+ ${PKG_PREFIX}/bin/ghc-pkg recache
+ ;;
+esac
diff -r 99b29f007782 -r ef5453633797 lang/ghc92/Makefile
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/lang/ghc92/Makefile Sun Feb 06 05:36:15 2022 +0000
@@ -0,0 +1,255 @@
+# $NetBSD: Makefile,v 1.1 2022/02/06 05:36:15 pho Exp $
+# -----------------------------------------------------------------------------
+# Package metadata
+#
+DISTNAME= ghc-9.2.1-src
+PKGNAME= ${DISTNAME:S/-src$//}
+CATEGORIES= lang
+MASTER_SITES= https://downloads.haskell.org/~ghc/${PKGVERSION_NOREV}/
+EXTRACT_SUFX= .tar.xz
+
+MAINTAINER= pkgsrc-users%NetBSD.org@localhost
+HOMEPAGE= https://www.haskell.org/ghc/
+COMMENT= Compiler for the functional language Haskell - 9.2 Release Series
+LICENSE= modified-bsd
+
+UNLIMIT_RESOURCES= datasize virtualsize
+
+# GHC requires GHC to build itself. We have to prepare stripped-down
+# binaries sufficient to bootstrap compilers for each platform. If
+# you want to build them yourself, follow instructions in
+# BOOTSTRAP.txt and ./bootstrap.mk
+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
+
+# We are going to do a PIE build on our responsibility. Do not put -pie in
+# wrappers, as that would prevent us from building stage-1 compiler.
+PKGSRC_OVERRIDE_MKPIE= yes
+
+.include "options.mk"
+
+
+# -----------------------------------------------------------------------------
+# Distfiles
+#
+DISTFILES= ${DEFAULT_DISTFILES}
+WRKSRC= ${WRKDIR}/${PKGNAME_NOREV}
+
+# We don't want to extract all of the DISTFILEs.
+EXTRACT_ONLY= ${DEFAULT_DISTFILES}
+
+
+# -----------------------------------------------------------------------------
+# Tools
+#
+USE_TOOLS+= autoconf gmake
+GNU_CONFIGURE= yes
+USE_GNU_CONFIGURE_HOST= no
+USE_LIBTOOL= yes
+
+
+# -----------------------------------------------------------------------------
+# Configuration
+#
+CONFIGURE_ARGS.common+= \
+ --with-curses-libraries=${BUILDLINK_PREFIX.curses}/${BUILDLINK_LIBDIRS.curses:Q} \
+ --with-gmp-includes=${BUILDLINK_PREFIX.gmp}/${BUILDLINK_INCDIRS.gmp:Q} \
+ --with-gmp-libraries=${BUILDLINK_PREFIX.gmp}/${BUILDLINK_LIBDIRS.gmp:Q} \
+ --with-iconv-includes=${BUILDLINK_PREFIX.iconv}/${BUILDLINK_INCDIRS.iconv:Q} \
+ --with-iconv-libraries=${BUILDLINK_PREFIX.iconv}/${BUILDLINK_LIBDIRS.iconv:Q} \
+ --with-ffi-includes=${BUILDLINK_PREFIX.libffi}/${BUILDLINK_INCDIRS.libffi:Q} \
+ --with-ffi-libraries=${BUILDLINK_PREFIX.libffi}/${BUILDLINK_LIBDIRS.libffi:Q}
+
+.include "../../mk/bsd.prefs.mk"
+.if ${OPSYS} == "NetBSD"
+# The GHC rts, by default, creates executable objects on the heap by first
+# mmap(2)'ing an anonymous memory with PROT_READ|PROT_WRITE and then calling
+# mprotect(2) with PROT_READ|PROT_EXEC after filling its content. However,
+# NetBSD PaX mprotect doesn't allow this practice. That is, turning pages that
+# have been initially mapped as non-executable into something executable is a
+# no-no. We must therefore take a different path although it might be a bit slower.
+CONFIGURE_ARGS.common+= --enable-libffi-adjustors
+# See rts/adjustor/NativeAmd64.c and rts/adjustor/LibffiAdjustor.c
+.endif
+
+# We must pass non-wrapper tools to ./configure because they will be
+# embedded in the compiler (actually ${WRKSRC}/settings).
+CONFIGURE_ENV+= ac_cv_prog_fp_prog_ar=${AR:Q}
+CONFIGURE_ENV+= ac_cv_prog_LIBTOOL=libtool
+CONFIGURE_ARGS.common+= LD=${LD:Q}
+
+CONFIGURE_ARGS+= ${CONFIGURE_ARGS.common}
+CONFIGURE_ARGS+= --with-system-libffi
+
+# CFLAGS and LDFLAGS are currently not honored by "./configure". Since
+# LDFLAGS contains rpath flags it's very important to force GHC to honor
+# it. Otherwise neither GHC itself nor executables it produces will have
+# any rpaths so users will have to put "${PREFIX}/lib" into their
+# "/etc/ld-elf.so.conf". See
+# http://hackage.haskell.org/trac/ghc/ticket/2933
+.for stage in 0 1 2
+CONFIGURE_ENV+= CONF_GCC_LINKER_OPTS_STAGE${stage}=${LDFLAGS:M*:Q}
+# Note that CONF_LD_LINKER_OPTS_STAGE{0,1,2} are only used for
+# creating static GHCi libraries (HS*.o). Setting them to ${LDFLAGS}
+# does more harm than good because our ${LDFLAGS} contains -Wl,*
+# flags. It's true that ../../mk/wrapper/cmd-sink-ld transforms them
+# but those flags will also be baked into the compiler (see
+# ${WRKSRC}/compiler/ghc.mk) so they cause problems when used outside
+# the buildlink.
+.endfor
+
+# The use of internal variable in mk/bsd.prefs.mk is not very satisfying,
+# but the current infrastructure does not export a public variable
+# indicating whether a PIE build is requested or not. Note that we can't
+# build stage-1 compiler as PIE, because our bootkit libraries aren't
+# necessarily built as PIC.
+.for stage in 0 1 2
+. if ${stage} == 0
+CONFIGURE_ENV+= CONF_CC_OPTS_STAGE${stage}=${CFLAGS:M*:Q}
+. else
+CONFIGURE_ENV+= CONF_HC_OPTS_STAGE${stage}=-fPIC\ -pie
+CONFIGURE_ENV+= CONF_CC_OPTS_STAGE${stage}=${CFLAGS:M*:Q}\ -fPIC
+. endif
+.endfor
+
+
+# -----------------------------------------------------------------------------
+# Security
+#
+# The runtime system of GHC (rts) has a mechanism called "RTS linker" whose
+# job is to load and execute *static* objects (.a and .o files) at run
+# time. It cannot survive PaX MPROTECT because preloadObjectFile() in
+# rts/linker.c tries to mmap pages with w+x. It doesn't play nice with ASLR
+# either because mmapForLinker() in rts/linker.c wants to always mmap pages
+# in the lower 32-bit area on 64-bit platforms.
+#
+# Luckily for us, the RTS linker is only used when the GHC executable (or
+# any user programs which uses GHC API as an interpreter, not a compiler)
+# is statically linked, which is no longer the case except for ghc-iserv
+# and ghc-iesrv-prof. They are launched when ghci is started with
+# -fexternal-interpreter without -dynamic, and their purpose is to run
+# non-PIC code from within a dynamically linked ghci using the evil RTS
+# linker.
+.for f in ghc-iserv ghc-iserv-prof
+NOT_PAX_MPROTECT_SAFE+= lib/${PKGNAME_NOREV}/bin/${f}
+NOT_PAX_ASLR_SAFE+= lib/${PKGNAME_NOREV}/bin/${f}
+.endfor
+
+
+# -----------------------------------------------------------------------------
+# Build hooks
+#
+
+# We patch configure.ac in some directories.
+post-patch:
+ @${PHASE_MSG} "Regenerating configuration scripts for ${PKGNAME}"
+ ${RUN} cd ${WRKSRC} && autoconf
+
+# Define the target "pre-configure" and non-standard "bootstrap".
+.include "bootstrap.mk"
+
+# Our pre-configure phase installs a bindist of bootstrapping compiler
+# directly into TOOLS_DIR so that ./configure can find it.
+
+# The version restriction on Sphinx in ${WRKSRC}/configure.ac is too
+# loose, and building docs/users_guide rarely succeeds. We don't know
+# which version is actually required for it.
+BUILD_SPHINX_HTML?= no
+
+# Here we generate mk/build.mk dynamically.
+post-configure:
+ ${RUN} ${RM} -f ${WRKSRC}/mk/build.mk
+
+# If there is HsColour in the PATH, GHC's build system tries to use it
+# without even checking if it really works. That's not what we
+# appreciate.
+ ${RUN} ${ECHO} "HSCOLOUR_SRCS = NO" >> ${WRKSRC}/mk/build.mk
+
+.if ${BUILD_SPHINX_HTML} == "no"
+ ${RUN} ${ECHO} "BUILD_SPHINX_HTML = NO" >> ${WRKSRC}/mk/build.mk
+.endif
+
+# Don't even think of PDF.
+ ${RUN} ${ECHO} "BUILD_SPHINX_PDF = NO" >> ${WRKSRC}/mk/build.mk
+
+# SplitSections is only enabled by default on platforms with GNU ld. On SunOS,
+# whose ld is not the GNU one, it can however be used as well.
+.if ${OPSYS} == "SunOS"
+ ${RUN} ${ECHO} "SplitSections = YES" >> ${WRKSRC}/mk/build.mk
+.endif
+
+
+# -----------------------------------------------------------------------------
+# Installation/removal hooks
+#
+
+# Substitutions for INSTALL and DEINSTALL that handles package.cache.
+FILES_SUBST+= GHC_VERSION=${PKGVERSION_NOREV}
+
+# We don't want package.cache to be in the PLIST.
+post-install:
+ ${RM} -f ${DESTDIR}${PREFIX}/lib/${PKGNAME_NOREV}/package.conf.d/package.cache
+
+
+# -----------------------------------------------------------------------------
+# PLIST
+#
+# We can't use static PLIST because the package installs files with a
+# hashed name. And "PLIST_TYPE = dynamic" appears to be broken atm
+# [2019-12-27; pho].
+GENERATE_PLIST+= \
+ cd ${DESTDIR}${PREFIX} && \
+ ${FIND} * \( -type f -o -type l \) | ${SORT};
+
+
+# -----------------------------------------------------------------------------
+# Sanity checks
+#
+
+# ghc57207_0.s: failed to add inputs for merge: Resource temporarily unavailable
+# XXX: On which platform? Is it still an issue?
+CTF_FILES_SKIP+= */libHS*-ghc${PKGVERSION_NOREV}.*
+
+# ld: fatal: relocation error ... relocation requires reference symbol
+# XXX: On which platform? Is it still an issue?
+STRIP_FILES_SKIP+= lib/${PKGNAME_NOREV}/libHSrts.a
+
+
+# -----------------------------------------------------------------------------
+# Dependencies
+#
+.if ${BUILD_SPHINX_HTML} != "no"
+BUILDLINK_DEPMETHOD.python:= build
+.include "../../lang/python/pyversion.mk"
+BUILD_DEPENDS+= ${PYPKGPREFIX}-sphinx-[0-9]*:../../textproc/py-sphinx
+.endif
+
+# NetBSD 9.x have libcurses with a newer major version than the
Home |
Main Index |
Thread Index |
Old Index