On Wed, 7 Nov 2012 10:22:17 +0100 Glauber Costa <glommer@xxxxxxxxxxxxx> wrote: > >>> container synchronously. If those objects are normally left floating > >>> around in an allocated but reclaimable state then we can address that > >>> by synchronously freeing them if their container has been destroyed. > >>> > >>> Or something like that. If it's something else then fine, but not this. > >>> > >>> What do we need to do to fix this? > >>> > >> The original patch had a unlikely() test in the free path, conditional > >> on whether or not the cache is dead, that would then call this is the > >> cache would now be empty. > >> > >> I got several requests to remove it and change it to something like > >> this, because that is a fast path (I myself think an unlikely branch is > >> not that bad) > >> > >> If you think such a test is acceptable, I can bring it back and argue in > >> the basis of "akpm made me do it!". But meanwhile I will give this extra > >> though to see if there is any alternative way I can do it... > > > > OK, thanks, please do take a look at it. > > > > I'd be interested in seeing the old version of the patch which had this > > test-n-branch. Perhaps there's some trick we can pull to lessen its cost. > > > Attached. > > This is the last version that used it (well, I believe it is). There is > other unrelated things in this patch, that I got rid of. Look for > kmem_cache_verify_dead(). > > In a summary, all calls to the free function would as a last step do: > kmem_cache_verify_dead() that would either be an empty placeholder, or: > > +static inline void kmem_cache_verify_dead(struct kmem_cache *s) > +{ > + if (unlikely(s->memcg_params.dead)) > + schedule_work(&s->memcg_params.cache_shrinker); > +} hm, a few things. What's up with kmem_cache_shrink? It's global and exported to modules but its only external caller is some weird and hopelessly poorly documented site down in drivers/acpi/osl.c. slab and slob implement kmem_cache_shrink() *only* for acpi! wtf? Let's work out what acpi is trying to actually do there, then do it properly, then killkillkill! Secondly, as slab and slub (at least) have the ability to shed cached memory, why aren't they hooked into the core cache-shinking machinery. After all, it's called "shrink_slab"! If we can fix all that up then I wonder whether this particular patch needs to exist at all. If the kmem_cache is no longer used then we can simply leave it floating around in memory and the regular cache shrinking code out of shrink_slab() will clean up any remaining pages. The kmem_cache itself can be reclaimed via another shrinker, if necessary? -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>