aboutsummaryrefslogtreecommitdiffstats
path: root/arch/s390
diff options
context:
space:
mode:
authorJens Freimann <jfrei@linux.vnet.ibm.com>2015-06-22 07:20:12 -0400
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2015-07-10 12:49:36 -0400
commit534c9f9886c25221d4f4dd396cd78b67214c1796 (patch)
tree7808cbc83687de64f4004999400e6f4d7be3734d /arch/s390
parent14fe2f14d73609cfdb19b71467d085e5347f7353 (diff)
KVM: s390: clear floating interrupt bitmap and parameters
commit f2ae45edbca7ba5324eef01719ede0151dc5cead upstream. commit 6d3da24141 ("KVM: s390: deliver floating interrupts in order of priority") introduced a regression for the reset handling. We don't clear the bitmap of pending floating interrupts and interrupt parameters. This could result in stale interrupts even after a reset. Let's fix this by clearing the pending bitmap and the parameters for service and machine check interrupts. Signed-off-by: Jens Freimann <jfrei@linux.vnet.ibm.com> Signed-off-by: Christian Borntraeger <borntraeger@de.ibm.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'arch/s390')
-rw-r--r--arch/s390/kvm/interrupt.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/arch/s390/kvm/interrupt.c b/arch/s390/kvm/interrupt.c
index 2836b25f63d3..b745a109bfc1 100644
--- a/arch/s390/kvm/interrupt.c
+++ b/arch/s390/kvm/interrupt.c
@@ -1606,6 +1606,9 @@ void kvm_s390_clear_float_irqs(struct kvm *kvm)
1606 int i; 1606 int i;
1607 1607
1608 spin_lock(&fi->lock); 1608 spin_lock(&fi->lock);
1609 fi->pending_irqs = 0;
1610 memset(&fi->srv_signal, 0, sizeof(fi->srv_signal));
1611 memset(&fi->mchk, 0, sizeof(fi->mchk));
1609 for (i = 0; i < FIRQ_LIST_COUNT; i++) 1612 for (i = 0; i < FIRQ_LIST_COUNT; i++)
1610 clear_irq_list(&fi->lists[i]); 1613 clear_irq_list(&fi->lists[i]);
1611 for (i = 0; i < FIRQ_MAX_COUNT; i++) 1614 for (i = 0; i < FIRQ_MAX_COUNT; i++)