Skip to content
Snippets Groups Projects
  • David Woodhouse's avatar
    a72ccc7f
    hw/xen: add support for Xen primary console in emulated mode · a72ccc7f
    David Woodhouse authored
    
    The primary console is special because the toolstack maps a page into
    the guest for its ring, and also allocates the guest-side event channel.
    The guest's grant table is even primed to export that page using a known
    grant ref#. Add support for all that in emulated mode, so that we can
    have a primary console.
    
    For reasons unclear, the backends running under real Xen don't just use
    a mapping of the well-known GNTTAB_RESERVED_CONSOLE grant ref (which
    would also be in the ring-ref node in XenStore). Instead, the toolstack
    sets the ring-ref node of the primary console to the GFN of the guest
    page. The backend is expected to handle that special case and map it
    with foreignmem operations instead.
    
    We don't have an implementation of foreignmem ops for emulated Xen mode,
    so just make it map GNTTAB_RESERVED_CONSOLE instead. This would probably
    work for real Xen too, but we can't work out how to make real Xen create
    a primary console of type "ioemu" to make QEMU drive it, so we can't
    test that; might as well leave it as it is for now under Xen.
    
    Now at last we can boot the Xen PV shim and run PV kernels in QEMU.
    
    Signed-off-by: default avatarDavid Woodhouse <dwmw@amazon.co.uk>
    Reviewed-by: default avatarPaul Durrant <paul@xen.org>
    a72ccc7f
    History
    hw/xen: add support for Xen primary console in emulated mode
    David Woodhouse authored
    
    The primary console is special because the toolstack maps a page into
    the guest for its ring, and also allocates the guest-side event channel.
    The guest's grant table is even primed to export that page using a known
    grant ref#. Add support for all that in emulated mode, so that we can
    have a primary console.
    
    For reasons unclear, the backends running under real Xen don't just use
    a mapping of the well-known GNTTAB_RESERVED_CONSOLE grant ref (which
    would also be in the ring-ref node in XenStore). Instead, the toolstack
    sets the ring-ref node of the primary console to the GFN of the guest
    page. The backend is expected to handle that special case and map it
    with foreignmem operations instead.
    
    We don't have an implementation of foreignmem ops for emulated Xen mode,
    so just make it map GNTTAB_RESERVED_CONSOLE instead. This would probably
    work for real Xen too, but we can't work out how to make real Xen create
    a primary console of type "ioemu" to make QEMU drive it, so we can't
    test that; might as well leave it as it is for now under Xen.
    
    Now at last we can boot the Xen PV shim and run PV kernels in QEMU.
    
    Signed-off-by: default avatarDavid Woodhouse <dwmw@amazon.co.uk>
    Reviewed-by: default avatarPaul Durrant <paul@xen.org>
xen_xenstore.c 49.13 KiB