if (to_vmx(vcpu)->exit_reason.enclave_mode)
                vmcs12->vm_exit_reason |= VMX_EXIT_REASONS_SGX_ENCLAVE_MODE;
        vmcs12->exit_qualification = exit_qualification;
-       vmcs12->vm_exit_intr_info = exit_intr_info;
-
-       vmcs12->idt_vectoring_info_field = 0;
-       vmcs12->vm_exit_instruction_len = vmcs_read32(VM_EXIT_INSTRUCTION_LEN);
-       vmcs12->vmx_instruction_info = vmcs_read32(VMX_INSTRUCTION_INFO);
 
+       /*
+        * On VM-Exit due to a failed VM-Entry, the VMCS isn't marked launched
+        * and only EXIT_REASON and EXIT_QUALIFICATION are updated, all other
+        * exit info fields are unmodified.
+        */
        if (!(vmcs12->vm_exit_reason & VMX_EXIT_REASONS_FAILED_VMENTRY)) {
                vmcs12->launch_state = 1;
 
                 * Transfer the event that L0 or L1 may wanted to inject into
                 * L2 to IDT_VECTORING_INFO_FIELD.
                 */
+               vmcs12->idt_vectoring_info_field = 0;
                vmcs12_save_pending_event(vcpu, vmcs12);
 
+               vmcs12->vm_exit_intr_info = exit_intr_info;
+               vmcs12->vm_exit_instruction_len = vmcs_read32(VM_EXIT_INSTRUCTION_LEN);
+               vmcs12->vmx_instruction_info = vmcs_read32(VMX_INSTRUCTION_INFO);
+
                /*
                 * According to spec, there's no need to store the guest's
                 * MSRs if the exit is due to a VM-entry failure that occurs