mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-07 14:32:23 +00:00
mm: do not use page_count() without a page pin
d179e84ba
("mm: vmscan: do not use page_count without a page pin") fixed
this problem in vmscan.c but same problem is in __count_immobile_pages().
I copy and paste d179e84ba's contents for description.
"It is unsafe to run page_count during the physical pfn scan because
compound_head could trip on a dangling pointer when reading
page->first_page if the compound page is being freed by another CPU."
Signed-off-by: Minchan Kim <minchan@kernel.org>
Cc: Andrea Arcangeli <aarcange@redhat.com>
Cc: Mel Gorman <mgorman@suse.de>
Cc: Michal Hocko <mhocko@suse.cz>
Reviewed-by: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
Cc: Wanpeng Li <liwp.linux@gmail.com>
Cc: Bartlomiej Zolnierkiewicz <b.zolnierkie@samsung.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
de34d965a8
commit
97d255c816
@ -5500,11 +5500,18 @@ __count_immobile_pages(struct zone *zone, struct page *page, int count)
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
page = pfn_to_page(check);
|
page = pfn_to_page(check);
|
||||||
if (!page_count(page)) {
|
/*
|
||||||
|
* We can't use page_count without pin a page
|
||||||
|
* because another CPU can free compound page.
|
||||||
|
* This check already skips compound tails of THP
|
||||||
|
* because their page->_count is zero at all time.
|
||||||
|
*/
|
||||||
|
if (!atomic_read(&page->_count)) {
|
||||||
if (PageBuddy(page))
|
if (PageBuddy(page))
|
||||||
iter += (1 << page_order(page)) - 1;
|
iter += (1 << page_order(page)) - 1;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!PageLRU(page))
|
if (!PageLRU(page))
|
||||||
found++;
|
found++;
|
||||||
/*
|
/*
|
||||||
|
Loading…
Reference in New Issue
Block a user