|
@@ -1806,14 +1806,17 @@ void kvm_lapic_set_base(struct kvm_vcpu *vcpu, u64 value)
|
|
u64 old_value = vcpu->arch.apic_base;
|
|
u64 old_value = vcpu->arch.apic_base;
|
|
struct kvm_lapic *apic = vcpu->arch.apic;
|
|
struct kvm_lapic *apic = vcpu->arch.apic;
|
|
|
|
|
|
- if (!apic) {
|
|
|
|
|
|
+ if (!apic)
|
|
value |= MSR_IA32_APICBASE_BSP;
|
|
value |= MSR_IA32_APICBASE_BSP;
|
|
- vcpu->arch.apic_base = value;
|
|
|
|
- return;
|
|
|
|
- }
|
|
|
|
|
|
|
|
vcpu->arch.apic_base = value;
|
|
vcpu->arch.apic_base = value;
|
|
|
|
|
|
|
|
+ if ((old_value ^ value) & MSR_IA32_APICBASE_ENABLE)
|
|
|
|
+ kvm_update_cpuid(vcpu);
|
|
|
|
+
|
|
|
|
+ if (!apic)
|
|
|
|
+ return;
|
|
|
|
+
|
|
/* update jump label if enable bit changes */
|
|
/* update jump label if enable bit changes */
|
|
if ((old_value ^ value) & MSR_IA32_APICBASE_ENABLE) {
|
|
if ((old_value ^ value) & MSR_IA32_APICBASE_ENABLE) {
|
|
if (value & MSR_IA32_APICBASE_ENABLE) {
|
|
if (value & MSR_IA32_APICBASE_ENABLE) {
|