Commit 6c5c7b9f authored by Zi Yan's avatar Zi Yan Committed by Linus Torvalds

mm/migrate: correct thp migration stats

PageTransHuge returns true for both thp and hugetlb, so thp stats was
counting both thp and hugetlb migrations.  Exclude hugetlb migration by
setting is_thp variable right.

Clean up thp handling code too when we are there.

Fixes: 1a5bae25 ("mm/vmstat: add events for THP migration without split")
Signed-off-by: default avatarZi Yan <ziy@nvidia.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Reviewed-by: default avatarDaniel Jordan <daniel.m.jordan@oracle.com>
Cc: Anshuman Khandual <anshuman.khandual@arm.com>
Link: https://lkml.kernel.org/r/20200917210413.1462975-1-zi.yan@sent.comSigned-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent d3f7b1bb
...@@ -1446,7 +1446,7 @@ int migrate_pages(struct list_head *from, new_page_t get_new_page, ...@@ -1446,7 +1446,7 @@ int migrate_pages(struct list_head *from, new_page_t get_new_page,
* Capture required information that might get lost * Capture required information that might get lost
* during migration. * during migration.
*/ */
is_thp = PageTransHuge(page); is_thp = PageTransHuge(page) && !PageHuge(page);
nr_subpages = thp_nr_pages(page); nr_subpages = thp_nr_pages(page);
cond_resched(); cond_resched();
...@@ -1472,7 +1472,7 @@ int migrate_pages(struct list_head *from, new_page_t get_new_page, ...@@ -1472,7 +1472,7 @@ int migrate_pages(struct list_head *from, new_page_t get_new_page,
* we encounter them after the rest of the list * we encounter them after the rest of the list
* is processed. * is processed.
*/ */
if (PageTransHuge(page) && !PageHuge(page)) { if (is_thp) {
lock_page(page); lock_page(page);
rc = split_huge_page_to_list(page, from); rc = split_huge_page_to_list(page, from);
unlock_page(page); unlock_page(page);
...@@ -1481,8 +1481,7 @@ int migrate_pages(struct list_head *from, new_page_t get_new_page, ...@@ -1481,8 +1481,7 @@ int migrate_pages(struct list_head *from, new_page_t get_new_page,
nr_thp_split++; nr_thp_split++;
goto retry; goto retry;
} }
}
if (is_thp) {
nr_thp_failed++; nr_thp_failed++;
nr_failed += nr_subpages; nr_failed += nr_subpages;
goto out; goto out;
......
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