[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20250926124912.243464-1-pmladek@suse.com>
Date: Fri, 26 Sep 2025 14:49:09 +0200
From: Petr Mladek <pmladek@...e.com>
To: John Ogness <john.ogness@...utronix.de>
Cc: Greg Kroah-Hartman <gregkh@...uxfoundation.org>,
Jiri Slaby <jirislaby@...nel.org>,
Sergey Senozhatsky <senozhatsky@...omium.org>,
Steven Rostedt <rostedt@...dmis.org>,
Thomas Gleixner <tglx@...utronix.de>,
Esben Haabendal <esben@...nix.com>,
linux-serial@...r.kernel.org,
linux-kernel@...r.kernel.org,
Andy Shevchenko <andriy.shevchenko@...ux.intel.com>,
Arnd Bergmann <arnd@...db.de>,
Tony Lindgren <tony@...mide.com>,
Niklas Schnelle <schnelle@...ux.ibm.com>,
Serge Semin <fancer.lancer@...il.com>,
Andrew Murray <amurray@...goodpenguin.co.uk>,
Petr Mladek <pmladek@...e.com>
Subject: [PATCH 0/3] printk/nbcon: Prevent hardlockup reports caused by atomic nbcon flush
This patchset should solve problem which was being discussed
at https://lore.kernel.org/all/aNFR45fL2L4PavNc@pathway.suse.cz
__nbcon_atomic_flush_pending_con() preserves the nbcon console
ownership all the time when flushing pending messages. It might
take a long time with slow serial consoles.
It might trigger a hardlockup report on another CPU which is
busy waiting for the nbcon console ownership, for example,
in nbcon_reacquire_nobuf() or __uart_port_nbcon_acquire().
The problem is solved by the 3rd patch. It releases the console
context ownership after each record.
The 3rd patch alone would increase the risk of takeovers and repeated
lines. It is prevented by the 1st patch which blocks the printk kthread
when any CPU is in an emergency context.
The 2nd patch allows to block the printk kthread also in panic.
It is not important. It is just an obvious update of the check
for emergency contexts.
Note: The patchset applies against current Linus' tree (v6.17-rc7).
The 2nd patch would need an update after the consolisation of
the panic state API gets merged via -mm tree,
see https://lore.kernel.org/r/20250825022947.1596226-2-wangjinchao600@gmail.com
Petr Mladek (3):
printk/nbcon: Block printk kthreads when any CPU is in an emergency
context
printk/nbcon/panic: Allow printk kthread to sleep when the system is
in panic
printk/nbcon: Release nbcon consoles ownership in atomic flush after
each emitted record
kernel/printk/internal.h | 1 +
kernel/printk/nbcon.c | 43 +++++++++++++++++++++++++++++++++++-----
kernel/printk/printk.c | 2 +-
3 files changed, 40 insertions(+), 6 deletions(-)
--
2.51.0
Powered by blists - more mailing lists