|
@@ -4535,6 +4535,7 @@ static void rebind_workers(struct worker_pool *pool)
|
|
|
pool->attrs->cpumask) < 0);
|
|
|
|
|
|
spin_lock_irq(&pool->lock);
|
|
|
+ pool->flags &= ~POOL_DISASSOCIATED;
|
|
|
|
|
|
for_each_pool_worker(worker, pool) {
|
|
|
unsigned int worker_flags = worker->flags;
|
|
@@ -4637,10 +4638,6 @@ static int workqueue_cpu_up_callback(struct notifier_block *nfb,
|
|
|
mutex_lock(&pool->attach_mutex);
|
|
|
|
|
|
if (pool->cpu == cpu) {
|
|
|
- spin_lock_irq(&pool->lock);
|
|
|
- pool->flags &= ~POOL_DISASSOCIATED;
|
|
|
- spin_unlock_irq(&pool->lock);
|
|
|
-
|
|
|
rebind_workers(pool);
|
|
|
} else if (pool->cpu < 0) {
|
|
|
restore_unbound_workers_cpumask(pool, cpu);
|