KVM: x86: introduce sched_in to kvm_x86_ops
authorRadim Krčmář <rkrcmar@redhat.com>
Thu, 21 Aug 2014 16:08:06 +0000 (18:08 +0200)
committerPaolo Bonzini <pbonzini@redhat.com>
Thu, 21 Aug 2014 16:45:22 +0000 (18:45 +0200)
sched_in preempt notifier is available for x86, allow its use in
specific virtualization technlogies as well.

Signed-off-by: Radim Krčmář <rkrcmar@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
arch/x86/include/asm/kvm_host.h
arch/x86/kvm/svm.c
arch/x86/kvm/vmx.c
arch/x86/kvm/x86.c

index 4bda61b582e6dbb51eec2a8e2ecb90962f83ff66..ac0f90e26a0b0312521fabf07c66fceb3031bd2a 100644 (file)
@@ -771,6 +771,8 @@ struct kvm_x86_ops {
        bool (*mpx_supported)(void);
 
        int (*check_nested_events)(struct kvm_vcpu *vcpu, bool external_intr);
+
+       void (*sched_in)(struct kvm_vcpu *kvm, int cpu);
 };
 
 struct kvm_arch_async_pf {
index 1f49c867e72e8aa782d878efe4e201ce11649985..1703aab84a6d0108672c8d8f020ff46111a99924 100644 (file)
@@ -4305,6 +4305,10 @@ static void svm_handle_external_intr(struct kvm_vcpu *vcpu)
        local_irq_enable();
 }
 
+static void svm_sched_in(struct kvm_vcpu *vcpu, int cpu)
+{
+}
+
 static struct kvm_x86_ops svm_x86_ops = {
        .cpu_has_kvm_support = has_svm,
        .disabled_by_bios = is_disabled,
@@ -4405,6 +4409,8 @@ static struct kvm_x86_ops svm_x86_ops = {
 
        .check_intercept = svm_check_intercept,
        .handle_external_intr = svm_handle_external_intr,
+
+       .sched_in = svm_sched_in,
 };
 
 static int __init svm_init(void)
index 286c2835e25c4fd4ba098b8175cc64c1d163f813..7c26533e149cfc07dfa3b22b0d0ea171ba1fe32e 100644 (file)
@@ -8848,6 +8848,10 @@ static int vmx_check_intercept(struct kvm_vcpu *vcpu,
        return X86EMUL_CONTINUE;
 }
 
+void vmx_sched_in(struct kvm_vcpu *vcpu, int cpu)
+{
+}
+
 static struct kvm_x86_ops vmx_x86_ops = {
        .cpu_has_kvm_support = cpu_has_kvm_support,
        .disabled_by_bios = vmx_disabled_by_bios,
@@ -8952,6 +8956,8 @@ static struct kvm_x86_ops vmx_x86_ops = {
        .mpx_supported = vmx_mpx_supported,
 
        .check_nested_events = vmx_check_nested_events,
+
+       .sched_in = vmx_sched_in,
 };
 
 static int __init vmx_init(void)
index 7d43dc7bb906aef057879685cc78f503ce1a4cf8..575d3fc67e7e692c2ff85153f096aa8f5f16986e 100644 (file)
@@ -7173,6 +7173,7 @@ void kvm_arch_vcpu_uninit(struct kvm_vcpu *vcpu)
 
 void kvm_arch_sched_in(struct kvm_vcpu *vcpu, int cpu)
 {
+       kvm_x86_ops->sched_in(vcpu, cpu);
 }
 
 int kvm_arch_init_vm(struct kvm *kvm, unsigned long type)