From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail143.messagelabs.com (mail143.messagelabs.com [216.82.254.35]) by kanga.kvack.org (Postfix) with ESMTP id 850056B00C6 for ; Tue, 24 Feb 2009 12:53:03 -0500 (EST) Date: Tue, 24 Feb 2009 17:53:00 +0000 From: Mel Gorman Subject: Re: [PATCH 10/19] Calculate the preferred zone for allocation only once Message-ID: <20090224175300.GC5333@csn.ul.ie> References: <1235477835-14500-1-git-send-email-mel@csn.ul.ie> <1235477835-14500-11-git-send-email-mel@csn.ul.ie> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-15 Content-Disposition: inline In-Reply-To: Sender: owner-linux-mm@kvack.org To: Christoph Lameter Cc: Linux Memory Management List , Pekka Enberg , Rik van Riel , KOSAKI Motohiro , Johannes Weiner , Nick Piggin , Linux Kernel Mailing List , Lin Ming , Zhang Yanmin , Peter Zijlstra List-ID: On Tue, Feb 24, 2009 at 12:31:41PM -0500, Christoph Lameter wrote: > On Tue, 24 Feb 2009, Mel Gorman wrote: > > > diff --git a/mm/page_alloc.c b/mm/page_alloc.c > > index 6f26944..074f9a6 100644 > > --- a/mm/page_alloc.c > > +++ b/mm/page_alloc.c > > @@ -1399,24 +1399,19 @@ static void zlc_mark_zone_full(struct zonelist *zonelist, struct zoneref *z) > > */ > > static struct page * > > get_page_from_freelist(gfp_t gfp_mask, nodemask_t *nodemask, unsigned int order, > > - struct zonelist *zonelist, int high_zoneidx, int alloc_flags) > > + struct zonelist *zonelist, int high_zoneidx, int alloc_flags, > > + struct zone *preferred_zone) > > { > > This gets into a quite a number of parameters now. Pass a structure like in > vmscan.c? I considered it, but thought that multiple offsets into structures might exceed the cost of pushing the parameters onto the stack. I never actually looked at the generated assembly though to make a proper assessment. > Or simplify things to be able to run get_page_from_freelist with > less parameters? The number of parameters seem to be too high for a > fastpath function. > Which is why I ended up inlining get_page_from_freelist() in V1. It's a rock and a hard place basically. Passing parameters is expensive, but calculating the information multiple times is too. -- 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