55} FREELDR_MEMORY_TYPE, *PFREELDR_MEMORY_TYPE;
57FREELDR_MEMORY_TYPE MemoryTypeArray[] =
76ULONG MemoryTypeCount =
sizeof(MemoryTypeArray) /
sizeof(MemoryTypeArray[0]);
88 return MemoryTypeArray[
Index].TypeString;
92 return MemoryTypeArray[0].TypeString;
102 for (
i = 0;
List[
i].PageCount != 0;
i++)
132 TRACE(
"AddMemoryDescriptor(0x%Ix, 0x%Ix, %u)\n",
133 BasePage, PageCount, MemoryType);
135 EndPage = BasePage + PageCount;
146 DescriptCount =
Index;
147 while (
List[DescriptCount].PageCount != 0)
156 TRACE(
"AddMemoryDescriptor conflict @%lu: new=[%lx:%lx], existing=[%lx,%lx]\n",
177 (DescriptCount -
Index) *
sizeof(
List[0]));
201 (DescriptCount -
Index) *
sizeof(
List[0]));
215 if (DescriptCount >= MaxCount)
221 "Ran out of static memory descriptors!");
225 if (
Index < DescriptCount)
229 (DescriptCount -
Index) *
sizeof(
List[0]));
238 DbgDumpMemoryMap(
List);
240 return DescriptCount;
271 ERR(
"Could not get NtHeaders!\n");
276 "Could not get NtHeaders!\n");
281 if ((FileHeader->
Machine != IMAGE_FILE_MACHINE_NATIVE) ||
287 ERR(
"FreeLdr FileHeader is invalid.\n");
292 "FreeLdr FileHeader is invalid.\n"
293 "Machine == 0x%lx, expected 0x%lx\n"
294 "NumberOfSections == 0x%lx, expected 0x%lx\n"
295 "PointerToSymbolTable == 0x%lx, expected 0\n"
296 "NumberOfSymbols == 0x%lx, expected 0\n"
297 "SizeOfOptionalHeader == 0x%lx, expected 0x%lx\n",
298 FileHeader->
Machine, IMAGE_FILE_MACHINE_NATIVE,
313 ERR(
"FreeLdr OptionalHeader is invalid.\n");
318 "FreeLdr OptionalHeader is invalid.\n"
319 "Magic == 0x%lx, expected 0x%lx\n"
320 "Subsystem == 0x%lx, expected 1 (native)\n"
321 "ImageBase == 0x%lx, expected 0x%lx\n"
322 "SizeOfImage == 0x%lx, maximum 0x%lx\n"
323 "SectionAlignment 0x%lx doesn't match FileAlignment 0x%lx\n",
342 TRACE(
"Initializing Memory Manager.\n");
351 TRACE(
"System Memory Map (Base Address, Length, Type):\n");
354 TRACE(
"%x\t %x\t %s\n",
371 printf(
"Error initializing memory manager!\n");
433 TRACE(
"MmGetAddressablePageCountIncludingHoles() returning 0x%x\n", PageCount);
440 SIZE_T PageLookupTableSize;
445 PVOID PageLookupTableMemAddress;
449 RequiredPages = PageLookupTableSize / MM_PAGE_SIZE;
464 if (
MemoryDescriptor->BasePage + RequiredPages >= MM_MAX_PAGE_LOADER)
continue;
472 PageLookupTableEndPage =
min(CandidateBasePage + CandidatePageCount,
476 PageLookupTableMemAddress = (
PVOID)((PageLookupTableEndPage *
PAGE_SIZE)
477 - PageLookupTableSize);
479 TRACE(
"MmFindLocationForPageLookupTable() returning 0x%x\n", PageLookupTableMemAddress);
481 return PageLookupTableMemAddress;
490 TRACE(
"MmInitPageLookupTable()\n");
504 TRACE(
"Marking pages 0x%lx-0x%lx as type %s\n",
514 TRACE(
"Ignoring pages 0x%lx-0x%lx (%s)\n",
523 TRACE(
"Marking the page lookup table pages as reserved StartPage: 0x%x PageCount: 0x%x\n", PageLookupTableStartPage, PageLookupTablePageCount);
531 TRACE(
"MmMarkPagesInLookupTable()\n");
537 ERR(
"Memory (0x%lx:0x%lx) outside of lookup table! Valid range: 0x%lx-0x%lx.\n",
554 TRACE(
"MmMarkPagesInLookupTable() Done\n");
585 return FreePageCount;
599 AvailablePagesSoFar = 0;
607 AvailablePagesSoFar = 0;
612 AvailablePagesSoFar++;
615 if (AvailablePagesSoFar >= PagesNeeded)
629 AvailablePagesSoFar = 0;
634 AvailablePagesSoFar++;
637 if (AvailablePagesSoFar >= PagesNeeded)
653 if (LastPage > TotalPageCount)
658 AvailablePagesSoFar = 0;
663 AvailablePagesSoFar = 0;
668 AvailablePagesSoFar++;
671 if (AvailablePagesSoFar >= PagesNeeded)
709 if ((
StartPage + PageCount) > TotalPageCount)
BIOS_MEMORY_MAP MemoryMap[32]
DECLSPEC_NORETURN VOID FrLdrBugCheckWithMessage(ULONG BugCode, PCHAR File, ULONG Line, PSTR Format,...)
#define MAX_FREELDR_PE_SIZE
@ FREELDR_IMAGE_CORRUPTION
#define DBG_DEFAULT_CHANNEL(ch)
struct PAGE_LOOKUP_TABLE_ITEM * PPAGE_LOOKUP_TABLE_ITEM
VOID MmInitializeHeap(PVOID PageLookupTable)
#define FREELDR_SECTION_COUNT
#define ROUND_UP(n, align)
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
PVOID PageLookupTableAddress
PFN_NUMBER MmGetAddressablePageCountIncludingHoles(VOID)
PFREELDR_MEMORY_DESCRIPTOR BiosMemoryMap
static VOID MmCheckFreeldrImageFile(VOID)
PFN_NUMBER TotalPagesInLookupTable
PFN_NUMBER MmGetPageNumberFromAddress(PVOID Address)
VOID MmMarkPagesInLookupTable(PVOID PageLookupTable, PFN_NUMBER StartPage, PFN_NUMBER PageCount, TYPE_OF_MEMORY PageAllocated)
PFN_NUMBER MmFindAvailablePages(PVOID PageLookupTable, PFN_NUMBER TotalPageCount, PFN_NUMBER PagesNeeded, BOOLEAN FromEnd)
const FREELDR_MEMORY_DESCRIPTOR * ArcGetMemoryDescriptor(const FREELDR_MEMORY_DESCRIPTOR *Current)
BOOLEAN MmInitializeMemoryManager(VOID)
VOID MmInitPageLookupTable(PVOID PageLookupTable, PFN_NUMBER TotalPageCount)
PFN_NUMBER MmCountFreePagesInLookupTable(PVOID PageLookupTable, PFN_NUMBER TotalPageCount)
PFN_NUMBER MmLowestPhysicalPage
PCSTR MmGetSystemMemoryMapTypeString(TYPE_OF_MEMORY Type)
PFN_NUMBER FreePagesInLookupTable
PFN_NUMBER MmFindAvailablePagesBeforePage(PVOID PageLookupTable, PFN_NUMBER TotalPageCount, PFN_NUMBER PagesNeeded, PFN_NUMBER LastPage)
ULONG MmGetBiosMemoryMap(_Out_ PFREELDR_MEMORY_DESCRIPTOR *MemoryMap)
VOID MmUpdateLastFreePageHint(PVOID PageLookupTable, PFN_NUMBER TotalPageCount)
PFN_NUMBER MmHighestPhysicalPage
PVOID MmFindLocationForPageLookupTable(PFN_NUMBER TotalPageCount)
PFN_NUMBER LastFreePageHint
ULONG AddMemoryDescriptor(IN OUT PFREELDR_MEMORY_DESCRIPTOR List, IN ULONG MaxCount, IN PFN_NUMBER BasePage, IN PFN_NUMBER PageCount, IN TYPE_OF_MEMORY MemoryType)
VOID MmAllocatePagesInLookupTable(PVOID PageLookupTable, PFN_NUMBER StartPage, PFN_NUMBER PageCount, TYPE_OF_MEMORY MemoryType)
BOOLEAN MmAreMemoryPagesAvailable(PVOID PageLookupTable, PFN_NUMBER TotalPageCount, PVOID PageAddress, PFN_NUMBER PageCount)
PFN_NUMBER MmGetHighestPhysicalPage(VOID)
ULONG BiosMemoryMapEntryCount
PFN_NUMBER MmGetTotalPagesInLookupTable(VOID)
#define IMAGE_SUBSYSTEM_NATIVE
#define IMAGE_NT_OPTIONAL_HDR_MAGIC
@ LoaderFirmwareTemporary
@ LoaderFirmwarePermanent
enum _TYPE_OF_MEMORY TYPE_OF_MEMORY
PFN_NUMBER PageAllocationLength
TYPE_OF_MEMORY PageAllocated
PFREELDR_MEMORY_DESCRIPTOR(* GetMemoryMap)(PULONG MaxMemoryMapSize)
#define RtlMoveMemory(Destination, Source, Length)
_In_ WDFCOLLECTION _In_ ULONG Index
_Must_inspect_result_ _In_ WDFCMRESLIST List
_Must_inspect_result_ _In_ WDFUSBDEVICE _In_opt_ WDFREQUEST _In_opt_ PWDF_REQUEST_SEND_OPTIONS _In_ PWDF_USB_CONTROL_SETUP_PACKET _In_opt_ PWDF_MEMORY_DESCRIPTOR MemoryDescriptor
int WINAPI EndPage(_In_ HDC)
int WINAPI StartPage(_In_ HDC)
_Must_inspect_result_ _In_ SIZE_T _In_ PVOID PageAddress