]> bbs.cooldavid.org Git - net-next-2.6.git/blobdiff - kernel/cgroup_freezer.c
Merge branch 'master' into export-slabh
[net-next-2.6.git] / kernel / cgroup_freezer.c
index d2ccd2798d7ac406a103cce43a40b99a9189cfb4..da5e139755319aa9a554a57ac699470144dcf055 100644 (file)
@@ -48,17 +48,20 @@ static inline struct freezer *task_freezer(struct task_struct *task)
                            struct freezer, css);
 }
 
-int cgroup_frozen(struct task_struct *task)
+int cgroup_freezing_or_frozen(struct task_struct *task)
 {
        struct freezer *freezer;
        enum freezer_state state;
 
        task_lock(task);
        freezer = task_freezer(task);
-       state = freezer->state;
+       if (!freezer->css.cgroup->parent)
+               state = CGROUP_THAWED; /* root cgroup can't be frozen */
+       else
+               state = freezer->state;
        task_unlock(task);
 
-       return state == CGROUP_FROZEN;
+       return (state == CGROUP_FREEZING) || (state == CGROUP_FROZEN);
 }
 
 /*