]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
riscv: ptdump: use seq_puts() in pt_dump_seq_puts() macro
authorJosephine Pfeiffer <hi@josie.lol>
Mon, 27 Oct 2025 17:40:43 +0000 (11:40 -0600)
committerPaul Walmsley <pjw@kernel.org>
Mon, 27 Oct 2025 17:40:43 +0000 (11:40 -0600)
The pt_dump_seq_puts() macro incorrectly uses seq_printf() instead of
seq_puts(). This is both a performance issue and conceptually wrong,
as the macro name suggests plain string output (puts) but the
implementation uses formatted output (printf).

The macro is used in ptdump.c:301 to output a newline character. Using
seq_printf() adds unnecessary overhead for format string parsing when
outputting this constant string.

This bug was introduced in commit 59c4da8640cc ("riscv: Add support to
dump the kernel page tables") in 2020, which copied the implementation
pattern from other architectures that had the same bug.

Fixes: 59c4da8640cc ("riscv: Add support to dump the kernel page tables")
Signed-off-by: Josephine Pfeiffer <hi@josie.lol>
Link: https://lore.kernel.org/r/20251018170451.3355496-1-hi@josie.lol
Signed-off-by: Paul Walmsley <pjw@kernel.org>
arch/riscv/mm/ptdump.c

index 3b51690cc876052c4e4b13742516705e99196538..34299c2b231f1572853b26b31f754da2aacedeb1 100644 (file)
@@ -21,7 +21,7 @@
 #define pt_dump_seq_puts(m, fmt)       \
 ({                                     \
        if (m)                          \
-               seq_printf(m, fmt);     \
+               seq_puts(m, fmt);       \
 })
 
 /*