mirror of
https://github.com/reactos/reactos.git
synced 2025-01-04 21:38:43 +00:00
- Replaced MmUpdateStackPageDir by MmUpdatePageDir which can establish
the pde's of a process for any address range within the kernel address range. svn path=/trunk/; revision=10603
This commit is contained in:
parent
7314aec7ff
commit
30188f2c6c
3 changed files with 36 additions and 22 deletions
|
@ -662,14 +662,14 @@ VOID MmDeleteVirtualMapping(struct _EPROCESS* Process,
|
|||
BOOL* WasDirty,
|
||||
PPFN_TYPE Page);
|
||||
|
||||
VOID MmUpdateStackPageDir(PULONG LocalPageDir, struct _KTHREAD* KThread);
|
||||
|
||||
BOOLEAN MmIsDirtyPage(struct _EPROCESS* Process, PVOID Address);
|
||||
|
||||
VOID MmMarkPageMapped(PFN_TYPE Page);
|
||||
|
||||
VOID MmMarkPageUnmapped(PFN_TYPE Page);
|
||||
|
||||
VOID MmUpdatePageDir(PEPROCESS Process, PVOID Address, ULONG Size);
|
||||
|
||||
/* wset.c ********************************************************************/
|
||||
|
||||
NTSTATUS MmTrimUserMemory(ULONG Target, ULONG Priority, PULONG NrFreedPages);
|
||||
|
|
|
@ -16,7 +16,7 @@
|
|||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
*/
|
||||
/* $Id: process.c,v 1.23 2004/08/15 16:39:05 chorns Exp $
|
||||
/* $Id: process.c,v 1.24 2004/08/19 21:47:51 hbirr Exp $
|
||||
*
|
||||
* PROJECT: ReactOS kernel
|
||||
* FILE: ntoskrnl/ke/process.c
|
||||
|
@ -43,7 +43,6 @@ KeAttachProcess (PEPROCESS Process)
|
|||
{
|
||||
KIRQL oldlvl;
|
||||
PETHREAD CurrentThread;
|
||||
PULONG AttachedProcessPageDir;
|
||||
ULONG PageDir;
|
||||
|
||||
DPRINT("KeAttachProcess(Process %x)\n",Process);
|
||||
|
@ -56,10 +55,6 @@ KeAttachProcess (PEPROCESS Process)
|
|||
KEBUGCHECK(INVALID_PROCESS_ATTACH_ATTEMPT);
|
||||
}
|
||||
|
||||
KeRaiseIrql(DISPATCH_LEVEL, &oldlvl);
|
||||
|
||||
KiSwapApcEnvironment(&CurrentThread->Tcb, &Process->Pcb);
|
||||
|
||||
/* The stack of the current process may be located in a page which is
|
||||
not present in the page directory of the process we're attaching to.
|
||||
That would lead to a page fault when this function returns. However,
|
||||
|
@ -69,9 +64,11 @@ KeAttachProcess (PEPROCESS Process)
|
|||
To prevent this, make sure the page directory of the process we're
|
||||
attaching to is up-to-date. */
|
||||
|
||||
AttachedProcessPageDir = ExAllocatePageWithPhysPage(Process->Pcb.DirectoryTableBase.QuadPart >> PAGE_SHIFT);
|
||||
MmUpdateStackPageDir(AttachedProcessPageDir, &CurrentThread->Tcb);
|
||||
ExUnmapPage(AttachedProcessPageDir);
|
||||
MmUpdatePageDir(Process, (PVOID)CurrentThread->Tcb.StackLimit, MM_STACK_SIZE);
|
||||
|
||||
KeRaiseIrql(DISPATCH_LEVEL, &oldlvl);
|
||||
|
||||
KiSwapApcEnvironment(&CurrentThread->Tcb, &Process->Pcb);
|
||||
|
||||
CurrentThread->OldProcess = PsGetCurrentProcess();
|
||||
CurrentThread->ThreadsProcess = Process;
|
||||
|
|
|
@ -16,7 +16,7 @@
|
|||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
*/
|
||||
/* $Id: page.c,v 1.70 2004/08/15 16:39:09 chorns Exp $
|
||||
/* $Id: page.c,v 1.71 2004/08/19 21:47:51 hbirr Exp $
|
||||
*
|
||||
* PROJECT: ReactOS kernel
|
||||
* FILE: ntoskrnl/mm/i386/page.c
|
||||
|
@ -1150,20 +1150,37 @@ MmGetPhysicalAddress(PVOID vaddr)
|
|||
return p;
|
||||
}
|
||||
|
||||
|
||||
VOID
|
||||
MmUpdateStackPageDir(PULONG LocalPageDir, PKTHREAD PThread)
|
||||
VOID MmUpdatePageDir(PEPROCESS Process, PVOID Address, ULONG Size)
|
||||
{
|
||||
unsigned EntryBase = ADDR_TO_PDE_OFFSET(PThread->StackLimit);
|
||||
unsigned EntryTop = ADDR_TO_PDE_OFFSET((char*)PThread->InitialStack - PAGE_SIZE);
|
||||
PULONG Pde;
|
||||
ULONG StartOffset, EndOffset, Offset;
|
||||
|
||||
if (0 == LocalPageDir[EntryBase])
|
||||
if (Address < (PVOID)KERNEL_BASE)
|
||||
{
|
||||
LocalPageDir[EntryBase] = MmGlobalKernelPageDirectory[EntryBase];
|
||||
KEBUGCHECK(0);
|
||||
}
|
||||
if (EntryBase != EntryTop && 0 == LocalPageDir[EntryTop])
|
||||
|
||||
StartOffset = ADDR_TO_PDE_OFFSET(Address);
|
||||
EndOffset = ADDR_TO_PDE_OFFSET(Address + Size);
|
||||
|
||||
if (Process != NULL && Process != PsGetCurrentProcess())
|
||||
{
|
||||
LocalPageDir[EntryTop] = MmGlobalKernelPageDirectory[EntryTop];
|
||||
Pde = ExAllocatePageWithPhysPage(Process->Pcb.DirectoryTableBase.u.LowPart >> PAGE_SHIFT);
|
||||
}
|
||||
else
|
||||
{
|
||||
Pde = (PULONG)PAGEDIRECTORY_MAP;
|
||||
}
|
||||
for (Offset = StartOffset; Offset <= EndOffset; Offset++)
|
||||
{
|
||||
if (Offset != ADDR_TO_PDE_OFFSET(PAGETABLE_MAP))
|
||||
{
|
||||
InterlockedCompareExchange(&Pde[Offset], MmGlobalKernelPageDirectory[Offset], 0);
|
||||
}
|
||||
}
|
||||
if (Pde != (PULONG)PAGEDIRECTORY_MAP)
|
||||
{
|
||||
ExUnmapPage(Pde);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue