]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
workqueue: Initialize wq_isolated_cpumask in workqueue_init_early()
authorChuyi Zhou <zhouchuyi@bytedance.com>
Tue, 17 Jun 2025 04:42:16 +0000 (12:42 +0800)
committerTejun Heo <tj@kernel.org>
Tue, 17 Jun 2025 18:58:29 +0000 (08:58 -1000)
Now when isolcpus is enabled via the cmdline, wq_isolated_cpumask does
not include these isolated CPUs, even wq_unbound_cpumask has already
excluded them. It is only when we successfully configure an isolate cpuset
partition that wq_isolated_cpumask gets overwritten by
workqueue_unbound_exclude_cpumask(), including both the cmdline-specified
isolated CPUs and the isolated CPUs within the cpuset partitions.

Fix this issue by initializing wq_isolated_cpumask properly in
workqueue_init_early().

Fixes: fe28f631fa94 ("workqueue: Add workqueue_unbound_exclude_cpumask() to exclude CPUs from wq_unbound_cpumask")
Signed-off-by: Chuyi Zhou <zhouchuyi@bytedance.com>
Reviewed-by: Waiman Long <longman@redhat.com>
Signed-off-by: Tejun Heo <tj@kernel.org>
kernel/workqueue.c

index 97f37b5bae669cfcf80363de052cd3d2265c108f..9f91480758288959ff61cfcc9f0a5788ef90728d 100644 (file)
@@ -7767,7 +7767,8 @@ void __init workqueue_init_early(void)
                restrict_unbound_cpumask("workqueue.unbound_cpus", &wq_cmdline_cpumask);
 
        cpumask_copy(wq_requested_unbound_cpumask, wq_unbound_cpumask);
-
+       cpumask_andnot(wq_isolated_cpumask, cpu_possible_mask,
+                                               housekeeping_cpumask(HK_TYPE_DOMAIN));
        pwq_cache = KMEM_CACHE(pool_workqueue, SLAB_PANIC);
 
        unbound_wq_update_pwq_attrs_buf = alloc_workqueue_attrs();