提交 a0747c91 编写于 作者: M Minchan Kim 提交者: Shile Zhang

mm: change PAGEREF_RECLAIM_CLEAN with PAGE_REFRECLAIM

commit 8940b34a4e082ae11498ddae8432f2ac07685d1c upstream

The local variable references in shrink_page_list is PAGEREF_RECLAIM_CLEAN
as default.  It is for preventing to reclaim dirty pages when CMA try to
migrate pages.  Strictly speaking, we don't need it because CMA didn't
allow to write out by .may_writepage = 0 in reclaim_clean_pages_from_list.

Moreover, it has a problem to prevent anonymous pages's swap out even
though force_reclaim = true in shrink_page_list on upcoming patch.  So
this patch makes references's default value to PAGEREF_RECLAIM and rename
force_reclaim with ignore_references to make it more clear.

This is a preparatory work for next patch.

Link: http://lkml.kernel.org/r/20190726023435.214162-3-minchan@kernel.orgSigned-off-by: NMinchan Kim <minchan@kernel.org>
Acked-by: NMichal Hocko <mhocko@suse.com>
Acked-by: NJohannes Weiner <hannes@cmpxchg.org>
Cc: Chris Zankel <chris@zankel.net>
Cc: Daniel Colascione <dancol@google.com>
Cc: Dave Hansen <dave.hansen@intel.com>
Cc: Hillf Danton <hdanton@sina.com>
Cc: James E.J. Bottomley <James.Bottomley@HansenPartnership.com>
Cc: Joel Fernandes (Google) <joel@joelfernandes.org>
Cc: kbuild test robot <lkp@intel.com>
Cc: Kirill A. Shutemov <kirill.shutemov@linux.intel.com>
Cc: Oleksandr Natalenko <oleksandr@redhat.com>
Cc: Ralf Baechle <ralf@linux-mips.org>
Cc: Richard Henderson <rth@twiddle.net>
Cc: Shakeel Butt <shakeelb@google.com>
Cc: Sonny Rao <sonnyrao@google.com>
Cc: Suren Baghdasaryan <surenb@google.com>
Cc: Tim Murray <timmurray@google.com>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
Reviewed-by: NYang Shi <yang.shi@linux.alibaba.com>
Signed-off-by: NXunlei Pang <xlpang@linux.alibaba.com>
上级 27a374d1
...@@ -1182,7 +1182,7 @@ static unsigned long shrink_page_list(struct list_head *page_list, ...@@ -1182,7 +1182,7 @@ static unsigned long shrink_page_list(struct list_head *page_list,
struct scan_control *sc, struct scan_control *sc,
enum ttu_flags ttu_flags, enum ttu_flags ttu_flags,
struct reclaim_stat *stat, struct reclaim_stat *stat,
bool force_reclaim) bool ignore_references)
{ {
LIST_HEAD(ret_pages); LIST_HEAD(ret_pages);
LIST_HEAD(free_pages); LIST_HEAD(free_pages);
...@@ -1202,7 +1202,7 @@ static unsigned long shrink_page_list(struct list_head *page_list, ...@@ -1202,7 +1202,7 @@ static unsigned long shrink_page_list(struct list_head *page_list,
struct address_space *mapping; struct address_space *mapping;
struct page *page; struct page *page;
int may_enter_fs; int may_enter_fs;
enum page_references references = PAGEREF_RECLAIM_CLEAN; enum page_references references = PAGEREF_RECLAIM;
bool dirty, writeback; bool dirty, writeback;
cond_resched(); cond_resched();
...@@ -1334,7 +1334,7 @@ static unsigned long shrink_page_list(struct list_head *page_list, ...@@ -1334,7 +1334,7 @@ static unsigned long shrink_page_list(struct list_head *page_list,
} }
} }
if (!force_reclaim) if (!ignore_references)
references = page_check_references(page, sc); references = page_check_references(page, sc);
switch (references) { switch (references) {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册