diff options
Diffstat (limited to 'arch/x86/kvm/lapic.c')
| -rw-r--r-- | arch/x86/kvm/lapic.c | 11 | 
1 files changed, 4 insertions, 7 deletions
diff --git a/arch/x86/kvm/lapic.c b/arch/x86/kvm/lapic.c index 924ac8ce9d50..391dda8d43b7 100644 --- a/arch/x86/kvm/lapic.c +++ b/arch/x86/kvm/lapic.c @@ -2002,14 +2002,13 @@ void kvm_lapic_set_base(struct kvm_vcpu *vcpu, u64 value)  void kvm_lapic_reset(struct kvm_vcpu *vcpu, bool init_event)  { -	struct kvm_lapic *apic; +	struct kvm_lapic *apic = vcpu->arch.apic;  	int i; -	apic_debug("%s\n", __func__); +	if (!apic) +		return; -	ASSERT(vcpu); -	apic = vcpu->arch.apic; -	ASSERT(apic != NULL); +	apic_debug("%s\n", __func__);  	/* Stop the timer in case it's a reset to an active apic */  	hrtimer_cancel(&apic->lapic_timer.timer); @@ -2165,7 +2164,6 @@ int kvm_create_lapic(struct kvm_vcpu *vcpu)  	 */  	vcpu->arch.apic_base = MSR_IA32_APICBASE_ENABLE;  	static_key_slow_inc(&apic_sw_disabled.key); /* sw disabled at reset */ -	kvm_lapic_reset(vcpu, false);  	kvm_iodevice_init(&apic->dev, &apic_mmio_ops);  	return 0; @@ -2569,7 +2567,6 @@ void kvm_apic_accept_events(struct kvm_vcpu *vcpu)  	pe = xchg(&apic->pending_events, 0);  	if (test_bit(KVM_APIC_INIT, &pe)) { -		kvm_lapic_reset(vcpu, true);  		kvm_vcpu_reset(vcpu, true);  		if (kvm_vcpu_is_bsp(apic->vcpu))  			vcpu->arch.mp_state = KVM_MP_STATE_RUNNABLE;  |