From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail203.messagelabs.com (mail203.messagelabs.com [216.82.254.243]) by kanga.kvack.org (Postfix) with ESMTP id 2E7F96B0047 for ; Tue, 21 Apr 2009 04:27:11 -0400 (EDT) Date: Tue, 21 Apr 2009 09:27:32 +0100 From: Mel Gorman Subject: Re: [PATCH 08/25] Calculate the preferred zone for allocation only once Message-ID: <20090421082732.GB12713@csn.ul.ie> References: <1240266011-11140-1-git-send-email-mel@csn.ul.ie> <1240266011-11140-9-git-send-email-mel@csn.ul.ie> <1240299457.771.42.camel@penberg-laptop> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-15 Content-Disposition: inline In-Reply-To: <1240299457.771.42.camel@penberg-laptop> Sender: owner-linux-mm@kvack.org To: Pekka Enberg Cc: Linux Memory Management List , KOSAKI Motohiro , Christoph Lameter , Nick Piggin , Linux Kernel Mailing List , Lin Ming , Zhang Yanmin , Peter Zijlstra , Andrew Morton List-ID: On Tue, Apr 21, 2009 at 10:37:37AM +0300, Pekka Enberg wrote: > Hi Mel, > > On Mon, 2009-04-20 at 23:19 +0100, Mel Gorman wrote: > > get_page_from_freelist() can be called multiple times for an > > allocation. > > Part of this calculates the preferred_zone which is the first usable > > zone in the zonelist. This patch calculates preferred_zone once. > > > > Signed-off-by: Mel Gorman > > Reviewed-by: Pekka Enberg > Thanks > > @@ -1772,11 +1774,20 @@ __alloc_pages_nodemask(gfp_t gfp_mask, > > unsigned int order, > > if (unlikely(!zonelist->_zonerefs->zone)) > > return NULL; > > > > + /* The preferred zone is used for statistics later */ > > + (void)first_zones_zonelist(zonelist, high_zoneidx, nodemask, > > + &preferred_zone); > > + if (!preferred_zone) > > + return NULL; > > You might want to add an explanation to the changelog why this change is > safe. It looked like a functional change at first glance and it was > pretty difficult to convince myself that __alloc_pages_slowpath() will > always return NULL when there's no preferred zone because of the other > cleanups in this patch series. > Is this better? get_page_from_freelist() can be called multiple times for an allocation. Part of this calculates the preferred_zone which is the first usable zone in the zonelist but the zone depends on the GFP flags specified at the beginning of the allocation call. This patch calculates preferred_zone once. It's safe to do this because if preferred_zone is NULL at the start of the call, no amount of direct reclaim or other actions will change the fact the allocation will fail. > > + > > + /* First allocation attempt */ > > page = get_page_from_freelist(gfp_mask|__GFP_HARDWALL, nodemask, order, > > - zonelist, high_zoneidx, ALLOC_WMARK_LOW|ALLOC_CPUSET); > > + zonelist, high_zoneidx, ALLOC_WMARK_LOW|ALLOC_CPUSET, > > + preferred_zone); > > if (unlikely(!page)) > > page = __alloc_pages_slowpath(gfp_mask, order, > > - zonelist, high_zoneidx, nodemask); > > + zonelist, high_zoneidx, nodemask, > > + preferred_zone); > > > > return page; > > } > -- Mel Gorman Part-time Phd Student Linux Technology Center University of Limerick IBM Dublin Software Lab -- 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: email@kvack.org