I have a laptop that will not allow anything but UEFI and I must run FreeDOS… (or one of many other OSes that wont boot via UEFI)
Is there a UEFI Bios shim? UEFI thinks it is an OS, but It loads the BIOS boot block and runs it?
Is that even possible?
Linux for example will boot easily under both UEFI and BIOS - but I suppose that is because Linux does not ask anything of either once it is running.
Indeed, I was thinking about OSes like DOS that use the BIOS API even at runtime, for tasks like accessing disks.
As you say, Linux is built for the same world that UEFI was built for, where the firmware is mostly used only to boot the system and for low-level stuff like power management. In that case, the “boot services” in UEFI help to get the kernel loaded and then that takes over most of the hardware interactions. Linux uses BIOS in the same limited way it uses UEFI.
But the IO.SYS in DOS (on IBM PC-compatible platforms, at least) is effectively a wrapper around the BIOS interrupts, and applications running under DOS also expect to be able to interact with BIOS directly sometimes, so I think to do what was asked would mean the OS effectively running inside the UEFI “boot services” environment, rather than the usual approach of the UEFI application only dealing with early boot and then transferring control fully to the OS.
(UEFI does have a legacy compatibility layer that I’ve been ignoring for the sake of this discussion because it’s something normally built in to your firmware rather than something you can add yourself. But it is technically possible for a BIOS implementation to run in that environment. I don’t think it’s possible for a normal UEFI application to use that facility, but I might be wrong about that.)
“UEFI does have a legacy compatibility layer” And this is how one may have a “system firmware” that allows both. Could DOS be made UEFI compatible maybe by loading a .sys driver or maybe by replacing io.sys with one that made use of UEFI?
In the early days (before everyone started cloning the IBM PC) replacing IO.SYS was indeed how MS-DOS was ported to other platforms, and so I suppose in theory that could work. However:
Honestly, if I were trying to do something like this I’d probably shoot for a very minimal Linux image that boots directly into something like QEMU/KVM running directly against the Linux framebuffer/KMS API, since the kernel would then presumably provide drivers for the real hardware (instead of using the more limited drivers in the UEFI firmware) and QEMU can already emulate various legacy hardware that software of the DOS era tends to expect to directly communicate with.
Of course, that’s not nearly as satisfying a solution as running directly as a UEFI application! I’m just concerned that UEFI isn’t really designed to provide equivalent services to IBM-style BIOS, so it would be an uphill struggle.
I think I read this is how HP supplies their “no OS” machines - a very thin Linux with a VM running the FreeDOS fullscreen.