Re: [PATCH -mm 3/3] slub: make dead caches discard free slabs immediately

From: Vladimir Davydov
Date: Tue Jan 27 2015 - 03:23:18 EST


Hi Joonsoo,

On Tue, Jan 27, 2015 at 05:00:09PM +0900, Joonsoo Kim wrote:
> On Mon, Jan 26, 2015 at 03:55:29PM +0300, Vladimir Davydov wrote:
> > @@ -3381,6 +3390,15 @@ void __kmem_cache_shrink(struct kmem_cache *s)
> > kmalloc(sizeof(struct list_head) * objects, GFP_KERNEL);
> > unsigned long flags;
> >
> > + if (deactivate) {
> > + /*
> > + * Disable empty slabs caching. Used to avoid pinning offline
> > + * memory cgroups by freeable kmem pages.
> > + */
> > + s->cpu_partial = 0;
> > + s->min_partial = 0;
> > + }
> > +
>
> Maybe, kick_all_cpus_sync() is needed here since object would
> be freed asynchronously so they can't see this updated value.

I thought flush_all() should do the trick, no?

Thanks,
Vladimir
--
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/