Re: Switch per cpu partial page support off for debugging

From: David Rientjes
Date: Wed Dec 14 2011 - 22:10:22 EST


On Mon, 12 Dec 2011, Pekka Enberg wrote:

> > Eric saw an issue with accounting of slabs during validation. Its not
> > possible to determine accurately how many per cpu partial slabs exist at
> > any time so this switches off per cpu partial pages during debug.
> >
> > Subject: Switch per cpu partial page support off for debugging
> >
> > Otherwise we have accounting issues.
> >
> > Signed-off-by: Christoph Lameter <cl@xxxxxxxxx>
> >
> >
> > ---
> > mm/slub.c | 4 +++-
> > 1 file changed, 3 insertions(+), 1 deletion(-)
> >
> > Index: linux-2.6/mm/slub.c
> > ===================================================================
> > --- linux-2.6.orig/mm/slub.c 2011-11-22 11:57:21.000000000 -0600
> > +++ linux-2.6/mm/slub.c 2011-11-22 11:57:55.000000000 -0600
> > @@ -3027,7 +3027,9 @@ static int kmem_cache_open(struct kmem_c
> > * per node list when we run out of per cpu objects. We only fetch
> > 50%
> > * to keep some capacity around for frees.
> > */
> > - if (s->size >= PAGE_SIZE)
> > + if (kmem_cache_debug(s))
> > + s->cpu_partial = 0;
> > + else if (s->size >= PAGE_SIZE)
> > s->cpu_partial = 2;
> > else if (s->size >= 1024)
> > s->cpu_partial = 6;

I think this deserves a comment since it's not clear why it's being done
neither in the code or by the changelog. Also, you'd want a check for
kmem_cache_debug() when storing to /sys/kernel/slab/cache/cpu_partial as
well, otherwise this could easily be broken from userspace again. (It
also seems like Documentation/ABI/testing/sysfs-kernel-slab got left out
of an update when that was added, too.)
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/