VirtualBox

Changeset 45792 in vbox for trunk/src


Ignore:
Timestamp:
Apr 28, 2013 4:28:51 PM (12 years ago)
Author:
vboxsync
Message:

CR0.WP applies to CPL > 3, not just CPL == 0. Sketched out a Netware hack.

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

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/VMM/VMMAll/PGMAll.cpp

    r45739 r45792  
    918918
    919919/**
     920 * Changing the page flags for a single page in the shadow page tables so as to
     921 * make it supervisor and writable.
     922 *
     923 * This if for dealing with CR0.WP=0 and readonly user pages.
     924 *
     925 * @returns VBox status code.
     926 * @param   pVCpu       Pointer to the VMCPU.
     927 * @param   GCPtr       Virtual address of the first page in the range.
     928 * @param   fOpFlags    A combination of the PGM_MK_PG_XXX flags.
     929 */
     930int pgmShwMakePageSupervisorAndWritable(PVMCPU pVCpu, RTGCPTR GCPtr, uint32_t fOpFlags)
     931{
     932    return pdmShwModifyPage(pVCpu, GCPtr, X86_PTE_RW, ~(uint64_t)X86_PTE_US, fOpFlags);
     933}
     934
     935
     936/**
    920937 * Gets the shadow page directory for the specified address, PAE.
    921938 *
  • trunk/src/VBox/VMM/VMMAll/PGMAllBth.h

    r45752 r45792  
    984984            if (    !GstWalk.Core.fEffectiveRW
    985985                &&  (CPUMGetGuestCR0(pVCpu) & (X86_CR0_WP | X86_CR0_PG)) == X86_CR0_PG
    986                 &&  CPUMGetGuestCPL(pVCpu) == 0)
     986                &&  CPUMGetGuestCPL(pVCpu) > 3)
    987987            {
    988988                Assert((uErr & (X86_TRAP_PF_RW | X86_TRAP_PF_P)) == (X86_TRAP_PF_RW | X86_TRAP_PF_P));
     989#    ifdef PGM_WITH_NETWARE_WP0_HACK
     990                if (   GstWalk.Core.fEffectiveUS
     991                    && !GstWalk.Core.fBigPage)
     992                {
     993                    /* Temorarily change the page to a RW super visor page. We'll trap
     994                       and switch it back when user mode tries to read from it again.
     995                       (See further down.) */
     996                    Log(("PGM #PF: Netware WP0+RO+US hack: pvFault=%RGp uErr=%#x\n", pvFault, uErr));
     997                    rc = pgmShwMakePageSupervisorAndWritable(pVCpu, pvFault, PGM_MK_PG_IS_WRITE_FAULT);
     998                    PGM_INVL_PG(pVCpu, pvFault);
     999                    if (rc == VINF_SUCCESS || rc == VINF_PGM_SYNC_CR3)
     1000                    {
     1001                        STAM_STATS({ pVCpu->pgm.s.CTX_SUFF(pStatTrap0eAttribution) = &pVCpu->pgm.s.CTX_SUFF(pStats)->StatRZTrap0eTime2WPEmulation; });  /**< @todo New stat. */
     1002                        return rc;
     1003                    }
     1004                    Log(("pgmShwMakePageSupervisorAndWritable(%RGv) failed with rc=%Rrc - ignored\n", pvFault, rc));
     1005                }
     1006#    endif
    9891007                rc = VBOXSTRICTRC_TODO(PGMInterpretInstruction(pVM, pVCpu, pRegFrame, pvFault));
    9901008                if (RT_SUCCESS(rc))
     
    10421060            }
    10431061        }
     1062#    if defined(PGM_WITH_NETWARE_WP0_HACK) && PGM_WITH_PAGING(PGM_GST_TYPE, PGM_SHW_TYPE)
     1063        /*
     1064         * Check for Netware WP0+RO+US hack from above and undo it when user
     1065         * mode accesses the page again.
     1066         */
     1067        else if (    !GstWalk.Core.fEffectiveRW
     1068                 &&  GstWalk.Core.fEffectiveUS
     1069                 &&  GstWalk.Core.fBigPage
     1070                 &&  (CPUMGetGuestCR0(pVCpu) & (X86_CR0_WP | X86_CR0_PG)) == X86_CR0_PG
     1071                 &&  CPUMGetGuestCPL(pVCpu) == 3
     1072                )
     1073        {
     1074            Log(("PGM #PF: Undo netware WP0+RO+US hack: pvFault=%RGp uErr=%#x\n", pvFault, uErr));
     1075            rc = PGM_BTH_NAME(SyncPage)(pVCpu, GstWalk.Pde, pvFault, 1, uErr);
     1076            if (RT_SUCCESS(rc))
     1077            {
     1078                PGM_INVL_PG(pVCpu, pvFault);
     1079                STAM_STATS({ pVCpu->pgm.s.CTX_SUFF(pStatTrap0eAttribution) = &pVCpu->pgm.s.CTX_SUFF(pStats)->StatRZTrap0eTime2WPEmulation; }); /**< @todo New stat. */
     1080                return VINF_SUCCESS;
     1081            }
     1082        }
     1083#    endif
     1084
    10441085        /** @todo else: why are we here? */
    10451086
  • trunk/src/VBox/VMM/include/PGMInternal.h

    r45741 r45792  
    40174017int             pgmMapDeactivateCR3(PVM pVM, PPGMPOOLPAGE pShwPageCR3);
    40184018
     4019int             pgmShwMakePageSupervisorAndWritable(PVMCPU pVCpu, RTGCPTR GCPtr, uint32_t fOpFlags);
    40194020int             pgmShwSyncPaePDPtr(PVMCPU pVCpu, RTGCPTR GCPtr, X86PGPAEUINT uGstPdpe, PX86PDPAE *ppPD);
    40204021int             pgmShwSyncNestedPageLocked(PVMCPU pVCpu, RTGCPHYS GCPhysFault, uint32_t cPages, PGMMODE enmShwPagingMode);
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