diff options
| author | Tejun Heo <tj@kernel.org> | 2014-05-13 11:28:30 -0400 | 
|---|---|---|
| committer | Tejun Heo <tj@kernel.org> | 2014-05-13 11:28:30 -0400 | 
| commit | 36e9d2ebcc15d029b33f42a36146ab5a5bcfcfe7 (patch) | |
| tree | 8de644b8fb941ee475163b59ad76506a647a9d85 | |
| parent | e5ced8ebb10c20a3b349bd798b69ccabd3b25d21 (diff) | |
cgroup: fix rcu_read_lock() leak in update_if_frozen()
While updating cgroup_freezer locking, 68fafb77d827 ("cgroup_freezer:
replace freezer->lock with freezer_mutex") introduced a bug in
update_if_frozen() where it returns with rcu_read_lock() held.  Fix it
by adding rcu_read_unlock() before returning.
Signed-off-by: Tejun Heo <tj@kernel.org>
Reported-by: kbuild test robot <fengguang.wu@intel.com>
| -rw-r--r-- | kernel/cgroup_freezer.c | 4 | 
1 files changed, 3 insertions, 1 deletions
diff --git a/kernel/cgroup_freezer.c b/kernel/cgroup_freezer.c index 12ead0b766ee..345628c78b5b 100644 --- a/kernel/cgroup_freezer.c +++ b/kernel/cgroup_freezer.c @@ -267,8 +267,10 @@ static void update_if_frozen(struct cgroup_subsys_state *css)  		struct freezer *child = css_freezer(pos);  		if ((child->state & CGROUP_FREEZER_ONLINE) && -		    !(child->state & CGROUP_FROZEN)) +		    !(child->state & CGROUP_FROZEN)) { +			rcu_read_unlock();  			return; +		}  	}  	rcu_read_unlock();  | 
