mm: check PageUnevictable in lru_deactivate_fn()
The lru_deactivate_fn should not move page which in on unevictable lru into inactive list. Otherwise, we can meet BUG when we use isolate_lru_pages as __isolate_lru_page could return -EINVAL. Reported-by: Ying Han <yinghan@google.com> Tested-by: Ying Han <yinghan@google.com> Signed-off-by: Minchan Kim <minchan.kim@gmail.com> Reviewed-by: KOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com> Reviewed-by: Rik van Riel<riel@redhat.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
committed by
Linus Torvalds
parent
52cd4e5c62
commit
bad49d9c89
@@ -396,6 +396,9 @@ static void lru_deactivate_fn(struct page *page, void *arg)
|
|||||||
if (!PageLRU(page))
|
if (!PageLRU(page))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if (PageUnevictable(page))
|
||||||
|
return;
|
||||||
|
|
||||||
/* Some processes are using the page */
|
/* Some processes are using the page */
|
||||||
if (page_mapped(page))
|
if (page_mapped(page))
|
||||||
return;
|
return;
|
||||||
|
|||||||
Reference in New Issue
Block a user