Commit 66421c1e authored by Wanpeng Li's avatar Wanpeng Li Committed by Radim Krčmář

KVM: X86: Introduce kvm_get_msr_feature()

Introduce kvm_get_msr_feature() to handle the msrs which are supported
by different vendors and sharing the same emulation logic.

Cc: Paolo Bonzini <pbonzini@redhat.com>
Cc: Radim Krčmář <rkrcmar@redhat.com>
Cc: Liran Alon <liran.alon@oracle.com>
Cc: Nadav Amit <nadav.amit@gmail.com>
Cc: Borislav Petkov <bp@alien8.de>
Cc: Tom Lendacky <thomas.lendacky@amd.com>
Signed-off-by: default avatarWanpeng Li <wanpengli@tencent.com>
Reviewed-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
Signed-off-by: default avatarRadim Krčmář <rkrcmar@redhat.com>
parent d1d93fa9
...@@ -1059,13 +1059,25 @@ static u32 msr_based_features[] = { ...@@ -1059,13 +1059,25 @@ static u32 msr_based_features[] = {
static unsigned int num_msr_based_features; static unsigned int num_msr_based_features;
static int kvm_get_msr_feature(struct kvm_msr_entry *msr)
{
switch (msr->index) {
default:
if (kvm_x86_ops->get_msr_feature(msr))
return 1;
}
return 0;
}
static int do_get_msr_feature(struct kvm_vcpu *vcpu, unsigned index, u64 *data) static int do_get_msr_feature(struct kvm_vcpu *vcpu, unsigned index, u64 *data)
{ {
struct kvm_msr_entry msr; struct kvm_msr_entry msr;
int r;
msr.index = index; msr.index = index;
if (kvm_x86_ops->get_msr_feature(&msr)) r = kvm_get_msr_feature(&msr);
return 1; if (r)
return r;
*data = msr.data; *data = msr.data;
...@@ -4522,7 +4534,7 @@ static void kvm_init_msr_list(void) ...@@ -4522,7 +4534,7 @@ static void kvm_init_msr_list(void)
struct kvm_msr_entry msr; struct kvm_msr_entry msr;
msr.index = msr_based_features[i]; msr.index = msr_based_features[i];
if (kvm_x86_ops->get_msr_feature(&msr)) if (kvm_get_msr_feature(&msr))
continue; continue;
if (j < i) if (j < i)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment