diff options
Diffstat (limited to 'arch/x86/kvm/lapic.c')
| -rw-r--r-- | arch/x86/kvm/lapic.c | 12 | 
1 files changed, 7 insertions, 5 deletions
diff --git a/arch/x86/kvm/lapic.c b/arch/x86/kvm/lapic.c index cd60c0bd1b32..ba8c045da782 100644 --- a/arch/x86/kvm/lapic.c +++ b/arch/x86/kvm/lapic.c @@ -373,6 +373,12 @@ static int __apic_accept_irq(struct kvm_lapic *apic, int delivery_mode,  		if (unlikely(!apic_enabled(apic)))  			break; +		if (trig_mode) { +			apic_debug("level trig mode for vector %d", vector); +			apic_set_vector(vector, apic->regs + APIC_TMR); +		} else +			apic_clear_vector(vector, apic->regs + APIC_TMR); +  		result = !apic_test_and_set_irr(vector, apic);  		trace_kvm_apic_accept_irq(vcpu->vcpu_id, delivery_mode,  					  trig_mode, vector, !result); @@ -383,11 +389,6 @@ static int __apic_accept_irq(struct kvm_lapic *apic, int delivery_mode,  			break;  		} -		if (trig_mode) { -			apic_debug("level trig mode for vector %d", vector); -			apic_set_vector(vector, apic->regs + APIC_TMR); -		} else -			apic_clear_vector(vector, apic->regs + APIC_TMR);  		kvm_vcpu_kick(vcpu);  		break; @@ -1150,6 +1151,7 @@ void kvm_apic_post_state_restore(struct kvm_vcpu *vcpu)  	hrtimer_cancel(&apic->lapic_timer.timer);  	update_divide_count(apic);  	start_apic_timer(apic); +	apic->irr_pending = true;  }  void __kvm_migrate_apic_timer(struct kvm_vcpu *vcpu)  | 
