kvm: Only include KVM support for supported kernels
authorAndreas Hansson <andreas.hansson@arm.com>
Wed, 2 Oct 2013 10:08:45 +0000 (06:08 -0400)
committerAndreas Hansson <andreas.hansson@arm.com>
Wed, 2 Oct 2013 10:08:45 +0000 (06:08 -0400)
This patch adds a check to ensure that the KVM API provided by the
running kernel is what we are expecting.

SConstruct

index 863a6cabaf07c509c3f6909f2b75253fcb32575f..298433dd510d9d129a6c724608da0a931e7ba553 100755 (executable)
@@ -936,10 +936,14 @@ if not have_fenv:
     print "Warning: Header file <fenv.h> not found."
     print "         This host has no IEEE FP rounding mode control."
 
-# Check if we should enable KVM-based hardware virtualization
-have_kvm = conf.CheckHeader('linux/kvm.h', '<>')
+# Check if we should enable KVM-based hardware virtualization. The API
+# we rely on exists since version 2.6.36 of the kernel, but somehow
+# the KVM_API_VERSION does not reflect the change. We test for one of
+# the types as a fall back.
+have_kvm = conf.CheckHeader('linux/kvm.h', '<>') and \
+    conf.CheckTypeSize('struct kvm_xsave', '#include <linux/kvm.h>') != 0
 if not have_kvm:
-    print "Info: Header file <linux/kvm.h> not found, " \
+    print "Info: Compatible header file <linux/kvm.h> not found, " \
         "disabling KVM support."
 
 # Check if the requested target ISA is compatible with the host