Skip to content

Commit c9155eb

Browse files
committed
KVM: x86: Unpack msr_data structure prior to calling kvm_apic_set_base()
Pass in the new value and "host initiated" as separate parameters to kvm_apic_set_base(), as forcing the KVM_SET_SREGS path to declare and fill an msr_data structure is awkward and kludgy, e.g. __set_sregs_common() doesn't even bother to set the proper MSR index. No functional change intended. Suggested-by: Kai Huang <kai.huang@intel.com> Reviewed-by: Kai Huang <kai.huang@intel.com> Link: https://lore.kernel.org/r/20241101183555.1794700-9-seanjc@google.com Signed-off-by: Sean Christopherson <seanjc@google.com>
1 parent ff6ce56 commit c9155eb

File tree

3 files changed

+8
-11
lines changed

3 files changed

+8
-11
lines changed

arch/x86/kvm/lapic.c

Lines changed: 5 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -2628,23 +2628,23 @@ static void __kvm_apic_set_base(struct kvm_vcpu *vcpu, u64 value)
26282628
}
26292629
}
26302630

2631-
int kvm_apic_set_base(struct kvm_vcpu *vcpu, struct msr_data *msr_info)
2631+
int kvm_apic_set_base(struct kvm_vcpu *vcpu, u64 value, bool host_initiated)
26322632
{
26332633
enum lapic_mode old_mode = kvm_get_apic_mode(vcpu);
2634-
enum lapic_mode new_mode = kvm_apic_mode(msr_info->data);
2634+
enum lapic_mode new_mode = kvm_apic_mode(value);
26352635
u64 reserved_bits = kvm_vcpu_reserved_gpa_bits_raw(vcpu) | 0x2ff |
26362636
(guest_cpuid_has(vcpu, X86_FEATURE_X2APIC) ? 0 : X2APIC_ENABLE);
26372637

2638-
if ((msr_info->data & reserved_bits) != 0 || new_mode == LAPIC_MODE_INVALID)
2638+
if ((value & reserved_bits) != 0 || new_mode == LAPIC_MODE_INVALID)
26392639
return 1;
2640-
if (!msr_info->host_initiated) {
2640+
if (!host_initiated) {
26412641
if (old_mode == LAPIC_MODE_X2APIC && new_mode == LAPIC_MODE_XAPIC)
26422642
return 1;
26432643
if (old_mode == LAPIC_MODE_DISABLED && new_mode == LAPIC_MODE_X2APIC)
26442644
return 1;
26452645
}
26462646

2647-
__kvm_apic_set_base(vcpu, msr_info->data);
2647+
__kvm_apic_set_base(vcpu, value);
26482648
kvm_recalculate_apic_map(vcpu->kvm);
26492649
return 0;
26502650
}

arch/x86/kvm/lapic.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -115,7 +115,7 @@ bool kvm_irq_delivery_to_apic_fast(struct kvm *kvm, struct kvm_lapic *src,
115115
struct kvm_lapic_irq *irq, int *r, struct dest_map *dest_map);
116116
void kvm_apic_send_ipi(struct kvm_lapic *apic, u32 icr_low, u32 icr_high);
117117

118-
int kvm_apic_set_base(struct kvm_vcpu *vcpu, struct msr_data *msr_info);
118+
int kvm_apic_set_base(struct kvm_vcpu *vcpu, u64 value, bool host_initiated);
119119
int kvm_apic_get_state(struct kvm_vcpu *vcpu, struct kvm_lapic_state *s);
120120
int kvm_apic_set_state(struct kvm_vcpu *vcpu, struct kvm_lapic_state *s);
121121
int kvm_lapic_find_highest_irr(struct kvm_vcpu *vcpu);

arch/x86/kvm/x86.c

Lines changed: 2 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -3863,7 +3863,7 @@ int kvm_set_msr_common(struct kvm_vcpu *vcpu, struct msr_data *msr_info)
38633863
case MSR_MTRRdefType:
38643864
return kvm_mtrr_set_msr(vcpu, msr, data);
38653865
case MSR_IA32_APICBASE:
3866-
return kvm_apic_set_base(vcpu, msr_info);
3866+
return kvm_apic_set_base(vcpu, data, msr_info->host_initiated);
38673867
case APIC_BASE_MSR ... APIC_BASE_MSR + 0xff:
38683868
return kvm_x2apic_msr_write(vcpu, msr, data);
38693869
case MSR_IA32_TSC_DEADLINE:
@@ -11870,16 +11870,13 @@ static bool kvm_is_valid_sregs(struct kvm_vcpu *vcpu, struct kvm_sregs *sregs)
1187011870
static int __set_sregs_common(struct kvm_vcpu *vcpu, struct kvm_sregs *sregs,
1187111871
int *mmu_reset_needed, bool update_pdptrs)
1187211872
{
11873-
struct msr_data apic_base_msr;
1187411873
int idx;
1187511874
struct desc_ptr dt;
1187611875

1187711876
if (!kvm_is_valid_sregs(vcpu, sregs))
1187811877
return -EINVAL;
1187911878

11880-
apic_base_msr.data = sregs->apic_base;
11881-
apic_base_msr.host_initiated = true;
11882-
if (kvm_apic_set_base(vcpu, &apic_base_msr))
11879+
if (kvm_apic_set_base(vcpu, sregs->apic_base, true))
1188311880
return -EINVAL;
1188411881

1188511882
if (vcpu->arch.guest_state_protected)

0 commit comments

Comments
 (0)