Skip to content

Commit d91060e

Browse files
committed
KVM: x86: Get vcpu->arch.apic_base directly and drop kvm_get_apic_base()
Access KVM's emulated APIC base MSR value directly instead of bouncing through a helper, as there is no reason to add a layer of indirection, and there are other MSRs with a "set" but no "get", e.g. EFER. No functional change intended. Reviewed-by: Kai Huang <kai.huang@intel.com> Reviewed-by: Paolo Bonzini <pbonzini@redhat.com> Link: https://lore.kernel.org/r/20241009181742.1128779-4-seanjc@google.com Link: https://lore.kernel.org/r/20241101183555.1794700-4-seanjc@google.com Signed-off-by: Sean Christopherson <seanjc@google.com>
1 parent 8166d25 commit d91060e

File tree

2 files changed

+4
-10
lines changed

2 files changed

+4
-10
lines changed

arch/x86/kvm/lapic.h

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -117,7 +117,6 @@ bool kvm_irq_delivery_to_apic_fast(struct kvm *kvm, struct kvm_lapic *src,
117117
struct kvm_lapic_irq *irq, int *r, struct dest_map *dest_map);
118118
void kvm_apic_send_ipi(struct kvm_lapic *apic, u32 icr_low, u32 icr_high);
119119

120-
u64 kvm_get_apic_base(struct kvm_vcpu *vcpu);
121120
int kvm_set_apic_base(struct kvm_vcpu *vcpu, struct msr_data *msr_info);
122121
int kvm_apic_get_state(struct kvm_vcpu *vcpu, struct kvm_lapic_state *s);
123122
int kvm_apic_set_state(struct kvm_vcpu *vcpu, struct kvm_lapic_state *s);

arch/x86/kvm/x86.c

Lines changed: 4 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -668,14 +668,9 @@ static void drop_user_return_notifiers(void)
668668
kvm_on_user_return(&msrs->urn);
669669
}
670670

671-
u64 kvm_get_apic_base(struct kvm_vcpu *vcpu)
672-
{
673-
return vcpu->arch.apic_base;
674-
}
675-
676671
enum lapic_mode kvm_get_apic_mode(struct kvm_vcpu *vcpu)
677672
{
678-
return kvm_apic_mode(kvm_get_apic_base(vcpu));
673+
return kvm_apic_mode(vcpu->arch.apic_base);
679674
}
680675
EXPORT_SYMBOL_GPL(kvm_get_apic_mode);
681676

@@ -4315,7 +4310,7 @@ int kvm_get_msr_common(struct kvm_vcpu *vcpu, struct msr_data *msr_info)
43154310
msr_info->data = 1 << 24;
43164311
break;
43174312
case MSR_IA32_APICBASE:
4318-
msr_info->data = kvm_get_apic_base(vcpu);
4313+
msr_info->data = vcpu->arch.apic_base;
43194314
break;
43204315
case APIC_BASE_MSR ... APIC_BASE_MSR + 0xff:
43214316
return kvm_x2apic_msr_read(vcpu, msr_info->index, &msr_info->data);
@@ -10173,7 +10168,7 @@ static void post_kvm_run_save(struct kvm_vcpu *vcpu)
1017310168

1017410169
kvm_run->if_flag = kvm_x86_call(get_if_flag)(vcpu);
1017510170
kvm_run->cr8 = kvm_get_cr8(vcpu);
10176-
kvm_run->apic_base = kvm_get_apic_base(vcpu);
10171+
kvm_run->apic_base = vcpu->arch.apic_base;
1017710172

1017810173
kvm_run->ready_for_interrupt_injection =
1017910174
pic_in_kernel(vcpu->kvm) ||
@@ -11725,7 +11720,7 @@ static void __get_sregs_common(struct kvm_vcpu *vcpu, struct kvm_sregs *sregs)
1172511720
sregs->cr4 = kvm_read_cr4(vcpu);
1172611721
sregs->cr8 = kvm_get_cr8(vcpu);
1172711722
sregs->efer = vcpu->arch.efer;
11728-
sregs->apic_base = kvm_get_apic_base(vcpu);
11723+
sregs->apic_base = vcpu->arch.apic_base;
1172911724
}
1173011725

1173111726
static void __get_sregs(struct kvm_vcpu *vcpu, struct kvm_sregs *sregs)

0 commit comments

Comments
 (0)