Linux Container Development
 help / color / mirror / Atom feed
  • [parent not found: <20110831102210.GC2828@mtj.dyndns.org>]
  • [parent not found: <20110831102100.GA2828-9pTldWuhBndy/B6EtB590w@public.gmane.org>]
  • [parent not found: <20110902004231.GF1919@count0.beaverton.ibm.com>]
  • * [PATCH pm-freezer 1/4] cgroup_freezer: fix freezer->state setting bug in freezer_change_state()
    @ 2011-08-31 10:21 Tejun Heo
      0 siblings, 0 replies; 16+ messages in thread
    From: Tejun Heo @ 2011-08-31 10:21 UTC (permalink / raw)
      To: Rafael J. Wysocki, Oleg Nesterov, Paul Menage
      Cc: containers-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA,
    	linux-pm-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA,
    	linux-kernel-u79uwXL29TY76Z2rM5mHXA
    
    d02f52811d0e "cgroup_freezer: prepare for removal of TIF_FREEZE" moved
    setting of freezer->state into freezer_change_state(); unfortunately,
    while doing so, when it's beginning to freeze tasks, it sets the state
    to CGROUP_FROZEN instead of CGROUP_FREEZING ending up skipping the
    whole freezing state.  Fix it.
    
    -v2: Oleg pointed out that re-freezing FROZEN cgroup could increment
         system_freezing_cnt.  Fixed.
    
    Signed-off-by: Tejun Heo <tj-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
    Reported-by: Oleg Nesterov <oleg-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
    Cc: Paul Menage <paul-inf54ven1CmVyaH7bEyXVA@public.gmane.org>
    Cc: "Rafael J. Wysocki" <rjw-KKrjLPT3xs0@public.gmane.org>
    ---
    I'm in the process of moving and can only use a quite old laptop.  I
    tested compile but couldn't really do much else, so please proceed
    with caution.  Oleg, can you please ack the patches if you agree with
    the updated versions?
    
    Thanks.
    
     kernel/cgroup_freezer.c |   20 +++++++++++---------
     1 file changed, 11 insertions(+), 9 deletions(-)
    
    Index: work/kernel/cgroup_freezer.c
    ===================================================================
    --- work.orig/kernel/cgroup_freezer.c
    +++ work/kernel/cgroup_freezer.c
    @@ -308,24 +308,26 @@ static int freezer_change_state(struct c
     	spin_lock_irq(&freezer->lock);
     
     	update_if_frozen(cgroup, freezer);
    -	if (goal_state == freezer->state)
    -		goto out;
    -
    -	freezer->state = goal_state;
     
     	switch (goal_state) {
     	case CGROUP_THAWED:
    -		atomic_dec(&system_freezing_cnt);
    -		unfreeze_cgroup(cgroup, freezer);
    +		if (freezer->state != CGROUP_THAWED) {
    +			freezer->state = CGROUP_THAWED;
    +			atomic_dec(&system_freezing_cnt);
    +			unfreeze_cgroup(cgroup, freezer);
    +		}
     		break;
     	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);
    +		}
     		break;
     	default:
     		BUG();
     	}
    -out:
    +
     	spin_unlock_irq(&freezer->lock);
     
     	return retval;
    
    ^ permalink raw reply	[flat|nested] 16+ messages in thread
    [parent not found: <20110829140418.GB18871@mtj.dyndns.org>]
    * [PATCH pm-freezer 1/4] cgroup_freezer: fix freezer->state setting bug in freezer_change_state()
    @ 2011-08-29 14:04 Tejun Heo
      0 siblings, 0 replies; 16+ messages in thread
    From: Tejun Heo @ 2011-08-29 14:04 UTC (permalink / raw)
      To: Rafael J. Wysocki, Oleg Nesterov, Paul Menage
      Cc: containers-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA,
    	linux-pm-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA,
    	linux-kernel-u79uwXL29TY76Z2rM5mHXA
    
    d02f52811d0e "cgroup_freezer: prepare for removal of TIF_FREEZE" moved
    setting of freezer->state into freezer_change_state(); unfortunately,
    while doing so, when it's beginning to freeze tasks, it sets the state
    to CGROUP_FROZEN instead of CGROUP_FREEZING ending up skipping the
    whole freezing state.  Fix it.
    
    Signed-off-by: Tejun Heo <tj-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
    Reported-by: Oleg Nesterov <oleg-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
    Cc: Paul Menage <paul-inf54ven1CmVyaH7bEyXVA@public.gmane.org>
    Cc: "Rafael J. Wysocki" <rjw-KKrjLPT3xs0@public.gmane.org>
    ---
    Rafael, these four patches fix the issues spotted by Oleg during
    review of the freezer patchset.  Please apply them on pm-freezer once
    Oleg acks them.  Thanks.
    
     kernel/cgroup_freezer.c |    4 ++--
     1 file changed, 2 insertions(+), 2 deletions(-)
    
    Index: work/kernel/cgroup_freezer.c
    ===================================================================
    --- work.orig/kernel/cgroup_freezer.c
    +++ work/kernel/cgroup_freezer.c
    @@ -311,14 +311,14 @@ static int freezer_change_state(struct c
     	if (goal_state == freezer->state)
     		goto out;
     
    -	freezer->state = goal_state;
    -
     	switch (goal_state) {
     	case CGROUP_THAWED:
    +		freezer->state = CGROUP_THAWED;
     		atomic_dec(&system_freezing_cnt);
     		unfreeze_cgroup(cgroup, freezer);
     		break;
     	case CGROUP_FROZEN:
    +		freezer->state = CGROUP_FREEZING;
     		atomic_inc(&system_freezing_cnt);
     		retval = try_to_freeze_cgroup(cgroup, freezer);
     		break;
    
    ^ permalink raw reply	[flat|nested] 16+ messages in thread

    end of thread, other threads:[~2011-09-02 18:31 UTC | newest]
    
    Thread overview: 16+ messages (download: mbox.gz follow: Atom feed
    -- links below jump to the message on this page --
         [not found] <20110831102100.GA2828@mtj.dyndns.org>
         [not found] ` <20110831102143.GB2828@mtj.dyndns.org>
         [not found]   ` <20110831102143.GB2828-9pTldWuhBndy/B6EtB590w@public.gmane.org>
    2011-08-31 10:22     ` [PATCH pm-freezer 3/4] freezer: restructure __refrigerator() Tejun Heo
         [not found]   ` <20110831102210.GC2828@mtj.dyndns.org>
         [not found]     ` <20110831102210.GC2828-9pTldWuhBndy/B6EtB590w@public.gmane.org>
    2011-08-31 10:22       ` [PATCH pm-freezer 4/4] freezer: use lock_task_sighand() in fake_signal_wake_up() Tejun Heo
    2011-09-02 17:08       ` [PATCH pm-freezer 3/4] freezer: restructure __refrigerator() Oleg Nesterov
         [not found] ` <20110831102100.GA2828-9pTldWuhBndy/B6EtB590w@public.gmane.org>
    2011-08-31 10:21   ` [PATCH pm-freezer 2/4] freezer: set PF_NOFREEZE on a dying task right before TASK_DEAD setting bug in freezer_change_state() Tejun Heo
    2011-08-31 18:08   ` [PATCH pm-freezer 1/4] cgroup_freezer: fix freezer->state " Oleg Nesterov
    2011-09-02  0:42   ` Matt Helsley
         [not found] ` <20110902004231.GF1919@count0.beaverton.ibm.com>
         [not found]   ` <20110902004231.GF1919-52DBMbEzqgQ/wnmkkaCWp/UQ3DHhIser@public.gmane.org>
    2011-09-02  2:50     ` Tejun Heo
    2011-09-02 16:58     ` Oleg Nesterov
         [not found]       ` <20110902165839.GA7478-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
    2011-09-02 17:08         ` Tejun Heo
    2011-09-02 18:31         ` Matt Helsley
         [not found]       ` <20110902170844.GJ2752@htj.dyndns.org>
         [not found]         ` <20110902170844.GJ2752-Gd/HAXX7CRxy/B6EtB590w@public.gmane.org>
    2011-09-02 17:15           ` Oleg Nesterov
    2011-09-02 17:30           ` Oleg Nesterov
         [not found]         ` <20110902171517.GA8247@redhat.com>
         [not found]           ` <20110902171517.GA8247-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
    2011-09-02 17:31             ` Tejun Heo
    2011-08-31 10:21 Tejun Heo
         [not found] <20110829140418.GB18871@mtj.dyndns.org>
         [not found] ` <20110829140418.GB18871-9pTldWuhBndy/B6EtB590w@public.gmane.org>
    2011-08-29 16:00   ` Oleg Nesterov
      -- strict thread matches above, loose matches on Subject: below --
    2011-08-29 14:04 Tejun Heo
    

    This is a public inbox, see mirroring instructions
    for how to clone and mirror all data and code used for this inbox