5. Release notes for version 8.10.3

The significant changes to the various parts of the compiler are listed in the following sections.

Like previous releases in the 8.10 series, the LLVM backend of this release is to be used with LLVM 9.

5.1. Highlights

  • Numerous stability improvements on Windows.
  • GHC now has far more robust support for architectures with weak memory ordering guarantees.
  • GHC can split up dynamic objects to mitigate the macOS RPATH size limitation when building large projects (#14444).
  • Several significant correctness bugs in the low-latency garbage collector have been fixed. Users of --nonmoving-gc are strongly encouraged to upgrade promptly.

5.2. Full details

5.2.1. Compiler

  • A compiler crash triggered by a SPECIALISE pragma on a binding with no unfolding has been fixed (#18118).
  • GHC now supports a command-line flag, -pgmc-supports-no-pie, allowing the user to indicate that the C compiler supplied via -pgmc ⟨cmd⟩ supports -no-pie.
  • A pair of flags, -pgmlm ⟨cmd⟩ and -optlm ⟨option⟩, allowing the user to override the linker used to be join GHCi object files has been added.
  • A regression in the treatment of the -fbyte-code flag has been fixed (#18955).
  • A bug in the determination of source spans of post-qualified imports has been fixed #19014.

5.2.2. Runtime system

  • GHC is now more careful to respect address space limits set via ulimit` when allocating its heap (#18623).
  • Numerous fixes on Windows. These include a bug in stack allocation triggering Windows’ stack verifier (#18601), various linker bugs (#15808, #18991), and a bug where libc may be called during image initialization resulting in undefined behavior (#18548).
  • GHC’s linker is now able to load macOS frameworks on Big Sur (#18446).
  • A soundness bug affecting programs relying on heavy mutation of MVars has been fixed (#18919).
  • The internal linker’s code unloading logic has been reenabled and now tracks object file dependencies, fixing a soundness bug (#16525).
  • A linker bug relying in the misalignment of loaded .rodata sections has been fixed.

5.3. Known issues

  • A long-standing bug (#16893) which can cause some applications of unsafeCoerce to segmentation fault is only partially fixed in this release. This release only avoids this issue in the uses of unsafeCoerce in Data.Typeable.Internal, which was the proximate cause of #16893.

    However, it is possible that this bug could manifest in user-code using unsafeCoerce to perform dynamic type checks. See the ticket for details.

    We expect that this issue will be fixed in the next major release of GHC.

  • A long-standing bug (#17760) where some uses of the touch# primop can be dropped by the simplifier is present in this release. This bug will be fixed in GHC 9.0.1. In the meantime, see the ticket for mitigations.

5.4. Included libraries

The package database provided with this distribution also contains a number of packages other than GHC itself. See the changelogs provided with these packages for further change information.

Package Version Reason for inclusion
ghc 8.10.4 The compiler itself
Cabal 3.2.1.0 Dependency of ghc-pkg utility
Win32 2.6.1.0 Dependency of ghc library
array 0.5.4.0 Dependency of ghc library
base 4.14.1.0 Core library
binary 0.8.8.0 Dependency of ghc library
bytestring 0.10.12.0 Dependency of ghc library
containers 0.6.2.1 Dependency of ghc library
deepseq 1.4.4.0 Dependency of ghc library
directory 1.3.6.0 Dependency of ghc library
exceptions 0.10.4 Dependency of haskeline library
filepath 1.4.2.1 Dependency of ghc library
ghc-boot-th 8.10.4 Internal compiler library
ghc-boot 8.10.4 Internal compiler library
ghc-compact 0.1.0.0 Core library
ghc-heap 8.10.4 GHC heap-walking library
ghc-prim 0.6.1 Core library
ghci 8.10.4 The REPL interface
haskeline 0.8.0.1 Dependency of ghci executable
hpc 0.6.1.0 Dependency of hpc executable
integer-gmp 1.0.3.0 Core library
libiserv 8.10.4 Internal compiler library
mtl 2.2.2 Dependency of Cabal library
parsec 3.1.14.0 Dependency of Cabal library
pretty 1.1.3.6 Dependency of ghc library
process 1.6.9.0 Dependency of ghc library
stm 2.5.0.0 Dependency of haskeline library
template-haskell 2.16.0.0 Core library
terminfo 0.4.1.4 Dependency of haskeline library
text 1.2.4.1 Dependency of Cabal library
time 1.9.3 Dependency of ghc library
transformers 0.5.6.2 Dependency of ghc library
unix 2.7.2.2 Dependency of ghc library
xhtml 3000.2.2.1 Dependency of haddock executable