diff options
| -rw-r--r-- | arch/s390/kvm/interrupt.c | 14 | ||||
| -rw-r--r-- | arch/s390/kvm/kvm-s390.c | 1 | ||||
| -rw-r--r-- | arch/s390/kvm/kvm-s390.h | 1 |
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 | ||
| 512 | void 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 | |||
| 512 | void kvm_s390_deliver_pending_interrupts(struct kvm_vcpu *vcpu) | 526 | void 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 | ||
| 400 | int kvm_arch_vcpu_postcreate(struct kvm_vcpu *vcpu) | 401 | int 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); | |||
| 129 | void kvm_s390_tasklet(unsigned long parm); | 129 | void kvm_s390_tasklet(unsigned long parm); |
| 130 | void kvm_s390_deliver_pending_interrupts(struct kvm_vcpu *vcpu); | 130 | void kvm_s390_deliver_pending_interrupts(struct kvm_vcpu *vcpu); |
| 131 | void kvm_s390_deliver_pending_machine_checks(struct kvm_vcpu *vcpu); | 131 | void kvm_s390_deliver_pending_machine_checks(struct kvm_vcpu *vcpu); |
| 132 | void kvm_s390_clear_local_irqs(struct kvm_vcpu *vcpu); | ||
| 132 | int __must_check kvm_s390_inject_vm(struct kvm *kvm, | 133 | int __must_check kvm_s390_inject_vm(struct kvm *kvm, |
| 133 | struct kvm_s390_interrupt *s390int); | 134 | struct kvm_s390_interrupt *s390int); |
| 134 | int __must_check kvm_s390_inject_vcpu(struct kvm_vcpu *vcpu, | 135 | int __must_check kvm_s390_inject_vcpu(struct kvm_vcpu *vcpu, |
