Ring no bell if the stopper thread is busy in handling enqueued works. Signed-off-by: Hillf Danton <dhi...@gmail.com> ---
--- a/kernel/stop_machine.c Wed Feb 6 20:05:44 2013 +++ b/kernel/stop_machine.c Wed Feb 6 20:06:56 2013 @@ -72,8 +72,10 @@ static void cpu_stop_queue_work(struct c spin_lock_irqsave(&stopper->lock, flags); if (stopper->enabled) { + int wakeup = list_empty(&stopper->works); list_add_tail(&work->list, &stopper->works); - wake_up_process(stopper->thread); + if (wakeup) + wake_up_process(stopper->thread); } else cpu_stop_signal_done(work->done, false, 0); -- -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/