• Mel Gorman's avatar
    mm, compaction: reduce premature advancement of the migration target scanner · d097a6f6
    Mel Gorman authored
    The fast isolation of free pages allows the cached PFN of the free
    scanner to advance faster than necessary depending on the contents of
    the free list.  The key is that fast_isolate_freepages() can update
    zone->compact_cached_free_pfn via isolate_freepages_block().  When the
    fast search fails, the linear scan can start from a point that has
    skipped valid migration targets, particularly pageblocks with just
    low-order free pages.  This can cause the migration source/target
    scanners to meet prematurely causing a reset.
    
    This patch starts by avoiding an update of the pageblock skip
    information and cached PFN from isolate_freepages_block() and puts the
    responsibility of updating that information in the callers.  The fast
    scanner will update the cached PFN if and only if it finds a block that
    is higher than the existing cached PFN and sets the skip if the
    pageblock is full or nearly full.  The linear scanner will update
    skipped information and the cached PFN only when a block is completely
    scanned.  The total impact is that the free scanner advances more slowly
    as it is primarily driven by the linear scanner instead of the fast
    search.
    
                                         5.0.0-rc1              5.0.0-rc1
                                   noresched-v3r17         slowfree-v3r17
    Amean     fault-both-3      2965.68 (   0.00%)     3036.75 (  -2.40%)
    Amean     fault-both-5      3995.90 (   0.00%)     4522.24 * -13.17%*
    Amean     fault-both-7      5842.12 (   0.00%)     6365.35 (  -8.96%)
    Amean     fault-both-12     9550.87 (   0.00%)    10340.93 (  -8.27%)
    Amean     fault-both-18    13304.72 (   0.00%)    14732.46 ( -10.73%)
    Amean     fault-both-24    14618.59 (   0.00%)    16288.96 ( -11.43%)
    Amean     fault-both-30    16650.96 (   0.00%)    16346.21 (   1.83%)
    Amean     fault-both-32    17145.15 (   0.00%)    19317.49 ( -12.67%)
    
    The impact to latency is higher than the last version but it appears to
    be due to a slight increase in the free scan rates which is a potential
    side-effect of the patch.  However, this is necessary for later patches
    that are more careful about how pageblocks are treated as earlier
    iterations of those patches hit corner cases where the restarts were
    punishing and very visible.
    
    Link: http://lkml.kernel.org/r/20190118175136.31341-19-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>
    d097a6f6
compaction.c 70.8 KB