forked from mirrors/linux
		
	A few panic() related functions have a global definition but not declaration, which causes a warning with W=1: kernel/panic.c:710:6: error: no previous prototype for '__warn_printk' [-Werror=missing-prototypes] kernel/panic.c:756:24: error: no previous prototype for '__stack_chk_fail' [-Werror=missing-prototypes] kernel/exit.c:1917:32: error: no previous prototype for 'abort' [-Werror=missing-prototypes] __warn_printk() is called both as a global function when CONFIG_BUG is enabled, and as a local function in other configs. The other two here are called indirectly from generated or assembler code. Add prototypes for all of these. Link: https://lkml.kernel.org/r/20230517131102.934196-9-arnd@kernel.org Signed-off-by: Arnd Bergmann <arnd@arndb.de> Cc: Boqun Feng <boqun.feng@gmail.com> Cc: Catalin Marinas <catalin.marinas@arm.com> Cc: Christoph Lameter <cl@linux.com> Cc: Dennis Zhou <dennis@kernel.org> Cc: Eric Paris <eparis@redhat.com> Cc: Heiko Carstens <hca@linux.ibm.com> Cc: Helge Deller <deller@gmx.de> Cc: Ingo Molnar <mingo@redhat.com> Cc: Michael Ellerman <mpe@ellerman.id.au> Cc: Michal Simek <monstr@monstr.eu> Cc: Palmer Dabbelt <palmer@dabbelt.com> Cc: Paul Moore <paul@paul-moore.com> Cc: Pavel Machek <pavel@ucw.cz> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Rafael J. Wysocki <rafael@kernel.org> Cc: Russell King <linux@armlinux.org.uk> Cc: Tejun Heo <tj@kernel.org> Cc: Thomas Bogendoerfer <tsbogend@alpha.franken.de> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Waiman Long <longman@redhat.com> Cc: Will Deacon <will@kernel.org> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
		
			
				
	
	
		
			97 lines
		
	
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			97 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);
 | |
| void check_panic_on_warn(const char *origin);
 | |
| extern void oops_enter(void);
 | |
| extern void oops_exit(void);
 | |
| extern bool oops_may_print(void);
 | |
| 
 | |
| 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;
 | |
| 
 | |
| extern void __stack_chk_fail(void);
 | |
| void abort(void);
 | |
| 
 | |
| /*
 | |
|  * 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_TEST			18
 | |
| #define TAINT_FLAGS_COUNT		19
 | |
| #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 */
 |