On 09/24, Peter Zijlstra wrote: > > A genuine bug, we cannot use blocking primitives inside a wait loop. > > So rewrite the wait_event_interruptible() usage to use the fresh > wait_woken() stuff.
OK, but ... > +static int wait_finished_loading(struct module *mod) > +{ > + DEFINE_WAIT_FUNC(wait, woken_wake_function); > + int ret = 0; > + > + add_wait_queue(&module_wq, &wait); > + for (;;) { > + if (finished_loading(mod->name)) > + break; > + > + if (signal_pending_state(TASK_INTERRUPTIBLE, current)) { I am puzzled by this line, why not if (signal_pending(current)) { ? this should be 100% equivalent. Oleg. -- 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/