summaryrefslogtreecommitdiffstats
path: root/mm/memory-failure.c
diff options
context:
space:
mode:
authorMiaohe Lin <linmiaohe@huawei.com>2023-07-11 07:50:12 +0200
committerAndrew Morton <akpm@linux-foundation.org>2023-08-18 19:12:19 +0200
commit55c7ac4527086d52dedc5da4ee3d676bcc9a7691 (patch)
tree2b9da0860dcb6d8b75517503e9b018dd666b8fce /mm/memory-failure.c
parentmm: memory-failure: don't account hwpoison_filter() filtered pages (diff)
downloadlinux-55c7ac4527086d52dedc5da4ee3d676bcc9a7691.tar.xz
linux-55c7ac4527086d52dedc5da4ee3d676bcc9a7691.zip
mm: memory-failure: use local variable huge to check hugetlb page
Use local variable huge to check whether page is hugetlb page to avoid calling PageHuge() multiple times to save cpu cycles. PageHuge() will be stable while extra page refcnt is held. Link: https://lkml.kernel.org/r/20230711055016.2286677-5-linmiaohe@huawei.com Signed-off-by: Miaohe Lin <linmiaohe@huawei.com> Acked-by: Naoya Horiguchi <naoya.horiguchi@nec.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Diffstat (limited to '')
-rw-r--r--mm/memory-failure.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/mm/memory-failure.c b/mm/memory-failure.c
index cac5413c5cc3..3b734d51e6de 100644
--- a/mm/memory-failure.c
+++ b/mm/memory-failure.c
@@ -2617,7 +2617,7 @@ static int soft_offline_in_use_page(struct page *page)
}
lock_page(page);
- if (!PageHuge(page))
+ if (!huge)
wait_on_page_writeback(page);
if (PageHWPoison(page)) {
unlock_page(page);
@@ -2626,7 +2626,7 @@ static int soft_offline_in_use_page(struct page *page)
return 0;
}
- if (!PageHuge(page) && PageLRU(page) && !PageSwapCache(page))
+ if (!huge && PageLRU(page) && !PageSwapCache(page))
/*
* Try to invalidate first. This should work for
* non dirty unmapped page cache pages.