mirror of
https://github.com/torvalds/linux.git
synced 2024-11-21 19:41:42 +00:00
io_uring/io-wq: inherit cpuset of cgroup in io worker
The io worker threads are userland threads that just never exit to the
userland. By that, they are also assigned to a cgroup (the group of the
creating task).
When creating a new io worker, this worker should inherit the cpuset
of the cgroup.
Fixes: da64d6db3b
("io_uring: One wqe per wq")
Signed-off-by: Felix Moessbauer <felix.moessbauer@siemens.com>
Link: https://lore.kernel.org/r/20240910171157.166423-3-felix.moessbauer@siemens.com
Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
parent
0997aa5497
commit
84eacf177f
@ -1168,7 +1168,7 @@ struct io_wq *io_wq_create(unsigned bounded, struct io_wq_data *data)
|
|||||||
|
|
||||||
if (!alloc_cpumask_var(&wq->cpu_mask, GFP_KERNEL))
|
if (!alloc_cpumask_var(&wq->cpu_mask, GFP_KERNEL))
|
||||||
goto err;
|
goto err;
|
||||||
cpumask_copy(wq->cpu_mask, cpu_possible_mask);
|
cpuset_cpus_allowed(data->task, wq->cpu_mask);
|
||||||
wq->acct[IO_WQ_ACCT_BOUND].max_workers = bounded;
|
wq->acct[IO_WQ_ACCT_BOUND].max_workers = bounded;
|
||||||
wq->acct[IO_WQ_ACCT_UNBOUND].max_workers =
|
wq->acct[IO_WQ_ACCT_UNBOUND].max_workers =
|
||||||
task_rlimit(current, RLIMIT_NPROC);
|
task_rlimit(current, RLIMIT_NPROC);
|
||||||
|
Loading…
Reference in New Issue
Block a user