kvm, vmx: Really fix lazy FPU on nested guest
authorPaolo Bonzini <[email protected]>
Thu, 27 Feb 2014 21:54:11 +0000 (22:54 +0100)
committerPaolo Bonzini <[email protected]>
Thu, 27 Feb 2014 21:54:11 +0000 (22:54 +0100)
commit1b385cbdd74aa803e966e01e5fe49490d6044e30
treeba74b3cac9727b3cacda97775729269b7f92781e
parenta08d3b3b99efd509133946056531cdf8f3a0c09b
kvm, vmx: Really fix lazy FPU on nested guest

Commit e504c9098ed6 (kvm, vmx: Fix lazy FPU on nested guest, 2013-11-13)
highlighted a real problem, but the fix was subtly wrong.

nested_read_cr0 is the CR0 as read by L2, but here we want to look at
the CR0 value reflecting L1's setup.  In other words, L2 might think
that TS=0 (so nested_read_cr0 has the bit clear); but if L1 is actually
running it with TS=1, we should inject the fault into L1.

The effective value of CR0 in L2 is contained in vmcs12->guest_cr0, use
it.

Fixes: e504c9098ed6acd9e1079c5e10e4910724ad429f
Reported-by: Kashyap Chamarty <[email protected]>
Reported-by: Stefan Bader <[email protected]>
Tested-by: Kashyap Chamarty <[email protected]>
Tested-by: Anthoine Bourgeois <[email protected]>
Cc: [email protected]
Signed-off-by: Paolo Bonzini <[email protected]>
arch/x86/kvm/vmx.c