From: Li Zefan <lizefan-hv44wF8Li93QT0dZR+AlfA@public.gmane.org>
To: Tejun Heo <tj-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
Cc: cgroups-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
containers-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org,
linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
Subject: Re: [PATCHSET cgroup/for-3.15] cgroup: convert to kernfs
Date: Tue, 11 Feb 2014 17:24:09 +0800 [thread overview]
Message-ID: <52F9EC39.40504@huawei.com> (raw)
In-Reply-To: <1390953285-16360-1-git-send-email-tj-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
On 2014/1/29 7:54, Tejun Heo wrote:
> Hello,
>
> cgroup filesystem code was derived from the original sysfs
> implementation which was heavily intertwined with vfs objects and
> locking with the goal of re-using the existing vfs infrastructure.
> That experiment turned out rather disastrous and sysfs switched, a
> long time ago, to distributed filesystem model where a separate
> representation is maintained which is queried by vfs. Unfortunately,
> cgroup stuck with the failed experiment all these years and
> accumulated even more problems over time.
>
> Locking and object lifetime management being entangled with vfs is
> probably the most egregious. vfs was never designed to be misused
> like this and cgroup ends up jumping through various convoluted
> dancing to make things work. Even then, operations across multiple
> cgroups can't be done safely as it'll deadlock with rename locking.
>
> Recently, kernfs is separated out from sysfs so that it can be used by
> users other than sysfs. This patchset converts cgroup to use kernfs.
> This simplifies code base quite a bit and allows further cleanups and
> implementation of features which depend on operating across multiple
> nodes.
>
> This patchset contains the following 13 patches.
>
> 0001-cgroup-improve-css_from_dir-into-css_tryget_from_dir.patch
> 0002-cgroup-introduce-cgroup_tree_mutex.patch
> 0003-cgroup-release-cgroup_mutex-over-file-removals.patch
> 0004-cgroup-restructure-locking-and-error-handling-in-cgr.patch
> 0005-cgroup-factor-out-cgroup_setup_root-from-cgroup_moun.patch
> 0006-cgroup-update-cgroup-name-handling.patch
> 0007-cgroup-make-cgroup_subsys-base_cftypes-use-cgroup_ad.patch
> 0008-cgroup-update-the-meaning-of-cftype-max_write_len.patch
> 0009-cgroup-introduce-cgroup_init-exit_cftypes.patch
> 0010-cgroup-introduce-cgroup_ino.patch
> 0011-cgroup-misc-preps-for-kernfs-conversion.patch
> 0012-cgroup-relocate-functions-in-preparation-of-kernfs-c.patch
> 0013-cgroup-convert-to-kernfs.patch
>
> 0001 updates css_from_dir() into css_tryget_from_dir() so that the
> caller doesn't have to worry about RCU locking.
>
> 0002-0004 introduce cgroup_tree_mutex and prepare locking.
>
> 0005-0006 are misc preps.
>
> 0007-0008 update cftype handling in preparation.
>
> 0009-0012 are misc preps.
>
> 0013 converts cgroup to kernfs.
>
> This patchset is on top of
>
> linus#master 54c0a4b46150 ("Merge branch 'akpm' (incoming from Andrew)")
> + [1] [PATCHSET cgroup/for-3.14-fixes] cgroup: four misc fixes
> + [2] [PATCH] arm, pm, vmpressure: add missing slab.h includes
> + [3] [PATCHSET v2 cgroup/for-3.15] cgroup: drop module support and cgroup_root_mutex
> + git://git.kernel.org/pub/scm/linux/kernel/git/tj/misc.git review-kernfs-cgroup-prep
>
> and also available in the following git branch.
>
> git://git.kernel.org/pub/scm/linux/kernel/git/tj/cgroup.git review-kernfs-conversion
>
> diffstat follows.
>
> block/blk-throttle.c | 4
> block/cfq-iosched.c | 3
> include/linux/cgroup.h | 71 --
> kernel/cgroup.c | 1712 ++++++++++++++++++++-----------------------------
> kernel/events/core.c | 17
> mm/memcontrol.c | 16
> mm/memory-failure.c | 8
> 7 files changed, 754 insertions(+), 1077 deletions(-)
>
Looks good to me!
Acked-by: Li Zefan <lizefan-hv44wF8Li93QT0dZR+AlfA@public.gmane.org>
Will look into remaining patchsets tomorrow.
WARNING: multiple messages have this Message-ID (diff)
From: Li Zefan <lizefan@huawei.com>
To: Tejun Heo <tj@kernel.org>
Cc: <containers@lists.linux-foundation.org>,
<cgroups@vger.kernel.org>, <linux-kernel@vger.kernel.org>
Subject: Re: [PATCHSET cgroup/for-3.15] cgroup: convert to kernfs
Date: Tue, 11 Feb 2014 17:24:09 +0800 [thread overview]
Message-ID: <52F9EC39.40504@huawei.com> (raw)
In-Reply-To: <1390953285-16360-1-git-send-email-tj@kernel.org>
On 2014/1/29 7:54, Tejun Heo wrote:
> Hello,
>
> cgroup filesystem code was derived from the original sysfs
> implementation which was heavily intertwined with vfs objects and
> locking with the goal of re-using the existing vfs infrastructure.
> That experiment turned out rather disastrous and sysfs switched, a
> long time ago, to distributed filesystem model where a separate
> representation is maintained which is queried by vfs. Unfortunately,
> cgroup stuck with the failed experiment all these years and
> accumulated even more problems over time.
>
> Locking and object lifetime management being entangled with vfs is
> probably the most egregious. vfs was never designed to be misused
> like this and cgroup ends up jumping through various convoluted
> dancing to make things work. Even then, operations across multiple
> cgroups can't be done safely as it'll deadlock with rename locking.
>
> Recently, kernfs is separated out from sysfs so that it can be used by
> users other than sysfs. This patchset converts cgroup to use kernfs.
> This simplifies code base quite a bit and allows further cleanups and
> implementation of features which depend on operating across multiple
> nodes.
>
> This patchset contains the following 13 patches.
>
> 0001-cgroup-improve-css_from_dir-into-css_tryget_from_dir.patch
> 0002-cgroup-introduce-cgroup_tree_mutex.patch
> 0003-cgroup-release-cgroup_mutex-over-file-removals.patch
> 0004-cgroup-restructure-locking-and-error-handling-in-cgr.patch
> 0005-cgroup-factor-out-cgroup_setup_root-from-cgroup_moun.patch
> 0006-cgroup-update-cgroup-name-handling.patch
> 0007-cgroup-make-cgroup_subsys-base_cftypes-use-cgroup_ad.patch
> 0008-cgroup-update-the-meaning-of-cftype-max_write_len.patch
> 0009-cgroup-introduce-cgroup_init-exit_cftypes.patch
> 0010-cgroup-introduce-cgroup_ino.patch
> 0011-cgroup-misc-preps-for-kernfs-conversion.patch
> 0012-cgroup-relocate-functions-in-preparation-of-kernfs-c.patch
> 0013-cgroup-convert-to-kernfs.patch
>
> 0001 updates css_from_dir() into css_tryget_from_dir() so that the
> caller doesn't have to worry about RCU locking.
>
> 0002-0004 introduce cgroup_tree_mutex and prepare locking.
>
> 0005-0006 are misc preps.
>
> 0007-0008 update cftype handling in preparation.
>
> 0009-0012 are misc preps.
>
> 0013 converts cgroup to kernfs.
>
> This patchset is on top of
>
> linus#master 54c0a4b46150 ("Merge branch 'akpm' (incoming from Andrew)")
> + [1] [PATCHSET cgroup/for-3.14-fixes] cgroup: four misc fixes
> + [2] [PATCH] arm, pm, vmpressure: add missing slab.h includes
> + [3] [PATCHSET v2 cgroup/for-3.15] cgroup: drop module support and cgroup_root_mutex
> + git://git.kernel.org/pub/scm/linux/kernel/git/tj/misc.git review-kernfs-cgroup-prep
>
> and also available in the following git branch.
>
> git://git.kernel.org/pub/scm/linux/kernel/git/tj/cgroup.git review-kernfs-conversion
>
> diffstat follows.
>
> block/blk-throttle.c | 4
> block/cfq-iosched.c | 3
> include/linux/cgroup.h | 71 --
> kernel/cgroup.c | 1712 ++++++++++++++++++++-----------------------------
> kernel/events/core.c | 17
> mm/memcontrol.c | 16
> mm/memory-failure.c | 8
> 7 files changed, 754 insertions(+), 1077 deletions(-)
>
Looks good to me!
Acked-by: Li Zefan <lizefan@huawei.com>
Will look into remaining patchsets tomorrow.
next prev parent reply other threads:[~2014-02-11 9:24 UTC|newest]
Thread overview: 51+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-01-28 23:54 [PATCHSET cgroup/for-3.15] cgroup: convert to kernfs Tejun Heo
2014-01-28 23:54 ` Tejun Heo
[not found] ` <1390953285-16360-1-git-send-email-tj-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
2014-01-28 23:54 ` [PATCH 01/13] cgroup: improve css_from_dir() into css_tryget_from_dir() Tejun Heo
2014-01-28 23:54 ` Tejun Heo
[not found] ` <1390953285-16360-2-git-send-email-tj-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
2014-01-29 9:24 ` Michal Hocko
2014-01-29 9:24 ` Michal Hocko
2014-01-28 23:54 ` [PATCH 02/13] cgroup: introduce cgroup_tree_mutex Tejun Heo
2014-01-28 23:54 ` Tejun Heo
[not found] ` <1390953285-16360-3-git-send-email-tj-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
2014-02-11 16:55 ` [PATCH v2 " Tejun Heo
2014-02-11 16:55 ` Tejun Heo
2014-01-28 23:54 ` [PATCH 03/13] cgroup: release cgroup_mutex over file removals Tejun Heo
2014-01-28 23:54 ` Tejun Heo
2014-01-28 23:54 ` [PATCH 04/13] cgroup: restructure locking and error handling in cgroup_mount() Tejun Heo
2014-01-28 23:54 ` Tejun Heo
2014-01-28 23:54 ` [PATCH 05/13] cgroup: factor out cgroup_setup_root() from cgroup_mount() Tejun Heo
2014-01-28 23:54 ` Tejun Heo
2014-01-28 23:54 ` [PATCH 06/13] cgroup: update cgroup name handling Tejun Heo
2014-01-28 23:54 ` Tejun Heo
2014-01-28 23:54 ` [PATCH 07/13] cgroup: make cgroup_subsys->base_cftypes use cgroup_add_cftypes() Tejun Heo
2014-01-28 23:54 ` Tejun Heo
2014-01-28 23:54 ` Tejun Heo
2014-01-28 23:54 ` [PATCH 08/13] cgroup: update the meaning of cftype->max_write_len Tejun Heo
2014-01-28 23:54 ` Tejun Heo
2014-01-28 23:54 ` [PATCH 09/13] cgroup: introduce cgroup_init/exit_cftypes() Tejun Heo
2014-01-28 23:54 ` [PATCH 10/13] cgroup: introduce cgroup_ino() Tejun Heo
2014-01-28 23:54 ` Tejun Heo
2014-01-28 23:54 ` [PATCH 11/13] cgroup: misc preps for kernfs conversion Tejun Heo
2014-01-28 23:54 ` Tejun Heo
2014-01-28 23:54 ` Tejun Heo
[not found] ` <1390953285-16360-12-git-send-email-tj-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
2014-02-11 16:56 ` [PATCH v2 " Tejun Heo
2014-02-11 16:56 ` Tejun Heo
2014-01-28 23:54 ` [PATCH 12/13] cgroup: relocate functions in preparation of " Tejun Heo
2014-01-28 23:54 ` Tejun Heo
2014-01-28 23:54 ` Tejun Heo
2014-01-28 23:54 ` [PATCH 13/13] cgroup: convert to kernfs Tejun Heo
2014-01-29 9:50 ` [PATCHSET cgroup/for-3.15] " Li Zefan
2014-01-29 9:50 ` Li Zefan
[not found] ` <52E8CED4.5010406-hv44wF8Li93QT0dZR+AlfA@public.gmane.org>
2014-01-29 16:10 ` Tejun Heo
2014-01-29 16:10 ` Tejun Heo
2014-02-11 9:24 ` Li Zefan [this message]
2014-02-11 9:24 ` Li Zefan
[not found] ` <52F9EC39.40504-hv44wF8Li93QT0dZR+AlfA@public.gmane.org>
2014-02-11 16:57 ` Tejun Heo
2014-02-11 16:57 ` Tejun Heo
2014-01-28 23:54 ` [PATCH 09/13] cgroup: introduce cgroup_init/exit_cftypes() Tejun Heo
2014-01-28 23:54 ` [PATCH 13/13] cgroup: convert to kernfs Tejun Heo
[not found] ` <1390953285-16360-14-git-send-email-tj-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
2014-01-29 16:09 ` [PATCH v2 " Tejun Heo
2014-01-29 16:09 ` Tejun Heo
2014-01-29 16:09 ` Tejun Heo
2014-02-11 16:56 ` [PATCH v4 " Tejun Heo
2014-02-11 16:56 ` Tejun Heo
2014-02-11 16:56 ` Tejun Heo
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=52F9EC39.40504@huawei.com \
--to=lizefan-hv44wf8li93qt0dzr+alfa@public.gmane.org \
--cc=cgroups-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=containers-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org \
--cc=linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=tj-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org \
/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.