All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] x86,kvm: remove duplicate kvm_put_guest_fpu()
@ 2019-01-30 22:07 Daniel Verkamp
  2019-01-30 22:29 ` [PATCH v2 for-4.14-stable] x86,kvm: remove extra kvm_{get,put}_guest_fpu Daniel Verkamp
  0 siblings, 1 reply; 5+ messages in thread
From: Daniel Verkamp @ 2019-01-30 22:07 UTC (permalink / raw)
  To: stable; +Cc: Rik van Riel, Daniel Verkamp

Commit 4124a4cff344 ("x86,kvm: move qemu/guest FPU switching out
to vcpu_run") applied a patch from upstream, but it appears that it
wasn't backported correctly to 4.14.  The extra out_fpu label and
kvm_put_guest_fpu() added in kvm_arch_vcpu_ioctl_run() result in calling
kvm_put_guest_fpu() twice in a row, corrupting guest state.

Fixes: 4124a4cff344 ("x86,kvm: move qemu/guest FPU switching out to vcpu_run")
Signed-off-by: Daniel Verkamp <dverkamp@chromium.org>
---

I'm unsure if this is the right way to send this fix - there is no
corresponding mainline commit to reference, since the code there is
already correct, and the problem was introduced in the cherry-picked
stable backport.  Please let me know if there's a different process for
fixes to stable-only issues.

 arch/x86/kvm/x86.c | 4 +---
 1 file changed, 1 insertion(+), 3 deletions(-)

diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c
index 130be2efafbe..3e767430d3b2 100644
--- a/arch/x86/kvm/x86.c
+++ b/arch/x86/kvm/x86.c
@@ -7430,7 +7430,7 @@ int kvm_arch_vcpu_ioctl_run(struct kvm_vcpu *vcpu, struct kvm_run *kvm_run)
 		vcpu->arch.complete_userspace_io = NULL;
 		r = cui(vcpu);
 		if (r <= 0)
-			goto out_fpu;
+			goto out;
 	} else
 		WARN_ON(vcpu->arch.pio.count || vcpu->mmio_needed);
 
@@ -7439,8 +7439,6 @@ int kvm_arch_vcpu_ioctl_run(struct kvm_vcpu *vcpu, struct kvm_run *kvm_run)
 	else
 		r = vcpu_run(vcpu);
 
-out_fpu:
-	kvm_put_guest_fpu(vcpu);
 out:
 	kvm_put_guest_fpu(vcpu);
 	post_kvm_run_save(vcpu);
-- 
2.20.1.495.gaa96b0ce6b-goog


^ permalink raw reply related	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2019-01-31 17:14 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2019-01-30 22:07 [PATCH] x86,kvm: remove duplicate kvm_put_guest_fpu() Daniel Verkamp
2019-01-30 22:29 ` [PATCH v2 for-4.14-stable] x86,kvm: remove extra kvm_{get,put}_guest_fpu Daniel Verkamp
2019-01-30 22:42   ` Daniel Verkamp
2019-01-31  7:18   ` Greg KH
2019-01-31 17:14     ` Daniel Verkamp

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.