Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1762720Ab3DDPby (ORCPT ); Thu, 4 Apr 2013 11:31:54 -0400 Received: from cantor2.suse.de ([195.135.220.15]:46042 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1762605Ab3DDPbt (ORCPT ); Thu, 4 Apr 2013 11:31:49 -0400 Date: Thu, 4 Apr 2013 17:31:48 +0200 From: Michal Hocko To: Li Zefan Cc: linux-mm@kvack.org, LKML , Cgroups , Tejun Heo , Glauber Costa , KAMEZAWA Hiroyuki , Johannes Weiner Subject: Re: [RFC][PATCH 5/7] cgroup: make sure parent won't be destroyed before its children Message-ID: <20130404153148.GM29911@dhcp22.suse.cz> References: <515BF233.6070308@huawei.com> <515BF2A4.1070703@huawei.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <515BF2A4.1070703@huawei.com> User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1851 Lines: 58 On Wed 03-04-13 17:13:08, Li Zefan wrote: > Suppose we rmdir a cgroup and there're still css refs, this cgroup won't > be freed. Then we rmdir the parent cgroup, and the parent is freed due > to css ref draining to 0. Now it would be a disaster if the child cgroup > tries to access its parent. > > Make sure this won't happen. > > Signed-off-by: Li Zefan OK, after clarification from Tejun, that this is helpful for other controllers as well I think it is better than a memcg specific handling. Reviewed-by: Michal Hocko > --- > kernel/cgroup.c | 10 ++++++++++ > 1 file changed, 10 insertions(+) > > diff --git a/kernel/cgroup.c b/kernel/cgroup.c > index fa54b92..78204bc 100644 > --- a/kernel/cgroup.c > +++ b/kernel/cgroup.c > @@ -888,6 +888,13 @@ static void cgroup_free_fn(struct work_struct *work) > mutex_unlock(&cgroup_mutex); > > /* > + * We get a ref to the parent's dentry, and put the ref when > + * this cgroup is being freed, so it's guaranteed that the > + * parent won't be destroyed before its children. > + */ > + dput(cgrp->parent->dentry); > + > + /* > * Drop the active superblock reference that we took when we > * created the cgroup > */ > @@ -4171,6 +4178,9 @@ static long cgroup_create(struct cgroup *parent, struct dentry *dentry, > for_each_subsys(root, ss) > dget(dentry); > > + /* hold a ref to the parent's dentry */ > + dget(parent->dentry); > + > /* creation succeeded, notify subsystems */ > for_each_subsys(root, ss) { > err = online_css(ss, cgrp); > -- > 1.8.0.2 -- Michal Hocko SUSE Labs -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/