From: Johannes Weiner <hannes@cmpxchg.org>
To: KOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com>
Cc: Andrew Morton <akpm@linux-foundation.org>,
Mel Gorman <mel@csn.ul.ie>,
linux-mm@kvack.org
Subject: Re: [patch 4/5] vmscan: remove isolate_pages callback scan control
Date: Wed, 19 May 2010 23:42:17 +0200 [thread overview]
Message-ID: <20100519214217.GC2868@cmpxchg.org> (raw)
In-Reply-To: <20100513122717.215E.A69D9226@jp.fujitsu.com>
On Thu, May 13, 2010 at 12:29:05PM +0900, KOSAKI Motohiro wrote:
> > For now, we have global isolation vs. memory control group isolation,
> > do not allow the reclaim entry function to set an arbitrary page
> > isolation callback, we do not need that flexibility.
> >
> > And since we already pass around the group descriptor for the memory
> > control group isolation case, just use it to decide which one of the
> > two isolator functions to use.
> >
> > The decisions can be merged into nearby branches, so no extra cost
> > there. In fact, we save the indirect calls.
> >
> > Signed-off-by: Johannes Weiner <hannes@cmpxchg.org>
> > ---
> > include/linux/memcontrol.h | 13 ++++++-----
> > mm/vmscan.c | 52 ++++++++++++++++++++++++---------------------
> > 2 files changed, 35 insertions(+), 30 deletions(-)
> >
> > --- a/mm/vmscan.c
> > +++ b/mm/vmscan.c
> > @@ -82,12 +82,6 @@ struct scan_control {
> > * are scanned.
> > */
> > nodemask_t *nodemask;
> > -
> > - /* Pluggable isolate pages callback */
> > - unsigned long (*isolate_pages)(unsigned long nr, struct list_head *dst,
> > - unsigned long *scanned, int order, int mode,
> > - struct zone *z, struct mem_cgroup *mem_cont,
> > - int active, int file);
> > };
> >
> > #define lru_to_page(_head) (list_entry((_head)->prev, struct page, lru))
> > @@ -1000,7 +994,6 @@ static unsigned long isolate_pages_globa
> > struct list_head *dst,
> > unsigned long *scanned, int order,
> > int mode, struct zone *z,
> > - struct mem_cgroup *mem_cont,
> > int active, int file)
> > {
> > int lru = LRU_BASE;
> > @@ -1144,11 +1137,11 @@ static unsigned long shrink_inactive_lis
> > unsigned long nr_anon;
> > unsigned long nr_file;
> >
> > - nr_taken = sc->isolate_pages(SWAP_CLUSTER_MAX,
> > - &page_list, &nr_scan, sc->order, mode,
> > - zone, sc->mem_cgroup, 0, file);
> > -
> > if (scanning_global_lru(sc)) {
> > + nr_taken = isolate_pages_global(SWAP_CLUSTER_MAX,
> > + &page_list, &nr_scan,
> > + sc->order, mode,
> > + zone, 0, file);
> > zone->pages_scanned += nr_scan;
> > if (current_is_kswapd())
> > __count_zone_vm_events(PGSCAN_KSWAPD, zone,
> > @@ -1156,6 +1149,16 @@ static unsigned long shrink_inactive_lis
> > else
> > __count_zone_vm_events(PGSCAN_DIRECT, zone,
> > nr_scan);
> > + } else {
> > + nr_taken = mem_cgroup_isolate_pages(SWAP_CLUSTER_MAX,
> > + &page_list, &nr_scan,
> > + sc->order, mode,
> > + zone, sc->mem_cgroup,
> > + 0, file);
> > + /*
> > + * mem_cgroup_isolate_pages() keeps track of
> > + * scanned pages on its own.
> > + */
> > }
>
> There are the same logic in shrink_active/inactive_list.
> Can we make wrapper function? It probably improve code readability.
They are not completely identical, PGSCAN_DIRECT/PGSCAN_KSWAPD
accounting is only done in shrink_inactive_list(), so we would need an
extra branch. Can we leave it like that for now?
Hannes
--
To unsubscribe, send a message with 'unsubscribe linux-mm' in
the body to majordomo@kvack.org. For more info on Linux MM,
see: http://www.linux-mm.org/ .
Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a>
next prev parent reply other threads:[~2010-05-19 21:42 UTC|newest]
Thread overview: 23+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-04-30 23:05 [patch 0/5] vmscan: cut down on struct scan_control Johannes Weiner
2010-04-30 23:05 ` [patch 1/5] vmscan: fix unmapping behaviour for RECLAIM_SWAP Johannes Weiner
2010-05-13 3:02 ` KOSAKI Motohiro
2010-05-19 21:32 ` Johannes Weiner
2010-04-30 23:05 ` [patch 2/5] vmscan: remove may_unmap scan control Johannes Weiner
2010-04-30 23:05 ` [patch 3/5] vmscan: remove all_unreclaimable " Johannes Weiner
2010-05-13 3:25 ` KOSAKI Motohiro
2010-05-19 21:34 ` Johannes Weiner
2010-05-31 18:32 ` Greg Thelen
2010-06-01 3:29 ` [PATCH] vmscan: Fix do_try_to_free_pages() return value when priority==0 reclaim failure KOSAKI Motohiro
2010-06-01 6:48 ` KAMEZAWA Hiroyuki
2010-06-01 8:10 ` Balbir Singh
2010-06-02 0:33 ` KAMEZAWA Hiroyuki
2010-06-01 14:50 ` Greg Thelen
2010-06-04 14:32 ` Johannes Weiner
2010-04-30 23:05 ` [patch 4/5] vmscan: remove isolate_pages callback scan control Johannes Weiner
2010-05-13 3:29 ` KOSAKI Motohiro
2010-05-19 21:42 ` Johannes Weiner [this message]
2010-05-20 23:23 ` KOSAKI Motohiro
2010-04-30 23:05 ` [patch 5/5] vmscan: remove may_swap " Johannes Weiner
2010-05-13 3:36 ` KOSAKI Motohiro
2010-05-19 21:44 ` Johannes Weiner
2010-05-21 0:15 ` KOSAKI Motohiro
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20100519214217.GC2868@cmpxchg.org \
--to=hannes@cmpxchg.org \
--cc=akpm@linux-foundation.org \
--cc=kosaki.motohiro@jp.fujitsu.com \
--cc=linux-mm@kvack.org \
--cc=mel@csn.ul.ie \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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).