On 04/22/2010 01:57 PM, Joerg Roedel wrote:
This patch adds code to ask the kernel about the svm features it supports for its guests and propagates them to the guest. The new capability is necessary because the old behavior of the kernel was to just return the host svm features but every svm-feature needs emulation in the nested svm kernel code. The new capability indicates that the kernel is aware of that when returning svm cpuid information.
No new capability here.
Signed-off-by: Joerg Roedel<joerg.roedel@xxxxxxx> --- qemu-kvm-x86.c | 14 ++++++++++++-- 1 files changed, 12 insertions(+), 2 deletions(-) diff --git a/qemu-kvm-x86.c b/qemu-kvm-x86.c index 748ff69..6eccd69 100644 --- a/qemu-kvm-x86.c +++ b/qemu-kvm-x86.c @@ -1327,8 +1327,18 @@ int kvm_arch_init_vcpu(CPUState *cenv) qemu_kvm_cpuid_on_env(©); limit = copy.regs[R_EAX]; - for (i = 0x80000000; i<= limit; ++i) - do_cpuid_ent(&cpuid_ent[cpuid_nent++], i, 0,©); + for (i = 0x80000000; i<= limit; ++i) { + do_cpuid_ent(&cpuid_ent[cpuid_nent], i, 0,©); + switch (i) { + case 0x8000000a: + cpuid_ent[cpuid_nent].eax = kvm_arch_get_supported_cpuid(cenv, 0x8000000a, R_EAX); + cpuid_ent[cpuid_nent].ebx = kvm_arch_get_supported_cpuid(cenv, 0x8000000a, R_EBX); + cpuid_ent[cpuid_nent].ebx = kvm_arch_get_supported_cpuid(cenv, 0x8000000a, R_EBX); + cpuid_ent[cpuid_nent].edx = kvm_arch_get_supported_cpuid(cenv, 0x8000000a, R_EDX); + break; + } + cpuid_nent += 1; + }
I don't understand why this is different compared to all other cpuid bits. -- error compiling committee.c: too many arguments to function -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html