diff options
author | David Woodhouse <dwmw@amazon.co.uk> | 2022-12-14 21:50:41 +0000 |
---|---|---|
committer | David Woodhouse <dwmw@amazon.co.uk> | 2023-03-01 08:22:49 +0000 |
commit | c789b9ef5f80ac471a270bf65cd22024594671a5 (patch) | |
tree | 19778844983544e543ff28a48e2608568608befc /target/i386 | |
parent | 79b7067dc6acec07d93407dd870268a5cd68924d (diff) | |
download | qemu-c789b9ef5f80ac471a270bf65cd22024594671a5.zip qemu-c789b9ef5f80ac471a270bf65cd22024594671a5.tar.gz qemu-c789b9ef5f80ac471a270bf65cd22024594671a5.tar.bz2 |
i386/xen: Implement SCHEDOP_poll and SCHEDOP_yield
They both do the same thing and just call sched_yield. This is enough to
stop the Linux guest panicking when running on a host kernel which doesn't
intercept SCHEDOP_poll and lets it reach userspace.
Signed-off-by: David Woodhouse <dwmw@amazon.co.uk>
Reviewed-by: Paul Durrant <paul@xen.org>
Diffstat (limited to 'target/i386')
-rw-r--r-- | target/i386/kvm/xen-emu.c | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/target/i386/kvm/xen-emu.c b/target/i386/kvm/xen-emu.c index 4ed8336..ebea27c 100644 --- a/target/i386/kvm/xen-emu.c +++ b/target/i386/kvm/xen-emu.c @@ -234,6 +234,19 @@ static bool kvm_xen_hcall_sched_op(struct kvm_xen_exit *exit, X86CPU *cpu, err = schedop_shutdown(cs, arg); break; + case SCHEDOP_poll: + /* + * Linux will panic if this doesn't work. Just yield; it's not + * worth overthinking it because with event channel handling + * in KVM, the kernel will intercept this and it will never + * reach QEMU anyway. The semantics of the hypercall explicltly + * permit spurious wakeups. + */ + case SCHEDOP_yield: + sched_yield(); + err = 0; + break; + default: return false; } |