The patch titled Be more agressive about stealing when MIGRATE_RECLAIMABLE allocations fallback has been removed from the -mm tree. Its filename was be-more-agressive-about-stealing-when-migrate_reclaimable-allocations-fallback.patch This patch was dropped because it was merged into mainline or a subsystem tree ------------------------------------------------------ Subject: Be more agressive about stealing when MIGRATE_RECLAIMABLE allocations fallback From: Mel Gorman <mel@xxxxxxxxx> MIGRATE_RECLAIMABLE allocations tend to be very bursty in nature like when updatedb starts. It is likely this will occur in situations where MAX_ORDER blocks of pages are not free. This means that updatedb can scatter MIGRATE_RECLAIMABLE pages throughout the address space. This patch is more agressive about stealing blocks of pages for MIGRATE_RECLAIMABLE. Signed-off-by: Mel Gorman <mel@xxxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx> --- mm/page_alloc.c | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) diff -puN mm/page_alloc.c~be-more-agressive-about-stealing-when-migrate_reclaimable-allocations-fallback mm/page_alloc.c --- a/mm/page_alloc.c~be-more-agressive-about-stealing-when-migrate_reclaimable-allocations-fallback +++ a/mm/page_alloc.c @@ -821,11 +821,23 @@ retry: /* * If breaking a large block of pages, move all free - * pages to the preferred allocation list + * pages to the preferred allocation list. If falling + * back for a reclaimable kernel allocation, be more + * agressive about taking ownership of free pages */ - if (unlikely(current_order >= MAX_ORDER / 2)) { + if (unlikely(current_order >= MAX_ORDER / 2) || + start_migratetype == MIGRATE_RECLAIMABLE) { + unsigned long pages; + pages = move_freepages_block(zone, page, + start_migratetype); + + /* Claim the whole block if over half of it is free */ + if ((pages << current_order) >= (1 << (MAX_ORDER-2)) && + migratetype != MIGRATE_HIGHATOMIC) + set_pageblock_migratetype(page, + start_migratetype); + migratetype = start_migratetype; - move_freepages_block(zone, page, migratetype); } /* Remove the page from the freelists */ _ Patches currently in -mm which might be from mel@xxxxxxxxx are origin.patch ext2-reservations.patch page-owner-tracking-leak-detector.patch add-debugging-aid-for-memory-initialisation-problems.patch - To unsubscribe from this list: send the line "unsubscribe mm-commits" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html