Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754515AbZIHMRt (ORCPT ); Tue, 8 Sep 2009 08:17:49 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1754493AbZIHMRs (ORCPT ); Tue, 8 Sep 2009 08:17:48 -0400 Received: from mk-filter-1-a-1.mail.uk.tiscali.com ([212.74.100.52]:47713 "EHLO mk-filter-1-a-1.mail.uk.tiscali.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754337AbZIHMRs (ORCPT ); Tue, 8 Sep 2009 08:17:48 -0400 X-Trace: 259440473/mk-filter-1.mail.uk.tiscali.com/B2C/$b2c-THROTTLED-DYNAMIC/b2c-CUSTOMER-DYNAMIC-IP/80.41.109.190/None/hugh.dickins@tiscali.co.uk X-SBRS: None X-RemoteIP: 80.41.109.190 X-IP-MAIL-FROM: hugh.dickins@tiscali.co.uk X-SMTP-AUTH: X-MUA: X-IP-BHB: Once X-IronPort-Anti-Spam-Filtered: true X-IronPort-Anti-Spam-Result: ApsEAJXopUpQKW2+/2dsb2JhbACBU9kThBgF X-IronPort-AV: E=Sophos;i="4.44,352,1249254000"; d="scan'208";a="259440473" Date: Tue, 8 Sep 2009 13:17:01 +0100 (BST) From: Hugh Dickins X-X-Sender: hugh@sister.anvils To: Nick Piggin cc: Andrew Morton , KAMEZAWA Hiroyuki , KOSAKI Motohiro , Linus Torvalds , Rik van Riel , linux-kernel@vger.kernel.org, linux-mm@kvack.org, linux-arch@vger.kernel.org Subject: Re: [PATCH 7/8] mm: reinstate ZERO_PAGE In-Reply-To: <20090908073119.GA29902@wotan.suse.de> Message-ID: References: <20090908073119.GA29902@wotan.suse.de> MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2339 Lines: 52 On Tue, 8 Sep 2009, Nick Piggin wrote: > On Mon, Sep 07, 2009 at 10:39:34PM +0100, Hugh Dickins wrote: > > KAMEZAWA Hiroyuki has observed customers of earlier kernels taking > > advantage of the ZERO_PAGE: which we stopped do_anonymous_page() from > > using in 2.6.24. And there were a couple of regression reports on LKML. > > > > Following suggestions from Linus, reinstate do_anonymous_page() use of > > the ZERO_PAGE; but this time avoid dirtying its struct page cacheline > > with (map)count updates - let vm_normal_page() regard it as abnormal. > > > > Use it only on arches which __HAVE_ARCH_PTE_SPECIAL (x86, s390, sh32, > > most powerpc): that's not essential, but minimizes additional branches > > (keeping them in the unlikely pte_special case); and incidentally > > excludes mips (some models of which needed eight colours of ZERO_PAGE > > to avoid costly exceptions). > > Without looking closely, why is it a big problem to have a > !HAVE PTE SPECIAL case? Couldn't it just be a check for > pfn == zero_pfn that is conditionally compiled away for pte > special architectures anyway? Yes, I'm uncomfortable with that restriction too: it makes for neater looking code in a couple of places, but it's not so good for the architectures to diverge gratuitously there. I'll give it a try without that restriction, see how it looks: it was Linus who proposed the "special" approach, I'm sure he'll speak up if he doesn't like how the alternative comes out. Tucking the test away in an asm-generic macro, we can leave the pain of a rangetest to the one mips case. By the way, in compiling that list of "special" architectures, I was surprised not to find ia64 amongst them. Not that it matters to me, but I thought the Fujitsu guys were usually keen on Itanium - do they realize that the special test is excluding it, or do they have their own special patch for it? > > If zero page is such a good idea, I don't see the logic of > limiting it like thisa. Your patch looks pretty clean though. > > At any rate, I think it might be an idea to cc linux-arch. Yes, thanks. Hugh -- 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/