提交 a8bc284e 编写于 作者: J Jim Mattson 提交者: Paolo Bonzini

kvm: nVMX: Refactor handle_vmptrld()

Handle_vmptrld is split into two parts: the part that handles the
VMPTRLD instruction, and the part that establishes the current VMCS
pointer.  The latter will be used when restoring the checkpointed state
of a vCPU that had a valid VMCS pointer when a snapshot was taken.
Signed-off-by: NJim Mattson <jmattson@google.com>
Signed-off-by: NPaolo Bonzini <pbonzini@redhat.com>
上级 e29acc55
...@@ -7678,6 +7678,18 @@ static int handle_vmwrite(struct kvm_vcpu *vcpu) ...@@ -7678,6 +7678,18 @@ static int handle_vmwrite(struct kvm_vcpu *vcpu)
return kvm_skip_emulated_instruction(vcpu); return kvm_skip_emulated_instruction(vcpu);
} }
static void set_current_vmptr(struct vcpu_vmx *vmx, gpa_t vmptr)
{
vmx->nested.current_vmptr = vmptr;
if (enable_shadow_vmcs) {
vmcs_set_bits(SECONDARY_VM_EXEC_CONTROL,
SECONDARY_EXEC_SHADOW_VMCS);
vmcs_write64(VMCS_LINK_POINTER,
__pa(vmx->vmcs01.shadow_vmcs));
vmx->nested.sync_shadow_vmcs = true;
}
}
/* Emulate the VMPTRLD instruction */ /* Emulate the VMPTRLD instruction */
static int handle_vmptrld(struct kvm_vcpu *vcpu) static int handle_vmptrld(struct kvm_vcpu *vcpu)
{ {
...@@ -7708,7 +7720,6 @@ static int handle_vmptrld(struct kvm_vcpu *vcpu) ...@@ -7708,7 +7720,6 @@ static int handle_vmptrld(struct kvm_vcpu *vcpu)
} }
nested_release_vmcs12(vmx); nested_release_vmcs12(vmx);
vmx->nested.current_vmptr = vmptr;
vmx->nested.current_vmcs12 = new_vmcs12; vmx->nested.current_vmcs12 = new_vmcs12;
vmx->nested.current_vmcs12_page = page; vmx->nested.current_vmcs12_page = page;
/* /*
...@@ -7717,14 +7728,7 @@ static int handle_vmptrld(struct kvm_vcpu *vcpu) ...@@ -7717,14 +7728,7 @@ static int handle_vmptrld(struct kvm_vcpu *vcpu)
*/ */
memcpy(vmx->nested.cached_vmcs12, memcpy(vmx->nested.cached_vmcs12,
vmx->nested.current_vmcs12, VMCS12_SIZE); vmx->nested.current_vmcs12, VMCS12_SIZE);
set_current_vmptr(vmx, vmptr);
if (enable_shadow_vmcs) {
vmcs_set_bits(SECONDARY_VM_EXEC_CONTROL,
SECONDARY_EXEC_SHADOW_VMCS);
vmcs_write64(VMCS_LINK_POINTER,
__pa(vmx->vmcs01.shadow_vmcs));
vmx->nested.sync_shadow_vmcs = true;
}
} }
nested_vmx_succeed(vcpu); nested_vmx_succeed(vcpu);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册