summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlexander Graf <agraf@suse.de>2010-08-05 12:24:40 +0200
committerAvi Kivity <avi@redhat.com>2010-10-24 10:52:14 +0200
commit9ee18b1e08e6a5648aeaaf998eabc72b5304cc17 (patch)
tree8d474d9652d47e5287386e0c6ee6482554ad94a0
parent512ba59ed9c580b5e5575beda0041bb19a641127 (diff)
downloadlwn-9ee18b1e08e6a5648aeaaf998eabc72b5304cc17.tar.gz
lwn-9ee18b1e08e6a5648aeaaf998eabc72b5304cc17.zip
KVM: PPC: Update int_pending also on dequeue
When having a decrementor interrupt pending, the dequeuing happens manually through an mtdec instruction. This instruction simply calls dequeue on that interrupt, so the int_pending hint doesn't get updated. This patch enables updating the int_pending hint also on dequeue, thus correctly enabling guests to stay in guest contexts more often. Signed-off-by: Alexander Graf <agraf@suse.de>
-rw-r--r--arch/powerpc/kvm/book3s.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/arch/powerpc/kvm/book3s.c b/arch/powerpc/kvm/book3s.c
index 02a9cb165d53..7adea6320654 100644
--- a/arch/powerpc/kvm/book3s.c
+++ b/arch/powerpc/kvm/book3s.c
@@ -201,6 +201,9 @@ static void kvmppc_book3s_dequeue_irqprio(struct kvm_vcpu *vcpu,
{
clear_bit(kvmppc_book3s_vec2irqprio(vec),
&vcpu->arch.pending_exceptions);
+
+ if (!vcpu->arch.pending_exceptions)
+ vcpu->arch.shared->int_pending = 0;
}
void kvmppc_book3s_queue_irqprio(struct kvm_vcpu *vcpu, unsigned int vec)