From 52a99ff20cbc560827823d849cbb75209bbfe6ed Mon Sep 17 00:00:00 2001 From: Moritz Angermann Date: Wed, 29 Nov 2023 06:04:26 +0800 Subject: [PATCH] fix some aarch64-musl libc loading issues (#2115) --- overlays/bootstrap.nix | 1 + .../ghc-8.10-aarch64-musl-gettimeofday.patch | 18 ++++++++++++++++++ 2 files changed, 19 insertions(+) create mode 100644 overlays/patches/ghc/ghc-8.10-aarch64-musl-gettimeofday.patch diff --git a/overlays/bootstrap.nix b/overlays/bootstrap.nix index 476bc8b50a..a2eb9d8e4b 100644 --- a/overlays/bootstrap.nix +++ b/overlays/bootstrap.nix @@ -265,6 +265,7 @@ in { # ++ fromUntil "9.6.1" "9.10" ./patches/ghc/iserv-syms.patch # Fix the bad fixups: https://gitlab.haskell.org/ghc/ghc/-/commit/2adc050857a9c1b992040fbfd55fbe65b2851b19 ++ final.lib.optional (versionAtLeast "9.6" && versionLessThan "9.8" && final.stdenv.targetPlatform.isAarch64) ./patches/ghc/2adc050857a9c1b992040fbfd55fbe65b2851b19.patch + ++ final.lib.optional (versionAtLeast "8.10.7" && versionLessThan "9.0" && final.stdenv.targetPlatform.isAarch64 && final.stdenv.targetPlatform.isMusl && final.stdenv.targetPlatform != final.stdenv.hostPlatform) ./patches/ghc/ghc-8.10-aarch64-musl-gettimeofday.patch ; in ({ ghc865 = final.callPackage ../compiler/ghc (traceWarnOld "8.6" { diff --git a/overlays/patches/ghc/ghc-8.10-aarch64-musl-gettimeofday.patch b/overlays/patches/ghc/ghc-8.10-aarch64-musl-gettimeofday.patch new file mode 100644 index 0000000000..4386be1387 --- /dev/null +++ b/overlays/patches/ghc/ghc-8.10-aarch64-musl-gettimeofday.patch @@ -0,0 +1,18 @@ +diff --git a/rts/RtsSymbols.c b/rts/RtsSymbols.c +index e0901c3..05a4310 100644 +--- a/rts/RtsSymbols.c ++++ b/rts/RtsSymbols.c +@@ -991,9 +991,13 @@ + SymI_HasProto(cas) \ + SymI_HasProto(_assertFail) \ + SymI_HasProto(keepCAFs) \ ++ SymI_NeedsProto(gettimeofday) \ ++ SymI_HasProto(clock) \ + RTS_USER_SIGNALS_SYMBOLS \ + RTS_INTCHAR_SYMBOLS + ++ // need gettimeofday, clock for split-mix; otherwise will segv when calling this from iserv :-/ ++ + + // 64-bit support functions in libgcc.a + #if defined(__GNUC__) && SIZEOF_VOID_P <= 4 && !defined(_ABIN32)