summaryrefslogtreecommitdiff
path: root/lib/bug.c
diff options
context:
space:
mode:
authorPeter Zijlstra <peterz@infradead.org>2025-06-07 10:51:24 +0200
committerPeter Zijlstra <peterz@infradead.org>2025-11-21 11:21:31 +0100
commit5c47b7f3d1a9d7589026a201abb8ad445f029246 (patch)
tree622fb4743ea482d30284b6554a719081a0d1abc9 /lib/bug.c
parent30b82568b04e279d0d99482db036f1bdfecac522 (diff)
bug: Add BUG_FORMAT_ARGS infrastructure
Add BUG_FORMAT_ARGS; when an architecture is able to provide a va_list given pt_regs, use this to print format arguments. Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org> Link: https://patch.msgid.link/20251110115757.457339417@infradead.org
Diffstat (limited to 'lib/bug.c')
-rw-r--r--lib/bug.c17
1 files changed, 15 insertions, 2 deletions
diff --git a/lib/bug.c b/lib/bug.c
index 6e57199ed1f7..8100258a2004 100644
--- a/lib/bug.c
+++ b/lib/bug.c
@@ -163,11 +163,23 @@ struct bug_entry *find_bug(unsigned long bugaddr)
return module_find_bug(bugaddr);
}
-static void __warn_printf(const char *fmt)
+static void __warn_printf(const char *fmt, struct pt_regs *regs)
{
if (!fmt)
return;
+#ifdef HAVE_ARCH_BUG_FORMAT_ARGS
+ if (regs) {
+ struct arch_va_list _args;
+ va_list *args = __warn_args(&_args, regs);
+
+ if (args) {
+ vprintk(fmt, *args);
+ return;
+ }
+ }
+#endif
+
printk("%s", fmt);
}
@@ -193,6 +205,7 @@ static enum bug_trap_type __report_bug(unsigned long bugaddr, struct pt_regs *re
once = bug->flags & BUGFLAG_ONCE;
done = bug->flags & BUGFLAG_DONE;
no_cut = bug->flags & BUGFLAG_NO_CUT_HERE;
+ has_args = bug->flags & BUGFLAG_ARGS;
if (warning && once) {
if (done)
@@ -212,7 +225,7 @@ static enum bug_trap_type __report_bug(unsigned long bugaddr, struct pt_regs *re
*/
if (!no_cut) {
printk(KERN_DEFAULT CUT_HERE);
- __warn_printf(fmt);
+ __warn_printf(fmt, has_args ? regs : NULL);
}
if (warning) {