diff options
Diffstat (limited to 'kernel/cgroup/cgroup.c')
| -rw-r--r-- | kernel/cgroup/cgroup.c | 21 | 
1 files changed, 7 insertions, 14 deletions
diff --git a/kernel/cgroup/cgroup.c b/kernel/cgroup/cgroup.c index 4bfb2908ec15..a662bfcbea0e 100644 --- a/kernel/cgroup/cgroup.c +++ b/kernel/cgroup/cgroup.c @@ -4524,10 +4524,10 @@ static struct cftype cgroup_base_files[] = {   * and thus involve punting to css->destroy_work adding two additional   * steps to the already complex sequence.   */ -static void css_free_work_fn(struct work_struct *work) +static void css_free_rwork_fn(struct work_struct *work)  { -	struct cgroup_subsys_state *css = -		container_of(work, struct cgroup_subsys_state, destroy_work); +	struct cgroup_subsys_state *css = container_of(to_rcu_work(work), +				struct cgroup_subsys_state, destroy_rwork);  	struct cgroup_subsys *ss = css->ss;  	struct cgroup *cgrp = css->cgroup; @@ -4573,15 +4573,6 @@ static void css_free_work_fn(struct work_struct *work)  	}  } -static void css_free_rcu_fn(struct rcu_head *rcu_head) -{ -	struct cgroup_subsys_state *css = -		container_of(rcu_head, struct cgroup_subsys_state, rcu_head); - -	INIT_WORK(&css->destroy_work, css_free_work_fn); -	queue_work(cgroup_destroy_wq, &css->destroy_work); -} -  static void css_release_work_fn(struct work_struct *work)  {  	struct cgroup_subsys_state *css = @@ -4631,7 +4622,8 @@ static void css_release_work_fn(struct work_struct *work)  	mutex_unlock(&cgroup_mutex); -	call_rcu(&css->rcu_head, css_free_rcu_fn); +	INIT_RCU_WORK(&css->destroy_rwork, css_free_rwork_fn); +	queue_rcu_work(cgroup_destroy_wq, &css->destroy_rwork);  }  static void css_release(struct percpu_ref *ref) @@ -4765,7 +4757,8 @@ static struct cgroup_subsys_state *css_create(struct cgroup *cgrp,  err_list_del:  	list_del_rcu(&css->sibling);  err_free_css: -	call_rcu(&css->rcu_head, css_free_rcu_fn); +	INIT_RCU_WORK(&css->destroy_rwork, css_free_rwork_fn); +	queue_rcu_work(cgroup_destroy_wq, &css->destroy_rwork);  	return ERR_PTR(err);  }  | 
