diff options
author | Jason Wang <jasowang@redhat.com> | 2012-08-31 01:32:44 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2012-09-04 18:55:34 -0400 |
commit | 1f94ea8181a9305a5d5cf635a6a4e9ac8ee3d2c3 (patch) | |
tree | 995ce59ace664ddcbab58a4042dac1b8e8e346f4 /drivers/hv | |
parent | 82aceae4f0d42f03d9ad7d1e90389e731153898f (diff) |
hv: vmbus_drv: detect hyperv through x86_hyper
There are two reasons we need to use x86_hyper instead of
query_hypervisor_presence():
- Not only hyperv but also other hypervisors such as kvm would set
X86_FEATURE_HYTPERVISOR, so query_hypervisor_presence() will return true even
in kvm. This may cause extra delay of 5 seconds before failing the probing in
kvm guest.
- The hypervisor has been detected in init_hypervisor(), so no need to do the
work again.
Signed-off-by: Jason Wang <jasowang@redhat.com>
Cc: Haiyang Zhang <haiyangz@microsoft.com>
Acked-by: K. Y. Srinivasan <kys@microsoft.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/hv')
-rw-r--r-- | drivers/hv/vmbus_drv.c | 25 |
1 files changed, 2 insertions, 23 deletions
diff --git a/drivers/hv/vmbus_drv.c b/drivers/hv/vmbus_drv.c index f40dd57bbec1..8e1a9ec53003 100644 --- a/drivers/hv/vmbus_drv.c +++ b/drivers/hv/vmbus_drv.c | |||
@@ -34,6 +34,7 @@ | |||
34 | #include <linux/completion.h> | 34 | #include <linux/completion.h> |
35 | #include <linux/hyperv.h> | 35 | #include <linux/hyperv.h> |
36 | #include <asm/hyperv.h> | 36 | #include <asm/hyperv.h> |
37 | #include <asm/hypervisor.h> | ||
37 | #include "hyperv_vmbus.h" | 38 | #include "hyperv_vmbus.h" |
38 | 39 | ||
39 | 40 | ||
@@ -719,33 +720,11 @@ static struct acpi_driver vmbus_acpi_driver = { | |||
719 | }, | 720 | }, |
720 | }; | 721 | }; |
721 | 722 | ||
722 | /* | ||
723 | * query_hypervisor_presence | ||
724 | * - Query the cpuid for presence of windows hypervisor | ||
725 | */ | ||
726 | static int query_hypervisor_presence(void) | ||
727 | { | ||
728 | unsigned int eax; | ||
729 | unsigned int ebx; | ||
730 | unsigned int ecx; | ||
731 | unsigned int edx; | ||
732 | unsigned int op; | ||
733 | |||
734 | eax = 0; | ||
735 | ebx = 0; | ||
736 | ecx = 0; | ||
737 | edx = 0; | ||
738 | op = HVCPUID_VERSION_FEATURES; | ||
739 | cpuid(op, &eax, &ebx, &ecx, &edx); | ||
740 | |||
741 | return ecx & HV_PRESENT_BIT; | ||
742 | } | ||
743 | |||
744 | static int __init hv_acpi_init(void) | 723 | static int __init hv_acpi_init(void) |
745 | { | 724 | { |
746 | int ret, t; | 725 | int ret, t; |
747 | 726 | ||
748 | if (!query_hypervisor_presence()) | 727 | if (x86_hyper != &x86_hyper_ms_hyperv) |
749 | return -ENODEV; | 728 | return -ENODEV; |
750 | 729 | ||
751 | init_completion(&probe_event); | 730 | init_completion(&probe_event); |