Commit c653414d authored by Mel Gorman's avatar Mel Gorman Committed by Ben Hutchings

mm: reduce the amount of work done when updating min_free_kbytes

commit 938929f1 upstream.

Stable note: Fixes https://bugzilla.novell.com/show_bug.cgi?id=726210 .
        Large machines with 1TB or more of RAM take a long time to boot
        without this patch and may spew out soft lockup warnings.

When min_free_kbytes is updated, some pageblocks are marked
MIGRATE_RESERVE.  Ordinarily, this work is unnoticable as it happens early
in boot but on large machines with 1TB of memory, this has been reported
to delay boot times, probably due to the NUMA distances involved.

The bulk of the work is due to calling calling pageblock_is_reserved() an
unnecessary amount of times and accessing far more struct page metadata
than is necessary.  This patch significantly reduces the amount of work
done by setup_zone_migrate_reserve() improving boot times on 1TB machines.

[akpm@linux-foundation.org: coding-style fixes]
Signed-off-by: default avatarMel Gorman <mgorman@suse.de>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: default avatarBen Hutchings <ben@decadent.org.uk>
parent f1e79c6a
...@@ -3407,26 +3407,34 @@ static void setup_zone_migrate_reserve(struct zone *zone) ...@@ -3407,26 +3407,34 @@ static void setup_zone_migrate_reserve(struct zone *zone)
if (page_to_nid(page) != zone_to_nid(zone)) if (page_to_nid(page) != zone_to_nid(zone))
continue; continue;
/* Blocks with reserved pages will never free, skip them. */ block_migratetype = get_pageblock_migratetype(page);
/* Only test what is necessary when the reserves are not met */
if (reserve > 0) {
/*
* Blocks with reserved pages will never free, skip
* them.
*/
block_end_pfn = min(pfn + pageblock_nr_pages, end_pfn); block_end_pfn = min(pfn + pageblock_nr_pages, end_pfn);
if (pageblock_is_reserved(pfn, block_end_pfn)) if (pageblock_is_reserved(pfn, block_end_pfn))
continue; continue;
block_migratetype = get_pageblock_migratetype(page);
/* If this block is reserved, account for it */ /* If this block is reserved, account for it */
if (reserve > 0 && block_migratetype == MIGRATE_RESERVE) { if (block_migratetype == MIGRATE_RESERVE) {
reserve--; reserve--;
continue; continue;
} }
/* Suitable for reserving if this block is movable */ /* Suitable for reserving if this block is movable */
if (reserve > 0 && block_migratetype == MIGRATE_MOVABLE) { if (block_migratetype == MIGRATE_MOVABLE) {
set_pageblock_migratetype(page, MIGRATE_RESERVE); set_pageblock_migratetype(page,
move_freepages_block(zone, page, MIGRATE_RESERVE); MIGRATE_RESERVE);
move_freepages_block(zone, page,
MIGRATE_RESERVE);
reserve--; reserve--;
continue; continue;
} }
}
/* /*
* If the reserve is met and this is a previous reserved block, * If the reserve is met and this is a previous reserved block,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment