summaryrefslogtreecommitdiffstats
path: root/arch/x86/include/asm/xen/interface.h
diff options
context:
space:
mode:
authorStefano Stabellini <stefano.stabellini@eu.citrix.com>2012-08-22 17:20:11 +0100
committerKonrad Rzeszutek Wilk <konrad.wilk@oracle.com>2012-08-23 10:18:07 -0400
commitb5e579232d635b79a3da052964cb357ccda8d9ea (patch)
treeb7920e93278da03f1cb2ba9950d010ba95bb0553 /arch/x86/include/asm/xen/interface.h
parent5c13f8067745efc15f6ad0158b58d57c44104c25 (diff)
downloadop-kernel-dev-b5e579232d635b79a3da052964cb357ccda8d9ea.zip
op-kernel-dev-b5e579232d635b79a3da052964cb357ccda8d9ea.tar.gz
xen/events: fix unmask_evtchn for PV on HVM guests
When unmask_evtchn is called, if we already have an event pending, we just set evtchn_pending_sel waiting for local_irq_enable to be called. That is because PV guests set the irq_enable pvops to xen_irq_enable_direct in xen_setup_vcpu_info_placement: xen_irq_enable_direct is implemented in assembly in arch/x86/xen/xen-asm.S and call xen_force_evtchn_callback if XEN_vcpu_info_pending is set. However HVM guests (and ARM guests) do not change or do not have the irq_enable pvop, so evtchn_unmask cannot work properly for them. Considering that having the pending_irq bit set when unmask_evtchn is called is not very common, and it is simpler to keep the native_irq_enable implementation for HVM guests (and ARM guests), the best thing to do is just use the EVTCHNOP_unmask hypercall (Xen re-injects pending events in response). Signed-off-by: Stefano Stabellini <stefano.stabellini@eu.citrix.com> Signed-off-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
Diffstat (limited to 'arch/x86/include/asm/xen/interface.h')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud