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

On the .efi extension #11

Closed
kuraga opened this issue Jan 25, 2024 · 7 comments
Closed

On the .efi extension #11

kuraga opened this issue Jan 25, 2024 · 7 comments

Comments

@kuraga
Copy link
Contributor

kuraga commented Jan 25, 2024

Good day!

We have the line:

[[ ${img} == *.efi ]] || exit 0

But when do we have the .efi extension? I don't see that case in the main binary...

P.S. I'm trying to manage the Linux kernel EFI stub (not UKI) using installkernel. And the sys-kernel/gentoo-kernel-bin's image is an EFI stub but it's not == *.efi.

@Nowa-Ammerlaan
Copy link
Collaborator

Nowa-Ammerlaan commented Jan 25, 2024

We have the .efi extension if we are installing an UKI (i.e. if uki.efi is present at the location of the kernel image):

if [ -f "${uki}" ]; then

90-uki-copy is for installing UKIs in the layout that is common for UKIs (Boot Loader Specification type 2), systemd-boot auto-discovers UKIs in that location.
It would be super confusing if this plugin would also install plain kernel images to the same location with the same name.

If you want to EFI stub without an UKI then all that is required is to have the kernel image somewhere on the ESP, if the ESP is mounted at /boot this is already the case and no extra steps are required. If the ESP is not at /boot I recommend writing some custom postinst script to copy it there. You likely need a custom postinst script anyway to update the firmware configuration with efibootmgr (or copy the kernel image to the same location always, which I would not recommend because it makes it impossible to have fallback kernel versions).

@kuraga
Copy link
Contributor Author

kuraga commented Jan 25, 2024

@AndrewAmmerlaan ,

We have the .efi extension if we are installing an UKI (i.e. if uki.efi is present at the location of the kernel image):

if [ -f "${uki}" ]; then

Aha, "if uki.efi is [already] present". Which tool generate such file? Thanks.

90-uki-copy is for installing UKIs in the layout that is common for UKIs (Boot Loader Specification type 2), systemd-boot auto-discovers UKIs in that location. It would be super confusing if this plugin would also install plain kernel images to the same location with the same name.

If you want to EFI stub without an UKI then all that is required is to have the kernel image somewhere on the ESP, if the ESP is mounted at /boot this is already the case and no extra steps are required. If the ESP is not at /boot I recommend writing some custom postinst script to copy it there. You likely need a custom postinst script anyway to update the firmware configuration with efibootmgr (or copy the kernel image to the same location always, which I would not recommend because it makes it impossible to have fallback kernel versions).

Are there plans for the efi USE/option?

@Nowa-Ammerlaan
Copy link
Collaborator

Nowa-Ammerlaan commented Jan 25, 2024

Aha, "if uki.efi is [already] present". Which tool generate such file? Thanks.

Systemd's ukify or dracut if uefi=yes is in /etc/dracut.conf, plugins for these tools are installed by the ukify and dracut USE flags on installkernel.

If you want an UKI without any initramfs then ukify is your only option, dracut will always make an initramfs first and then generate an UKI, though you can of course configure dracut to create a very small and bare bones initramfs.

See also:
https://wiki.gentoo.org/wiki/Unified_kernel_image
https://wiki.gentoo.org/wiki/Installkernel

Are there plans for the efi USE/option?

What would this do? If we want to move the whole installation tree then I think it makes more sense to remove the hardcoded /boot and allow users to override this (with e.g. /efi). Note that systemd's kernel-install (enabled with USE=systemd) can already do this.

@kuraga
Copy link
Contributor Author

kuraga commented Jan 25, 2024

Thanks!

@kuraga kuraga closed this as completed Jan 25, 2024
@Nowa-Ammerlaan
Copy link
Collaborator

P.S. I'm trying to manage the Linux kernel EFI stub (not UKI) using installkernel. And the sys-kernel/gentoo-kernel-bin's image is an EFI stub but it's not == *.efi.

See also: #19

@Nowa-Ammerlaan
Copy link
Collaborator

If you want to EFI stub without an UKI then all that is required is to have the kernel image somewhere on the ESP, if the ESP is mounted at /boot this is already the case and no extra steps are required. If the ESP is not at /boot I recommend writing some custom postinst script to copy it there. You likely need a custom postinst script anyway to update the firmware configuration with efibootmgr (or copy the kernel image to the same location always, which I would not recommend because it makes it impossible to have fallback kernel versions).

This is now a bit easier in version 29 via the new USE flag efistub.

@kuraga
Copy link
Contributor Author

kuraga commented Apr 9, 2024

Changed in 34 via #20. Thanks!

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

No branches or pull requests

2 participants