From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1759692AbYDPApB (ORCPT ); Tue, 15 Apr 2008 20:45:01 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1753575AbYDPAow (ORCPT ); Tue, 15 Apr 2008 20:44:52 -0400 Received: from mx2.mail.elte.hu ([157.181.151.9]:40026 "EHLO mx2.mail.elte.hu" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752951AbYDPAow (ORCPT ); Tue, 15 Apr 2008 20:44:52 -0400 Date: Wed, 16 Apr 2008 02:44:30 +0200 From: Ingo Molnar To: Yinghai Lu Cc: Linus Torvalds , Pekka Enberg , Christoph Lameter , linux-kernel@vger.kernel.org, Mel Gorman , Nick Piggin , Andrew Morton , "Rafael J. Wysocki" , apw@shadowen.org, KAMEZAWA Hiroyuki Subject: Re: [patch] mm: sparsemem memory_present() memory corruption fix Message-ID: <20080416004430.GA26928@elte.hu> References: <20080415195430.GA23015@elte.hu> <20080415201734.GA25628@elte.hu> <4805115D.5030703@cs.helsinki.fi> <20080415204025.GA29784@elte.hu> <20080416000356.GA24737@elte.hu> <20080416001816.GA26295@elte.hu> <86802c440804151732j519a541t9d8e4f6b49a53313@mail.gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <86802c440804151732j519a541t9d8e4f6b49a53313@mail.gmail.com> User-Agent: Mutt/1.5.17 (2007-11-01) X-ELTE-VirusStatus: clean X-ELTE-SpamScore: -1.5 X-ELTE-SpamLevel: X-ELTE-SpamCheck: no X-ELTE-SpamVersion: ELTE 2.0 X-ELTE-SpamCheck-Details: score=-1.5 required=5.9 tests=BAYES_00 autolearn=no SpamAssassin version=3.2.3 -1.5 BAYES_00 BODY: Bayesian spam probability is 0 to 1% [score: 0.0000] Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org * Yinghai Lu wrote: > > + unsigned long max_arch_pfn = 1ULL << (MAX_PHYSMEM_BITS-PAGE_SHIFT); > > > > and also check my analysis whether it is correct and whether it > > matches the reported bug patterns. But otherwise the fix looks like > > a safe fix for v2.6.25-final to me - it only filters out values > > from sparsemem input that are nonsensical in the sparsemem > > framework anyway. > > can you check why find_max_pfn() e820_32.c need to call > memory_present? wonder if it can be removed. this is the only call to memory_present() we do in 32-bit arch setup, so it's required. (the function find_max_pfn() is woefully misnamed, but that's a cleanup - i just fixed this in x86.git.) Ingo