On Fri, Sep 02, 2011 at 06:58:39PM +0200, Oleg Nesterov wrote: > On 09/01, Matt Helsley wrote: > > > > On Wed, Aug 31, 2011 at 12:21:07PM +0200, Tejun Heo wrote: > > > case CGROUP_FROZEN: > > > - atomic_inc(&system_freezing_cnt); > > > - retval = try_to_freeze_cgroup(cgroup, freezer); > > > + if (freezer->state == CGROUP_THAWED) { > > > + freezer->state = CGROUP_FREEZING; > > > + atomic_inc(&system_freezing_cnt); > > > + retval = try_to_freeze_cgroup(cgroup, freezer); > > > > This still doesn't look quite right. If the cgroup is FREEZING it should > > also call try_to_freeze_cgroup(). I think this is what's needed: > > > > if (freezer->state == CGROUP_THAWED) > > atomic_inc(&system_freezing_cnt); > > freezer->state = CGROUP_FREEZING; > > retval = try_to_freeze_cgroup(cgroup, freezer); > > This is what I mentioned before, to me this looks like a win. > > Why do we need try_to_freeze_cgroup() in this case? "for safety" > could actually mean "hide the bug" ;) Well, I need to check Tejun's latest freezer bits to see if this is still the case but it was possible to get to the FREEZING state and not enter FROZEN before returning to userspace. So you could come back into the state change function in the FREEZING state with FROZEN as the goal state. Note that for the cgroup freezer the FREEZING state is optional -- so skipping it is fine so long was we guarantee that by the time we exit to userspace with a FROZEN state all the tasks in the cgroup are actually frozen (in the refrigerator loop) or frozen enough (about to enter the refrigerator loop without causing more IO -- e.g. stopped). Cheers, -Matt _______________________________________________ linux-pm mailing list linux-pm@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linux-foundation.org/mailman/listinfo/linux-pm