aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/hv
diff options
context:
space:
mode:
authorJason Wang <jasowang@redhat.com>2012-08-31 01:32:44 -0400
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2012-09-04 18:55:34 -0400
commit1f94ea8181a9305a5d5cf635a6a4e9ac8ee3d2c3 (patch)
tree995ce59ace664ddcbab58a4042dac1b8e8e346f4 /drivers/hv
parent82aceae4f0d42f03d9ad7d1e90389e731153898f (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.c25
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 */
726static 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
744static int __init hv_acpi_init(void) 723static 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);