]> xenbits.xensource.com Git - people/pauldu/qemu.git/commit
i386/xen: manage and save/restore Xen guest long_mode setting
authorDavid Woodhouse <dwmw@amazon.co.uk>
Mon, 12 Dec 2022 14:03:41 +0000 (14:03 +0000)
committerDavid Woodhouse <dwmw@amazon.co.uk>
Fri, 20 Jan 2023 12:28:51 +0000 (12:28 +0000)
commit3fc2863badf77e8e8997a9a923f62d2aa19ed6a8
tree6eb4238db6cb37e9a2329638059af504b27a7fdf
parent9e1e31fb4ee01f94f095301df85ef53b0e9e5811
i386/xen: manage and save/restore Xen guest long_mode setting

Xen will "latch" the guest's 32-bit or 64-bit ("long mode") setting when
the guest writes the MSR to fill in the hypercall page, or when the guest
sets the event channel callback in HVM_PARAM_CALLBACK_IRQ.

KVM handles the former and sets the kernel's long_mode flag accordingly.
The latter will be handled in userspace. Keep them in sync by noticing
when a hypercall is made in a mode that doesn't match qemu's idea of
the guest mode, and resyncing from the kernel. Do that same sync right
before serialization too, in case the guest has set the hypercall page
but hasn't yet made a system call.

Signed-off-by: David Woodhouse <dwmw@amazon.co.uk>
Reviewed-by: Paul Durrant <paul@xen.org>
hw/i386/kvm/xen_overlay.c
hw/i386/kvm/xen_overlay.h
target/i386/kvm/xen-emu.c