diff options
author | Avi Kivity <avi@redhat.com> | 2012-09-20 08:04:41 -0400 |
---|---|---|
committer | Avi Kivity <avi@redhat.com> | 2012-09-20 08:04:41 -0400 |
commit | 1d86b5cc4c6d9a1be1458be3701ac9c915a9706f (patch) | |
tree | 313fee0269d75f0dd5146762dd32c78b8ced4f75 /virt | |
parent | ecba9a52acdf20530d561b7634b80c35c308943a (diff) | |
parent | c5421519f30bd5ed77857a78de6dc8414385e602 (diff) |
Merge branch 'queue' into next
* queue:
KVM: MMU: Eliminate pointless temporary 'ac'
KVM: MMU: Avoid access/dirty update loop if all is well
KVM: MMU: Eliminate eperm temporary
KVM: MMU: Optimize is_last_gpte()
KVM: MMU: Simplify walk_addr_generic() loop
KVM: MMU: Optimize pte permission checks
KVM: MMU: Update accessed and dirty bits after guest pagetable walk
KVM: MMU: Move gpte_access() out of paging_tmpl.h
KVM: MMU: Optimize gpte_access() slightly
KVM: MMU: Push clean gpte write protection out of gpte_access()
KVM: clarify kvmclock documentation
KVM: make processes waiting on vcpu mutex killable
KVM: SVM: Make use of asm.h
KVM: VMX: Make use of asm.h
KVM: VMX: Make lto-friendly
Signed-off-by: Avi Kivity <avi@redhat.com>
Diffstat (limited to 'virt')
-rw-r--r-- | virt/kvm/kvm_main.c | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/virt/kvm/kvm_main.c b/virt/kvm/kvm_main.c index 4fe02d900810..cc3f6dc506e4 100644 --- a/virt/kvm/kvm_main.c +++ b/virt/kvm/kvm_main.c | |||
@@ -131,11 +131,12 @@ bool kvm_is_mmio_pfn(pfn_t pfn) | |||
131 | /* | 131 | /* |
132 | * Switches to specified vcpu, until a matching vcpu_put() | 132 | * Switches to specified vcpu, until a matching vcpu_put() |
133 | */ | 133 | */ |
134 | void vcpu_load(struct kvm_vcpu *vcpu) | 134 | int vcpu_load(struct kvm_vcpu *vcpu) |
135 | { | 135 | { |
136 | int cpu; | 136 | int cpu; |
137 | 137 | ||
138 | mutex_lock(&vcpu->mutex); | 138 | if (mutex_lock_killable(&vcpu->mutex)) |
139 | return -EINTR; | ||
139 | if (unlikely(vcpu->pid != current->pids[PIDTYPE_PID].pid)) { | 140 | if (unlikely(vcpu->pid != current->pids[PIDTYPE_PID].pid)) { |
140 | /* The thread running this VCPU changed. */ | 141 | /* The thread running this VCPU changed. */ |
141 | struct pid *oldpid = vcpu->pid; | 142 | struct pid *oldpid = vcpu->pid; |
@@ -148,6 +149,7 @@ void vcpu_load(struct kvm_vcpu *vcpu) | |||
148 | preempt_notifier_register(&vcpu->preempt_notifier); | 149 | preempt_notifier_register(&vcpu->preempt_notifier); |
149 | kvm_arch_vcpu_load(vcpu, cpu); | 150 | kvm_arch_vcpu_load(vcpu, cpu); |
150 | put_cpu(); | 151 | put_cpu(); |
152 | return 0; | ||
151 | } | 153 | } |
152 | 154 | ||
153 | void vcpu_put(struct kvm_vcpu *vcpu) | 155 | void vcpu_put(struct kvm_vcpu *vcpu) |
@@ -1891,7 +1893,9 @@ static long kvm_vcpu_ioctl(struct file *filp, | |||
1891 | #endif | 1893 | #endif |
1892 | 1894 | ||
1893 | 1895 | ||
1894 | vcpu_load(vcpu); | 1896 | r = vcpu_load(vcpu); |
1897 | if (r) | ||
1898 | return r; | ||
1895 | switch (ioctl) { | 1899 | switch (ioctl) { |
1896 | case KVM_RUN: | 1900 | case KVM_RUN: |
1897 | r = -EINVAL; | 1901 | r = -EINVAL; |