[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20230125134434.18017-1-mgorman@techsingularity.net>
Date: Wed, 25 Jan 2023 13:44:30 +0000
From: Mel Gorman <mgorman@...hsingularity.net>
To: Vlastimil Babka <vbabka@...e.cz>
Cc: Andrew Morton <akpm@...ux-foundation.org>,
Jiri Slaby <jirislaby@...nel.org>,
Maxim Levitsky <mlevitsk@...hat.com>,
Michal Hocko <mhocko@...nel.org>,
Pedro Falcato <pedro.falcato@...il.com>,
Paolo Bonzini <pbonzini@...hat.com>,
Chuyi Zhou <zhouchuyi@...edance.com>,
Linux-MM <linux-mm@...ck.org>,
LKML <linux-kernel@...r.kernel.org>,
Mel Gorman <mgorman@...hsingularity.net>
Subject: [RFC PATCH 0/4] Fix excessive CPU usage during compaction
Commit 7efc3b726103 ("mm/compaction: fix set skip in fast_find_migrateblock")
fixed a problem where pageblocks found by fast_find_migrateblock() were
ignored. Unfortunately there were numerous bug reports complaining about high
CPU usage and massive stalls once 6.1 was released. Due to the severity,
the patch was reverted by Vlastimil as a short-term fix[1] to -stable and
is currently sitting in the Andrew's git branch mm/mm-hotfixes-unstable.
The underlying problem for each of the bugs is suspected to be the
repeated scanning of the same pageblocks. This series should guarantee
forward progress even with commit 7efc3b726103. More information is in
the changelog for patch 4.
If this series is accepted and merged after the revert of 7efc3b726103
then a "revert of the revert" will be needed.
[1] http://lore.kernel.org/r/20230113173345.9692-1-vbabka@suse.cz
mm/compaction.c | 73 +++++++++++++++++++++++++++++++------------------
mm/internal.h | 6 +++-
2 files changed, 52 insertions(+), 27 deletions(-)
--
2.35.3
Mel Gorman (4):
mm, compaction: Rename compact_control->rescan to finish_pageblock
mm, compaction: Check if a page has been captured before draining PCP
pages
mm, compaction: Finish scanning the current pageblock if requested
mm, compaction: Finish pageblocks on complete migration failure
mm/compaction.c | 73 +++++++++++++++++++++++++++++++------------------
mm/internal.h | 6 +++-
2 files changed, 52 insertions(+), 27 deletions(-)
--
2.35.3
Powered by blists - more mailing lists