linux-mips
[Top] [All Lists]

[PATCH v3 02/16] KVM: Prepare for moving vcpu_load/vcpu_put into arch sp

To: kvm@vger.kernel.org
Subject: [PATCH v3 02/16] KVM: Prepare for moving vcpu_load/vcpu_put into arch specific code
From: Christoffer Dall <cdall@kernel.org>
Date: Mon, 4 Dec 2017 21:35:24 +0100
Cc: Andrew Jones <drjones@redhat.com>, Christoffer Dall <christoffer.dall@linaro.org>, Paolo Bonzini <pbonzini@redhat.com>, Radim Krčmář <rkrcmar@redhat.com>, Marc Zyngier <marc.zyngier@arm.com>, kvmarm@lists.cs.columbia.edu, linux-arm-kernel@lists.infradead.org, James Hogan <jhogan@kernel.org>, linux-mips@linux-mips.org, Paul Mackerras <paulus@ozlabs.org>, kvm-ppc@vger.kernel.org, Christian Borntraeger <borntraeger@de.ibm.com>, Cornelia Huck <cohuck@redhat.com>, linux-s390@vger.kernel.org
Dkim-signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=christofferdall-dk.20150623.gappssmtp.com; s=20150623; h=sender:from:to:cc:subject:date:message-id:in-reply-to:references; bh=H3UHU6SKbUaYY+fJMVRFGAOcJOcW4NAOt6j9Jv1qXKw=; b=hkyyIOgNiD2yk/QiH/b+ZJ7bja7odRW6fhLeq4vgJnhFUk2R88fLvHgC4F0jZTP2yz g0SW2fbYTDFzw3ek2jtatoLIq3AOzjBzcqhDpbiWPbQBrEbglZfWaZ3hkI9MpOtJgVXm UYLcHUriynwBE2BJvAyniPBQ0XPLbk+Fk9Ledy/T8Xi2Zy0Tfs4yamv5fyx0MuK6cduZ KTOO8rBSNjr3eif7G/nL/FW9E9ye8mofVeCJnOgfxpxdY1ROLmEabYkdSwVKw2se2BhR 9JesGNFfhdvHYNJvjiMaeNILL4xcXA+nATFysw5jxMAoJzOEVrfPAMGVRqy/u3AXHpD8 9hcw==
In-reply-to: <20171204203538.8370-1-cdall@kernel.org>
List-archive: <http://www.linux-mips.org/archives/linux-mips/>
List-help: <mailto:ecartis@linux-mips.org?Subject=help>
List-id: linux-mips <linux-mips.eddie.linux-mips.org>
List-owner: <mailto:ralf@linux-mips.org>
List-post: <mailto:linux-mips@linux-mips.org>
List-software: Ecartis version 1.0.0
List-subscribe: <mailto:ecartis@linux-mips.org?subject=subscribe%20linux-mips>
List-unsubscribe: <mailto:ecartis@linux-mips.org?subject=unsubscribe%20linux-mips>
Original-recipient: rfc822;linux-mips@linux-mips.org
References: <20171204203538.8370-1-cdall@kernel.org>
Sender: linux-mips-bounce@linux-mips.org
From: Christoffer Dall <christoffer.dall@linaro.org>

In preparation for moving calls to vcpu_load() and vcpu_put() into the
architecture specific implementations of the KVM vcpu ioctls, move the
calls in the main kvm_vcpu_ioctl() dispatcher function to each case
of the ioctl select statement.  This allows us to move the vcpu_load()
and vcpu_put() calls into architecture specific implementations of vcpu
ioctls, one by one.

Reviewed-by: David Hildenbrand <david@redhat.com>
Signed-off-by: Christoffer Dall <christoffer.dall@linaro.org>
---
 virt/kvm/kvm_main.c | 26 ++++++++++++++++++++++++--
 1 file changed, 24 insertions(+), 2 deletions(-)

