Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753125AbbBQFWR (ORCPT ); Tue, 17 Feb 2015 00:22:17 -0500 Received: from lgeamrelo02.lge.com ([156.147.1.126]:50849 "EHLO lgeamrelo02.lge.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752257AbbBQFWQ (ORCPT ); Tue, 17 Feb 2015 00:22:16 -0500 X-Original-SENDERIP: 10.177.222.153 X-Original-MAILFROM: iamjoonsoo.kim@lge.com Date: Tue, 17 Feb 2015 14:24:47 +0900 From: Joonsoo Kim To: Gioh Kim Cc: Andrew Morton , Rik van Riel , Johannes Weiner , Mel Gorman , Laura Abbott , Minchan Kim , Heesub Shin , Marek Szyprowski , Michal Nazarewicz , "Aneesh Kumar K.V" , linux-mm@kvack.org, linux-kernel@vger.kernel.org, Hui Zhu , Bartlomiej Zolnierkiewicz , Ritesh Harjani , Vlastimil Babka Subject: Re: [RFC 07/16] mm/page_isolation: watch out zone range overlap Message-ID: <20150217052446.GB15413@js1304-P5Q-DELUXE> References: <1423726340-4084-1-git-send-email-iamjoonsoo.kim@lge.com> <1423726340-4084-8-git-send-email-iamjoonsoo.kim@lge.com> <54DD9C48.90803@lge.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <54DD9C48.90803@lge.com> User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1917 Lines: 52 On Fri, Feb 13, 2015 at 03:40:08PM +0900, Gioh Kim wrote: > > > diff --git a/mm/page_isolation.c b/mm/page_isolation.c > > index c8778f7..883e78d 100644 > > --- a/mm/page_isolation.c > > +++ b/mm/page_isolation.c > > @@ -210,8 +210,8 @@ int undo_isolate_page_range(unsigned long start_pfn, unsigned long end_pfn, > > * Returns 1 if all pages in the range are isolated. > > */ > > static int > > -__test_page_isolated_in_pageblock(unsigned long pfn, unsigned long end_pfn, > > - bool skip_hwpoisoned_pages) > > +__test_page_isolated_in_pageblock(struct zone *zone, unsigned long pfn, > > + unsigned long end_pfn, bool skip_hwpoisoned_pages) > > { > > struct page *page; > > > > @@ -221,6 +221,9 @@ __test_page_isolated_in_pageblock(unsigned long pfn, unsigned long end_pfn, > > continue; > > } > > page = pfn_to_page(pfn); > > + if (page_zone(page) != zone) > > + break; > > + > > if (PageBuddy(page)) { > > /* > > * If race between isolatation and allocation happens, > > @@ -281,7 +284,7 @@ int test_pages_isolated(unsigned long start_pfn, unsigned long end_pfn, > > /* Check all pages are free or marked as ISOLATED */ > > zone = page_zone(page); > > spin_lock_irqsave(&zone->lock, flags); > > - ret = __test_page_isolated_in_pageblock(start_pfn, end_pfn, > > + ret = __test_page_isolated_in_pageblock(zone, start_pfn, end_pfn, > > skip_hwpoisoned_pages); > > spin_unlock_irqrestore(&zone->lock, flags); > > return ret ? 0 : -EBUSY; > > > > What about checking zone at test_pages_isolated? > It might be a little bit early and without locking zone. Hello, Will do in next spin. 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/