Hi Avi,
  Attached is the patch for the bugfix1, as we discussed in the earlier
email.


For cpuid leaf 0xb the bits 8-15 in ECX register define the end of
counting leaf.
The previous code was using bits 0-7 for this purpose, which is a bug.
    
Signed-off-by: Nitin A Kamble <[EMAIL PROTECTED]>


Please Apply,
Thanks & Regards,
Nitin
commit 96ab287a9d90fc4c04438f6943b36049bbdfe854
Author: Nitin A Kamble <[EMAIL PROTECTED]>
Date:   Wed Nov 5 15:28:13 2008 -0800

    For cpuid leaf 0xb the bits 8-15 in ECX register define the end of counting leaf.
    The previous code was using bits 0-7 for this purpose, which is a bug.
    
    Signed-off-by: Nitin A Kamble <[EMAIL PROTECTED]>

diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c
index 38f79b6..7ac7d5f 100644
--- a/arch/x86/kvm/x86.c
+++ b/arch/x86/kvm/x86.c
@@ -1276,7 +1276,7 @@ static void do_cpuid_ent(struct kvm_cpuid_entry2 *entry, u32 function,
 		entry->flags |= KVM_CPUID_FLAG_SIGNIFCANT_INDEX;
 		/* read more entries until level_type is zero */
 		for (i = 1; *nent < maxnent; ++i) {
-			level_type = entry[i - 1].ecx & 0xff;
+			level_type = entry[i - 1].ecx & 0xff00;
 			if (!level_type)
 				break;
 			do_cpuid_1_ent(&entry[i], function, i);

Attachment: signature.asc
Description: This is a digitally signed message part

Reply via email to