Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit e504c909 authored by Anthoine Bourgeois's avatar Anthoine Bourgeois Committed by Paolo Bonzini
Browse files

kvm, vmx: Fix lazy FPU on nested guest



If a nested guest does a NM fault but its CR0 doesn't contain the TS
flag (because it was already cleared by the guest with L1 aid) then we
have to activate FPU ourselves in L0 and then continue to L2. If TS flag
is set then we fallback on the previous behavior, forward the fault to
L1 if it asked for.

Signed-off-by: default avatarAnthoine Bourgeois <bourgeois@bertin.fr>
Signed-off-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
parent ede58222
Loading
Loading
Loading
Loading
+3 −0
Original line number Diff line number Diff line
@@ -6643,6 +6643,9 @@ static bool nested_vmx_exit_handled(struct kvm_vcpu *vcpu)
			return 0;
		else if (is_page_fault(intr_info))
			return enable_ept;
		else if (is_no_device(intr_info) &&
			 !(nested_read_cr0(vmcs12) & X86_CR0_TS))
			return 0;
		return vmcs12->exception_bitmap &
				(1u << (intr_info & INTR_INFO_VECTOR_MASK));
	case EXIT_REASON_EXTERNAL_INTERRUPT: