aboutsummaryrefslogtreecommitdiff
path: root/scripts/dtc/libfdt/fdt_strerror.c
diff options
context:
space:
mode:
authorSergey Senozhatsky <[email protected]>2020-03-03 20:30:02 +0900
committerLinus Torvalds <[email protected]>2020-04-10 13:18:57 -0700
commitab6f762f0f53162d41497708b33c9a3236d3609e (patch)
treee0d405ac3f1a4c99cc46609cb24bc64ee5cfea19 /scripts/dtc/libfdt/fdt_strerror.c
parent87ad46e601340394cd75c1c79b19ca906f82c543 (diff)
printk: queue wake_up_klogd irq_work only if per-CPU areas are ready
printk_deferred(), similarly to printk_safe/printk_nmi, does not immediately attempt to print a new message on the consoles, avoiding calls into non-reentrant kernel paths, e.g. scheduler or timekeeping, which potentially can deadlock the system. Those printk() flavors, instead, rely on per-CPU flush irq_work to print messages from safer contexts. For same reasons (recursive scheduler or timekeeping calls) printk() uses per-CPU irq_work in order to wake up user space syslog/kmsg readers. However, only printk_safe/printk_nmi do make sure that per-CPU areas have been initialised and that it's safe to modify per-CPU irq_work. This means that, for instance, should printk_deferred() be invoked "too early", that is before per-CPU areas are initialised, printk_deferred() will perform illegal per-CPU access. Lech Perczak [0] reports that after commit 1b710b1b10ef ("char/random: silence a lockdep splat with printk()") user-space syslog/kmsg readers are not able to read new kernel messages. The reason is printk_deferred() being called too early (as was pointed out by Petr and John). Fix printk_deferred() and do not queue per-CPU irq_work before per-CPU areas are initialized. Link: https://lore.kernel.org/lkml/[email protected]/ Reported-by: Lech Perczak <[email protected]> Signed-off-by: Sergey Senozhatsky <[email protected]> Tested-by: Jann Horn <[email protected]> Reviewed-by: Petr Mladek <[email protected]> Cc: Greg Kroah-Hartman <[email protected]> Cc: Theodore Ts'o <[email protected]> Cc: John Ogness <[email protected]> Signed-off-by: Linus Torvalds <[email protected]>
Diffstat (limited to 'scripts/dtc/libfdt/fdt_strerror.c')
0 files changed, 0 insertions, 0 deletions