mirror of
https://github.com/reactos/reactos.git
synced 2025-01-03 21:09:19 +00:00
71fefa32db
* Add an NDK header to define INIT_FUNCTION/INIT_SECTION globally * Use _declspec(allocate(x)) and _declspec(code_seg(x)) on MSVC versions that support it * Use INIT_FUNCTION on functions only and INIT_SECTION on data only (required by MSVC) * Place INIT_FUNCTION before the return type (required by MSVC) * Make sure declarations and implementations share the same modifiers (required by MSVC) * Add a global linker option to suppress warnings about defined but unused INIT section * Merge INIT section into .text in freeldr
104 lines
2.6 KiB
C
104 lines
2.6 KiB
C
/*
|
|
* PROJECT: ReactOS Kernel
|
|
* LICENSE: BSD - See COPYING.ARM in the top level directory
|
|
* FILE: ntoskrnl/mm/ARM3/largepag.c
|
|
* PURPOSE: ARM Memory Manager Large Page Support
|
|
* PROGRAMMERS: ReactOS Portable Systems Group
|
|
*/
|
|
|
|
/* INCLUDES *******************************************************************/
|
|
|
|
#include <ntoskrnl.h>
|
|
#define NDEBUG
|
|
#include <debug.h>
|
|
|
|
#define MODULE_INVOLVED_IN_ARM3
|
|
#include <mm/ARM3/miarm.h>
|
|
|
|
/* GLOBALS ********************************************************************/
|
|
|
|
LIST_ENTRY MmProcessList;
|
|
PMMPTE MiLargePageHyperPte;
|
|
ULONG MiLargePageRangeIndex;
|
|
MI_LARGE_PAGE_RANGES MiLargePageRanges[64];
|
|
WCHAR MmLargePageDriverBuffer[512] = {0};
|
|
ULONG MmLargePageDriverBufferLength = -1;
|
|
LIST_ENTRY MiLargePageDriverList;
|
|
BOOLEAN MiLargePageAllDrivers;
|
|
|
|
/* FUNCTIONS ******************************************************************/
|
|
|
|
INIT_FUNCTION
|
|
VOID
|
|
NTAPI
|
|
MiInitializeLargePageSupport(VOID)
|
|
{
|
|
#if _MI_PAGING_LEVELS > 2
|
|
DPRINT1("MiInitializeLargePageSupport: PAE/x64 Not Implemented\n");
|
|
//ASSERT(FALSE);
|
|
#else
|
|
/* Initialize the large-page hyperspace PTE used for initial mapping */
|
|
MiLargePageHyperPte = MiReserveSystemPtes(1, SystemPteSpace);
|
|
ASSERT(MiLargePageHyperPte);
|
|
MiLargePageHyperPte->u.Long = 0;
|
|
|
|
/* Initialize the process tracking list, and insert the system process */
|
|
InitializeListHead(&MmProcessList);
|
|
InsertTailList(&MmProcessList, &PsGetCurrentProcess()->MmProcessLinks);
|
|
#endif
|
|
}
|
|
|
|
INIT_FUNCTION
|
|
VOID
|
|
NTAPI
|
|
MiSyncCachedRanges(VOID)
|
|
{
|
|
ULONG i;
|
|
|
|
/* Scan every range */
|
|
for (i = 0; i < MiLargePageRangeIndex; i++)
|
|
{
|
|
UNIMPLEMENTED_DBGBREAK("No support for large pages\n");
|
|
}
|
|
}
|
|
|
|
INIT_FUNCTION
|
|
VOID
|
|
NTAPI
|
|
MiInitializeDriverLargePageList(VOID)
|
|
{
|
|
PWCHAR p, pp;
|
|
|
|
/* Initialize the list */
|
|
InitializeListHead(&MiLargePageDriverList);
|
|
|
|
/* Bail out if there's nothing */
|
|
if (MmLargePageDriverBufferLength == 0xFFFFFFFF) return;
|
|
|
|
/* Loop from start to finish */
|
|
p = MmLargePageDriverBuffer;
|
|
pp = MmLargePageDriverBuffer + (MmLargePageDriverBufferLength / sizeof(WCHAR));
|
|
while (p < pp)
|
|
{
|
|
/* Skip whitespaces */
|
|
if ((*p == L' ') || (*p == L'\n') || (*p == L'\r') || (*p == L'\t'))
|
|
{
|
|
/* Skip the character */
|
|
p++;
|
|
continue;
|
|
}
|
|
|
|
/* A star means everything */
|
|
if (*p == L'*')
|
|
{
|
|
/* No need to keep going */
|
|
MiLargePageAllDrivers = TRUE;
|
|
break;
|
|
}
|
|
|
|
DPRINT1("Large page drivers not supported\n");
|
|
ASSERT(FALSE);
|
|
}
|
|
}
|
|
|
|
/* EOF */
|