mirror of
https://github.com/reactos/reactos.git
synced 2025-07-23 13:03:47 +00:00
[NTOS]: Start using colored pages. This will help performance on real systems significantly as cache is now taken into account by the memory manager. Also radically changes the way page allocations are given out and creates a less uniform physical memory layout. The fact this now works means that the PFN lists are finally now sane.
svn path=/trunk/; revision=49559
This commit is contained in:
parent
d5c3a8295f
commit
ef4089933a
1 changed files with 3 additions and 14 deletions
|
@ -356,18 +356,15 @@ MiRemoveAnyPage(IN ULONG Color)
|
|||
ASSERT(KeGetCurrentIrql() == DISPATCH_LEVEL);
|
||||
ASSERT(MmAvailablePages != 0);
|
||||
ASSERT(Color < MmSecondaryColors);
|
||||
#if 0
|
||||
|
||||
/* Check the colored free list */
|
||||
PageIndex = MmFreePagesByColor[FreePageList][Color].Flink;
|
||||
DPRINT1("Found free page: %lx\n", PageIndex);
|
||||
if (PageIndex == LIST_HEAD)
|
||||
{
|
||||
/* Check the colored zero list */
|
||||
PageIndex = MmFreePagesByColor[ZeroedPageList][Color].Flink;
|
||||
DPRINT1("Found zero page: %lx\n", PageIndex);
|
||||
if (PageIndex == LIST_HEAD)
|
||||
{
|
||||
#endif
|
||||
/* Check the free list */
|
||||
ASSERT_LIST_INVARIANT(&MmFreePageListHead);
|
||||
PageIndex = MmFreePageListHead.Flink;
|
||||
|
@ -385,10 +382,9 @@ MiRemoveAnyPage(IN ULONG Color)
|
|||
ASSERT(MmZeroedPageListHead.Total == 0);
|
||||
}
|
||||
}
|
||||
#if 0
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
/* Remove the page from its list */
|
||||
PageIndex = MiRemovePageByColor(PageIndex, Color);
|
||||
|
||||
|
@ -419,11 +415,9 @@ MiRemoveZeroPage(IN ULONG Color)
|
|||
ASSERT(Color < MmSecondaryColors);
|
||||
|
||||
/* Check the colored zero list */
|
||||
#if 0
|
||||
PageIndex = MmFreePagesByColor[ZeroedPageList][Color].Flink;
|
||||
if (PageIndex == LIST_HEAD)
|
||||
{
|
||||
#endif
|
||||
/* Check the zero list */
|
||||
ASSERT_LIST_INVARIANT(&MmZeroedPageListHead);
|
||||
PageIndex = MmZeroedPageListHead.Flink;
|
||||
|
@ -433,12 +427,11 @@ MiRemoveZeroPage(IN ULONG Color)
|
|||
/* This means there's no zero pages, we have to look for free ones */
|
||||
ASSERT(MmZeroedPageListHead.Total == 0);
|
||||
Zero = TRUE;
|
||||
#if 0
|
||||
|
||||
/* Check the colored free list */
|
||||
PageIndex = MmFreePagesByColor[FreePageList][Color].Flink;
|
||||
if (PageIndex == LIST_HEAD)
|
||||
{
|
||||
#endif
|
||||
/* Check the free list */
|
||||
ASSERT_LIST_INVARIANT(&MmFreePageListHead);
|
||||
PageIndex = MmFreePageListHead.Flink;
|
||||
|
@ -449,13 +442,9 @@ MiRemoveZeroPage(IN ULONG Color)
|
|||
/* FIXME: Should check the standby list */
|
||||
ASSERT(MmZeroedPageListHead.Total == 0);
|
||||
}
|
||||
#if 0
|
||||
}
|
||||
#endif
|
||||
}
|
||||
#if 0
|
||||
}
|
||||
#endif
|
||||
|
||||
/* Sanity checks */
|
||||
Pfn1 = MI_PFN_ELEMENT(PageIndex);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue