KVM: Emulate hlt in the kernel
By sleeping in the kernel when hlt is executed, we simplify the in-kernel guest interrupt path considerably. Signed-off-by: Gregory Haskins <ghaskins@novell.com> Signed-off-by: Yaozu (Eddie) Dong <eddie.dong@intel.com> Signed-off-by: Avi Kivity <avi@qumranet.com>
This commit is contained in:
@@ -1961,8 +1961,12 @@ static void post_kvm_run_save(struct kvm_vcpu *vcpu,
|
||||
kvm_run->if_flag = (vmcs_readl(GUEST_RFLAGS) & X86_EFLAGS_IF) != 0;
|
||||
kvm_run->cr8 = get_cr8(vcpu);
|
||||
kvm_run->apic_base = kvm_get_apic_base(vcpu);
|
||||
kvm_run->ready_for_interrupt_injection = (vcpu->interrupt_window_open &&
|
||||
vcpu->irq_summary == 0);
|
||||
if (irqchip_in_kernel(vcpu->kvm))
|
||||
kvm_run->ready_for_interrupt_injection = 1;
|
||||
else
|
||||
kvm_run->ready_for_interrupt_injection =
|
||||
(vcpu->interrupt_window_open &&
|
||||
vcpu->irq_summary == 0);
|
||||
}
|
||||
|
||||
static int handle_interrupt_window(struct kvm_vcpu *vcpu,
|
||||
|
Reference in New Issue
Block a user