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

Add mkosi-addon and kernel-install plugin #3263

Merged
merged 1 commit into from
Jan 20, 2025
Merged

Add mkosi-addon and kernel-install plugin #3263

merged 1 commit into from
Jan 20, 2025

Conversation

bluca
Copy link
Member

@bluca bluca commented Dec 7, 2024

Add new mkosi-addon and kernel-install plugin to build local customizations into an EFI addon.

This allows us to move closer to the desired goal of having universal UKIs, built by vendors, used together with locally built enhancements.

@bluca
Copy link
Member Author

bluca commented Dec 7, 2024

Tested on my laptop, seems to work nicely. To install the addon requires a change to 90-uki-copy.install that I'll send once this is sorted out.

@bluca bluca force-pushed the addon branch 2 times, most recently from ccd776e to 7319fcc Compare December 7, 2024 00:35
@DaanDeMeyer
Copy link
Contributor

I think this belongs in systemd, not in mkosi. Users should be able to use their vendor provided UKI with an addon without needing mkosi installed on their system.

The UKI is supposed to come with a set of kernel modules to satisfy 99% common use cases, so shipping the entirety of host loaded kernel modules as an addon doesn't make sense to me.

Also we created mkosi-initrd specifically to generate hostonly initrds. That's it's only reason to exist, so adding a --host-only switch to it seems counter intuitive. I know you're trying to use mkosi-initrd and mkosi-addon together, but that means you're using a locally built initrd and then pretending it's not locally built. To me this is just overcomplicating the setup for the sake of pretending we're doing vendor built UKIs because distributions don't actually have vendor built UKIs yet.

So I agree that an addon generating ker el-install plugin makes sense, but it should live in systemd next to the ukify plugin, not in mkosi, and we shouldn't try to make mkosi-initrd generate vendor built initrds when it's specifically built to generate local initrds.

@DaanDeMeyer
Copy link
Contributor

cc @keszybz

@bluca
Copy link
Member Author

bluca commented Dec 7, 2024

It needs the logic to copy the kernel modules and firmware from the host, which is in the mkosi library code, so while the script could be moved, it would still depend on mkosi anyway, so why not keep it here so both plugins can be kept in sync?

@DaanDeMeyer
Copy link
Contributor

I'm arguing it doesn't need that logic. The vendor uki should include a default set of modules and firmware that work for most use cases. And then in super special cases addons are used to include a few extras.

So it can live in systemd without having to depend on mkosi.

@bluca
Copy link
Member Author

bluca commented Dec 7, 2024

That's unlikely to work though, you'd need a UKI with hundreds of MBs of stuff - the NVIDIA firmware alone is like 200M. Plus there's a gazillion different bluetooth/wifi firmwares, each in the tens of MBs each. There will always be demand for a minimal generic UKI + local-specific modifications. Otherwise why have that logic in mkosi-initrd either? Just build UKIs with everything, no?

@DaanDeMeyer
Copy link
Contributor

DaanDeMeyer commented Dec 7, 2024

That's unlikely to work though, you'd need a UKI with hundreds of MBs of stuff - the NVIDIA firmware alone is like 200M. Plus there's a gazillion different bluetooth/wifi firmwares, each in the tens of MBs each. There will always be demand for a minimal generic UKI + local-specific modifications. Otherwise why have that logic in mkosi-initrd either? Just build UKIs with everything, no?

We have that logic in mkosi-initrd precisely because the initrd is built locally. We're building locally anyway so we might as well make use of the advantages that brings us.

With your approach, you're using a vendor signed UKI and then requiring every user to enroll their own key since they need to add their own addon with kernel modules and firmware. So the entire point of the vendor signed UKI becomes moot because every single user still has to enroll their own key.

The entire goal of the vendor signed UKIs is that they work out of the box for most use cases or the vendor also provides signed addons that extend the UKI. As soon as you require every single user to enroll their own key, you might as well build and sign the entire UKI locally and not bother with vendor signing to begin with. And if you're building and signing the UKI locally there's no point in using addons since you can just add everything straight into the UKI.

So a solution like this that implies every user enrolling their own key is not an option in my opinion.

@DaanDeMeyer
Copy link
Contributor

And if you want this just for the niche use case where a user wants a locally signed addon with kernel modules with a minimal signed vendor UKI, that's too niche to me to justify all this extra code in mkosi for that specific use case. I would much rather we focus on building the entire UKI ourselves and signing that locally then instead of focusing on building addons for vendor signed UKIs.

@DaanDeMeyer
Copy link
Contributor

What is attractive to add to mkosi is a way to build those signed vendor addons. So I am actually interested in the addon output format as a similar mechanism to sysexts you can use it together with Overlay=yes to package an overlay on top of the base initrd mage into an addon.

@bluca
Copy link
Member Author

bluca commented Dec 7, 2024

Having the possibility of building local customizations will always be needed, it cannot possibly be preditected what all combinations one might need will be, especially including local configuration (eg: crypttab) and kernel command line. Yes that will require local keys, but that's always been the case, eg: out of tree kernel drivers or filesystems

@DaanDeMeyer
Copy link
Contributor

Having the possibility of building local customizations will always be needed, it cannot possibly be preditected what all combinations one might need will be, especially including local configuration (eg: crypttab) and kernel command line. Yes that will require local keys, but that's always been the case, eg: out of tree kernel drivers or filesystems

