]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
mm: skip mlocked THPs that are underused early in deferred_split_scan()
authorLance Yang <lance.yang@linux.dev>
Mon, 8 Sep 2025 09:07:41 +0000 (17:07 +0800)
committerAndrew Morton <akpm@linux-foundation.org>
Fri, 12 Sep 2025 00:26:01 +0000 (17:26 -0700)
When we stumble over a fully-mapped mlocked THP in the deferred shrinker,
it does not make sense to try to detect whether it is underused, because
try_to_map_unused_to_zeropage(), called while splitting the folio, will
not actually replace any zeroed pages by the shared zeropage.

Splitting the folio in that case does not make any sense, so let's not
even scan to check if the folio is underused.

Link: https://lkml.kernel.org/r/20250908090741.61519-1-lance.yang@linux.dev
Signed-off-by: Lance Yang <lance.yang@linux.dev>
Suggested-by: David Hildenbrand <david@redhat.com>
Acked-by: David Hildenbrand <david@redhat.com>
Acked-by: Usama Arif <usamaarif642@gmail.com>
Reviewed-by: Lorenzo Stoakes <lorenzo.stoakes@oracle.com>
Reviewed-by: Baolin Wang <baolin.wang@linux.alibaba.com>
Cc: Barry Song <baohua@kernel.org>
Cc: Dev Jain <dev.jain@arm.com>
Cc: Lance Yang <lance.yang@linux.dev>
Cc: Liam Howlett <liam.howlett@oracle.com>
Cc: Mariano Pache <npache@redhat.com>
Cc: Ryan Roberts <ryan.roberts@arm.com>
Cc: Zi Yan <ziy@nvidia.com>
Cc: Kiryl Shutsemau <kirill@shutemov.name>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
mm/huge_memory.c

index a9fc7a09167a7c53b21b7fda5b9f2af05fc73ffb..5acca24bbabbec2ab6c7b881ddf30441bf14cf77 100644 (file)
@@ -4175,6 +4175,13 @@ static unsigned long deferred_split_scan(struct shrinker *shrink,
                bool underused = false;
 
                if (!folio_test_partially_mapped(folio)) {
+                       /*
+                        * See try_to_map_unused_to_zeropage(): we cannot
+                        * optimize zero-filled pages after splitting an
+                        * mlocked folio.
+                        */
+                       if (folio_test_mlocked(folio))
+                               goto next;
                        underused = thp_underused(folio);
                        if (!underused)
                                goto next;