On Mon, Apr 09, 2018 at 06:50:12PM +0200, Laszlo Ersek wrote: > On 04/09/18 10:19, Gerd Hoffmann wrote: > >>> +{ 'enum' : 'SystemFirmwareType', > >>> + 'data' : [ 'bios', 'slof', 'uboot', 'uefi' ] } > >> > >> The naming here is quite a bad mixture between firmware interface > >> ('bios', 'uefi') and firmware implementations ('slof', 'uboot'). There > >> could be other implementations of BIOS or UEFI than SeaBIOS and EDK2 ... > >> so I'd suggest to rather name them 'seabios' and 'edk2' here instead. > > > > uboot for example implements uefi unterfaces too (dunno how complete, > > but reportly recent versions can run uefi shell and grub just fine). > > Indeed: when I was struggling with this enum type and tried to look for > more firmware types to add, my googling turned up the "UEFI on Top of > U-Boot" whitepaper, from Alex and Andreas :) > > Again, this reaches to the root of the problem: when a user creates a > new domain, using high-level tools, they just want to tick "UEFI". (Dan > has emphasized this to me several times, so I think I get the idea by > now, if not the full environment.) We cannot ask the user, "please be > more specific, do you want UEFI from edk2, or UEFI on top of U-Boot?" > > Instead, each of those firmware images will have to come with a JSON > document that states "uefi" in SystemFirmware.type, and the host admin > will be responsible for establishing a priority order between them. > Then, when the user asks for "UEFI" (and no more details), they'll get > (compatibly with the target architecture) whichever firmware the host > admin marked as "higher priority". Yep, I don't think there's any problem here. If they have asked for "uefi", they'll get whichever UEFI implementation is the default for that host. Today it'll be an EDK2 impl, but if there's a uboot impl of UEFI available instead, that's fine too. If both are available we'll have some deterministic manner in which we pick one, even if it as simple as which has alphabetically first filename. This is really only about getting good default choices. If the user really badly wants to have a specific firmware, they can still provide a path to it themselves instead of having libvirt choose it. Regards, Daniel -- |: https://berrange.com -o- https://www.flickr.com/photos/dberrange :| |: https://libvirt.org -o- https://fstop138.berrange.com :| |: https://entangle-photo.org -o- https://www.instagram.com/dberrange :| -- libvir-list mailing list libvir-list@xxxxxxxxxx https://www.redhat.com/mailman/listinfo/libvir-list