> It doesn't come as a surprise that recursive printk() calls are not the > only way for us to deadlock in printk() and we still have a whole bunch > of other printk() deadlock scenarios. For instance, those that involve > TTY port->lock spin_lock and UART port->lock spin_lock. The tty layer code there is not re-entrant. Nor is it supposed to be > So the idea of this patch set is to take tty_port->lock and > uart_port->lock from printk_safe context and to eliminate some > of non-recursive printk() deadlocks - the ones that don't start > in printk(), but involve console related locks and thus eventually > deadlock us in printk(). For this purpose the patch set introduces > several helper macros: I don't see how this helps - if you recurse into the uart code you are still hitting the paths that are unsafe when re-entered. All you've done is messed up a pile of locking code on critical performance paths. As it stands I think it's a bad idea. > Of course, TTY and UART port spin_locks are not the only locks that > we can deadlock on. So this patch set does not address all deadlock > scenarios, it just makes a small step forward. > > Any opinions? The cure is worse than the disease. The only case that's worth looking at is the direct polled console code paths. The moment you touch the other layers you add essentially never needed code to hot paths. Given printk nowdays is already somewhat unreliable with all the perf related changes, and we have other good debug tools I think it would be far cleaner to have some kind of if (spin_trylock(...)) { console_defer(buffer); return; } helper layer in the printk/console logic, at least for the non panic/oops cases. Alan -- To unsubscribe from this list: send the line "unsubscribe linux-serial" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html