Commit 19483d14 authored by Avi Kivity's avatar Avi Kivity

KVM: PPC: Centralize locking of arch specific vcpu ioctls

Signed-off-by: default avatarAvi Kivity <avi@redhat.com>
parent bc923cc9
...@@ -512,15 +512,17 @@ long kvm_arch_vcpu_ioctl(struct file *filp, ...@@ -512,15 +512,17 @@ long kvm_arch_vcpu_ioctl(struct file *filp,
void __user *argp = (void __user *)arg; void __user *argp = (void __user *)arg;
long r; long r;
switch (ioctl) { if (ioctl == KVM_INTERRUPT) {
case KVM_INTERRUPT: {
struct kvm_interrupt irq; struct kvm_interrupt irq;
r = -EFAULT; r = -EFAULT;
if (copy_from_user(&irq, argp, sizeof(irq))) if (copy_from_user(&irq, argp, sizeof(irq)))
goto out; goto out_nolock;
r = kvm_vcpu_ioctl_interrupt(vcpu, &irq); r = kvm_vcpu_ioctl_interrupt(vcpu, &irq);
break; goto out_nolock;
} }
vcpu_load(vcpu);
switch (ioctl) {
case KVM_ENABLE_CAP: case KVM_ENABLE_CAP:
{ {
struct kvm_enable_cap cap; struct kvm_enable_cap cap;
...@@ -535,6 +537,8 @@ long kvm_arch_vcpu_ioctl(struct file *filp, ...@@ -535,6 +537,8 @@ long kvm_arch_vcpu_ioctl(struct file *filp,
} }
out: out:
vcpu_put(vcpu);
out_nolock:
return r; return r;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment