From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail144.messagelabs.com (mail144.messagelabs.com [216.82.254.51]) by kanga.kvack.org (Postfix) with ESMTP id 554EE6B004A for ; Mon, 29 Nov 2010 19:48:09 -0500 (EST) Date: Tue, 30 Nov 2010 09:38:04 +0900 From: Daisuke Nishimura Subject: Re: [PATCH 53 of 66] add numa awareness to hugepage allocations Message-Id: <20101130093804.23f8c355.nishimura@mxp.nes.nec.co.jp> In-Reply-To: <20101129161103.GE24474@random.random> References: <223ee926614158fc1353.1288798108@v2.random> <20101129143801.abef5228.nishimura@mxp.nes.nec.co.jp> <20101129161103.GE24474@random.random> Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: owner-linux-mm@kvack.org To: Andrea Arcangeli Cc: linux-mm@kvack.org, Linus Torvalds , Andrew Morton , linux-kernel@vger.kernel.org, Marcelo Tosatti , Adam Litke , Avi Kivity , Hugh Dickins , Rik van Riel , Mel Gorman , Dave Hansen , Benjamin Herrenschmidt , Ingo Molnar , Mike Travis , KAMEZAWA Hiroyuki , Christoph Lameter , Chris Wright , bpicco@redhat.com, KOSAKI Motohiro , Balbir Singh , "Michael S. Tsirkin" , Peter Zijlstra , Johannes Weiner , Chris Mason , Borislav Petkov , Daisuke Nishimura List-ID: On Mon, 29 Nov 2010 17:11:03 +0100 Andrea Arcangeli wrote: > On Mon, Nov 29, 2010 at 02:38:01PM +0900, Daisuke Nishimura wrote: > > I think this should be: > > > > if (unlikely(mem_cgroup_newpage_charge(new_page, mm, GFP_KERNEL))) { > > #ifdef CONFIG_NUMA > > put_page(new_page); > > #endif > > goto out; > > } > > Hmm no, the change you suggest would generate memory corruption with > use after free. I'm sorry if I miss something, "new_page" will be reused in !CONFIG_NUMA case as you say, but, in CONFIG_NUMA case, it is allocated in this function (collapse_huge_page()) by alloc_hugepage_vma(), and is not freed when memcg's charge failed. Actually, we do in collapse_huge_page(): if (unlikely(!isolated)) { ... #ifdef CONFIG_NUMA put_page(new_page); #endif goto out; } later. I think we need a similar logic in memcg's failure path too. Thanks, Daisuke Nishimura. -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Fight unfair telecom policy in Canada: sign http://dissolvethecrtc.ca/ Don't email: email@kvack.org