[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20111219172027.GJ24519@google.com>
Date: Mon, 19 Dec 2011 09:20:27 -0800
From: Tejun Heo <tj@...nel.org>
To: Mandeep Singh Baines <msb@...omium.org>
Cc: Li Zefan <lizf@...fujitsu.com>, linux-kernel@...r.kernel.org,
containers@...ts.linux-foundation.org, cgroups@...r.kernel.org,
KAMEZAWA Hiroyuki <kamezawa.hiroyu@...fujitsu.com>,
Frederic Weisbecker <fweisbec@...il.com>,
Oleg Nesterov <oleg@...hat.com>,
Andrew Morton <akpm@...ux-foundation.org>,
Paul Menage <paul@...lmenage.org>
Subject: Re: [PATCH] cgroup: remove redundate get/put of old css_set from
migrate
On Fri, Dec 16, 2011 at 08:38:31AM -0800, Mandeep Singh Baines wrote:
> We can now assume that the css_set reference held by the task
> will not go away for an exiting task. PF_EXITING state can be
> trusted throughout migration by checking it after locking
> threadgroup.
>
> This patch depends on:
>
> commit cd3d095275374220921fcf0d4e0c16584b26ddbc
> Author: Tejun Heo <tj@...nel.org>
> Date: Mon Dec 12 18:12:21 2011 -0800
>
> cgroup: always lock threadgroup during migration
>
> Signed-off-by: Mandeep Singh Baines <msb@...omium.org>
> Cc: Tejun Heo <tj@...nel.org>
> Cc: Li Zefan <lizf@...fujitsu.com>
> Cc: containers@...ts.linux-foundation.org
> Cc: cgroups@...r.kernel.org
> Cc: KAMEZAWA Hiroyuki <kamezawa.hiroyu@...fujitsu.com>
> Cc: Frederic Weisbecker <fweisbec@...il.com>
> Cc: Oleg Nesterov <oleg@...hat.com>
> Cc: Andrew Morton <akpm@...ux-foundation.org>
> Cc: Paul Menage <paul@...lmenage.org>
> ---
> kernel/cgroup.c | 25 ++++++-------------------
> 1 files changed, 6 insertions(+), 19 deletions(-)
>
> diff --git a/kernel/cgroup.c b/kernel/cgroup.c
> index 1b3b841..eb95e32 100644
> --- a/kernel/cgroup.c
> +++ b/kernel/cgroup.c
> @@ -1856,7 +1856,6 @@ static int cgroup_task_migrate(struct cgroup *cgrp, struct cgroup *oldcgrp,
> */
> task_lock(tsk);
> oldcg = tsk->cgroups;
> - get_css_set(oldcg);
> task_unlock(tsk);
>
> /* locate or allocate a new css_set for this task. */
> @@ -1872,12 +1871,9 @@ static int cgroup_task_migrate(struct cgroup *cgrp, struct cgroup *oldcgrp,
> might_sleep();
> /* find_css_set will give us newcg already referenced. */
> newcg = find_css_set(oldcg, cgrp);
> - if (!newcg) {
> - put_css_set(oldcg);
> + if (!newcg)
> return -ENOMEM;
> - }
> }
> - put_css_set(oldcg);
>
> /* @tsk can't exit as its threadgroup is locked */
> task_lock(tsk);
> @@ -2015,9 +2011,8 @@ struct cg_list_entry {
> struct list_head links;
> };
>
> -static bool css_set_check_fetched(struct cgroup *cgrp,
> - struct task_struct *tsk, struct css_set *cg,
> - struct list_head *newcg_list)
> +static bool css_set_fetched(struct cgroup *cgrp, struct task_struct *tsk,
> + struct css_set *cg, struct list_head *newcg_list)
I know this is a trivial change and am generally okay with somewhat
related trivial stuff being tacked on other changes but can you please
note it in the patch description, so that it's clear the change is
intentional and not from patch contamination? I usually add a
paragraph starting with "while at it" at the end.
Thanks.
--
tejun
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists