Changeset 12162 in vbox
- Timestamp:
- Sep 5, 2008 11:28:27 PM (16 years ago)
- Location:
- trunk/src/VBox/VMM
- Files:
-
- 3 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/VBox/VMM/HWACCMInternal.h
r12121 r12162 387 387 bool fHostDebugRegsSaved; 388 388 } savedhoststate; 389 #endif 390 391 #ifdef VBOX_STRICT 392 /** The CPU ID of the CPU currently owning the VMCS. Set in 393 * HWACCMR0Enter and cleared in HWACCMR0Leave. */ 394 RTCPUID idEnteredCpu; 395 # if HC_ARCH_BITS == 32 396 RTCPUID Alignment0; 397 # endif 389 398 #endif 390 399 -
trunk/src/VBox/VMM/VMMR0/HWACCMR0.cpp
r12121 r12162 681 681 pVM->hwaccm.s.cpuid.u32AMDFeatureEDX = HWACCMR0Globals.cpuid.u32AMDFeatureEDX; 682 682 pVM->hwaccm.s.lLastError = HWACCMR0Globals.lLastError; 683 #ifdef VBOX_STRICT 684 pVM->hwaccm.s.idEnteredCpu = NIL_RTCPUID; 685 #endif 683 686 684 687 /* Init a VT-x or AMD-V VM. */ … … 774 777 rc |= HWACCMR0Globals.pfnLoadGuestState(pVM, pCtx); 775 778 AssertRC(rc); 779 780 #ifdef VBOX_STRICT 781 /* keep track of the CPU owning the VMCS for debugging scheduling weirdness and ring-3 calls. */ 782 if (RT_SUCCESS(rc)) 783 { 784 AssertMsg(pVM->hwaccm.s.idEnteredCpu == NIL_RTCPUID, ("%d", (int)pVM->hwaccm.s.idEnteredCpu)); 785 pVM->hwaccm.s.idEnteredCpu = idCpu; 786 } 787 #endif 776 788 return rc; 777 789 } … … 826 838 /* Resync the debug register on the next entry. */ 827 839 pVM->hwaccm.s.fContextUseFlags |= HWACCM_CHANGED_GUEST_DEBUG; 828 return HWACCMR0Globals.pfnLeaveSession(pVM); 840 rc = HWACCMR0Globals.pfnLeaveSession(pVM); 841 842 #ifdef VBOX_STRICT 843 /* keep track of the CPU owning the VMCS for debugging scheduling weirdness and ring-3 calls. */ 844 RTCPUID idCpu = RTMpCpuId(); 845 AssertMsg(pVM->hwaccm.s.idEnteredCpu == idCpu, ("owner is %d, I'm %d", (int)pVM->hwaccm.s.idEnteredCpu, (int)idCpu)); 846 pVM->hwaccm.s.idEnteredCpu = NIL_RTCPUID; 847 #endif 848 849 return rc; 829 850 } 830 851 -
trunk/src/VBox/VMM/VMMR0/HWVMXR0.cpp
r12121 r12162 1195 1195 */ 1196 1196 ResumeExecution: 1197 AssertMsg(pVM->hwaccm.s.idEnteredCpu == RTMpCpuId(), 1198 ("Expected %d, I'm %d; cResume=%d exitReason=%RTreg exitQualification=%RTreg\n", 1199 (int)pVM->hwaccm.s.idEnteredCpu, (int)RTMpCpuId(), cResume, exitReason, exitQualification)); 1200 1197 1201 /* Safety precaution; looping for too long here can have a very bad effect on the host */ 1198 1202 if (++cResume > HWACCM_MAX_RESUME_LOOPS) … … 1763 1767 case X86_XCPT_DB: /* Debug exception. */ 1764 1768 { 1765 /* DR6, DR7.GD and IA32_DEBUGCTL.LBR are not updated yet. 1769 /* DR6, DR7.GD and IA32_DEBUGCTL.LBR are not updated yet. 1766 1770 * 1767 1771 * Exit qualification bits:
Note:
See TracChangeset
for help on using the changeset viewer.