KVM: async_pf: Allow to wait for outstanding work
On s390 we are not able to cancel work. Instead we will flush the work and wait for completion. Signed-off-by: Dominik Dingel <dingel@linux.vnet.ibm.com> Signed-off-by: Christian Borntraeger <borntraeger@de.ibm.com>
This commit is contained in:
parent
e0ead41a6d
commit
9f2ceda49c
|
@ -113,11 +113,16 @@ void kvm_clear_async_pf_completion_queue(struct kvm_vcpu *vcpu)
|
||||||
list_entry(vcpu->async_pf.queue.next,
|
list_entry(vcpu->async_pf.queue.next,
|
||||||
typeof(*work), queue);
|
typeof(*work), queue);
|
||||||
list_del(&work->queue);
|
list_del(&work->queue);
|
||||||
|
|
||||||
|
#ifdef CONFIG_KVM_ASYNC_PF_SYNC
|
||||||
|
flush_work(&work->work);
|
||||||
|
#else
|
||||||
if (cancel_work_sync(&work->work)) {
|
if (cancel_work_sync(&work->work)) {
|
||||||
mmdrop(work->mm);
|
mmdrop(work->mm);
|
||||||
kvm_put_kvm(vcpu->kvm); /* == work->vcpu->kvm */
|
kvm_put_kvm(vcpu->kvm); /* == work->vcpu->kvm */
|
||||||
kmem_cache_free(async_pf_cache, work);
|
kmem_cache_free(async_pf_cache, work);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
spin_lock(&vcpu->async_pf.lock);
|
spin_lock(&vcpu->async_pf.lock);
|
||||||
|
|
Loading…
Reference in New Issue