2009-06-27 22:39:03 +00:00
|
|
|
/*
|
|
|
|
* PROJECT: ReactOS Kernel
|
|
|
|
* LICENSE: BSD - See COPYING.ARM in the top level directory
|
|
|
|
* FILE: ntoskrnl/mm/ARM3/dynamic.c
|
|
|
|
* PURPOSE: ARM Memory Manager Dynamic Physical Memory Support
|
|
|
|
* PROGRAMMERS: ReactOS Portable Systems Group
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* INCLUDES *******************************************************************/
|
|
|
|
|
|
|
|
#include <ntoskrnl.h>
|
|
|
|
#define NDEBUG
|
|
|
|
#include <debug.h>
|
|
|
|
|
|
|
|
#define MODULE_INVOLVED_IN_ARM3
|
2014-11-10 16:26:55 +00:00
|
|
|
#include <mm/ARM3/miarm.h>
|
2009-06-27 22:39:03 +00:00
|
|
|
|
|
|
|
/* FUNCTIONS *****************************************************************/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @unimplemented
|
|
|
|
*/
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
MmAddPhysicalMemory (IN PPHYSICAL_ADDRESS StartAddress,
|
|
|
|
IN OUT PLARGE_INTEGER NumberOfBytes)
|
|
|
|
{
|
|
|
|
UNIMPLEMENTED;
|
|
|
|
return STATUS_NOT_IMPLEMENTED;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @unimplemented
|
|
|
|
*/
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
MmMarkPhysicalMemoryAsBad(IN PPHYSICAL_ADDRESS StartAddress,
|
|
|
|
IN OUT PLARGE_INTEGER NumberOfBytes)
|
|
|
|
{
|
|
|
|
UNIMPLEMENTED;
|
|
|
|
return STATUS_NOT_IMPLEMENTED;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @unimplemented
|
|
|
|
*/
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
MmMarkPhysicalMemoryAsGood(IN PPHYSICAL_ADDRESS StartAddress,
|
|
|
|
IN OUT PLARGE_INTEGER NumberOfBytes)
|
|
|
|
{
|
|
|
|
UNIMPLEMENTED;
|
|
|
|
return STATUS_NOT_IMPLEMENTED;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @unimplemented
|
|
|
|
*/
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
MmRemovePhysicalMemory(IN PPHYSICAL_ADDRESS StartAddress,
|
|
|
|
IN OUT PLARGE_INTEGER NumberOfBytes)
|
|
|
|
{
|
|
|
|
UNIMPLEMENTED;
|
|
|
|
return STATUS_NOT_IMPLEMENTED;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @implemented
|
|
|
|
*/
|
|
|
|
PPHYSICAL_MEMORY_RANGE
|
|
|
|
NTAPI
|
|
|
|
MmGetPhysicalMemoryRanges(VOID)
|
|
|
|
{
|
|
|
|
ULONG Size, i;
|
2010-12-26 15:23:03 +00:00
|
|
|
PPHYSICAL_MEMORY_RANGE Entry, Buffer;
|
2009-06-27 22:39:03 +00:00
|
|
|
KIRQL OldIrql;
|
|
|
|
ASSERT(KeGetCurrentIrql() == PASSIVE_LEVEL);
|
|
|
|
|
|
|
|
//
|
|
|
|
// Calculate how much memory we'll need
|
|
|
|
//
|
|
|
|
Size = sizeof(PHYSICAL_MEMORY_RANGE) * (MmPhysicalMemoryBlock->NumberOfRuns + 1);
|
2010-12-26 15:23:03 +00:00
|
|
|
|
2009-06-27 22:39:03 +00:00
|
|
|
//
|
|
|
|
// Allocate a copy
|
|
|
|
//
|
|
|
|
Entry = Buffer = ExAllocatePoolWithTag(NonPagedPool, Size, 'hPmM');
|
|
|
|
if (!Buffer) return NULL;
|
|
|
|
|
|
|
|
//
|
|
|
|
// Lock the PFN database
|
|
|
|
//
|
2017-11-21 22:33:42 +00:00
|
|
|
OldIrql = MiAcquirePfnLock();
|
2010-12-26 15:23:03 +00:00
|
|
|
|
2009-06-27 22:39:03 +00:00
|
|
|
//
|
|
|
|
// Make sure it hasn't changed before we had acquired the lock
|
|
|
|
//
|
2010-12-26 15:23:03 +00:00
|
|
|
ASSERT(Size == (sizeof(PHYSICAL_MEMORY_RANGE) *
|
2009-06-27 22:39:03 +00:00
|
|
|
(MmPhysicalMemoryBlock->NumberOfRuns + 1)));
|
2010-12-26 15:23:03 +00:00
|
|
|
|
2009-06-27 22:39:03 +00:00
|
|
|
//
|
|
|
|
// Now loop our block
|
|
|
|
//
|
|
|
|
for (i = 0; i < MmPhysicalMemoryBlock->NumberOfRuns; i++)
|
|
|
|
{
|
|
|
|
//
|
|
|
|
// Copy the data, but format it into bytes
|
|
|
|
//
|
|
|
|
Entry->BaseAddress.QuadPart = MmPhysicalMemoryBlock->Run[i].BasePage << PAGE_SHIFT;
|
|
|
|
Entry->NumberOfBytes.QuadPart = MmPhysicalMemoryBlock->Run[i].PageCount << PAGE_SHIFT;
|
|
|
|
Entry++;
|
|
|
|
}
|
2010-12-26 15:23:03 +00:00
|
|
|
|
2009-06-27 22:39:03 +00:00
|
|
|
//
|
|
|
|
// Last entry is empty
|
|
|
|
//
|
|
|
|
Entry->BaseAddress.QuadPart = 0;
|
|
|
|
Entry->NumberOfBytes.QuadPart = 0;
|
|
|
|
|
|
|
|
//
|
|
|
|
// Release the lock and return
|
|
|
|
//
|
2017-11-21 22:33:42 +00:00
|
|
|
MiReleasePfnLock(OldIrql);
|
2009-06-27 22:39:03 +00:00
|
|
|
return Buffer;
|
|
|
|
}
|