diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2018-04-03 21:00:13 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2018-04-03 21:00:13 -0400 |
commit | d92cd810e64aa7cf22b05f0ea1c7d3e8dbae75fe (patch) | |
tree | 592e040010a30d1dbce4e54eb597011af0df290e /kernel/cgroup | |
parent | a23867f1d2de572f84b459651dfe99fa9e79fadf (diff) | |
parent | f75da8a8a918d7c343a2ec95d1ed99e5689e0f23 (diff) |
Merge branch 'for-4.17' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/wq
Pull workqueue updates from Tejun Heo:
"rcu_work addition and a couple trivial changes"
* 'for-4.17' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/wq:
workqueue: remove the comment about the old manager_arb mutex
workqueue: fix the comments of nr_idle
fs/aio: Use rcu_work instead of explicit rcu and work item
cgroup: Use rcu_work instead of explicit rcu and work item
RCU, workqueue: Implement rcu_work
Diffstat (limited to 'kernel/cgroup')
-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[] = { | |||
4524 | * and thus involve punting to css->destroy_work adding two additional | 4524 | * and thus involve punting to css->destroy_work adding two additional |
4525 | * steps to the already complex sequence. | 4525 | * steps to the already complex sequence. |
4526 | */ | 4526 | */ |
4527 | static void css_free_work_fn(struct work_struct *work) | 4527 | static void css_free_rwork_fn(struct work_struct *work) |
4528 | { | 4528 | { |
4529 | struct cgroup_subsys_state *css = | 4529 | struct cgroup_subsys_state *css = container_of(to_rcu_work(work), |
4530 | container_of(work, struct cgroup_subsys_state, destroy_work); | 4530 | struct cgroup_subsys_state, destroy_rwork); |
4531 | struct cgroup_subsys *ss = css->ss; | 4531 | struct cgroup_subsys *ss = css->ss; |
4532 | struct cgroup *cgrp = css->cgroup; | 4532 | struct cgroup *cgrp = css->cgroup; |
4533 | 4533 | ||
@@ -4573,15 +4573,6 @@ static void css_free_work_fn(struct work_struct *work) | |||
4573 | } | 4573 | } |
4574 | } | 4574 | } |
4575 | 4575 | ||
4576 | static void css_free_rcu_fn(struct rcu_head *rcu_head) | ||
4577 | { | ||
4578 | struct cgroup_subsys_state *css = | ||
4579 | container_of(rcu_head, struct cgroup_subsys_state, rcu_head); | ||
4580 | |||
4581 | INIT_WORK(&css->destroy_work, css_free_work_fn); | ||
4582 | queue_work(cgroup_destroy_wq, &css->destroy_work); | ||
4583 | } | ||
4584 | |||
4585 | static void css_release_work_fn(struct work_struct *work) | 4576 | static void css_release_work_fn(struct work_struct *work) |
4586 | { | 4577 | { |
4587 | struct cgroup_subsys_state *css = | 4578 | struct cgroup_subsys_state *css = |
@@ -4631,7 +4622,8 @@ static void css_release_work_fn(struct work_struct *work) | |||
4631 | 4622 | ||
4632 | mutex_unlock(&cgroup_mutex); | 4623 | mutex_unlock(&cgroup_mutex); |
4633 | 4624 | ||
4634 | call_rcu(&css->rcu_head, css_free_rcu_fn); | 4625 | INIT_RCU_WORK(&css->destroy_rwork, css_free_rwork_fn); |
4626 | queue_rcu_work(cgroup_destroy_wq, &css->destroy_rwork); | ||
4635 | } | 4627 | } |
4636 | 4628 | ||
4637 | static void css_release(struct percpu_ref *ref) | 4629 | static void css_release(struct percpu_ref *ref) |
@@ -4765,7 +4757,8 @@ static struct cgroup_subsys_state *css_create(struct cgroup *cgrp, | |||
4765 | err_list_del: | 4757 | err_list_del: |
4766 | list_del_rcu(&css->sibling); | 4758 | list_del_rcu(&css->sibling); |
4767 | err_free_css: | 4759 | err_free_css: |
4768 | call_rcu(&css->rcu_head, css_free_rcu_fn); | 4760 | INIT_RCU_WORK(&css->destroy_rwork, css_free_rwork_fn); |
4761 | queue_rcu_work(cgroup_destroy_wq, &css->destroy_rwork); | ||
4769 | return ERR_PTR(err); | 4762 | return ERR_PTR(err); |
4770 | } | 4763 | } |
4771 | 4764 | ||