[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <Pine.LNX.4.64.0610191432540.10401@schroedinger.engr.sgi.com>
Date: Thu, 19 Oct 2006 14:39:05 -0700 (PDT)
From: Christoph Lameter <clameter@....com>
To: Will Schmidt <will_schmidt@...t.ibm.com>
cc: Anton Blanchard <anton@...ba.org>, akpm@...l.org,
linuxppc-dev@...abs.org, Paul Mackerras <paulus@...ba.org>,
linux-kernel@...r.kernel.org
Subject: Re: kernel BUG in __cache_alloc_node at linux-2.6.git/mm/slab.c:3177!
On Thu, 19 Oct 2006, Will Schmidt wrote:
> This didnt fix the problem on my box. I tried this both against mm and
> linux-2.6.git
GFP_THISNODE is also set at a higher level for fallback but it should not
be set for the initial allocation. If you try this with the debug printks
then please use this patch to make sure that all allocs fall back,
Index: linux-2.6.19-rc2-mm1/mm/slab.c
===================================================================
--- linux-2.6.19-rc2-mm1.orig/mm/slab.c 2006-10-19 11:54:24.000000000 -0500
+++ linux-2.6.19-rc2-mm1/mm/slab.c 2006-10-19 16:32:09.454825851 -0500
@@ -1589,7 +1589,10 @@ static void *kmem_getpages(struct kmem_c
* the needed fallback ourselves since we want to serve from our
* per node object lists first for other nodes.
*/
- flags |= cachep->gfpflags | GFP_THISNODE;
+ if (g_cpucache_up != FULL)
+ flags |= cachep->gfpflags & ~__GFP_THISNODE;
+ else
+ flags |= cachep->gfpflags | GFP_THISNODE;
page = alloc_pages_node(nodeid, flags, cachep->gfporder);
if (!page)
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists