aboutsummaryrefslogtreecommitdiffstats
path: root/arch/s390
diff options
context:
space:
mode:
authorJens Freimann <jfrei@linux.vnet.ibm.com>2014-02-11 07:48:07 -0500
committerChristian Borntraeger <borntraeger@de.ibm.com>2014-03-25 08:27:12 -0400
commit2ed10cc15e7edf2daf22ce807a877a1266e97711 (patch)
tree07af72afb5acc318c9ee4e8c562e74dd324912d4 /arch/s390
parent91880d07fc9b2b6b7a726765039897af99d9ca78 (diff)
KVM: s390: clear local interrupts at cpu initial reset
Empty list of local interrupts when vcpu goes through initial reset to provide a clean state Signed-off-by: Jens Freimann <jfrei@linux.vnet.ibm.com> Signed-off-by: Christian Borntraeger <borntraeger@de.ibm.com>
Diffstat (limited to 'arch/s390')
-rw-r--r--arch/s390/kvm/interrupt.c14
-rw-r--r--arch/s390/kvm/kvm-s390.c1
-rw-r--r--arch/s390/kvm/kvm-s390.h1
3 files changed, 16 insertions, 0 deletions
diff --git a/arch/s390/kvm/interrupt.c b/arch/s390/kvm/interrupt.c
index 79d2e4fa9f9c..05bffd74961f 100644
--- a/arch/s390/kvm/interrupt.c
+++ b/arch/s390/kvm/interrupt.c
@@ -509,6 +509,20 @@ enum hrtimer_restart kvm_s390_idle_wakeup(struct hrtimer *timer)
509 return HRTIMER_NORESTART; 509 return HRTIMER_NORESTART;
510} 510}
511 511
512void kvm_s390_clear_local_irqs(struct kvm_vcpu *vcpu)
513{
514 struct kvm_s390_local_interrupt *li = &vcpu->arch.local_int;
515 struct kvm_s390_interrupt_info *n, *inti = NULL;
516
517 spin_lock_bh(&li->lock);
518 list_for_each_entry_safe(inti, n, &li->list, list) {
519 list_del(&inti->list);
520 kfree(inti);
521 }
522 atomic_set(&li->active, 0);
523 spin_unlock_bh(&li->lock);
524}
525
512void kvm_s390_deliver_pending_interrupts(struct kvm_vcpu *vcpu) 526void kvm_s390_deliver_pending_interrupts(struct kvm_vcpu *vcpu)
513{ 527{
514 struct kvm_s390_local_interrupt *li = &vcpu->arch.local_int; 528 struct kvm_s390_local_interrupt *li = &vcpu->arch.local_int;
diff --git a/arch/s390/kvm/kvm-s390.c b/arch/s390/kvm/kvm-s390.c
index a02979f1e1af..83b79447de55 100644
--- a/arch/s390/kvm/kvm-s390.c
+++ b/arch/s390/kvm/kvm-s390.c
@@ -395,6 +395,7 @@ static void kvm_s390_vcpu_initial_reset(struct kvm_vcpu *vcpu)
395 vcpu->arch.pfault_token = KVM_S390_PFAULT_TOKEN_INVALID; 395 vcpu->arch.pfault_token = KVM_S390_PFAULT_TOKEN_INVALID;
396 kvm_clear_async_pf_completion_queue(vcpu); 396 kvm_clear_async_pf_completion_queue(vcpu);
397 atomic_set_mask(CPUSTAT_STOPPED, &vcpu->arch.sie_block->cpuflags); 397 atomic_set_mask(CPUSTAT_STOPPED, &vcpu->arch.sie_block->cpuflags);
398 kvm_s390_clear_local_irqs(vcpu);
398} 399}
399 400
400int kvm_arch_vcpu_postcreate(struct kvm_vcpu *vcpu) 401int kvm_arch_vcpu_postcreate(struct kvm_vcpu *vcpu)
diff --git a/arch/s390/kvm/kvm-s390.h b/arch/s390/kvm/kvm-s390.h
index ed4750a5bc3c..6311170843b6 100644
--- a/arch/s390/kvm/kvm-s390.h
+++ b/arch/s390/kvm/kvm-s390.h
@@ -129,6 +129,7 @@ enum hrtimer_restart kvm_s390_idle_wakeup(struct hrtimer *timer);
129void kvm_s390_tasklet(unsigned long parm); 129void kvm_s390_tasklet(unsigned long parm);
130void kvm_s390_deliver_pending_interrupts(struct kvm_vcpu *vcpu); 130void kvm_s390_deliver_pending_interrupts(struct kvm_vcpu *vcpu);
131void kvm_s390_deliver_pending_machine_checks(struct kvm_vcpu *vcpu); 131void kvm_s390_deliver_pending_machine_checks(struct kvm_vcpu *vcpu);
132void kvm_s390_clear_local_irqs(struct kvm_vcpu *vcpu);
132int __must_check kvm_s390_inject_vm(struct kvm *kvm, 133int __must_check kvm_s390_inject_vm(struct kvm *kvm,
133 struct kvm_s390_interrupt *s390int); 134 struct kvm_s390_interrupt *s390int);
134int __must_check kvm_s390_inject_vcpu(struct kvm_vcpu *vcpu, 135int __must_check kvm_s390_inject_vcpu(struct kvm_vcpu *vcpu,