docker-haskell icon indicating copy to clipboard operation
docker-haskell copied to clipboard

Include llvm in image

Open flip111 opened this issue 1 year ago • 10 comments

Would it be an option to include the relevant llvm version of a particular version of ghc? Newer versions of host operating systems don't have older llvm versions in the repository, in that case the haskell docker image comes in handy

flip111 avatar Mar 17 '24 23:03 flip111

for GHC 9.2.6 up to llvm 12 is supported. But debian buster only included up to llvm 11. So the docker OS versions don't match for the latest llvm version for the ghc version

flip111 avatar Mar 18 '24 00:03 flip111

@flip111 You may be interested in my multi‑arch (linux/amd64, linux/arm64/v8) GHC musl docker images:

  1. Multi‑arch: linux/amd64, linux/arm64/v8
  2. Built using Hadrian[^1], from source, without docs
  3. Built using the LLVM backend
    • flavour: perf+llvm+split_sections

[^1]: GHC versions ≥ 9.2.8.

👉 See the Version Matrix to find out which version of LLVM is included in the image.

ℹ️ Based on Alpine Linux (that is musl libc and BusyBox) = Made to build statically linked executables.

benz0li avatar Apr 17 '24 08:04 benz0li

GHC musl Dev Containers available, too.

benz0li avatar Apr 17 '24 08:04 benz0li

@benz0li thanks that great, i mentioned your repo as unofficial docker image here https://gitlab.haskell.org/ghc/ghc/-/wikis/building/preparation/linux

i will leave this open because i believe the official image should also either have llvm or provide the ability to install the latest llvm version that is supported by a specific GHC version

flip111 avatar Apr 19 '24 09:04 flip111

or provide the ability to install the latest llvm version that is supported by a specific GHC version

@flip111 IMHO the "Haskell Docker Official Images" are released according to the supported platforms.

For GHC 9.2.6 this is Debian 10. And the Debian 10 package repository serves LLVM versions 6, 7, 11 and 13.

My 'Alpine Linux'-based images only include a supported LLVM version – which does not have to be the latest[^1].

[^1]: 2024-04-22, Addendum: The latest version of LLVM supported by a specific GHC version.

benz0li avatar Apr 19 '24 10:04 benz0li

So the docker OS versions don't match for the right llvm version for the right ghc version

@flip111 It does. LLVM 11 is among the supported LLVM versions for GHC 9.2.6.

benz0li avatar Apr 19 '24 10:04 benz0li

the "Haskell Docker Official Images" are released according to the supported platforms.

Well not exactly in the url you linked you can see the following platforms supported: Alpine, Debian 10, Debian 9, Fedora 27, ubuntu 20.04, CentOS 7. Of those 7 distros only one has the official docker image buster.

My 'Alpine Linux'-based images only include a supported LLVM version – which does not have to be the latest.

I mean the latest supported version by GHC. Not the latest LLVM (19) version which would be incompatible with any GHC version at the moment.

It does. LLVM 11 is among the supported LLVM versions for GHC 9.2.6.

For 11 yes. Question is though why make a docker image for GHC based on an OS that does not support the same LLVM version as GHC, i'm talking about LLVM 12. You want to have the latest supported version for performance and LLVM bugs.

flip111 avatar Apr 19 '24 18:04 flip111

Question is though why make a docker image for GHC based on an OS that does not support the same LLVM version as GHC

@flip111 Because for GHC 9.2.6 there is no binary distribution for Debian 11 (bullseye).

Addendum: If you want something unofficial, you have to build it yourself – from source.

benz0li avatar Apr 22 '24 05:04 benz0li

Because for GHC 9.2.6 there is no binary distribution for Debian 11 (bullseye).

@benz0li i appreciate you thinking along, but this doesn't make sense. Specifically choosing Debian for the docker container is a choice of for the docker container and not from the binary distribution. If we look at the release page for 9.2.4 there are more OS supported as i mentioned before. The docker image could be based on ubuntu for example which has LLVM 12 and is also supported by the binary release of 9.2.6.

flip111 avatar Apr 22 '24 10:04 flip111

Specifically choosing Debian for the docker container is a choice of for the docker container and not from the binary distribution.

@flip111 You are correct.

So either

  • ask the maintainer(s) to add Ubuntu-based images

or

  • create a pull request that adds Ubuntu-based images

benz0li avatar Apr 22 '24 14:04 benz0li