On Fri, Jun 06, 2014 at 05:22:45PM +0400, Vladimir Davydov wrote: > Since a dead memcg cache is destroyed only after the last slab allocated > to it is freed, we must disable caching of empty slabs for such caches, > otherwise they will be hanging around forever. > > This patch makes SLAB discard dead memcg caches' slabs as soon as they > become empty. To achieve that, it disables per cpu free object arrays by > setting array_cache->limit to 0 on each cpu and sets per node free_limit > to 0 in order to zap slabs_free lists. This is done on kmem_cache_shrink > (in do_drain, drain_array, drain_alien_cache, and drain_freelist to be > more exact), which is always called on memcg offline (see > memcg_unregister_all_caches) > > Note, since array_cache->limit and kmem_cache_node->free_limit are per > cpu/node and, as a result, they may be updated on cpu/node > online/offline, we have to patch every place where the limits are > initialized. Hello, You mentioned that disabling per cpu arrays would degrade performance. But, this patch is implemented to disable per cpu arrays. Is there any reason to do like this? How about not disabling per cpu arrays and others? Leaving it as is makes the patch less intrusive and has low impact on performance. I guess that amount of reclaimed memory has no big difference between both approaches. Thanks. -- 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>