- Subject: [C/R v20][PATCH 16/96] cgroup freezer: Update stale locking comments
- From: Oren Laadan <orenl@xxxxxxxxxxxxxxx>
- Date: Wed, 17 Mar 2010 12:08:04 -0400
- Cc: linux-kernel@xxxxxxxxxxxxxxx, linux-mm@xxxxxxxxx, linux-api@xxxxxxxxxxxxxxx, Serge Hallyn <serue@xxxxxxxxxx>, Ingo Molnar <mingo@xxxxxxx>, containers@xxxxxxxxxxxxxxxxxxxxxxxxxx, Matt Helsley <matthltc@xxxxxxxxxx>, Oren Laadan <orenl@xxxxxxxxxxxxxxx>, Cedric Le Goater <legoater@xxxxxxx>, Paul Menage <menage@xxxxxxxxxx>, Li Zefan <lizf@xxxxxxxxxxxxxx>
- In-reply-to: <1268842164-5590-16-git-send-email-orenl@xxxxxxxxxxxxxxx>
- References: <1268842164-5590-1-git-send-email-orenl@xxxxxxxxxxxxxxx> <1268842164-5590-2-git-send-email-orenl@xxxxxxxxxxxxxxx> <1268842164-5590-3-git-send-email-orenl@xxxxxxxxxxxxxxx> <1268842164-5590-4-git-send-email-orenl@xxxxxxxxxxxxxxx> <1268842164-5590-5-git-send-email-orenl@xxxxxxxxxxxxxxx> <1268842164-5590-6-git-send-email-orenl@xxxxxxxxxxxxxxx> <1268842164-5590-7-git-send-email-orenl@xxxxxxxxxxxxxxx> <1268842164-5590-8-git-send-email-orenl@xxxxxxxxxxxxxxx> <1268842164-5590-9-git-send-email-orenl@xxxxxxxxxxxxxxx> <1268842164-5590-10-git-send-email-orenl@xxxxxxxxxxxxxxx> <1268842164-5590-11-git-send-email-orenl@xxxxxxxxxxxxxxx> <1268842164-5590-12-git-send-email-orenl@xxxxxxxxxxxxxxx> <1268842164-5590-13-git-send-email-orenl@xxxxxxxxxxxxxxx> <1268842164-5590-14-git-send-email-orenl@xxxxxxxxxxxxxxx> <1268842164-5590-15-git-send-email-orenl@xxxxxxxxxxxxxxx> <1268842164-5590-16-git-send-email-orenl@xxxxxxxxxxxxxxx>
From: Matt Helsley <matthltc@xxxxxxxxxx>
Update stale comments regarding locking order and add a little more detail
so it's easier to follow the locking between the cgroup freezer and the
power management freezer code.
Signed-off-by: Matt Helsley <matthltc@xxxxxxxxxx>
Cc: Oren Laadan <orenl@xxxxxxxxxxxxxxx>
Cc: Cedric Le Goater <legoater@xxxxxxx>
Cc: Paul Menage <menage@xxxxxxxxxx>
Cc: Li Zefan <lizf@xxxxxxxxxxxxxx>
---
kernel/cgroup_freezer.c | 21 +++++++++++++--------
1 files changed, 13 insertions(+), 8 deletions(-)
diff --git a/kernel/cgroup_freezer.c b/kernel/cgroup_freezer.c
index eb3f34d..2c44736 100644
--- a/kernel/cgroup_freezer.c
+++ b/kernel/cgroup_freezer.c
@@ -88,10 +88,10 @@ struct cgroup_subsys freezer_subsys;
/* Locks taken and their ordering
* ------------------------------
- * css_set_lock
* cgroup_mutex (AKA cgroup_lock)
- * task->alloc_lock (AKA task_lock)
* freezer->lock
+ * css_set_lock
+ * task->alloc_lock (AKA task_lock)
* task->sighand->siglock
*
* cgroup code forces css_set_lock to be taken before task->alloc_lock
@@ -99,33 +99,38 @@ struct cgroup_subsys freezer_subsys;
* freezer_create(), freezer_destroy():
* cgroup_mutex [ by cgroup core ]
*
- * can_attach():
- * cgroup_mutex
+ * freezer_can_attach():
+ * cgroup_mutex (held by caller of can_attach)
*
- * cgroup_frozen():
+ * cgroup_freezing_or_frozen():
* task->alloc_lock (to get task's cgroup)
*
* freezer_fork() (preserving fork() performance means can't take cgroup_mutex):
- * task->alloc_lock (to get task's cgroup)
* freezer->lock
* sighand->siglock (if the cgroup is freezing)
*
* freezer_read():
* cgroup_mutex
* freezer->lock
+ * write_lock css_set_lock (cgroup iterator start)
+ * task->alloc_lock
* read_lock css_set_lock (cgroup iterator start)
*
* freezer_write() (freeze):
* cgroup_mutex
* freezer->lock
+ * write_lock css_set_lock (cgroup iterator start)
+ * task->alloc_lock
* read_lock css_set_lock (cgroup iterator start)
- * sighand->siglock
+ * sighand->siglock (fake signal delivery inside freeze_task())
*
* freezer_write() (unfreeze):
* cgroup_mutex
* freezer->lock
+ * write_lock css_set_lock (cgroup iterator start)
+ * task->alloc_lock
* read_lock css_set_lock (cgroup iterator start)
- * task->alloc_lock (to prevent races with freeze_task())
+ * task->alloc_lock (inside thaw_process(), prevents race with refrigerator())
* sighand->siglock
*/
static struct cgroup_subsys_state *freezer_create(struct cgroup_subsys *ss,
--
1.6.3.3
--
To unsubscribe from this list: send the line "unsubscribe linux-api" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
[Home]
[Linux USB Devel]
[Video for Linux]
[Linux Audio Users]
[Photo]
[Yosemite News]
[Yosemite Photos]
[Free Online Dating]
[Linux Kernel]
[Linux SCSI]
[XFree86]