Commit 9bebefd5 authored by Mel Gorman's avatar Mel Gorman Committed by Linus Torvalds

mm, compaction: check early for huge pages encountered by the migration scanner

When scanning for sources or targets, PageCompound is checked for huge
pages as they can be skipped quickly but it happens relatively late
after a lot of setup and checking.  This patch short-cuts the check to
make it earlier.  It might still change when the lock is acquired but
this has less overhead overall.  The free scanner advances but the
migration scanner does not.  Typically the free scanner encounters more
movable blocks that change state over the lifetime of the system and
also tends to scan more aggressively as it's actively filling its
portion of the physical address space with data.  This could change in
the future but for the moment, this worked better in practice and
incurred fewer scan restarts.

The impact on latency and allocation success rates is marginal but the
free scan rates are reduced by 15% and system CPU usage is reduced by
3.3%.  The 2-socket results are not materially different.

Link: http://lkml.kernel.org/r/20190118175136.31341-15-mgorman@techsingularity.netSigned-off-by: default avatarMel Gorman <mgorman@techsingularity.net>
Acked-by: default avatarVlastimil Babka <vbabka@suse.cz>
Cc: Andrea Arcangeli <aarcange@redhat.com>
Cc: Dan Carpenter <dan.carpenter@oracle.com>
Cc: David Rientjes <rientjes@google.com>
Cc: YueHaibing <yuehaibing@huawei.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent cb2dcaf0
...@@ -1061,6 +1061,9 @@ static bool suitable_migration_source(struct compact_control *cc, ...@@ -1061,6 +1061,9 @@ static bool suitable_migration_source(struct compact_control *cc,
{ {
int block_mt; int block_mt;
if (pageblock_skip_persistent(page))
return false;
if ((cc->mode != MIGRATE_ASYNC) || !cc->direct_compaction) if ((cc->mode != MIGRATE_ASYNC) || !cc->direct_compaction)
return true; return true;
...@@ -1697,12 +1700,17 @@ static isolate_migrate_t isolate_migratepages(struct zone *zone, ...@@ -1697,12 +1700,17 @@ static isolate_migrate_t isolate_migratepages(struct zone *zone,
continue; continue;
/* /*
* For async compaction, also only scan in MOVABLE blocks. * For async compaction, also only scan in MOVABLE blocks
* Async compaction is optimistic to see if the minimum amount * without huge pages. Async compaction is optimistic to see
* of work satisfies the allocation. * if the minimum amount of work satisfies the allocation.
* The cached PFN is updated as it's possible that all
* remaining blocks between source and target are unsuitable
* and the compaction scanners fail to meet.
*/ */
if (!suitable_migration_source(cc, page)) if (!suitable_migration_source(cc, page)) {
update_cached_migrate(cc, block_end_pfn);
continue; continue;
}
/* Perform the isolation */ /* Perform the isolation */
low_pfn = isolate_migratepages_block(cc, low_pfn, low_pfn = isolate_migratepages_block(cc, low_pfn,
......
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