Merge branch 'rework/fixup-for-5.15' into for-linus
[platform/kernel/linux-rpi.git] / kernel / printk / internal.h
1 /* SPDX-License-Identifier: GPL-2.0-or-later */
2 /*
3  * internal.h - printk internal definitions
4  */
5 #include <linux/percpu.h>
6
7 #ifdef CONFIG_PRINTK
8
9 #define PRINTK_SAFE_CONTEXT_MASK        0x007ffffff
10 #define PRINTK_NMI_DIRECT_CONTEXT_MASK  0x008000000
11 #define PRINTK_NMI_CONTEXT_MASK         0xff0000000
12
13 #define PRINTK_NMI_CONTEXT_OFFSET       0x010000000
14
15 /* Flags for a single printk record. */
16 enum printk_info_flags {
17         LOG_NEWLINE     = 2,    /* text ended with a newline */
18         LOG_CONT        = 8,    /* text is a fragment of a continuation line */
19 };
20
21 __printf(4, 0)
22 int vprintk_store(int facility, int level,
23                   const struct dev_printk_info *dev_info,
24                   const char *fmt, va_list args);
25
26 __printf(1, 0) int vprintk_default(const char *fmt, va_list args);
27 __printf(1, 0) int vprintk_deferred(const char *fmt, va_list args);
28 void __printk_safe_enter(void);
29 void __printk_safe_exit(void);
30
31 void printk_safe_init(void);
32 bool printk_percpu_data_ready(void);
33
34 #define printk_safe_enter_irqsave(flags)        \
35         do {                                    \
36                 local_irq_save(flags);          \
37                 __printk_safe_enter();          \
38         } while (0)
39
40 #define printk_safe_exit_irqrestore(flags)      \
41         do {                                    \
42                 __printk_safe_exit();           \
43                 local_irq_restore(flags);       \
44         } while (0)
45
46 #define printk_safe_enter_irq()         \
47         do {                                    \
48                 local_irq_disable();            \
49                 __printk_safe_enter();          \
50         } while (0)
51
52 #define printk_safe_exit_irq()                  \
53         do {                                    \
54                 __printk_safe_exit();           \
55                 local_irq_enable();             \
56         } while (0)
57
58 void defer_console_output(void);
59
60 u16 printk_parse_prefix(const char *text, int *level,
61                         enum printk_info_flags *flags);
62 #else
63
64 /*
65  * In !PRINTK builds we still export console_sem
66  * semaphore and some of console functions (console_unlock()/etc.), so
67  * printk-safe must preserve the existing local IRQ guarantees.
68  */
69 #define printk_safe_enter_irqsave(flags) local_irq_save(flags)
70 #define printk_safe_exit_irqrestore(flags) local_irq_restore(flags)
71
72 #define printk_safe_enter_irq() local_irq_disable()
73 #define printk_safe_exit_irq() local_irq_enable()
74
75 static inline void printk_safe_init(void) { }
76 static inline bool printk_percpu_data_ready(void) { return false; }
77 #endif /* CONFIG_PRINTK */