diff options
Diffstat (limited to 'kernel/bpf/cgroup.c')
| -rw-r--r-- | kernel/bpf/cgroup.c | 11 | 
1 files changed, 5 insertions, 6 deletions
| diff --git a/kernel/bpf/cgroup.c b/kernel/bpf/cgroup.c index 180b630279b9..248f517d66d0 100644 --- a/kernel/bpf/cgroup.c +++ b/kernel/bpf/cgroup.c @@ -27,14 +27,15 @@ EXPORT_SYMBOL(cgroup_bpf_enabled_key);  /*   * cgroup bpf destruction makes heavy use of work items and there can be a lot   * of concurrent destructions.  Use a separate workqueue so that cgroup bpf - * destruction work items don't end up filling up max_active of system_wq + * destruction work items don't end up filling up max_active of system_percpu_wq   * which may lead to deadlock.   */  static struct workqueue_struct *cgroup_bpf_destroy_wq;  static int __init cgroup_bpf_wq_init(void)  { -	cgroup_bpf_destroy_wq = alloc_workqueue("cgroup_bpf_destroy", 0, 1); +	cgroup_bpf_destroy_wq = alloc_workqueue("cgroup_bpf_destroy", +						WQ_PERCPU, 1);  	if (!cgroup_bpf_destroy_wq)  		panic("Failed to alloc workqueue for cgroup bpf destroy.\n");  	return 0; @@ -71,8 +72,7 @@ bpf_prog_run_array_cg(const struct cgroup_bpf *cgrp,  	u32 func_ret;  	run_ctx.retval = retval; -	migrate_disable(); -	rcu_read_lock(); +	rcu_read_lock_dont_migrate();  	array = rcu_dereference(cgrp->effective[atype]);  	item = &array->items[0];  	old_run_ctx = bpf_set_run_ctx(&run_ctx.run_ctx); @@ -88,8 +88,7 @@ bpf_prog_run_array_cg(const struct cgroup_bpf *cgrp,  		item++;  	}  	bpf_reset_run_ctx(old_run_ctx); -	rcu_read_unlock(); -	migrate_enable(); +	rcu_read_unlock_migrate();  	return run_ctx.retval;  } | 