diff --git a/virt/kvm/kvm_main.c b/virt/kvm/kvm_main.c
index 39961fb8aef7..480b16c48f6b 100644
--- a/virt/kvm/kvm_main.c
+++ b/virt/kvm/kvm_main.c
@@ -2525,13 +2525,13 @@ static long kvm_vcpu_ioctl(struct file *filp,
 
        if (mutex_lock_killable(&vcpu->mutex))
                return -EINTR;
-       vcpu_load(vcpu);
        switch (ioctl) {
        case KVM_RUN: {
                struct pid *oldpid;
                r = -EINVAL;
                if (arg)
                        goto out;
+               vcpu_load(vcpu);
                oldpid = rcu_access_pointer(vcpu->pid);
                if (unlikely(oldpid != current->pids[PIDTYPE_PID].pid)) {
                        /* The thread running this VCPU changed. */
@@ -2543,6 +2543,7 @@ static long kvm_vcpu_ioctl(struct file *filp,
                        put_pid(oldpid);
                }
                r = kvm_arch_vcpu_ioctl_run(vcpu, vcpu->run);
+               vcpu_put(vcpu);
                trace_kvm_userspace_exit(vcpu->run->exit_reason, r);
                break;
        }
@@ -2553,7 +2554,9 @@ static long kvm_vcpu_ioctl(struct file *filp,
                kvm_regs = kzalloc(sizeof(struct kvm_regs), GFP_KERNEL);
                if (!kvm_regs)
                        goto out;
+               vcpu_load(vcpu);
                r = kvm_arch_vcpu_ioctl_get_regs(vcpu, kvm_regs);
+               vcpu_put(vcpu);
                if (r)
                        goto out_free1;
                r = -EFAULT;
@@ -2573,7 +2576,9 @@ static long kvm_vcpu_ioctl(struct file *filp,
                        r = PTR_ERR(kvm_regs);
                        goto out;
                }
+               vcpu_load(vcpu);
                r = kvm_arch_vcpu_ioctl_set_regs(vcpu, kvm_regs);
+               vcpu_put(vcpu);
                kfree(kvm_regs);
                break;
        }
@@ -2582,7 +2587,9 @@ static long kvm_vcpu_ioctl(struct file *filp,
                r = -ENOMEM;
                if (!kvm_sregs)
                        goto out;
+               vcpu_load(vcpu);
                r = kvm_arch_vcpu_ioctl_get_sregs(vcpu, kvm_sregs);
+               vcpu_put(vcpu);
                if (r)
                        goto out;
                r = -EFAULT;
@@ -2598,13 +2605,17 @@ static long kvm_vcpu_ioctl(struct file *filp,
                        kvm_sregs = NULL;
                        goto out;
                }
+               vcpu_load(vcpu);
                r = kvm_arch_vcpu_ioctl_set_sregs(vcpu, kvm_sregs);
+               vcpu_put(vcpu);
                break;
        }
        case KVM_GET_MP_STATE: {
                struct kvm_mp_state mp_state;
 
+               vcpu_load(vcpu);
                r = kvm_arch_vcpu_ioctl_get_mpstate(vcpu, &mp_state);
+               vcpu_put(vcpu);
                if (r)
                        goto out;
                r = -EFAULT;
@@ -2619,7 +2630,9 @@ static long kvm_vcpu_ioctl(struct file *filp,
                r = -EFAULT;
                if (copy_from_user(&mp_state, argp, sizeof(mp_state)))
                        goto out;
+               vcpu_load(vcpu);
                r = kvm_arch_vcpu_ioctl_set_mpstate(vcpu, &mp_state);
+               vcpu_put(vcpu);
                break;
        }
        case KVM_TRANSLATE: {
@@ -2628,7 +2641,9 @@ static long kvm_vcpu_ioctl(struct file *filp,
                r = -EFAULT;
                if (copy_from_user(&tr, argp, sizeof(tr)))
                        goto out;
+               vcpu_load(vcpu);
                r = kvm_arch_vcpu_ioctl_translate(vcpu, &tr);
+               vcpu_put(vcpu);
                if (r)
                        goto out;
                r = -EFAULT;
@@ -2643,7 +2658,9 @@ static long kvm_vcpu_ioctl(struct file *filp,
                r = -EFAULT;
                if (copy_from_user(&dbg, argp, sizeof(dbg)))
                        goto out;
+               vcpu_load(vcpu);
                r = kvm_arch_vcpu_ioctl_set_guest_debug(vcpu, &dbg);
+               vcpu_put(vcpu);
                break;
        }
        case KVM_SET_SIGNAL_MASK: {
@@ -2674,7 +2691,9 @@ static long kvm_vcpu_ioctl(struct file *filp,
                r = -ENOMEM;
                if (!fpu)
                        goto out;
+               vcpu_load(vcpu);
                r = kvm_arch_vcpu_ioctl_get_fpu(vcpu, fpu);
+               vcpu_put(vcpu);
                if (r)
                        goto out;
                r = -EFAULT;
@@ -2690,14 +2709,17 @@ static long kvm_vcpu_ioctl(struct file *filp,
                        fpu = NULL;
                        goto out;
                }
+               vcpu_load(vcpu);
                r = kvm_arch_vcpu_ioctl_set_fpu(vcpu, fpu);
+               vcpu_put(vcpu);
                break;
        }
        default:
+               vcpu_load(vcpu);
                r = kvm_arch_vcpu_ioctl(filp, ioctl, arg);
+               vcpu_put(vcpu);
        }
 out:
-       vcpu_put(vcpu);
        mutex_unlock(&vcpu->mutex);
        kfree(fpu);
        kfree(kvm_sregs);
-- 
2.14.2


<Prev in Thread] Current Thread [Next in Thread>