53#define MAX_MAD_COUNT 200
63 TRACE(
"MempAddMemoryBlock(BasePage=0x%lx, PageCount=0x%lx, Type=%ld)\n",
64 BasePage, PageCount,
Type);
68 if (BasePage >= MM_MAX_PAGE)
75 if (BasePage + PageCount > MM_MAX_PAGE)
78 PageCount = MM_MAX_PAGE - BasePage;
84 ERR(
"Error: no MAD slots left!\n");
106 TRACE(
"MempSetupPagingForRegion(BasePage=0x%lx, PageCount=0x%lx, Type=%ld)\n",
107 BasePage, PageCount,
Type);
165 ERR(
"Error during MempSetupPaging\n");
176 PFN_NUMBER i, PagesCount, MemoryMapSizeInPages, NoEntries;
216 UiMessageBox(
"Can not retrieve the current memory map.");
224 TRACE(
"Got memory map with %d entries\n", NoEntries);
230 ERR(
"Error during MempSetupPaging of first page\n");
236 LastPageType =
MemoryMap[1].PageAllocated;
237 for (
i = 2;
i < NoEntries;
i++)
239 if ((
MemoryMap[
i].PageAllocated != LastPageType) ||
240 (
i == NoEntries - 1))
254 LastPageType =
MemoryMap[0].PageAllocated;
255 for (
i = 1;
i < NoEntries;
i++)
258 if (
i >= MemoryMapStartPage &&
259 i < (MemoryMapStartPage+MemoryMapSizeInPages))
266 if (
MemoryMap[
i].PageAllocated == LastPageType &&
339 TRACE(
"Memory Descriptor List prepared, printing PDE\n");
340 List_PaToVa(&LoaderBlock->MemoryDescriptorListHead);
355 PLIST_ENTRY ListHead = &LoaderBlock->MemoryDescriptorListHead;
363 PreviousEntry = ListHead;
364 NextEntry = ListHead->
Flink;
365 while (NextEntry != ListHead)
373 PreviousEntry = NextEntry;
374 PreviousDescriptor = NextDescriptor;
375 NextEntry = NextEntry->
Flink;
402 if ((NextEntry != ListHead) &&
BOOLEAN MempSetupPaging(IN PFN_NUMBER StartPage, IN PFN_NUMBER NumberOfPages, IN BOOLEAN KernelMapping)
BIOS_MEMORY_MAP MemoryMap[32]
#define DBG_DEFAULT_CHANNEL(ch)
PVOID MmAllocateMemoryWithType(SIZE_T MemorySize, TYPE_OF_MEMORY MemoryType)
ULONG MmGetBiosMemoryMap(_Out_ PFREELDR_MEMORY_DESCRIPTOR *MemoryMap)
PPAGE_LOOKUP_TABLE_ITEM MmGetMemoryMap(PFN_NUMBER *NoEntries)
PFN_NUMBER MmGetHighestPhysicalPage(VOID)
PFN_NUMBER MmGetLoaderPagesSpanned(VOID)
VOID FrLdrHeapCleanupAll(VOID)
VOID UiMessageBox(_In_ PCSTR Format,...)
#define RemoveEntryList(Entry)
#define InsertHeadList(ListHead, Entry)
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
VOID List_PaToVa(_In_ LIST_ENTRY *ListEntry)
PFREELDR_MEMORY_DESCRIPTOR BiosMemoryMap
ULONG BiosMemoryMapEntryCount
@ LoaderFirmwareTemporary
@ LoaderFirmwarePermanent
@ LoaderStartupKernelStack
@ LoaderStartupPanicStack
TYPE_OF_MEMORY MemoryType
struct _LIST_ENTRY * Flink
TYPE_OF_MEMORY MemoryType
#define CONTAINING_RECORD(address, type, field)
VOID WinLdrpDumpMemoryDescriptors(PLOADER_PARAMETER_BLOCK LoaderBlock)
MEMORY_ALLOCATION_DESCRIPTOR * Mad
BOOLEAN WinLdrSetupMemoryLayout(IN OUT PLOADER_PARAMETER_BLOCK LoaderBlock)
static const PCSTR MemTypeDesc[]
static VOID WinLdrInsertDescriptor(IN OUT PLOADER_PARAMETER_BLOCK LoaderBlock, IN PMEMORY_ALLOCATION_DESCRIPTOR NewDescriptor)
VOID MempSetupPagingForRegion(PFN_NUMBER BasePage, PFN_NUMBER PageCount, ULONG Type)
VOID MempAddMemoryBlock(IN OUT PLOADER_PARAMETER_BLOCK LoaderBlock, PFN_NUMBER BasePage, PFN_NUMBER PageCount, ULONG Type)
_In_opt_ PSECURITY_DESCRIPTOR _Out_ PSECURITY_DESCRIPTOR * NewDescriptor