Changeset 38378 in vbox
- Timestamp:
- Aug 9, 2011 1:37:41 PM (13 years ago)
- Location:
- trunk
- Files:
-
- 3 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/include/VBox/vmm/em.h
r38349 r38378 140 140 * @param pVM The VM to operate on. 141 141 */ 142 #define EMIsHwVirtExecutionEnabled(pVM) (!(pVM)->fRecompileSupervisor && !(pVM)->fRecompileSupervisor) 142 #define EMIsHwVirtExecutionEnabled(pVM) (!(pVM)->fRecompileSupervisor && !(pVM)->fRecompileUser) 143 144 /** 145 * Checks if execution of supervisor code should be done in the 146 * recompiler or not. 147 * 148 * @returns true if enabled. 149 * @returns false if disabled. 150 * @param pVM The VM to operate on. 151 */ 152 #define EMIsSupervisorCodeRecompiled(pVM) ((pVM)->fRecompileSupervisor) 143 153 144 154 VMMDECL(void) EMSetInhibitInterruptsPC(PVMCPU pVCpu, RTGCUINTPTR PC); -
trunk/src/VBox/VMM/VMMR3/EM.cpp
r38327 r38378 1578 1578 /* 1579 1579 * The instruction following an emulated STI should *always* be executed! 1580 * 1581 * Note! We intentionally don't clear VM_FF_INHIBIT_INTERRUPTS here if 1582 * the eip is the same as the inhibited instr address. Before we 1583 * are able to execute this instruction in raw mode (iret to 1584 * guest code) an external interrupt might force a world switch 1585 * again. Possibly allowing a guest interrupt to be dispatched 1586 * in the process. This could break the guest. Sounds very 1587 * unlikely, but such timing sensitive problem are not as rare as 1588 * you might think. 1580 1589 */ 1581 1590 if ( VMCPU_FF_ISPENDING(pVCpu, VMCPU_FF_INHIBIT_INTERRUPTS) … … 1584 1593 Log(("VMCPU_FF_INHIBIT_INTERRUPTS at %RGv successor %RGv\n", (RTGCPTR)CPUMGetGuestRIP(pVCpu), EMGetInhibitInterruptsPC(pVCpu))); 1585 1594 if (CPUMGetGuestRIP(pVCpu) != EMGetInhibitInterruptsPC(pVCpu)) 1586 {1587 /* Note: we intentionally don't clear VM_FF_INHIBIT_INTERRUPTS here if the eip is the same as the inhibited instr address.1588 * Before we are able to execute this instruction in raw mode (iret to guest code) an external interrupt might1589 * force a world switch again. Possibly allowing a guest interrupt to be dispatched in the process. This could1590 * break the guest. Sounds very unlikely, but such timing sensitive problem are not as rare as you might think.1591 */1592 1595 VMCPU_FF_CLEAR(pVCpu, VMCPU_FF_INHIBIT_INTERRUPTS); 1593 } 1594 if (HWACCMR3IsActive(pVCpu)) 1596 1597 if (EMIsSupervisorCodeRecompiled(pVM)) 1598 rc2 = VINF_EM_RESCHEDULE_REM; 1599 else if (HWACCMR3IsActive(pVCpu)) 1595 1600 rc2 = VINF_EM_RESCHEDULE_HWACC; 1596 1601 else … … 1842 1847 { 1843 1848 rc = emR3ForcedActions(pVM, pVCpu, rc); 1844 if ( 1845 1846 && 1849 if ( ( rc == VINF_EM_RESCHEDULE_REM 1850 || rc == VINF_EM_RESCHEDULE_HWACC) 1851 && pVCpu->em.s.fForceRAW) 1847 1852 rc = VINF_EM_RESCHEDULE_RAW; 1848 1853 } -
trunk/src/VBox/VMM/VMMR3/TRPM.cpp
r36823 r38378 79 79 #include <VBox/vmm/ssm.h> 80 80 #include <VBox/vmm/pdmapi.h> 81 #include <VBox/vmm/em.h> 81 82 #include <VBox/vmm/pgm.h> 82 83 #include "internal/pgm.h" … … 1454 1455 Assert(enmEvent == TRPM_HARDWARE_INT); 1455 1456 1456 if (REMR3QueryPendingInterrupt(pVM, pVCpu) == REM_NO_PENDING_IRQ) 1457 if ( REMR3QueryPendingInterrupt(pVM, pVCpu) == REM_NO_PENDING_IRQ 1458 && !EMIsSupervisorCodeRecompiled(pVM)) 1457 1459 { 1458 1460 #ifdef TRPM_FORWARD_TRAPS_IN_GC
Note:
See TracChangeset
for help on using the changeset viewer.