-
Notifications
You must be signed in to change notification settings - Fork 91
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Allow GHCup to build & run on OpenBSD #1138
Conversation
@habibalamin You need to rebase against master. Please let me know if there's anything else blocking you. |
@habibalamin we're planning a new release... before the end of the year. Do you think we can get this in? |
Hey, yeah sorry. I'll try and get that done in a bit. You might be interested to hear that Greg Steuck and I finally got GHC working to run on and produce (seemingly working) binaries for OpenBSD/arm64, by cross-compiling from OpenBSD/amd64. It should, God willing, land in the OpenBSD 7.7 release, which is the upcoming one. |
`libarchive` (the Haskell package, not its upstream C library) vendors the `config.h` header files generated by autoconf for each platform it supports instead of using autoconf (or even CMake, which the C library offers as an option). So apart from those specific platforms, just use `tar` & `zip`. `lzma-static` currently does the same, but we're gonna fix it upstream then update the minimum version bounds on our dependency of it.
1905069
to
0273670
Compare
"mingw32" -> pure PlatformResult { _platform = Windows, _distroVersion = Nothing } | ||
what -> throwE $ NoCompatiblePlatform what | ||
lift $ logDebug $ "Identified Platform as: " <> T.pack (prettyShow pfr) | ||
pure pfr | ||
where | ||
getOpenBSDVersion = lift $ fmap _stdOut $ executeOut "uname" ["-r"] Nothing |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Are you sure uname
is the OpenBSD version and not just the kernel?
What are the outputs? Are they purely numeric? Otherwise we will have a hard time matching on them.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think the BSDs have a kernel version distinct from the OS version, since they're all developed by the same people under a single umbrella; a release is the kernel, plus base packages (userland), plus ports (package repository for that version).
I developed these changes on my real OpenBSD/amd64 machine and tested the uname -r
command after reading the man page at the time.
OpenBSD's man page for uname
says:
-r Print the operating system release. On OpenBSD, the format is digit.digit.
(and digit.digit is underlined, but (GitHub's) Markdown doesn't seem to support that, nor setting monospace font quote without a code block which makes things literal anyway.)
However, I just realised the man page doesn't specify, and I hadn't considered, what would happen on OpenBSD-snapshot or -current (which are non-stable tracks that some OpenBSD users do prefer)? I'm gonna check on a VM now.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is what I get on my -snapshot VM:
OpenBSD 7.6-current (GENERIC.MP) #243: Mon Nov 18 13:30:33 MST 2024 Welcome to OpenBSD: The proactively secure Unix-like operating system. Please use the sendbug(1) utility to report bugs in the system. Before reporting a bug, please try to reproduce it with the latest version of the code. With bug reports, please try to ensure that enough information to reproduce the problem is enclosed, and if a known fix for it exists, include that as well. You have new mail. foo# uname -r 7.6
I generally stick to release, but I do think the login message starting with 7.6-current is correct, even though it's -snapshot, because according to the docs I just checked, -current is essentially following trunk and can only be done by building from source oneself, and -snapshot is just a snapshot of -current compiled for release as non-stable.
So yeah, -r
is always a release number and nothing else.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Comments on this Reddit thread basically confirm that there's no such thing as a -snapshot track, so that was my bad; snapshots are just compiled releases of the -current track.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Interestingly, stack uses C FFI to get uname
:
- https://github.com/commercialhaskell/stack/blob/26616861004037d7626ac1e4fb220dcdcf6c883c/src/Stack/Setup.hs#L1846
- https://github.com/commercialhaskell/stack/blob/26616861004037d7626ac1e4fb220dcdcf6c883c/src/unix/System/Uname.hsc#L13-L17
- https://github.com/commercialhaskell/stack/blob/master/src/unix/cbits/uname.c
I'm not sure it's worth it to do.
GHCup currently doesn't run on OpenBSD (or any platform not explicitly supported), even if it builds. This adds explicit support for OpenBSD. We may later not block it from running on unsupported platforms, even when we don't explicitly make sure our build scripts work for them or provide bindists or CI for them.
0273670
to
175da25
Compare
How do I test these changes? I have private freebsd runners with pots. Afaiu there is a way to have OpenBSD pots, is there? |
I don't understand what you mean by pots. |
|
I mean, the site mentions that you can use jails or VMs, so I suppose you could have an OpenBSD pot if you virtualise it, but the documentation seems to only focus on jails for now. Last I used FreeBSD, their hypervisor was far more developed than OpenBSD, and it should definitely be able to virtualise OpenBSD. |
Just clarifying why this is necessary. Is this to boot up a fresh FreeBSD runner for each CI run?, |
The CI runner runs inside a manually created FreeBSD jail. |
I tried with beehyve and beehyve-vm with no success. |
SourceHut supports OpenBSD latest and one version behind (multiple architectures). They have an API you can use to submit builds. I don't know if that works for you. |
CI is generally a waste of time without having local access to the platform, where you can do proper step-by-step analysis. VirtualBox VMs are awfully slow and waste tons of space, so I was hoping to get it done via beehyve, but it does not have good UX. So I'm not sure how much time I can invest. |
This page from a BSD blog I've seen before has a guide which seems decent, though I haven't tried it. They show two methods to run both FreeBSD and OpenBSD in a bhyve VM; one using stock bhyve, one using a package to make it easier to work with called vm-bhyve. |
I was able to create a VM and boot into the OpenBSD guest installer. But I'm unable to make networking (internet connection via the host) work. None of the tutorials really go into that. |
Do you have an I have an OpenBSD VM on UTM (a QEMU frontend), but (lately?) all my QEMU VMs (maybe due to a UTM update) seem to require bridged networking to work. I think either way, the
I get a Try that, then run |
OpenBSD is not installed yet, so I have limited access to tools. I'm inside the install medium where I get asked questions about network config. There is an option |
Ah, I'm guessing you're using the installation medium which downloads the file sets on demand, instead of preloading them on. Would you be able to give me access to the FreeBSD instance so I can debug, and then give you the installation instructions? |
Can you send me your ssh pubkey signed with your gpg key corresponding to the mail you use in github? You can find my mail in the git commits. |
@habibalamin I was swamped... I try to get to it this week |
I'm using Vultr now which has OpenBSD virtual cloud servers. But Edit: appears it's just VERY slow. |
Ok, I can compile and run it. Do we have any bindists at all that I can test this against? |
No, there are no OpenBSD/amd64 bindists for 7.6 at the moment AFAIK. I can give you a build script to build one, if you like. It might have to be tomorrow, though. Or you can figure it out from OpenBSD's port. |
I get build errors when compiling GHC:
Which is weird, because hadrian is supposed to add the correct flags: https://gitlab.haskell.org/ghc/ghc/-/blob/ghc-9.8/hadrian/src/Hadrian/Builder/Tar.hs#L36-43 |
GNU tar detects the compression, so the GHC doesn't provide the |
Yeah, I'm not sure if I have the time for this. But I need at least one bindist to actually test installation. |
No worries, I'll build one for you this weekend. |
Okay, I built a bindist, but turns out the Without it, it'll install fine, but will compile broken (segfaulting) binaries. The bindist initially has those settings, but the I didn't have to do this for the cross-compiled bindists I did for OpenBSD, which also used those flags for the build, and I haven't done the investigation to figure out why the difference. Either way, you can find the bindist here. SHA512 checksum should be |
I suppose the PR will have to be modified to pass those flags when |
I'm not sure that's a good long term strategy to fidget with such variables during bindist configure. I've told GHC HQ before that the configure script of the bindist needs to be a proper interface to the "GHC settings file". How are other platforms handled that need specific link flags to produce correct binaries @bgamari @AndreasPK? |
Indeed it is not.
The way to proceed here is to introduce Many checks like this can be found in GHC's |
That makes sense. I think these flags are just necessary in general on OpenBSD. They're used in the amd64 port Makefile, and we also had to use them when cross-compiling a port to arm64. So I guess that's a |
@habibalamin do you mind preparing a GHC PR? |
I think it'd be better that a We can improve the configure checks in the original build, but fundamentally, the bindist configure should default to flags set in the original build as well. Anyway, I don't really have much time to work on this any further. I'll try to get to it before the end of the year, but I can't promise anything. Otherwise, it'll have to wait until the new year. |
Can you provide a follow up PR? |
A followup PR to GHC upstream to add the configure checks (and possibly also make it so that running configure in the bindist doesn't by default undo options set in the build)? Or are you talking about a followup PR to GHCup (to provide those linker flags when installing the bindist with GHCup downstream or what)? (Based on the new ticket you created, I'm assuming the latter.) |
Yes |
Fix #707.
This doesn't ensure that GHCup's GHC build scripts/manifests work for OpenBSD, merely that it itself builds and runs on OpenBSD.