Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753016Ab1FLOuH (ORCPT ); Sun, 12 Jun 2011 10:50:07 -0400 Received: from cantor.suse.de ([195.135.220.2]:34049 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751378Ab1FLOuD (ORCPT ); Sun, 12 Jun 2011 10:50:03 -0400 Date: Sun, 12 Jun 2011 16:49:55 +0200 From: Michal Hocko To: Minchan Kim Cc: Andrew Morton , linux-mm , LKML , KOSAKI Motohiro , Mel Gorman , Andrea Arcangeli , Rik van Riel , Johannes Weiner , KAMEZAWA Hiroyuki Subject: Re: [PATCH v3 04/10] compaction: make isolate_lru_page with filter aware Message-ID: <20110612144955.GC24323@tiehlicka.suse.cz> References: <10ad16e14fdbe47ac36f7e55ae72ed59ae73ed0c.1307455422.git.minchan.kim@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <10ad16e14fdbe47ac36f7e55ae72ed59ae73ed0c.1307455422.git.minchan.kim@gmail.com> User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2772 Lines: 76 On Tue 07-06-11 23:38:17, Minchan Kim wrote: > In async mode, compaction doesn't migrate dirty or writeback pages. > So, it's meaningless to pick the page and re-add it to lru list. > > Of course, when we isolate the page in compaction, the page might > be dirty or writeback but when we try to migrate the page, the page > would be not dirty, writeback. So it could be migrated. But it's > very unlikely as isolate and migration cycle is much faster than > writeout. > > So, this patch helps cpu and prevent unnecessary LRU churning. I think you should introduce ISOLATE_CLEAN with this patch. Apart from that it makes perfect sense. Feel free to add my Reviewed-by: Michal Hocko > > Cc: Andrea Arcangeli > Reviewed-by: KAMEZAWA Hiroyuki > Reviewed-by: KOSAKI Motohiro > Acked-by: Johannes Weiner > Acked-by: Mel Gorman > Acked-by: Rik van Riel > Signed-off-by: Minchan Kim > --- > mm/compaction.c | 7 +++++-- > 1 files changed, 5 insertions(+), 2 deletions(-) > > diff --git a/mm/compaction.c b/mm/compaction.c > index f0d75e9..8079346 100644 > --- a/mm/compaction.c > +++ b/mm/compaction.c > @@ -243,6 +243,7 @@ static unsigned long isolate_migratepages(struct zone *zone, > unsigned long last_pageblock_nr = 0, pageblock_nr; > unsigned long nr_scanned = 0, nr_isolated = 0; > struct list_head *migratelist = &cc->migratepages; > + enum ISOLATE_MODE mode = ISOLATE_ACTIVE|ISOLATE_INACTIVE; > > /* Do not scan outside zone boundaries */ > low_pfn = max(cc->migrate_pfn, zone->zone_start_pfn); > @@ -326,9 +327,11 @@ static unsigned long isolate_migratepages(struct zone *zone, > continue; > } > > + if (!cc->sync) > + mode |= ISOLATE_CLEAN; > + > /* Try isolate the page */ > - if (__isolate_lru_page(page, > - ISOLATE_ACTIVE|ISOLATE_INACTIVE, 0) != 0) > + if (__isolate_lru_page(page, mode, 0) != 0) > continue; > > VM_BUG_ON(PageTransCompound(page)); > -- > 1.7.0.4 > > -- > 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/ . > Fight unfair telecom internet charges in Canada: sign http://stopthemeter.ca/ > Don't email: email@kvack.org -- Michal Hocko SUSE Labs SUSE LINUX s.r.o. Lihovarska 1060/12 190 00 Praha 9 Czech Republic -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/