提交 ea85c9e4 编写于 作者: E Eduardo Habkost 提交者: Marcelo Tosatti

i386: kvm: mask cpuid_kvm_features earlier

Instead of masking the KVM feature bits very late (while building the
KVM_SET_CPUID2 data), mask it out on env->cpuid_kvm_features, at the
same point where the other feature words are masked out.
Signed-off-by: NEduardo Habkost <ehabkost@redhat.com>
Signed-off-by: NMarcelo Tosatti <mtosatti@redhat.com>
上级 41e5e76d
...@@ -428,6 +428,9 @@ int kvm_arch_init_vcpu(CPUX86State *env) ...@@ -428,6 +428,9 @@ int kvm_arch_init_vcpu(CPUX86State *env)
env->cpuid_svm_features &= kvm_arch_get_supported_cpuid(s, 0x8000000A, env->cpuid_svm_features &= kvm_arch_get_supported_cpuid(s, 0x8000000A,
0, R_EDX); 0, R_EDX);
env->cpuid_kvm_features &=
kvm_arch_get_supported_cpuid(s, KVM_CPUID_FEATURES, 0, R_EAX);
cpuid_i = 0; cpuid_i = 0;
/* Paravirtualization CPUIDs */ /* Paravirtualization CPUIDs */
...@@ -448,8 +451,7 @@ int kvm_arch_init_vcpu(CPUX86State *env) ...@@ -448,8 +451,7 @@ int kvm_arch_init_vcpu(CPUX86State *env)
c = &cpuid_data.entries[cpuid_i++]; c = &cpuid_data.entries[cpuid_i++];
memset(c, 0, sizeof(*c)); memset(c, 0, sizeof(*c));
c->function = KVM_CPUID_FEATURES; c->function = KVM_CPUID_FEATURES;
c->eax = env->cpuid_kvm_features & c->eax = env->cpuid_kvm_features;
kvm_arch_get_supported_cpuid(s, KVM_CPUID_FEATURES, 0, R_EAX);
if (hyperv_enabled()) { if (hyperv_enabled()) {
memcpy(signature, "Hv#1\0\0\0\0\0\0\0\0", 12); memcpy(signature, "Hv#1\0\0\0\0\0\0\0\0", 12);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册