Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756780AbZFWLET (ORCPT ); Tue, 23 Jun 2009 07:04:19 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1753043AbZFWLEM (ORCPT ); Tue, 23 Jun 2009 07:04:12 -0400 Received: from fgwmail5.fujitsu.co.jp ([192.51.44.35]:55377 "EHLO fgwmail5.fujitsu.co.jp" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752751AbZFWLEK (ORCPT ); Tue, 23 Jun 2009 07:04:10 -0400 From: KOSAKI Motohiro To: Mel Gorman Subject: Re: BUG: Bad page state [was: Strange oopses in 2.6.30] Cc: kosaki.motohiro@jp.fujitsu.com, Jiri Slaby , Maxim Levitsky , linux-kernel@vger.kernel.org, linux-mm@kvack.org, Andrew Morton , Lee Schermerhorn , Christoph Lameter , Pekka Enberg , Hugh Dickins , Johannes Weiner , Rik van Riel In-Reply-To: <20090622091626.GA3981@csn.ul.ie> References: <20090622113652.21E7.A69D9226@jp.fujitsu.com> <20090622091626.GA3981@csn.ul.ie> Message-Id: <20090623200147.2236.A69D9226@jp.fujitsu.com> MIME-Version: 1.0 Content-Type: text/plain; charset="US-ASCII" Content-Transfer-Encoding: 7bit X-Mailer: Becky! ver. 2.50.07 [ja] Date: Tue, 23 Jun 2009 20:04:11 +0900 (JST) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1985 Lines: 56 > On Mon, Jun 22, 2009 at 11:39:53AM +0900, KOSAKI Motohiro wrote: > > (cc to Mel and some reviewer) > > > > > Flags are: > > > 0000000000400000 -- __PG_MLOCKED > > > 800000000050000c -- my page flags > > > 3650000c -- Maxim's page flags > > > 0000000000693ce1 -- my PAGE_FLAGS_CHECK_AT_FREE > > > > I guess commit da456f14d (page allocator: do not disable interrupts in > > free_page_mlock()) is a bit wrong. > > > > current code is: > > ------------------------------------------------------------- > > static void free_hot_cold_page(struct page *page, int cold) > > { > > (snip) > > int clearMlocked = PageMlocked(page); > > (snip) > > if (free_pages_check(page)) > > return; > > (snip) > > local_irq_save(flags); > > if (unlikely(clearMlocked)) > > free_page_mlock(page); > > ------------------------------------------------------------- > > > > Oh well, we remove PG_Mlocked *after* free_pages_check(). > > Then, it makes false-positive warning. > > > > Sorry, my review was also wrong. I think reverting this patch is better ;) > > > > I think a revert is way overkill. The intention of the patch is sound - > reducing the number of times interrupts are disabled. Having pages > with the PG_locked bit is now somewhat of an expected situation. I'd > prefer to go with either > > 1. Unconditionally clearing the bit with TestClearPageLocked as the > patch already posted does > 2. Removing PG_locked from the free_pages_check() > 3. Unlocking the pages as we go when an mlocked VMA is being torn town > > The patch that addresses 1 seemed ok to me. What do you think? Yes, I've overlooked Hanns's patch. I think that is good patch. Thansk folks. -- 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/