[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Xen-devel] [PATCH v5 4/7] xen: Put EFI machinery in place



On Mon, Jun 16, 2014 at 12:55:35PM +0100, Stefano Stabellini wrote:
> On Fri, 13 Jun 2014, Daniel Kiper wrote:
> > This patch enables EFI usage under Xen dom0. Standard EFI Linux
> > Kernel infrastructure cannot be used because it requires direct
> > access to EFI data and code. However, in dom0 case it is not possible
> > because above mentioned EFI stuff is fully owned and controlled
> > by Xen hypervisor. In this case all calls from dom0 to EFI must
> > be requested via special hypercall which in turn executes relevant
> > EFI code in behalf of dom0.
> >
> > When dom0 kernel boots it checks for EFI availability on a machine.
> > If it is detected then artificial EFI system table is filled.
> > Native EFI callas are replaced by functions which mimics them
> > by calling relevant hypercall. Later pointer to EFI system table
> > is passed to standard EFI machinery and it continues EFI subsystem
> > initialization taking into account that there is no direct access
> > to EFI boot services, runtime, tables, structures, etc. After that
> > system runs as usual.
> >
> > This patch is based on Jan Beulich and Tang Liang work.
> >
> > v5 - suggestions/fixes:
> >    - improve macro usage readability
> >      (suggested by Andrew Cooper and David Vrabel),
> >    - conditions cleanup
> >      (suggested by David Vrabel),
> >    - use -fshort-wchar option
> >      (suggested by Jan Beulich),
> >    - Kconfig rule cleanup
> >      (suggested by Jan Beulich),
> >    - forward port fixes from SUSE kernel
> >      (suggested by Jan Beulich),
> >    - improve commit message
> >      (suggested by David Vrabel).
> >
> > v4 - suggestions/fixes:
> >    - "just populate an efi_system_table_t object"
> >      (suggested by Matt Fleming).
> >
> > Signed-off-by: Jan Beulich <jbeulich@xxxxxxxx>
> > Signed-off-by: Tang Liang <liang.tang@xxxxxxxxxx>
> > Signed-off-by: Daniel Kiper <daniel.kiper@xxxxxxxxxx>
>
> Sorry for commenting on your patches so late in the review cycle.

No problem.

[...]

> > +efi_system_table_t __init *xen_efi_probe(void)
> > +{
> > +   struct xen_platform_op op = {
> > +           .cmd = XENPF_firmware_info,
> > +           .u.firmware_info = {
> > +                   .type = XEN_FW_EFI_INFO,
> > +                   .index = XEN_FW_EFI_CONFIG_TABLE
> > +           }
> > +   };
> > +   union xenpf_efi_info *info = &op.u.firmware_info.u.efi_info;
> > +
> > +   if (!xen_initial_domain() || HYPERVISOR_dom0_op(&op) < 0)
> > +           return NULL;
> > +
> > +   /* Here we know that Xen runs on EFI platform. */
> > +
> > +   efi = efi_xen;
> > +
> > +   op.cmd = XENPF_firmware_info;
> > +   op.u.firmware_info.type = XEN_FW_EFI_INFO;
> > +   op.u.firmware_info.index = XEN_FW_EFI_VENDOR;
> > +   info->vendor.bufsz = sizeof(vendor);
> > +   set_xen_guest_handle(info->vendor.name, vendor);
> > +
> > +   if (HYPERVISOR_dom0_op(&op) == 0) {
> > +           efi_systab_xen.fw_vendor = __pa_symbol(vendor);
> > +           efi_systab_xen.fw_revision = info->vendor.revision;
> > +   } else
> > +           efi_systab_xen.fw_vendor = __pa_symbol(L"UNKNOWN");
> > +
> > +   op.cmd = XENPF_firmware_info;
> > +   op.u.firmware_info.type = XEN_FW_EFI_INFO;
> > +   op.u.firmware_info.index = XEN_FW_EFI_VERSION;
> > +
> > +   if (HYPERVISOR_dom0_op(&op) == 0)
> > +           efi_systab_xen.hdr.revision = info->version;
> > +
> > +   op.cmd = XENPF_firmware_info;
> > +   op.u.firmware_info.type = XEN_FW_EFI_INFO;
> > +   op.u.firmware_info.index = XEN_FW_EFI_RT_VERSION;
> > +
> > +   if (HYPERVISOR_dom0_op(&op) == 0)
> > +           efi.runtime_version = info->version;
> > +
> > +   op.cmd = XENPF_firmware_info;
> > +   op.u.firmware_info.type = XEN_FW_EFI_INFO;
> > +   op.u.firmware_info.index = XEN_FW_EFI_CONFIG_TABLE;
> > +
> > +   if (HYPERVISOR_dom0_op(&op) < 0)
> > +           BUG();
>
> Is it really worth of a BUG()? Can't we just print a warning and return
> NULL? We could still boot without EFI support.

Earlier the same hypercall function succeeded so if here it failed
it means that something is really broken. However, I will try remove
this call and get all data from earlier one. This way we avoid this
BUG() call.

Daniel

_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel


 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.