[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <alpine.DEB.2.00.1010131342310.15185@chino.kir.corp.google.com>
Date: Wed, 13 Oct 2010 13:48:50 -0700 (PDT)
From: David Rientjes <rientjes@...gle.com>
To: Christoph Lameter <cl@...ux.com>
cc: Pekka Enberg <penberg@...helsinki.fi>,
Andrew Morton <akpm@...ux-foundation.org>,
Eric Dumazet <eric.dumazet@...il.com>,
David Miller <davem@...emloft.net>,
netdev <netdev@...r.kernel.org>,
Michael Chan <mchan@...adcom.com>,
Eilon Greenstein <eilong@...adcom.com>,
Christoph Hellwig <hch@....de>,
LKML <linux-kernel@...r.kernel.org>,
Nick Piggin <npiggin@...nel.dk>
Subject: Re: [PATCH net-next] net: allocate skbs on local node
On Wed, 13 Oct 2010, Christoph Lameter wrote:
> > Will you be adding the extensive slub debugging to slab then? It would be
> > a shame to lose it because one allocator is chosen over another for
> > performance reasons and then we need to recompile to debug issues as they
> > arise.
>
> Well basically we would copy SLUB to SLAB apply unification patches to
> SLAB instead of SLUBB. We first have to make sure that the unified patches
> have the same performance as SLAB.
>
I see, so all of the development will be done in Pekka's tree on mm/slub.c
and then when we can see no performance regression compared to the slab
baseline, merge it into Linus' tree as mm/slab.c. I'm not exactly sure
how that set of diffs being sent to Linus would look.
Are the changes to slub in the unification patchset so intrusive that it
wouldn't be possible to isolate many of the features under #ifdef or
boot-time options in a single, truly unified, allocator? It seems like a
shame that we'll have two allocators where the base is the same and much
of the debugging code is the same.
> It maybe much better to isolate the debug features and general bootstrap
> from the particulars of the allocation strategy of either SLUB or SLAB.
> That way a common code base exists and it would be easier to add different
> allocation strategies.
>
> Basically have slab.c with the basic functions and then slab_queueing.c
> and slab_noqueue.c for SLAB/SLUB with the particulars of the allocation
> strategy?
>
I was going to mention that as an idea, but I thought storing the metadata
for certain debugging features might differ from the two allocators so
substantially that it would be even more convoluted and difficult to
maintain?
--
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