|
@@ -1804,8 +1804,8 @@ static void pool_mayday_timeout(unsigned long __pool)
|
|
|
struct worker_pool *pool = (void *)__pool;
|
|
|
struct work_struct *work;
|
|
|
|
|
|
- spin_lock_irq(&wq_mayday_lock); /* for wq->maydays */
|
|
|
- spin_lock(&pool->lock);
|
|
|
+ spin_lock_irq(&pool->lock);
|
|
|
+ spin_lock(&wq_mayday_lock); /* for wq->maydays */
|
|
|
|
|
|
if (need_to_create_worker(pool)) {
|
|
|
/*
|
|
@@ -1818,8 +1818,8 @@ static void pool_mayday_timeout(unsigned long __pool)
|
|
|
send_mayday(work);
|
|
|
}
|
|
|
|
|
|
- spin_unlock(&pool->lock);
|
|
|
- spin_unlock_irq(&wq_mayday_lock);
|
|
|
+ spin_unlock(&wq_mayday_lock);
|
|
|
+ spin_unlock_irq(&pool->lock);
|
|
|
|
|
|
mod_timer(&pool->mayday_timer, jiffies + MAYDAY_INTERVAL);
|
|
|
}
|