mirror of
https://github.com/adulau/aha.git
synced 2025-01-03 22:53:18 +00:00
KVM: Fix pit memory leak if unable to allocate irq source id
Reported-By: Daniel Marjamäki <danielm77@spray.se> Signed-off-by: Avi Kivity <avi@qumranet.com>
This commit is contained in:
parent
c60ff51eb2
commit
e17d1dc086
1 changed files with 3 additions and 1 deletions
|
@ -548,8 +548,10 @@ struct kvm_pit *kvm_create_pit(struct kvm *kvm)
|
||||||
mutex_lock(&kvm->lock);
|
mutex_lock(&kvm->lock);
|
||||||
pit->irq_source_id = kvm_request_irq_source_id(kvm);
|
pit->irq_source_id = kvm_request_irq_source_id(kvm);
|
||||||
mutex_unlock(&kvm->lock);
|
mutex_unlock(&kvm->lock);
|
||||||
if (pit->irq_source_id < 0)
|
if (pit->irq_source_id < 0) {
|
||||||
|
kfree(pit);
|
||||||
return NULL;
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
mutex_init(&pit->pit_state.lock);
|
mutex_init(&pit->pit_state.lock);
|
||||||
mutex_lock(&pit->pit_state.lock);
|
mutex_lock(&pit->pit_state.lock);
|
||||||
|
|
Loading…
Reference in a new issue