From: Li Zefan <lizf@cn.fujitsu.com>
To: Liu Aleaxander <aleaxander@gmail.com>
Cc: Paul Menage <menage@google.com>,
linux-kernel@vger.kernel.org,
"containers@lists.osdl.org" <containers@lists.osdl.org>
Subject: Re: [PATCH 2/3] Fix the 'current css_set' problem in debug subsystem
Date: Tue, 03 Nov 2009 09:05:38 +0800 [thread overview]
Message-ID: <4AEF81E2.3060403@cn.fujitsu.com> (raw)
In-Reply-To: <b741c2440911012346k7213befcida229606f10c0399@mail.gmail.com>
Liu Aleaxander wrote:
>>From 61c93b1a66e43d44820e9b8d22ef0bec80dfc814 Mon Sep 17 00:00:00 2001
> From: Liu Aleaxander <Aleaxander@gmail.com>
> Date: Mon, 2 Nov 2009 14:30:07 +0800
> Subject: [PATCH 2/3] Fix the 'current css_set' problem in debug subsystem
>
> In the current implementation, it always print the same information
> no matter which group you are in. And this would be meaningless. So
> we should make it print the information of the 'real' current one.
>
> Well, I am not sure it's the current one, but I'm sure it's the first
> one of that cgroup.
>
I don't think there is a bug with current 'curent_css_set'. The
"current" in all debug.current_xxx interfaces means "current task".
Besides we already print out a cgroup's css links through
debug.cgroup_css_links, without showing the refcount of
each css_set, but we can, if it can be useful:
# cat debug.cgroup_css_links
css_set c10d92e0
> Signed-off-by: Liu Aleaxander <Aleaxander@gmail.com>
> ---
> include/linux/cgroup.h | 2 --
> kernel/cgroup.c | 19 ++++++++++++-------
> 2 files changed, 12 insertions(+), 9 deletions(-)
>
> diff --git a/include/linux/cgroup.h b/include/linux/cgroup.h
> index 4d63c5c..0008dee 100644
> --- a/include/linux/cgroup.h
> +++ b/include/linux/cgroup.h
> @@ -389,8 +389,6 @@ int cgroup_add_files(struct cgroup *cgrp,
> const struct cftype cft[],
> int count);
>
> -struct css_set* cgroup_first_css_set(const struct cgroup *cgrp);
> -
> int cgroup_is_removed(const struct cgroup *cgrp);
>
> int cgroup_path(const struct cgroup *cgrp, char *buf, int buflen);
> diff --git a/kernel/cgroup.c b/kernel/cgroup.c
> index 863089f..ddd4d33 100644
> --- a/kernel/cgroup.c
> +++ b/kernel/cgroup.c
> @@ -340,7 +340,7 @@ static inline void put_css_set_taskexit(struct css_set *cg)
> /*
> * Get the first css_set of the cgroup 'cgrp'.
> */
> -struct css_set* cgroup_first_css_set(const struct cgroup *cgrp)
> +static struct css_set* cgroup_first_css_set(const struct cgroup *cgrp)
> {
> struct list_head *head = &cgrp->css_sets;
> struct cg_cgroup_link *link;
> @@ -4093,17 +4093,22 @@ static u64 debug_taskcount_read(struct cgroup
> *cont, struct cftype *cft)
>
> static u64 current_css_set_read(struct cgroup *cont, struct cftype *cft)
> {
> - return (u64)(unsigned long)current->cgroups;
> + return (u64)(long)cgroup_first_css_set(cont);
> }
>
> static u64 current_css_set_refcount_read(struct cgroup *cont,
> struct cftype *cft)
> {
> - u64 count;
> -
> - rcu_read_lock();
> - count = atomic_read(¤t->cgroups->refcount);
> - rcu_read_unlock();
> + u64 count = 0;
> + struct css_set *cg;
> +
> + cg = cgroup_first_css_set(cont);
> + if (cg) {
> + rcu_read_lock();
> + count = atomic_read(&cg->refcount);
> + rcu_read_unlock();
> + }
> +
> return count;
> }
>
next prev parent reply other threads:[~2009-11-03 1:05 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-11-02 7:46 [PATCH 2/3] Fix the 'current css_set' problem in debug subsystem Liu Aleaxander
2009-11-03 1:05 ` Li Zefan [this message]
2009-11-03 1:21 ` Liu Aleaxander
2009-11-03 1:23 ` Paul Menage
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4AEF81E2.3060403@cn.fujitsu.com \
--to=lizf@cn.fujitsu.com \
--cc=aleaxander@gmail.com \
--cc=containers@lists.osdl.org \
--cc=linux-kernel@vger.kernel.org \
--cc=menage@google.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.