Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753134Ab2KGUQs (ORCPT ); Wed, 7 Nov 2012 15:16:48 -0500 Received: from e23smtp08.au.ibm.com ([202.81.31.141]:42248 "EHLO e23smtp08.au.ibm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751752Ab2KGUQq (ORCPT ); Wed, 7 Nov 2012 15:16:46 -0500 Message-ID: <509AC164.1050403@linux.vnet.ibm.com> Date: Thu, 08 Nov 2012 01:45:32 +0530 From: "Srivatsa S. Bhat" User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:15.0) Gecko/20120828 Thunderbird/15.0 MIME-Version: 1.0 To: Dave Hansen CC: akpm@linux-foundation.org, mgorman@suse.de, mjg59@srcf.ucam.org, paulmck@linux.vnet.ibm.com, maxime.coquelin@stericsson.com, loic.pallardy@stericsson.com, arjan@linux.intel.com, kmpark@infradead.org, kamezawa.hiroyu@jp.fujitsu.com, lenb@kernel.org, rjw@sisk.pl, gargankita@gmail.com, amit.kachhap@linaro.org, svaidy@linux.vnet.ibm.com, thomas.abraham@linaro.org, santosh.shilimkar@ti.com, linux-pm@vger.kernel.org, linux-mm@kvack.org, linux-kernel@vger.kernel.org Subject: Re: [RFC PATCH 6/8] mm: Demarcate and maintain pageblocks in region-order in the zones' freelists References: <20121106195026.6941.24662.stgit@srivatsabhat.in.ibm.com> <20121106195342.6941.94892.stgit@srivatsabhat.in.ibm.com> <509985DE.8000508@linux.vnet.ibm.com> In-Reply-To: <509985DE.8000508@linux.vnet.ibm.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit x-cbid: 12110720-5140-0000-0000-00000254D827 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1765 Lines: 37 On 11/07/2012 03:19 AM, Dave Hansen wrote: > On 11/06/2012 11:53 AM, Srivatsa S. Bhat wrote: >> This is the main change - we keep the pageblocks in region-sorted order, >> where pageblocks belonging to region-0 come first, followed by those belonging >> to region-1 and so on. But the pageblocks within a given region need *not* be >> sorted, since we need them to be only region-sorted and not fully >> address-sorted. >> >> This sorting is performed when adding pages back to the freelists, thus >> avoiding any region-related overhead in the critical page allocation >> paths. > > It's probably _better_ to do it at free time than alloc, but it's still > pretty bad to be doing a linear walk over a potentially 256-entry array > holding the zone lock. The overhead is going to show up somewhere. How > does this do with a kernel compile? Looks like exit() when a process > has a bunch of memory might get painful. > As I mentioned in the cover-letter, kernbench numbers haven't shown any observable performance degradation. On the contrary, (as unbelievable as it may sound), they actually indicate a slight performance *improvement* with my patchset! I'm trying to figure out what could be the reason behind that. Going forward, we could try to optimize the sorting logic in the free() part, but in any case, IMHO that's the right place to push the overhead to, since the performance of free() is not expected to be _that_ critical (unlike alloc()) for overall system performance. Regards, Srivatsa S. Bhat -- 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/