mirror of
https://github.com/reactos/reactos.git
synced 2025-07-31 09:11:42 +00:00
- Removed some hard coded values, which depend on a kernel base of 0xc0000000.
svn path=/trunk/; revision=11202
This commit is contained in:
parent
306d451c3b
commit
3fdd7a717c
2 changed files with 68 additions and 45 deletions
|
@ -4,10 +4,6 @@
|
|||
#include <internal/ps.h>
|
||||
#include <internal/i386/mm.h>
|
||||
|
||||
/* FIXME: These should be calculated from Command Line */
|
||||
#define KERNEL_PD_START (KERNEL_BASE / 0x100000) /* Page Directory Start. Only the High 3 bits. */
|
||||
#define KERNEL_PD_END ((KERNEL_BASE + 0x00400000) / 0x100000) /* Page Directory End. Only the High 3 bits. */
|
||||
|
||||
#define MULTIBOOT_HEADER_MAGIC (0x1BADB002)
|
||||
|
||||
#define MULTIBOOT_HEADER_FLAGS (0x00010003)
|
||||
|
@ -112,8 +108,8 @@ _multiboot_entry:
|
|||
*/
|
||||
movl $V2P(startup_pagedirectory), %esi
|
||||
movl $(V2P(lowmem_pagetable) + 0x3), 0x0(%esi)
|
||||
movl $(V2P(kernel_pagetable) + 0x3), 0xC00(%esi)
|
||||
movl $(V2P(kernel_pagetable+4096) + 0x3), 0xC04(%esi)
|
||||
movl $(V2P(kernel_pagetable) + 0x3), (KERNEL_BASE >> 20)(%esi)
|
||||
movl $(V2P(kernel_pagetable+4096) + 0x3), ((KERNEL_BASE >> 20) + 4)(%esi)
|
||||
|
||||
movl $(V2P(startup_pagedirectory) + 0x3), 0xF00(%esi)
|
||||
movl $(V2P(kernelmap_pagetable) + 0x3), 0xF0C(%esi)
|
||||
|
|
|
@ -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.74 2004/09/26 16:32:17 hbirr Exp $
|
||||
/* $Id: page.c,v 1.75 2004/10/05 18:53:28 hbirr Exp $
|
||||
*
|
||||
* PROJECT: ReactOS kernel
|
||||
* FILE: ntoskrnl/mm/i386/page.c
|
||||
|
@ -58,7 +58,7 @@
|
|||
#define PAE_PAGEDIRECTORY_MAP (0xf0000000 + (PAGETABLE_MAP / (512)))
|
||||
|
||||
ULONG MmGlobalKernelPageDirectory[1024];
|
||||
ULONGLONG MmGlobalKernelPageDirectoryForPAE[512];
|
||||
ULONGLONG MmGlobalKernelPageDirectoryForPAE[2048];
|
||||
|
||||
#define PTE_TO_PFN(X) ((X) >> PAGE_SHIFT)
|
||||
#define PFN_TO_PTE(X) ((X) << PAGE_SHIFT)
|
||||
|
@ -158,7 +158,9 @@ ProtectToPTE(ULONG flProtect)
|
|||
|
||||
#define PAE_ADDR_TO_PDTE_OFFSET(v) (((ULONG_PTR)(v)) / (512 * 512 * PAGE_SIZE))
|
||||
|
||||
#define PAE_ADDR_TO_PDE_OFFSET(v) ((((ULONG_PTR)(v)) % (512 * 512 * PAGE_SIZE)) / (512 * PAGE_SIZE))
|
||||
#define PAE_ADDR_TO_PDE_PAGE_OFFSET(v) ((((ULONG_PTR)(v)) % (512 * 512 * PAGE_SIZE)) / (512 * PAGE_SIZE))
|
||||
|
||||
#define PAE_ADDR_TO_PDE_OFFSET(v) (((ULONG_PTR)(v))/ (512 * PAGE_SIZE))
|
||||
|
||||
#define PAE_ADDR_TO_PTE_OFFSET(v) ((((ULONG_PTR)(v)) % (512 * PAGE_SIZE)) / PAGE_SIZE)
|
||||
|
||||
|
@ -193,7 +195,7 @@ NTSTATUS Mmi386ReleaseMmInfo(PEPROCESS Process)
|
|||
PageDirTable = (PULONGLONG)ExAllocatePageWithPhysPage(Process->Pcb.DirectoryTableBase.QuadPart >> PAGE_SHIFT);
|
||||
for (i = 0; i < 4; i++)
|
||||
{
|
||||
if (i < 3)
|
||||
if (i < PAE_ADDR_TO_PDTE_OFFSET(KERNEL_BASE))
|
||||
{
|
||||
PageDir = (PULONGLONG)ExAllocatePageWithPhysPage(PageDirTable[i] >> PAGE_SHIFT);
|
||||
for (j = 0; j < 512; j++)
|
||||
|
@ -318,23 +320,29 @@ NTSTATUS MmCopyMmInfo(PEPROCESS Src, PEPROCESS Dest)
|
|||
PageDirTable[i] = (Pfn[i] << PAGE_SHIFT) | PA_PRESENT;
|
||||
}
|
||||
ExUnmapPage(PageDirTable);
|
||||
PageDir = (PULONGLONG)ExAllocatePageWithPhysPage(Pfn[3]);
|
||||
if (PageDir == NULL)
|
||||
for (i = PAE_ADDR_TO_PDTE_OFFSET(KERNEL_BASE); i < 4; i++)
|
||||
{
|
||||
for (i = 0; i < 4; i++)
|
||||
PageDir = (PULONGLONG)ExAllocatePageWithPhysPage(Pfn[i]);
|
||||
if (PageDir == NULL)
|
||||
{
|
||||
for (j = 0; j < 4; j++)
|
||||
{
|
||||
MmReleasePageMemoryConsumer(MC_NPPOOL, Pfn[j]);
|
||||
}
|
||||
ExUnmapPage(PageDirTable);
|
||||
MmReleasePageMemoryConsumer(MC_NPPOOL, PhysPageDirectory.QuadPart >> PAGE_SHIFT);
|
||||
return STATUS_UNSUCCESSFUL;
|
||||
}
|
||||
memcpy(PageDir, &MmGlobalKernelPageDirectoryForPAE[i * 512], 512 * sizeof(ULONGLONG));
|
||||
if (PAE_ADDR_TO_PDTE_OFFSET(PAGETABLE_MAP) == i)
|
||||
{
|
||||
MmReleasePageMemoryConsumer(MC_NPPOOL, Pfn[i]);
|
||||
for (j = 0; j < 4; j++)
|
||||
{
|
||||
PageDir[PAE_ADDR_TO_PDE_PAGE_OFFSET(PAGETABLE_MAP) + j] = (Pfn[j] << PAGE_SHIFT) | PA_PRESENT | PA_READWRITE;
|
||||
}
|
||||
}
|
||||
ExUnmapPage(PageDirTable);
|
||||
MmReleasePageMemoryConsumer(MC_NPPOOL, PhysPageDirectory.QuadPart >> PAGE_SHIFT);
|
||||
return STATUS_UNSUCCESSFUL;
|
||||
ExUnmapPage(PageDir);
|
||||
}
|
||||
memcpy(PageDir, &MmGlobalKernelPageDirectoryForPAE[0], 512 * sizeof(ULONGLONG));
|
||||
for (i = 0; i < 4; i++)
|
||||
{
|
||||
PageDir[PAE_ADDR_TO_PDE_OFFSET(PAGETABLE_MAP) + i] = (Pfn[i] << PAGE_SHIFT) | PA_PRESENT | PA_READWRITE;
|
||||
}
|
||||
ExUnmapPage(PageDir);
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -482,7 +490,7 @@ MmGetPageTableForProcessForPAE(PEPROCESS Process, PVOID Address, BOOLEAN Create)
|
|||
{
|
||||
KEBUGCHECK(0);
|
||||
}
|
||||
PageDir += PAE_ADDR_TO_PDE_OFFSET(Address);
|
||||
PageDir += PAE_ADDR_TO_PDE_PAGE_OFFSET(Address);
|
||||
Entry = ExfInterlockedCompareExchange64(PageDir, &ZeroEntry, &ZeroEntry);
|
||||
if (Entry == 0LL)
|
||||
{
|
||||
|
@ -2089,28 +2097,47 @@ VOID MmUpdatePageDir(PEPROCESS Process, PVOID Address, ULONG Size)
|
|||
PULONGLONG PageDirTable;
|
||||
PULONGLONG Pde;
|
||||
ULONGLONG ZeroPde = 0LL;
|
||||
StartOffset = PAE_ADDR_TO_PDE_OFFSET(Address);
|
||||
EndOffset = PAE_ADDR_TO_PDE_OFFSET(Address + Size);
|
||||
ULONG i;
|
||||
|
||||
if (Process != NULL && Process != PsGetCurrentProcess())
|
||||
for (i = PAE_ADDR_TO_PDTE_OFFSET(Address); i <= PAE_ADDR_TO_PDTE_OFFSET(Address + Size); i++)
|
||||
{
|
||||
PageDirTable = ExAllocatePageWithPhysPage(Process->Pcb.DirectoryTableBase.u.LowPart >> PAGE_SHIFT);
|
||||
Pde = (PULONGLONG)ExAllocatePageWithPhysPage(PageDirTable[3] >> PAGE_SHIFT);
|
||||
ExUnmapPage(PageDirTable);
|
||||
}
|
||||
else
|
||||
{
|
||||
Pde = (PULONGLONG)PAE_PAGEDIRECTORY_MAP + 3*512;
|
||||
}
|
||||
if (i == PAE_ADDR_TO_PDTE_OFFSET(Address))
|
||||
{
|
||||
StartOffset = PAE_ADDR_TO_PDE_PAGE_OFFSET(Address);
|
||||
}
|
||||
else
|
||||
{
|
||||
StartOffset = 0;
|
||||
}
|
||||
if (i == PAE_ADDR_TO_PDTE_OFFSET(Address + Size))
|
||||
{
|
||||
EndOffset = PAE_ADDR_TO_PDE_PAGE_OFFSET(Address + Size);
|
||||
}
|
||||
else
|
||||
{
|
||||
EndOffset = 511;
|
||||
}
|
||||
|
||||
for (Offset = StartOffset; Offset <= EndOffset; Offset++)
|
||||
{
|
||||
if (Offset < PAE_ADDR_TO_PDE_OFFSET(PAGETABLE_MAP) || Offset >= PAE_ADDR_TO_PDE_OFFSET(PAGETABLE_MAP)+4)
|
||||
if (Process != NULL && Process != PsGetCurrentProcess())
|
||||
{
|
||||
ExfInterlockedCompareExchange64(&Pde[Offset], &MmGlobalKernelPageDirectoryForPAE[Offset], &ZeroPde);
|
||||
PageDirTable = ExAllocatePageWithPhysPage(Process->Pcb.DirectoryTableBase.u.LowPart >> PAGE_SHIFT);
|
||||
Pde = (PULONGLONG)ExAllocatePageWithPhysPage(PageDirTable[i] >> PAGE_SHIFT);
|
||||
ExUnmapPage(PageDirTable);
|
||||
}
|
||||
else
|
||||
{
|
||||
Pde = (PULONGLONG)PAE_PAGEDIRECTORY_MAP + i*512;
|
||||
}
|
||||
|
||||
for (Offset = StartOffset; Offset <= EndOffset; Offset++)
|
||||
{
|
||||
if (i * 512 + Offset < PAE_ADDR_TO_PDE_OFFSET(PAGETABLE_MAP) || i * 512 + Offset >= PAE_ADDR_TO_PDE_OFFSET(PAGETABLE_MAP)+4)
|
||||
{
|
||||
ExfInterlockedCompareExchange64(&Pde[Offset], &MmGlobalKernelPageDirectoryForPAE[i*512 + Offset], &ZeroPde);
|
||||
}
|
||||
}
|
||||
MmUnmapPageTable((PULONG)Pde);
|
||||
}
|
||||
MmUnmapPageTable((PULONG)Pde);
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -2146,8 +2173,8 @@ MmInitGlobalKernelPageDirectory(VOID)
|
|||
ULONG i;
|
||||
if (Ke386Pae)
|
||||
{
|
||||
PULONGLONG CurrentPageDirectory = (PULONGLONG)PAE_PAGEDIRECTORY_MAP + 3*512;
|
||||
for (i = 0; i < 512; i++)
|
||||
PULONGLONG CurrentPageDirectory = (PULONGLONG)PAE_PAGEDIRECTORY_MAP;
|
||||
for (i = PAE_ADDR_TO_PDE_OFFSET(KERNEL_BASE); i < 4 * 512; i++)
|
||||
{
|
||||
if ((i < PAE_ADDR_TO_PDE_OFFSET(PAGETABLE_MAP) || i >= PAE_ADDR_TO_PDE_OFFSET(PAGETABLE_MAP) + 4) &&
|
||||
0LL == MmGlobalKernelPageDirectoryForPAE[i] && 0LL != CurrentPageDirectory[i])
|
||||
|
@ -2208,12 +2235,12 @@ MiEnablePAE(PVOID* LastKernelAddress)
|
|||
|
||||
for (i = 0; i < 4; i++)
|
||||
{
|
||||
PageDir[3*512+PAE_ADDR_TO_PDE_OFFSET(PAGETABLE_MAP) + i] = PageDirTable[i] | PA_READWRITE;
|
||||
PageDir[3*512+PAE_ADDR_TO_PDE_PAGE_OFFSET(PAGETABLE_MAP) + i] = PageDirTable[i] | PA_READWRITE;
|
||||
}
|
||||
|
||||
for (i = 0; i < 2048; i++)
|
||||
{
|
||||
if (i < /*PAE_ADDR_TO_PDE_OFFSET(PAE_PAGEDIRECTORY_MAP)*/0x780 || i >= /*PAE_ADDR_TO_PDE_OFFSET(PAE_PAGEDIRECTORY_MAP)*/0x780 + 4)
|
||||
if (i < PAE_ADDR_TO_PDE_OFFSET(PAGETABLE_MAP) || i >= PAE_ADDR_TO_PDE_OFFSET(PAGETABLE_MAP) + 4)
|
||||
{
|
||||
PVOID Address = (PVOID)(i * 512 * PAGE_SIZE);
|
||||
PULONG Pde = ADDR_TO_PDE(Address);
|
||||
|
@ -2266,7 +2293,7 @@ MiEnablePAE(PVOID* LastKernelAddress)
|
|||
ULONG
|
||||
MiGetUserPageDirectoryCount(VOID)
|
||||
{
|
||||
return Ke386Pae ? 1536 : 768;
|
||||
return Ke386Pae ? PAE_ADDR_TO_PDE_OFFSET(KERNEL_BASE) : ADDR_TO_PDE_OFFSET(KERNEL_BASE);
|
||||
}
|
||||
|
||||
VOID INIT_FUNCTION
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue