* Oleg Nesterov <[EMAIL PROTECTED]> wrote: > Currently it is allowed that work->func() does flush_workqueue() on > its own workqueue. So we have > > run_workqueue() > work->func() > flush_workqueue() > run_workqueue() > > All but work->func() take wq->lockdep_map, I guess check_deadlock() > won't be happy.
yep. > OTOH. Perhaps we can can forbid such a behaviour? Andrew, do you know > any good example of "keventd trying to flush its own queue" ? i'd prefer to make the API a little bit stricter: such recursion is nasty. Btw., what mechanism prevents the second instance of run_workqueue() calling into a work->func() again? Ingo - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/