mirror of
https://github.com/Fishwaldo/linux-bl808.git
synced 2025-06-17 20:25:19 +00:00
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
This commit is contained in:
commit
d92cd810e6
5 changed files with 93 additions and 34 deletions
|
@ -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);
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue