mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 9fe6299dde
			
		
	
	
		9fe6299dde
		
	
	
	
	
		
			
			When the kernel.print-fatal-signals sysctl has been enabled, a simple
userspace crash will cause the kernel to write a crash dump that contains,
among other things, the kernel gsbase into dmesg.
As suggested by Andy, limit output to pt_regs, FS_BASE and KERNEL_GS_BASE
in this case.
This also moves the bitness-specific logic from show_regs() into
process_{32,64}.c.
Fixes: 45807a1df9 ("vdso: print fatal signals")
Signed-off-by: Jann Horn <jannh@google.com>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Cc: "H. Peter Anvin" <hpa@zytor.com>
Cc: Andy Lutomirski <luto@kernel.org>
Cc: Borislav Petkov <bpetkov@suse.de>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Cc: stable@vger.kernel.org
Link: https://lkml.kernel.org/r/20180831194151.123586-1-jannh@google.com
		
	
			
		
			
				
	
	
		
			44 lines
		
	
	
		
			964 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			964 B
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| #ifndef _ASM_X86_KDEBUG_H
 | |
| #define _ASM_X86_KDEBUG_H
 | |
| 
 | |
| #include <linux/notifier.h>
 | |
| 
 | |
| struct pt_regs;
 | |
| 
 | |
| /* Grossly misnamed. */
 | |
| enum die_val {
 | |
| 	DIE_OOPS = 1,
 | |
| 	DIE_INT3,
 | |
| 	DIE_DEBUG,
 | |
| 	DIE_PANIC,
 | |
| 	DIE_NMI,
 | |
| 	DIE_DIE,
 | |
| 	DIE_KERNELDEBUG,
 | |
| 	DIE_TRAP,
 | |
| 	DIE_GPF,
 | |
| 	DIE_CALL,
 | |
| 	DIE_PAGE_FAULT,
 | |
| 	DIE_NMIUNKNOWN,
 | |
| };
 | |
| 
 | |
| enum show_regs_mode {
 | |
| 	SHOW_REGS_SHORT,
 | |
| 	/*
 | |
| 	 * For when userspace crashed, but we don't think it's our fault, and
 | |
| 	 * therefore don't print kernel registers.
 | |
| 	 */
 | |
| 	SHOW_REGS_USER,
 | |
| 	SHOW_REGS_ALL
 | |
| };
 | |
| 
 | |
| extern void die(const char *, struct pt_regs *,long);
 | |
| extern int __must_check __die(const char *, struct pt_regs *, long);
 | |
| extern void show_stack_regs(struct pt_regs *regs);
 | |
| extern void __show_regs(struct pt_regs *regs, enum show_regs_mode);
 | |
| extern void show_iret_regs(struct pt_regs *regs);
 | |
| extern unsigned long oops_begin(void);
 | |
| extern void oops_end(unsigned long, struct pt_regs *, int signr);
 | |
| 
 | |
| #endif /* _ASM_X86_KDEBUG_H */
 |