Skip to content
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

Pass variables with host properties to scripts #3187

Open
davide125 opened this issue Nov 13, 2024 · 4 comments
Open

Pass variables with host properties to scripts #3187

davide125 opened this issue Nov 13, 2024 · 4 comments
Labels

Comments

@davide125
Copy link
Contributor

davide125 commented Nov 13, 2024

mkosi commit the issue has been seen with

main

Used host distribution

Fedora Linux 41

Used target distribution

Fedora Linux 41

Linux kernel version used

No response

CPU architectures issue was seen on

None

Unexpected behaviour you saw

It would be useful to know the host distribution, release and architecture when inside scripts such as mkosi.sync; while detection is easy enough to reimplement, mkosi is already doing it and uses a consistent format (e.g. it always refers to aarch64 as arm64). For these, I'd suggest adding $HOST_DISTRIBUTION, $HOST_RELEASE, $HOST_ARCHITECTURE. It would also be useful to have a $MKOSI variable pointing to the mkosi binary, so that if one needs to run mkosi from inside one of the scripts it'll be guaranteed to be the same version.

Used mkosi config

No response

mkosi output

No response

@davide125 davide125 added the bug label Nov 13, 2024
@DaanDeMeyer DaanDeMeyer added RFE and removed bug labels Nov 14, 2024
@septatrix
Copy link
Contributor

What is you use case - should this also apply to the tools tree distro?

@davide125
Copy link
Contributor Author

In https://github.com/davide125/arcadeos/blob/66435dd4328aa16fc8d58b98e379a7ef3640d975/mkosi.sync I'm building systemd inside mkosi.sync; this is done by calling mkosi, and it would be good to ensure it's the same mkosi that's running one level up (hence the $MKOSI variable suggestion). As for the host distribution variables, in this scenario the inner mkosi build (for the "host" systemd) ends up building a tools tree, and I would like to ensure it's always targeting the host distribution and release (right now e.g. it will build debian testing when run on ubuntu, which seems to be fine in practice, but IMO is a needless deviation).

@davide125
Copy link
Contributor Author

And to elaborate, IMO $HOST_DISTRIBUTION and friends should always be the actual host, regardless of whether a tools tree is in play; we should add a separate set for the tools tree (say, $TOOLS_TREE_DISTRIBUTION etc) if that's desired.

@septatrix
Copy link
Contributor

Not quite sure why you need to build systemd for the host and the target but I assume you will have your reasons. For now a workaround could be to mount your host's os-release under a different path as a build source and source it inside your script. Mkosi, I think, will always refer to the same binary as you invoked it with (maybe unless you install a mkosi on the tools tree, not sure about that)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Development

No branches or pull requests

3 participants