Yes it will be needed, it's just not something I want to maintain the code for in mkosi. If the kernel modules logic is dropped I think it's perfectly fine to propose this for inclusion in systemd.

I think mkosi should focus on either building vendor signed UKIs + vendor signed addons or locally signed UKIs and not everything inbetween.

@aafeijoo-suse
Copy link
Contributor

Also we created mkosi-initrd specifically to generate hostonly initrds. That's it's only reason to exist, so adding a --host-only switch to it seems counter intuitive.

So, the idea is having mkosi-initrd only for host specific initrds and use mkosi --format=cpio --include=mkosi-initrd ... for generic initrds? IMHO, having a --host-only switch to generate initrds with and without local configuration on them is a must-have feature if mkosi-initrd is intended to be a complete initrd generator.

Copy link
Contributor

@DaanDeMeyer DaanDeMeyer left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So we have the initrd-addon output format now so that logic can be removed from this PR.

After taking another look I see the value in having this, but with some changes, see other comments.

mkosi/addon.py Outdated Show resolved Hide resolved
mkosi/resources/mkosi-addon/mkosi.conf Outdated Show resolved Hide resolved
mkosi/addon.py Outdated Show resolved Hide resolved
kernel-install/51-mkosi-addon.install Show resolved Hide resolved
mkosi/addon.py Show resolved Hide resolved
mkosi/addon.py Outdated Show resolved Hide resolved
mkosi/addon.py Outdated Show resolved Hide resolved
mkosi/addon.py Outdated Show resolved Hide resolved
mkosi/addon.py Outdated Show resolved Hide resolved
mkosi/resources/mkosi-addon/mkosi.conf Outdated Show resolved Hide resolved
mkosi/addon.py Fixed Show fixed Hide fixed
mkosi/addon.py Fixed Show fixed Hide fixed
@bluca bluca force-pushed the addon branch 5 times, most recently from e612dcd to 61a60c9 Compare January 17, 2025 20:03
kernel-install/51-mkosi-addon.install Outdated Show resolved Hide resolved
kernel-install/51-mkosi-addon.install Outdated Show resolved Hide resolved
mkosi/__init__.py Outdated Show resolved Hide resolved
mkosi/__init__.py Outdated Show resolved Hide resolved
mkosi/__init__.py Outdated Show resolved Hide resolved
mkosi/util.py Outdated Show resolved Hide resolved
mkosi/addon.py Outdated Show resolved Hide resolved
mkosi/addon.py Outdated Show resolved Hide resolved
mkosi/__init__.py Outdated Show resolved Hide resolved
@bluca bluca force-pushed the addon branch 6 times, most recently from 4b0ee63 to 2519394 Compare January 19, 2025 23:24
@DaanDeMeyer
Copy link
Contributor

One more change that we should make, since we now only run the kernel-install plugin when passed a vendor provided UKI, we can extract the initrd from the vendor provided UKI and use it as a base tree.

That would make this a lot more powerful, since if the vendor provided UKI would include a package database, it'd become possible to install extra packages in the addon. It also makes sure we only add kernel modules to the addon that aren't already in the vendor UKI initrd after #3390 is merged.

We have a function extract_pe_section() to extract sections from a UKI. You'll also have to add extract_cpio() to archive.py to implement the CPIO extraction.

@DaanDeMeyer
Copy link
Contributor

One more change that we should make, since we now only run the kernel-install plugin when passed a vendor provided UKI, we can extract the initrd from the vendor provided UKI and use it as a base tree.

That would make this a lot more powerful, since if the vendor provided UKI would include a package database, it'd become possible to install extra packages in the addon. It also makes sure we only add kernel modules to the addon that aren't already in the vendor UKI initrd after #3390 is merged.

We have a function extract_pe_section() to extract sections from a UKI. You'll also have to add extract_cpio() to archive.py to implement the CPIO extraction.

Actually nvm this doesn't account for UKI profiles, ignore my blabber

kernel-install/50-mkosi.install Outdated Show resolved Hide resolved
kernel-install/50-mkosi.install Outdated Show resolved Hide resolved
kernel-install/50-mkosi.install Outdated Show resolved Hide resolved
kernel-install/50-mkosi.install Outdated Show resolved Hide resolved
kernel-install/51-mkosi-addon.install Outdated Show resolved Hide resolved
mkosi/resources/man/mkosi-addon.1.md Outdated Show resolved Hide resolved
mkosi/resources/man/mkosi-addon.1.md Outdated Show resolved Hide resolved
mkosi/resources/man/mkosi-addon.1.md Outdated Show resolved Hide resolved
mkosi/resources/man/mkosi-addon.1.md Outdated Show resolved Hide resolved
mkosi/resources/man/mkosi-addon.1.md Outdated Show resolved Hide resolved
README.md Outdated Show resolved Hide resolved
mkosi/resources/man/mkosi-addon.1.md Outdated Show resolved Hide resolved
Add new mkosi-addon and kernel-install plugin to build local
customizations into an EFI addon.

This allows us to move closer to the desired goal of having
universal UKIs, built by vendors, used together with locally
built enhancements.
@bluca bluca merged commit 3551986 into systemd:main Jan 20, 2025
30 of 31 checks passed
@bluca bluca deleted the addon branch January 20, 2025 15:03
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Development

Successfully merging this pull request may close these issues.

4 participants