Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754441AbbLEADG (ORCPT ); Fri, 4 Dec 2015 19:03:06 -0500 Received: from mail.linuxfoundation.org ([140.211.169.12]:48575 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752137AbbLEADD (ORCPT ); Fri, 4 Dec 2015 19:03:03 -0500 Date: Fri, 4 Dec 2015 16:03:02 -0800 From: Andrew Morton To: Cc: Seth Jennings , Greg Kroah-Hartman , Russ Anderson , Subject: Re: [PATCH] drivers: memory: check for missing sections when testing zones Message-Id: <20151204160302.55d7fd03724fa53b54b335f0@linux-foundation.org> In-Reply-To: <566082D6.3070905@sgi.com> References: <1449068821-9870-1-git-send-email-sjennings@variantweb.net> <1449068821-9870-3-git-send-email-sjennings@variantweb.net> <20151202144556.c21211967d835f5607a909bb@linux-foundation.org> <566082D6.3070905@sgi.com> X-Mailer: Sylpheed 3.4.1 (GTK+ 2.24.23; x86_64-pc-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2117 Lines: 52 On Thu, 3 Dec 2015 11:58:46 -0600 Andrew Banman wrote: > test_pages_in_a_zone does not account for the possibility of missing sections > in the given pfn range. Since pfn_valid_within always returns 1 when > CONFIG_HOLES_IN_ZONE is not set, invalid pfns from missing sections > will pass the test, resulting in a kernel oops. This is remedied by simply > checking for the presence of the pfn's section. We don't have to remove > the pfn_valid_within optimization. > > The patch also prevents a crash from offlining memory devices with missing > sections. Despite this, it's probably best to keep > > [PATCH 3/3] drivers: memory: prohibit offlining of memory blocks withmissing sections > > because missing sections may indicate other problems, like overlapping mem > blocks and who knows what else (see the discussion at BZ 107781). > > --- > mm/memory_hotplug.c | 3 +++ > 1 file changed, 3 insertions(+) > > diff --git a/mm/memory_hotplug.c b/mm/memory_hotplug.c > index 67d488a..74f5bcd 100644 > --- a/mm/memory_hotplug.c > +++ b/mm/memory_hotplug.c > @@ -1383,6 +1383,9 @@ int test_pages_in_a_zone(unsigned long start_pfn, unsigned long end_pfn) > pfn < end_pfn; > pfn += MAX_ORDER_NR_PAGES) { > i = 0; > + /* Make sure the memory section is present */ > + if (!present_section_nr(pfn_to_section_nr(pfn))) > + continue; > /* This is just a CONFIG_HOLES_IN_ZONE check.*/ > while ((i < MAX_ORDER_NR_PAGES) && !pfn_valid_within(pfn + i)) > i++; Please send a Signed-off-by: for this patch. Your email client is replacing tabs with spaces. Please confirm that this patch is applicable to current mainline. Please confirm that this patch is suitable for backporting into -stable trees. Thanks. -- 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/