]> git.baikalelectronics.ru Git - kernel.git/commit
powerpc/watchdog: help remote CPUs to flush NMI printk output
authorNicholas Piggin <npiggin@gmail.com>
Fri, 19 Nov 2021 11:31:46 +0000 (21:31 +1000)
committerMichael Ellerman <mpe@ellerman.id.au>
Mon, 29 Nov 2021 12:08:43 +0000 (23:08 +1100)
commit71cf77670c810b90114dc3496151fbccd8ed2d6e
treec21fd1d9a026ed1b096a1fec92bc71ed848d10d4
parent01033d451cf1e51c5edb5da465aab87026eb0bf1
powerpc/watchdog: help remote CPUs to flush NMI printk output

The printk layer at the moment does not seem to have a good way to force
flush printk messages that are created in NMI context, except in the
panic path.

NMI-context printk messages normally get to the console with irq_work,
but that won't help if the CPU is stuck with irqs disabled, as can be
the case for hard lockup watchdog messages.

The watchdog currently flushes the printk buffers after detecting a
lockup on remote CPUs, but they may not have processed their NMI IPI
yet by that stage, or they may have self-detected a lockup in which
case they won't go via this NMI IPI path.

Improve the situation by having NMI-context mark a flag if it called
printk, and have watchdog timer interrupts check if that flag was set
and try to flush if it was. Latency is not a big problem because we
were already stuck for a while, just need to try to make sure the
messages eventually make it out.

Depends-on: a62d7739d577 ("printk: restore flushing of NMI buffers on remote CPUs after NMI backtraces")
Signed-off-by: Nicholas Piggin <npiggin@gmail.com>
Reviewed-by: Laurent Dufour <ldufour@linux.ibm.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/20211119113146.752759-6-npiggin@gmail.com
arch/powerpc/kernel/watchdog.c