// SPDX-License-Identifier: GPL-2.0-or-later /* * printk_safe.c - Safe printk for printk-deadlock-prone contexts */ #include <linux/preempt.h> #include <linux/kdb.h> #include <linux/smp.h> #include <linux/cpumask.h> #include <linux/printk.h> #include <linux/kprobes.h> #include "internal.h" static DEFINE_PER_CPU(int, printk_context); /* Can be preempted by NMI. */ void __printk_safe_enter(void) { … } /* Can be preempted by NMI. */ void __printk_safe_exit(void) { … } void __printk_deferred_enter(void) { … } void __printk_deferred_exit(void) { … } bool is_printk_legacy_deferred(void) { … } asmlinkage int vprintk(const char *fmt, va_list args) { … } EXPORT_SYMBOL(…);