diff options
author | Jan Kiszka <jan.kiszka@siemens.com> | 2013-04-14 06:12:50 -0400 |
---|---|---|
committer | Gleb Natapov <gleb@redhat.com> | 2013-04-14 11:27:10 -0400 |
commit | c0d1c770c05ac7051df86914f9627b68f29c1d67 (patch) | |
tree | e33fd8d4e5728b1afec04f6ec62d3649e32781b5 | |
parent | e8457c67a4ec1268ec616bd8be1d9f1cc20f1493 (diff) |
KVM: nVMX: Avoid reading VM_EXIT_INTR_ERROR_CODE needlessly on nested exits
We only need to update vm_exit_intr_error_code if there is a valid exit
interruption information and it comes with a valid error code.
Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com>
Signed-off-by: Gleb Natapov <gleb@redhat.com>
-rw-r--r-- | arch/x86/kvm/vmx.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/arch/x86/kvm/vmx.c b/arch/x86/kvm/vmx.c index 5e6391112275..71755573b7ca 100644 --- a/arch/x86/kvm/vmx.c +++ b/arch/x86/kvm/vmx.c | |||
@@ -7426,7 +7426,11 @@ static void prepare_vmcs12(struct kvm_vcpu *vcpu, struct vmcs12 *vmcs12) | |||
7426 | vmcs12->exit_qualification = vmcs_readl(EXIT_QUALIFICATION); | 7426 | vmcs12->exit_qualification = vmcs_readl(EXIT_QUALIFICATION); |
7427 | 7427 | ||
7428 | vmcs12->vm_exit_intr_info = vmcs_read32(VM_EXIT_INTR_INFO); | 7428 | vmcs12->vm_exit_intr_info = vmcs_read32(VM_EXIT_INTR_INFO); |
7429 | vmcs12->vm_exit_intr_error_code = vmcs_read32(VM_EXIT_INTR_ERROR_CODE); | 7429 | if ((vmcs12->vm_exit_intr_info & |
7430 | (INTR_INFO_VALID_MASK | INTR_INFO_DELIVER_CODE_MASK)) == | ||
7431 | (INTR_INFO_VALID_MASK | INTR_INFO_DELIVER_CODE_MASK)) | ||
7432 | vmcs12->vm_exit_intr_error_code = | ||
7433 | vmcs_read32(VM_EXIT_INTR_ERROR_CODE); | ||
7430 | vmcs12->idt_vectoring_info_field = 0; | 7434 | vmcs12->idt_vectoring_info_field = 0; |
7431 | vmcs12->vm_exit_instruction_len = vmcs_read32(VM_EXIT_INSTRUCTION_LEN); | 7435 | vmcs12->vm_exit_instruction_len = vmcs_read32(VM_EXIT_INSTRUCTION_LEN); |
7432 | vmcs12->vmx_instruction_info = vmcs_read32(VMX_INSTRUCTION_INFO); | 7436 | vmcs12->vmx_instruction_info = vmcs_read32(VMX_INSTRUCTION_INFO); |