Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752569Ab3DEF7I (ORCPT ); Fri, 5 Apr 2013 01:59:08 -0400 Received: from fgwmail5.fujitsu.co.jp ([192.51.44.35]:43909 "EHLO fgwmail5.fujitsu.co.jp" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1161640Ab3DEF7B (ORCPT ); Fri, 5 Apr 2013 01:59:01 -0400 X-SecurityPolicyCheck: OK by SHieldMailChecker v1.8.4 Message-ID: <515E680D.5040805@jp.fujitsu.com> Date: Fri, 05 Apr 2013 14:58:37 +0900 From: Kamezawa Hiroyuki User-Agent: Mozilla/5.0 (Windows NT 6.1; rv:17.0) Gecko/20130307 Thunderbird/17.0.4 MIME-Version: 1.0 To: Li Zefan CC: linux-mm@kvack.org, LKML , Cgroups , Tejun Heo , Glauber Costa , Michal Hocko , Johannes Weiner Subject: Re: [RFC][PATCH 5/7] cgroup: make sure parent won't be destroyed before its children References: <515BF233.6070308@huawei.com> <515BF2A4.1070703@huawei.com> In-Reply-To: <515BF2A4.1070703@huawei.com> Content-Type: text/plain; charset=GB2312 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1697 Lines: 52 (2013/04/03 18:13), 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 > --- > 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); > Acked-by: KAMEZAWA Hiroyuki -- 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/