x86/nmi: Upgrade NMI backtrace stall checks & messages
authorPaul E. McKenney <paulmck@kernel.org>
Fri, 8 Mar 2024 01:32:15 +0000 (17:32 -0800)
committerIngo Molnar <mingo@kernel.org>
Tue, 26 Mar 2024 09:07:59 +0000 (10:07 +0100)
commit3186b61812c007179f1852d8e63a0f0f7dd7c783
treecb3c07ef6657ccafde80245e8fc6d9f0ae335194
parentb6540de9b5c867b4c8bc31225db181cc017d8cc7
x86/nmi: Upgrade NMI backtrace stall checks & messages

The commit to improve NMI stall debuggability:

  344da544f177 ("x86/nmi: Print reasons why backtrace NMIs are ignored")

... has shown value, but widespread use has also identified a few
opportunities for improvement.

The systems have (as usual) shown far more creativity than that commit's
author, demonstrating yet again that failing CPUs can do whatever they want.

In addition, the current message format is less friendly than one might
like to those attempting to use these messages to identify failing CPUs.

Therefore, separately flag CPUs that, during the full time that the
stack-backtrace request was waiting, were always in an NMI handler,
were never in an NMI handler, or exited one NMI handler.

Also, split the message identifying the CPU and the time since that CPU's
last NMI-related activity so that a single line identifies the CPU without
any other variable information, greatly reducing the processing overhead
required to identify repeat-offender CPUs.

Co-developed-by: Breno Leitao <leitao@debian.org>
Signed-off-by: Breno Leitao <leitao@debian.org>
Signed-off-by: Paul E. McKenney <paulmck@kernel.org>
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Link: https://lore.kernel.org/r/ab4d70c8-c874-42dc-b206-643018922393@paulmck-laptop
arch/x86/kernel/nmi.c