From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail202.messagelabs.com (mail202.messagelabs.com [216.82.254.227]) by kanga.kvack.org (Postfix) with SMTP id CFA745F0001 for ; Tue, 3 Feb 2009 07:07:35 -0500 (EST) From: Nick Piggin Subject: Re: [patch] SLQB slab allocator (try 2) Date: Tue, 3 Feb 2009 23:07:07 +1100 References: <20090123154653.GA14517@wotan.suse.de> <200902032250.55968.nickpiggin@yahoo.com.au> <20090203120139.GM9840@csn.ul.ie> In-Reply-To: <20090203120139.GM9840@csn.ul.ie> MIME-Version: 1.0 Content-Type: text/plain; charset="iso-8859-15" Content-Transfer-Encoding: 7bit Content-Disposition: inline Message-Id: <200902032307.09025.nickpiggin@yahoo.com.au> Sender: owner-linux-mm@kvack.org To: Mel Gorman Cc: Pekka Enberg , Nick Piggin , Linux Memory Management List , Linux Kernel Mailing List , Andrew Morton , Lin Ming , "Zhang, Yanmin" , Christoph Lameter List-ID: On Tuesday 03 February 2009 23:01:39 Mel Gorman wrote: > On Tue, Feb 03, 2009 at 10:50:54PM +1100, Nick Piggin wrote: > > On Tuesday 03 February 2009 22:28:52 Mel Gorman wrote: > > > On Tue, Feb 03, 2009 at 09:36:24PM +1100, Nick Piggin wrote: > > > > I'd be interested to see how slub performs if booted with > > > > slub_min_objects=1 (which should give similar order pages to SLAB and > > > > SLQB). > > > > > > Just to clarify on this last point, do you mean slub_max_order=0 to > > > force order-0 allocations in SLUB? > > > > Hmm... I think slub_min_objects=1 should also do basically the same. > > Actually slub_min_object=1 and slub_max_order=1 should get closest I > > think. > > I'm going with slub_min_objects=1 and slub_max_order=0. A quick glance > of the source shows the calculation as > > for (order = max(min_order, > fls(min_objects * size - 1) - PAGE_SHIFT); > order <= max_order; order++) { > > so the max_order is inclusive not exclusive. This will force the order-0 > allocations I think you are looking for. Well, but in the case of really bad internal fragmentation in the page, SLAB will do order-1 allocations even if it doesn't strictly need to. Probably this isn't a huge deal, but I think if we do slub_min_objects=1, then SLUB won't care about number of objects per page, and slub_max_order=1 will mean it stops caring about fragmentation after order-1. I think. Which would be pretty close to SLAB (depending on exactly how much fragmentation it cares about). -- 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