forked from mirrors/linux
		
	kernel.h is being used as a dump for all kinds of stuff for a long time. Here is the attempt to start cleaning it up by splitting out panic and oops helpers. There are several purposes of doing this: - dropping dependency in bug.h - dropping a loop by moving out panic_notifier.h - unload kernel.h from something which has its own domain At the same time convert users tree-wide to use new headers, although for the time being include new header back to kernel.h to avoid twisted indirected includes for existing users. [akpm@linux-foundation.org: thread_info.h needs limits.h] [andriy.shevchenko@linux.intel.com: ia64 fix] Link: https://lkml.kernel.org/r/20210520130557.55277-1-andriy.shevchenko@linux.intel.com Link: https://lkml.kernel.org/r/20210511074137.33666-1-andriy.shevchenko@linux.intel.com Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com> Reviewed-by: Bjorn Andersson <bjorn.andersson@linaro.org> Co-developed-by: Andrew Morton <akpm@linux-foundation.org> Acked-by: Mike Rapoport <rppt@linux.ibm.com> Acked-by: Corey Minyard <cminyard@mvista.com> Acked-by: Christian Brauner <christian.brauner@ubuntu.com> Acked-by: Arnd Bergmann <arnd@arndb.de> Acked-by: Kees Cook <keescook@chromium.org> Acked-by: Wei Liu <wei.liu@kernel.org> Acked-by: Rasmus Villemoes <linux@rasmusvillemoes.dk> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Acked-by: Sebastian Reichel <sre@kernel.org> Acked-by: Luis Chamberlain <mcgrof@kernel.org> Acked-by: Stephen Boyd <sboyd@kernel.org> Acked-by: Thomas Bogendoerfer <tsbogend@alpha.franken.de> Acked-by: Helge Deller <deller@gmx.de> # parisc Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
		
			
				
	
	
		
			98 lines
		
	
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			98 lines
		
	
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* SPDX-License-Identifier: GPL-2.0 */
 | 
						|
#ifndef _LINUX_PANIC_H
 | 
						|
#define _LINUX_PANIC_H
 | 
						|
 | 
						|
#include <linux/compiler_attributes.h>
 | 
						|
#include <linux/types.h>
 | 
						|
 | 
						|
struct pt_regs;
 | 
						|
 | 
						|
extern long (*panic_blink)(int state);
 | 
						|
__printf(1, 2)
 | 
						|
void panic(const char *fmt, ...) __noreturn __cold;
 | 
						|
void nmi_panic(struct pt_regs *regs, const char *msg);
 | 
						|
extern void oops_enter(void);
 | 
						|
extern void oops_exit(void);
 | 
						|
extern bool oops_may_print(void);
 | 
						|
 | 
						|
#ifdef CONFIG_SMP
 | 
						|
extern unsigned int sysctl_oops_all_cpu_backtrace;
 | 
						|
#else
 | 
						|
#define sysctl_oops_all_cpu_backtrace 0
 | 
						|
#endif /* CONFIG_SMP */
 | 
						|
 | 
						|
extern int panic_timeout;
 | 
						|
extern unsigned long panic_print;
 | 
						|
extern int panic_on_oops;
 | 
						|
extern int panic_on_unrecovered_nmi;
 | 
						|
extern int panic_on_io_nmi;
 | 
						|
extern int panic_on_warn;
 | 
						|
 | 
						|
extern unsigned long panic_on_taint;
 | 
						|
extern bool panic_on_taint_nousertaint;
 | 
						|
 | 
						|
extern int sysctl_panic_on_rcu_stall;
 | 
						|
extern int sysctl_max_rcu_stall_to_panic;
 | 
						|
extern int sysctl_panic_on_stackoverflow;
 | 
						|
 | 
						|
extern bool crash_kexec_post_notifiers;
 | 
						|
 | 
						|
/*
 | 
						|
 * panic_cpu is used for synchronizing panic() and crash_kexec() execution. It
 | 
						|
 * holds a CPU number which is executing panic() currently. A value of
 | 
						|
 * PANIC_CPU_INVALID means no CPU has entered panic() or crash_kexec().
 | 
						|
 */
 | 
						|
extern atomic_t panic_cpu;
 | 
						|
#define PANIC_CPU_INVALID	-1
 | 
						|
 | 
						|
/*
 | 
						|
 * Only to be used by arch init code. If the user over-wrote the default
 | 
						|
 * CONFIG_PANIC_TIMEOUT, honor it.
 | 
						|
 */
 | 
						|
static inline void set_arch_panic_timeout(int timeout, int arch_default_timeout)
 | 
						|
{
 | 
						|
	if (panic_timeout == arch_default_timeout)
 | 
						|
		panic_timeout = timeout;
 | 
						|
}
 | 
						|
 | 
						|
/* This cannot be an enum because some may be used in assembly source. */
 | 
						|
#define TAINT_PROPRIETARY_MODULE	0
 | 
						|
#define TAINT_FORCED_MODULE		1
 | 
						|
#define TAINT_CPU_OUT_OF_SPEC		2
 | 
						|
#define TAINT_FORCED_RMMOD		3
 | 
						|
#define TAINT_MACHINE_CHECK		4
 | 
						|
#define TAINT_BAD_PAGE			5
 | 
						|
#define TAINT_USER			6
 | 
						|
#define TAINT_DIE			7
 | 
						|
#define TAINT_OVERRIDDEN_ACPI_TABLE	8
 | 
						|
#define TAINT_WARN			9
 | 
						|
#define TAINT_CRAP			10
 | 
						|
#define TAINT_FIRMWARE_WORKAROUND	11
 | 
						|
#define TAINT_OOT_MODULE		12
 | 
						|
#define TAINT_UNSIGNED_MODULE		13
 | 
						|
#define TAINT_SOFTLOCKUP		14
 | 
						|
#define TAINT_LIVEPATCH			15
 | 
						|
#define TAINT_AUX			16
 | 
						|
#define TAINT_RANDSTRUCT		17
 | 
						|
#define TAINT_FLAGS_COUNT		18
 | 
						|
#define TAINT_FLAGS_MAX			((1UL << TAINT_FLAGS_COUNT) - 1)
 | 
						|
 | 
						|
struct taint_flag {
 | 
						|
	char c_true;	/* character printed when tainted */
 | 
						|
	char c_false;	/* character printed when not tainted */
 | 
						|
	bool module;	/* also show as a per-module taint flag */
 | 
						|
};
 | 
						|
 | 
						|
extern const struct taint_flag taint_flags[TAINT_FLAGS_COUNT];
 | 
						|
 | 
						|
enum lockdep_ok {
 | 
						|
	LOCKDEP_STILL_OK,
 | 
						|
	LOCKDEP_NOW_UNRELIABLE,
 | 
						|
};
 | 
						|
 | 
						|
extern const char *print_tainted(void);
 | 
						|
extern void add_taint(unsigned flag, enum lockdep_ok);
 | 
						|
extern int test_taint(unsigned flag);
 | 
						|
extern unsigned long get_taint(void);
 | 
						|
 | 
						|
#endif	/* _LINUX_PANIC_H */
 |