]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
basic: detect_vm_cpuid: fix hypervisor detection
authorMike Gilbert <floppym@gentoo.org>
Sat, 30 Dec 2017 17:48:20 +0000 (12:48 -0500)
committerLennart Poettering <lennart@poettering.net>
Tue, 2 Jan 2018 11:12:57 +0000 (12:12 +0100)
The __get_cpuid() function only calls __cpuid() if __get_cpuid_max()
returns a value that is less than or equal to the leaf value.

In QEMU/KVM, I found that the special hypervisor leaf value (0x40000000U)
is always larger than the value retured by __get_cpuid_max().

Avoid this problem by calling the __cpuid() macro directly once we have
checked the hypervisor bit from leaf 1.

Fixes: d31b0033b7743393562a2e9d3c1e74afea981c13
src/basic/virt.c

index 2ea3f0749f36c3279b169235f9bb76fcd33c16c3..fe582833a75dda930050a7a465e9cf45e96dd14b 100644 (file)
@@ -78,8 +78,7 @@ static int detect_vm_cpuid(void) {
                 unsigned j;
 
                 /* There is a hypervisor, see what it is */
-                if (__get_cpuid(0x40000000U, &eax, &ebx, &ecx, &edx) == 0)
-                        return VIRTUALIZATION_NONE;
+                __cpuid(0x40000000U, eax, ebx, ecx, edx);
 
                 sig.sig32[0] = ebx;
                 sig.sig32[1] = ecx;