Page 1 of 1

Moving to UEFI Booting

Posted: Thu Mar 15, 2018 8:55 pm
by chauhanjpr
Hello,

My baremetal hypervisor currently boots using the multiboot specification with the help of GRUB. I use VGA for printing and not framebuffer. I want to move to UEFI mode booting. What are your recommendations to do that? What would be required to continue booting from GRUB in UEFI mode. Can the OS be a UEFI application and stays in UEFI-land for ever?

Any help or pointer would be of help.

Regards
Himanshu

Re: Moving to UEFI Booting

Posted: Fri Mar 16, 2018 6:16 am
by Brendan
Hi,
chauhanjpr wrote:My baremetal hypervisor currently boots using the multiboot specification with the help of GRUB. I use VGA for printing and not framebuffer. I want to move to UEFI mode booting. What are your recommendations to do that?
My recommendation would be to find anything that depends on legacy stuff (BIOS) and replace them with things that don't (while still using BIOS); and then start trying to move to UEFI afterwards. My reason is that it's easier to change one piece at a time while everything else still works (and harder to fix many incompatibilities at the same time).
chauhanjpr wrote:What would be required to continue booting from GRUB in UEFI mode.
If you use multi-boot's memory map, GRUB's video mode setting, and multi-boot's "video mode information" structures (and the frame buffer GRUB sets up); then it can (in theory, depending on which multi-boot it uses) involve no changes to the code at all (e.g. just fighting with tools to generate a disk image for UEFI).
chauhanjpr wrote:Can the OS be a UEFI application and stays in UEFI-land for ever?
Can you call something an OS if it doesn't take control of the hardware (e.g. by calling UEFI's "exitBootServices()" function)? I'd say that (in general, excluding virtualisation and paravirtualisation) an application (that depends on something else) can't be an OS, and an OS (that doesn't depend on something else) can't be an application.


Cheers,

Brendan

Re: Moving to UEFI Booting

Posted: Fri Mar 16, 2018 9:37 pm
by anatolik
chauhanjpr wrote:Hello,

My baremetal hypervisor currently boots using the multiboot specification with the help of GRUB. I use VGA for printing and not framebuffer. I want to move to UEFI mode booting. What are your recommendations to do that? What would be required to continue booting from GRUB in UEFI mode. Can the OS be a UEFI application and stays in UEFI-land for ever?

Any help or pointer would be of help.

Regards
Himanshu
Hello Himanshu, I am literally in the same position. Currently I am porting my homebrewed OS from multiboot1 to UEFI. The are some progress but the work is not fully completed yet.

Basically there are multiple differences between these two boot mechanisms:
- The system starts in 64bit mode (vs 32bit mode of multiboot). Thus your OS initialization code need to do slightly less.
- UEFI firmware loads UEFI applications and provides pointers to BootServices structure. UEFI application have to be a PE binary (i.e. Windows format app). And to deal with it you either need to compile the application in PE format or write a simple bootloader that loads your ELF into memory and then jump to its entry point.
- I believe there is no VGA text mode available for UEFI application. So if you want to output a text to screen you need to use framebuffer and draw fonts directly to it. Or use serial port that is useful for QEMU development.

Re: Moving to UEFI Booting

Posted: Sat Mar 17, 2018 6:11 am
by chauhanjpr
Thanks for the reply Brenden!
Brenden wrote:Can you call something an OS if it doesn't take control of the hardware (e.g. by calling UEFI's "exitBootServices()" function)? I'd say that (in general, excluding virtualisation and paravirtualisation) an application (that depends on something else) can't be an OS, and an OS (that doesn't depend on something else) can't be an application.
I was just thinking out loud. BTW, I got the framebuffer to work in non-UEFI mode but on the machines with UEFI its not working. Possibly because in UEFI mode multiboot's vbeinfo is not populated. I am yet to try the frame buffer specific section in multiboot header. Anything else that would be needed to get FB to work under UEFI?

Regards
Himanshu

Re: Moving to UEFI Booting

Posted: Sat Mar 17, 2018 6:21 am
by chauhanjpr
anatolik wrote:Hello Himanshu, I am literally in the same position. Currently I am porting my homebrewed OS from multiboot1 to UEFI. The are some progress but the work is not fully completed yet.
I am also trying to get Multiboot 1 to work with UEFI.

anatolik wrote: - The system starts in 64bit mode (vs 32bit mode of multiboot). Thus your OS initialization code need to do slightly less.
It would be easier for me as I am not planning to support 32bit, I guess, ever! So I can fixate on booting part.
anatolik wrote: - UEFI firmware loads UEFI applications and provides pointers to BootServices structure. UEFI application have to be a PE binary (i.e. Windows format app). And to deal with it you either need to compile the application in PE format or write a simple bootloader that loads your ELF into memory and then jump to its entry point.
I am using Grub to boot the hypervisor. Grub, as I have read on the internet, exits the boot services before it launches the OS. So I need to just get the framebuffer working in UEFI mode. I don't know if the framebuffer section of multiboot header will give the enough information because VBE section info doesn't work.

Regards
Himanshu

Re: Moving to UEFI Booting

Posted: Sat Mar 17, 2018 6:54 am
by Brendan
Hi,
chauhanjpr wrote:I was just thinking out loud. BTW, I got the framebuffer to work in non-UEFI mode but on the machines with UEFI its not working. Possibly because in UEFI mode multiboot's vbeinfo is not populated. I am yet to try the frame buffer specific section in multiboot header. Anything else that would be needed to get FB to work under UEFI?
I'm not sure how much of what GRUB supports under UEFI; but the reason they created multi-boot 2 is that the original multi-boot 1 was only designed for BIOS systems and wasn't very portable. Also note that GRUB 2 tends to rely on "optional" modules, so maybe the problem is that GRUB 2 is missing some sort of video related module.
chauhanjpr wrote:
anatolik wrote:Hello Himanshu, I am literally in the same position. Currently I am porting my homebrewed OS from multiboot1 to UEFI. The are some progress but the work is not fully completed yet.
I am also trying to get Multiboot 1 to work with UEFI.
I'm fairly sure (based on information elsewhere) that anatolik is porting code to "raw UEFI" so that it won't use multi boot and won't need a loader like GRUB.

You seem to want to continue using multi-boot and GRUB; which is quite different to what anatolik is doing.
anatolik wrote:I am using Grub to boot the hypervisor. Grub, as I have read on the internet, exits the boot services before it launches the OS. So I need to just get the framebuffer working in UEFI mode. I don't know if the framebuffer section of multiboot header will give the enough information because VBE section info doesn't work.
Erm, this is getting a little confusing.

Just to be sure, for what you're planning:
  • GRUB starts running on the real/host machine
  • GRUB (on the host machine) exits the host machine's boot services
  • GRUB (on the host machine) starts a hypervisor
  • Hypervisor creates a whole new (virtual) machine with it's own completely unrelated UEFI and it's own boot services
  • Hypervisor starts a completely different copy of GRUB inside the virtual machine
  • GRUB (in the virtual machine) exits the virtual machine's boot services
  • GRUB (in the virtual machine) passes control to your code using "multi-boot 1"
The alternative is something like:
  • GRUB starts running on the real/host machine
  • GRUB (on the host machine) exits the host machine's boot services
  • GRUB (on the host machine) starts a hypervisor
  • Hypervisor creates a whole new (virtual) machine with it's own completely unrelated UEFI and it's own boot services
  • Hypervisor starts boots your code (without using GRUB inside the virtual machine, and without multi-boot being used by your code at all) and you have to exit boot services yourself

Cheers,

Brendan

Re: Moving to UEFI Booting

Posted: Sat Mar 17, 2018 9:01 am
by chauhanjpr
Hi Brendan,
Brendan wrote: Erm, this is getting a little confusing.

Just to be sure, for what you're planning:
  • GRUB starts running on the real/host machine
  • GRUB (on the host machine) exits the host machine's boot services
  • GRUB (on the host machine) starts a hypervisor
  • Hypervisor creates a whole new (virtual) machine with it's own completely unrelated UEFI and it's own boot services
  • Hypervisor starts a completely different copy of GRUB inside the virtual machine
  • GRUB (in the virtual machine) exits the virtual machine's boot services
  • GRUB (in the virtual machine) passes control to your code using "multi-boot 1"
Till point 3 its good. My code is hypervisor. I am trying to get my hypervisor booting in UEFI mode. Currently it boots on a real machine using Multiboot-1. On another machine, UEFI is enabled and I want to support UEFI mode in my hypervisor.

Regards
Himanshu

Re: Moving to UEFI Booting

Posted: Fri Mar 23, 2018 8:52 pm
by iamtim
GNU-EFI has a Print() function you can use until you call ExitBootServices();

https://www.rodsbooks.com/efi-programming/hello.html