On 04/02/2013 12:03 PM, Li Zefan wrote: > On 2013/4/2 15:35, Li Zefan wrote: >> If memcg_init_kmem() returns -errno when a memcg is being created, >> mem_cgroup_css_online() will decrement memcg and its parent's refcnt, > >> (but strangely there's no mem_cgroup_put() for mem_cgroup_get() called >> in memcg_propagate_kmem()). > > The comment in memcg_propagate_kmem() suggests it knows mem_cgroup_css_free() > will be called in failure, while mem_cgroup_css_online() doesn't know. > This is a bit suspicious. At first your analysis seems fair, but I've extensively tested memcg teardown process with kmemcg (and even uncovered some bugs at that), and it works when and how expected. Also, note that this teardown code long predates kmemcg. I am not saying your are wrong - on the contrary, you seem to be right, but I think this one needs to be handled with extra care. I will run some tests, take a look, and get back to you. -- 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>