x86: Update xen-detect utility to scan for Xen signature in CPUID space.
authorKeir Fraser <keir.fraser@citrix.com>
Tue, 16 Dec 2008 12:04:13 +0000 (12:04 +0000)
committerKeir Fraser <keir.fraser@citrix.com>
Tue, 16 Dec 2008 12:04:13 +0000 (12:04 +0000)
Signed-off-by: Keir Fraser <keir.fraser@citrix.com>
tools/misc/xen-detect.c

index c918945f812a781a06d623fe30d1bde93bc21939..c50cf185accd86e758ece6dcfbf0d10166d0fb25 100644 (file)
@@ -50,17 +50,25 @@ static int check_for_xen(void)
 {
     uint32_t eax, ebx, ecx, edx;
     char signature[13];
+    uint32_t base;
 
-    cpuid(0x40000000, &eax, &ebx, &ecx, &edx);
-    *(uint32_t *)(signature + 0) = ebx;
-    *(uint32_t *)(signature + 4) = ecx;
-    *(uint32_t *)(signature + 8) = edx;
-    signature[12] = '\0';
+    for ( base = 0x40000000; base < 0x40001000; base += 0x100 )
+    {
+        cpuid(base, &eax, &ebx, &ecx, &edx);
 
-    if ( strcmp("XenVMMXenVMM", signature) || (eax < 0x40000002) )
-        return 0;
+        *(uint32_t *)(signature + 0) = ebx;
+        *(uint32_t *)(signature + 4) = ecx;
+        *(uint32_t *)(signature + 8) = edx;
+        signature[12] = '\0';
+
+        if ( !strcmp("XenVMMXenVMM", signature) && (eax >= (base + 2)) )
+            goto found;
+    }
+
+    return 0;
 
-    cpuid(0x40000001, &eax, &ebx, &ecx, &edx);
+ found:
+    cpuid(base + 1, &eax, &ebx, &ecx, &edx);
     printf("Running in %s context on Xen v%d.%d.\n",
            pv_context ? "PV" : "HVM", (uint16_t)(eax >> 16), (uint16_t)eax);
     return 1;