On 2019-02-27, Petr Mladek <pmladek@xxxxxxxx> wrote: > I mean that your patch does the reply on a very hidden location. Right. I understand that and I agree. > Regarding the per-console kthread. It would make sense if > we stop handling all consoles synchronously. For example, > when we push messages to fast consoles immediately and > offload the work for slow consoles. My per-console kthread suggestion relating to fast consoles is so that some consoles (such as netconsole, which is quite fast) could drop less messages than a slow console (such as uart). > Anyway, we first need to make the offload reliable enough. > It is not acceptable to always offload all messages. > We have been there last few years. We must keep a high > chance to see the messages. Any warning might be important > when it causes the system to die. Nobody knows what message > is such an important. You seem to be missing the point of the series. It _is_ acceptable to offload all messages because they are being offloaded to non-emergency consoles. If messages are lost, it sucks (and the appropriate "dropped" messages are sent), but it isn't critical. Once we can agree to this point, printk becomes so much easier to work with. Emergency consoles exist for handling important messages. They will not drop messages. They are synchronous and immediate. >> It is not necessary. It is desired. Why should _any_ task be punished >> with console writing? That is what the printk kthread is for. > > I do not know about any acceptable solution without punishing > the tasks. But we might find a better compromise between the > punishment and reliability. I do not want printk to compromise. That compromise is part of the problem. Let's partition printk to important and non-important so that we can optimize both. _That_ is the heart of this series. John Ogness