KVM: Fix userspace IRQ chip migration
Re-put pending IRQ vector into interrupt_bitmap before migration. Otherwise it will be lost if migration happens in the wrong time. Signed-off-by: Gleb Natapov <gleb@redhat.com> Signed-off-by: Avi Kivity <avi@redhat.com>
This commit is contained in:
@@ -3566,17 +3566,17 @@ int kvm_arch_vcpu_ioctl_get_sregs(struct kvm_vcpu *vcpu,
|
|||||||
sregs->efer = vcpu->arch.shadow_efer;
|
sregs->efer = vcpu->arch.shadow_efer;
|
||||||
sregs->apic_base = kvm_get_apic_base(vcpu);
|
sregs->apic_base = kvm_get_apic_base(vcpu);
|
||||||
|
|
||||||
if (irqchip_in_kernel(vcpu->kvm)) {
|
if (irqchip_in_kernel(vcpu->kvm))
|
||||||
memset(sregs->interrupt_bitmap, 0,
|
memset(sregs->interrupt_bitmap, 0,
|
||||||
sizeof sregs->interrupt_bitmap);
|
sizeof sregs->interrupt_bitmap);
|
||||||
pending_vec = kvm_x86_ops->get_irq(vcpu);
|
else
|
||||||
if (pending_vec >= 0)
|
|
||||||
set_bit(pending_vec,
|
|
||||||
(unsigned long *)sregs->interrupt_bitmap);
|
|
||||||
} else
|
|
||||||
memcpy(sregs->interrupt_bitmap, vcpu->arch.irq_pending,
|
memcpy(sregs->interrupt_bitmap, vcpu->arch.irq_pending,
|
||||||
sizeof sregs->interrupt_bitmap);
|
sizeof sregs->interrupt_bitmap);
|
||||||
|
|
||||||
|
pending_vec = kvm_x86_ops->get_irq(vcpu);
|
||||||
|
if (pending_vec >= 0)
|
||||||
|
set_bit(pending_vec, (unsigned long *)sregs->interrupt_bitmap);
|
||||||
|
|
||||||
vcpu_put(vcpu);
|
vcpu_put(vcpu);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
Reference in New Issue
Block a user