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

firmware: want auto-added boot options to always be before EFI shell #787

Open
iximeow opened this issue Oct 10, 2024 · 0 comments
Open
Labels
guest-firmware Relates to EDK2 or Propolis configuration thereof.

Comments

@iximeow
Copy link
Member

iximeow commented Oct 10, 2024

i think i can't add issues to oxidecomputer/EDK2 because it's a fork rather than a repo in its own right, so filing this here instead.

this is, fundamentally, the misbehavior that is noted in Omicron#5112: a boot device's description changed, its previous entry was removed, a new entry was added, and that new entry was after the EFI shell in boot order. we should make sure the EFI Internal Shell option is close to the last option, which will help keep guests from auto-discovering their way into not booting.

it seems extremely unlikely that someone would want to end up at the EFI shell specifically - in almost every case someone ends up in the EFI shell rather than their expected OS, it comes with a question of, "oh no, what did i break, and can i fix it?". now that users can specify a boot disk, and that boot order takes precedence over existing UEFI boot option variables, it is at least fixable! but it seems like a misbehavior to end up in that situation in the first place. if a user did want to get to the EFI shell, it probably would be through a procedure like booting a guest OS, modifying the UEFI BootOrder variable to move the EFI shell up, and then rebooting. or booting an instance with no disks.

in practice this would probably be some change to EDK2 around where the EFI Internal Shell option is added, but i couldn't figure out an obvious tiny change this morning.

overall this seems like pretty low priority, but nice to have.

@iximeow iximeow added the guest-firmware Relates to EDK2 or Propolis configuration thereof. label Oct 10, 2024
iximeow added a commit that referenced this issue Jan 8, 2025
there are also specific conditions where failing this assertion is fine - say,
if we've done #787, or changed
how we're processing UEFI boot variables. just, as things are right now, we're
surprisingly dependent on dancing with OVMF in exactly the same way every time
a guest boots.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
guest-firmware Relates to EDK2 or Propolis configuration thereof.
Projects
None yet
Development

No branches or pull requests

1 participant