VirtualBox

Changeset 4615 in vbox for trunk/src/VBox


Ignore:
Timestamp:
Sep 7, 2007 7:25:16 PM (17 years ago)
Author:
vboxsync
Message:

REM(R3)NotifyHandlerPhysicalModify no longer needs a pvHC pointer, made it a flag instead.

Location:
trunk/src/VBox/VMM
Files:
3 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/VMM/REMInternal.h

    r4071 r4615  
    9292        struct
    9393        {
    94             RTHCPTR             pvHCPtr;
    9594            RTGCPHYS            GCPhysOld;
    9695            RTGCPHYS            GCPhysNew;
     
    9897            PGMPHYSHANDLERTYPE  enmType;
    9998            bool                fHasHCHandler;
     99            bool                fRestoreAsRAM;
    100100        } PhysicalModify;
    101101        uint64_t                padding[3 + (HC_ARCH_BITS == 64)];
  • trunk/src/VBox/VMM/VMMAll/PGMAllHandler.cpp

    r4071 r4615  
    495495         */
    496496        pgmHandlerPhysicalResetRamFlags(pVM, pCur);
    497         RTHCPTR pvRange = 0;
    498         if (pCur->pfnHandlerR3 && pCur->enmType != PGMPHYSHANDLERTYPE_MMIO)
    499             PGMRamGCPhys2HCPtr(&pVM->pgm.s, GCPhysCurrent, &pvRange); /* ASSUMES it doesn't change pvRange on failure. */
     497        const bool fRestoreAsRAM = pCur->pfnHandlerR3
     498                                && pCur->enmType != PGMPHYSHANDLERTYPE_MMIO; /** @todo this isn't entirely correct. */
    500499
    501500        /*
     
    534533#ifndef IN_RING3
    535534                    REMNotifyHandlerPhysicalModify(pVM, pCur->enmType, GCPhysCurrent, GCPhys,
    536                                                    pCur->Core.KeyLast - GCPhys + 1, !!pCur->pfnHandlerR3, pvRange);
     535                                                   pCur->Core.KeyLast - GCPhys + 1, !!pCur->pfnHandlerR3, fRestoreAsRAM);
    537536#else
    538537                    REMR3NotifyHandlerPhysicalModify(pVM, pCur->enmType, GCPhysCurrent, GCPhys,
    539                                                      pCur->Core.KeyLast - GCPhys + 1, !!pCur->pfnHandlerR3, pvRange);
     538                                                     pCur->Core.KeyLast - GCPhys + 1, !!pCur->pfnHandlerR3, fRestoreAsRAM);
    540539#endif
    541540                    pgmUnlock(pVM);
     
    544543                    return VINF_SUCCESS;
    545544                }
     545
    546546                AssertMsgFailed(("Conflict! GCPhys=%VGp GCPhysLast=%VGp\n", GCPhys, GCPhysLast));
    547547                rc = VERR_PGM_HANDLER_PHYSICAL_CONFLICT;
  • trunk/src/VBox/VMM/VMMAll/REMAll.cpp

    r4268 r4615  
    129129 * @param   cb              Size of the handler range.
    130130 * @param   fHasHCHandler   Set if the handler have a HC callback function.
    131  * @param   pvHCPtr         The HC virtual address corresponding to GCPhys if available.
     131 * @param   fRestoreAsRAM   Whether the to restore it as normal RAM or as unassigned memory.
    132132 */
    133 REMDECL(void) REMNotifyHandlerPhysicalModify(PVM pVM, PGMPHYSHANDLERTYPE enmType, RTGCPHYS GCPhysOld, RTGCPHYS GCPhysNew, RTGCPHYS cb, bool fHasHCHandler, RTHCPTR pvHCPtr)
     133REMDECL(void) REMNotifyHandlerPhysicalModify(PVM pVM, PGMPHYSHANDLERTYPE enmType, RTGCPHYS GCPhysOld, RTGCPHYS GCPhysNew, RTGCPHYS cb, bool fHasHCHandler, bool fRestoreAsRAM)
    134134{
    135135    if (pVM->rem.s.cHandlerNotifications >= ELEMENTS(pVM->rem.s.aHandlerNotifications))
     
    142142    pRec->u.PhysicalModify.cb = cb;
    143143    pRec->u.PhysicalModify.fHasHCHandler = fHasHCHandler;
    144     pRec->u.PhysicalModify.pvHCPtr = pvHCPtr;
     144    pRec->u.PhysicalModify.fRestoreAsRAM = fRestoreAsRAM;
    145145}
    146146
Note: See TracChangeset for help on using the changeset viewer.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette