[RFC] pr_warn_once() issue in x86 MSR extable code
From: Stephane Eranian
Date: Fri Jun 17 2022 - 07:09:10 EST
Hi,
Some changes to the way invalid MSR accesses are reported by the kernel is
causing some problems with messages printed on the console.
We have seen several cases of ex_handler_msr() printing invalid MSR
accesses once but
the callstack multiple times causing confusion on the console.
The last time the exception MSR code was modified (5.16) by PeterZ was:
d52a7344bdfa x86/msr: Remove .fixup usage:
if (!safe && wrmsr && pr_warn_once("unchecked MSR access error: ..."))
show_stack_regs(regs);
Note that this code pattern was also present, though in a different
form, before this commit.
The problem here is that another earlier commit (5.13):
a358f40600b3 once: implement DO_ONCE_LITE for non-fast-path "do once"
functionality
Modifies all the pr_*_once() calls to always return true claiming that
no caller is ever
checking the return value of the functions.
This is why we are seeing the callstack printed without the associated
printk() msg.
I believe that having the pr_*_once() functions return true the first
time they are called
is useful especially when extra information, such as callstack, must
be printed to help
track the origin of the problem.
The exception handling code seems to be the only place where the
return value is checked
for pr_warn_once(). A minimal change would be to create another
version of that function
that calls DO_ONCE() instead of DO_ONCE_LITE(), e.g., pr_warn_once_return().
I can post a patch to that effect if we all agree on the approach.
Thanks.