- Timestamp:
- May 19, 2017 1:02:48 PM (8 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/VBox/VMM/VMMR0/HMSVMR0.cpp
r66961 r66979 4063 4063 { 4064 4064 /* 4065 * If event delivery caused an #VMEXIT that is not an exception (e.g. #NPF) then reflect the original 4066 * exception to the guest after handling the #VMEXIT. 4065 * If delivery of an event caused a #VMEXIT that is not an exception (e.g. #NPF) then we 4066 * end up here. 4067 * 4068 * If the event was: 4069 * - a software interrupt, we can re-execute the instruction which will regenerate 4070 * the event. 4071 * - an NMI, we need to clear NMI blocking and re-inject the NMI. 4072 * - a hardware exception or external interrupt, we re-inject it. 4067 4073 */ 4068 enmRaise = IEMXCPTRAISE_PREV_EVENT; 4069 fRaiseInfo = IEMXCPTRAISEINFO_NONE; 4074 if (pVmcb->ctrl.ExitIntInfo.n.u3Type == SVM_EVENT_SOFTWARE_INT) 4075 { 4076 enmRaise = IEMXCPTRAISE_REEXEC_INSTR; 4077 fRaiseInfo = IEMXCPTRAISEINFO_NONE; 4078 } 4079 else if (pVmcb->ctrl.ExitIntInfo.n.u3Type == SVM_EVENT_NMI) 4080 { 4081 enmRaise = IEMXCPTRAISE_PREV_EVENT; 4082 fRaiseInfo = IEMXCPTRAISEINFO_SOFT_INT_XCPT; 4083 } 4084 else 4085 { 4086 enmRaise = IEMXCPTRAISE_PREV_EVENT; 4087 fRaiseInfo = IEMXCPTRAISEINFO_NONE; 4088 } 4070 4089 } 4071 4090 … … 4087 4106 if (fRaiseInfo & (IEMXCPTRAISEINFO_EXT_INT_PF | IEMXCPTRAISEINFO_NMI_PF)) 4088 4107 pSvmTransient->fVectoringPF = true; 4089 else if (uIdtVector == X86_XCPT_PF) 4108 else if ( uIdtVector == X86_XCPT_PF 4109 && pVmcb->ctrl.ExitIntInfo.n.u3Type == SVM_EVENT_EXCEPTION) 4090 4110 { 4091 4111 /* … … 4101 4121 4102 4122 /** @todo r=michaln: The comment makes no sense with nested paging on! */ 4103 /* If uExitVector is #PF, CR2 value will be updated from the VMCB if it's a guest #PF. See hmR0SvmExitXcptPF(). */ 4104 Log4(("IDT: Pending vectoring event %#RX64 ErrValid=%RTbool Err=%#RX32 GCPtrFaultAddress=%#RX64\n", pVmcb->ctrl.ExitIntInfo.u, 4105 !!pVmcb->ctrl.ExitIntInfo.n.u1ErrorCodeValid, pVmcb->ctrl.ExitIntInfo.n.u32ErrorCode, GCPtrFaultAddress)); 4123 /* If uExitVector is #PF, CR2 value will be updated from the VMCB if it's a guest #PF, 4124 see hmR0SvmExitXcptPF(). */ 4125 Log4(("IDT: Pending vectoring event %#RX64 ErrValid=%RTbool Err=%#RX32 GCPtrFaultAddress=%#RX64\n", 4126 pVmcb->ctrl.ExitIntInfo.u, RT_BOOL(pVmcb->ctrl.ExitIntInfo.n.u1ErrorCodeValid), 4127 pVmcb->ctrl.ExitIntInfo.n.u32ErrorCode, GCPtrFaultAddress)); 4106 4128 } 4129 break; 4130 } 4131 4132 case IEMXCPTRAISE_REEXEC_INSTR: 4133 { 4134 Assert(rc == VINF_SUCCESS); 4107 4135 break; 4108 4136 }
Note:
See TracChangeset
for help on using the changeset viewer.