]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
KVM: PPC: BookE: Add check_requests helper function
authorAlexander Graf <agraf@suse.de>
Wed, 8 Aug 2012 18:31:13 +0000 (20:31 +0200)
committerAlexander Graf <agraf@suse.de>
Tue, 14 Aug 2012 22:29:02 +0000 (00:29 +0200)
We need a central place to check for pending requests in. Add one that
only does the timer check we already do in a different place.

Later, this central function can be extended by more checks.

Signed-off-by: Alexander Graf <agraf@suse.de>
arch/powerpc/kvm/booke.c

index 1d4ce9a80f557d76e0ce37bd57db88b172ee7b5d..bcf87fe891797de569db22fc333be6c8ed1a1f41 100644 (file)
@@ -419,13 +419,6 @@ static void kvmppc_core_check_exceptions(struct kvm_vcpu *vcpu)
        unsigned long *pending = &vcpu->arch.pending_exceptions;
        unsigned int priority;
 
-       if (vcpu->requests) {
-               if (kvm_check_request(KVM_REQ_PENDING_TIMER, vcpu)) {
-                       smp_mb();
-                       update_timer_ints(vcpu);
-               }
-       }
-
        priority = __ffs(*pending);
        while (priority < BOOKE_IRQPRIO_MAX) {
                if (kvmppc_booke_irqprio_deliver(vcpu, priority))
@@ -461,6 +454,14 @@ int kvmppc_core_prepare_to_enter(struct kvm_vcpu *vcpu)
        return r;
 }
 
+static void kvmppc_check_requests(struct kvm_vcpu *vcpu)
+{
+       if (vcpu->requests) {
+               if (kvm_check_request(KVM_REQ_PENDING_TIMER, vcpu))
+                       update_timer_ints(vcpu);
+       }
+}
+
 /*
  * Common checks before entering the guest world.  Call with interrupts
  * disabled.
@@ -485,6 +486,15 @@ static int kvmppc_prepare_to_enter(struct kvm_vcpu *vcpu)
                        break;
                }
 
+               smp_mb();
+               if (vcpu->requests) {
+                       /* Make sure we process requests preemptable */
+                       local_irq_enable();
+                       kvmppc_check_requests(vcpu);
+                       local_irq_disable();
+                       continue;
+               }
+
                if (kvmppc_core_prepare_to_enter(vcpu)) {
                        /* interrupts got enabled in between, so we
                           are back at square 1 */