linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH v1] hugetlb: pass head page to remove_hugetlb_page()
@ 2021-05-26 23:52 Naoya Horiguchi
  2021-05-27  0:31 ` Matthew Wilcox
                   ` (5 more replies)
  0 siblings, 6 replies; 10+ messages in thread
From: Naoya Horiguchi @ 2021-05-26 23:52 UTC (permalink / raw)
  To: linux-mm, Mike Kravetz
  Cc: Michal Hocko, Oscar Salvador, Muchun Song, Andrew Morton,
	David Hildenbrand, Naoya Horiguchi, linux-kernel

From: Naoya Horiguchi <naoya.horiguchi@nec.com>

When memory_failure() or soft_offline_page() is called on a tail page of
some hugetlb page, "BUG: unable to handle page fault" error can be
triggered.

remove_hugetlb_page() dereferences page->lru, so it's assumed that the
page points to a head page, but one of the caller,
dissolve_free_huge_page(), provides remove_hugetlb_page() with 'page'
which could be a tail page.  So pass 'head' to it, instead.

Fixes: 6eb4e88a6d27 ("hugetlb: create remove_hugetlb_page() to separate functionality")
Signed-off-by: Naoya Horiguchi <naoya.horiguchi@nec.com>
---
 mm/hugetlb.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git v5.13-rc3/mm/hugetlb.c v5.13-rc3_patched/mm/hugetlb.c
index 95918f410c0f..470f7b5b437e 100644
--- v5.13-rc3/mm/hugetlb.c
+++ v5.13-rc3_patched/mm/hugetlb.c
@@ -1793,7 +1793,7 @@ int dissolve_free_huge_page(struct page *page)
 			SetPageHWPoison(page);
 			ClearPageHWPoison(head);
 		}
-		remove_hugetlb_page(h, page, false);
+		remove_hugetlb_page(h, head, false);
 		h->max_huge_pages--;
 		spin_unlock_irq(&hugetlb_lock);
 		update_and_free_page(h, head);
-- 
2.25.1


^ permalink raw reply related	[flat|nested] 10+ messages in thread

end of thread, other threads:[~2021-05-27 21:12 UTC | newest]

Thread overview: 10+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-05-26 23:52 [PATCH v1] hugetlb: pass head page to remove_hugetlb_page() Naoya Horiguchi
2021-05-27  0:31 ` Matthew Wilcox
2021-05-27  0:55 ` Mike Kravetz
2021-05-27  2:43 ` [External] " Muchun Song
2021-05-27  6:58 ` Michal Hocko
2021-05-27  7:47 ` Oscar Salvador
2021-05-27  8:22   ` Michal Hocko
2021-05-27 16:28 ` Mike Kravetz
2021-05-27 19:54   ` Michal Hocko
2021-05-27 21:12     ` Mike Kravetz

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).