Commit ba54d856 authored by Borislav Petkov's avatar Borislav Petkov Committed by Thomas Gleixner

x86/fault: Dump user opcode bytes on fatal faults

Sometimes it is useful to see which user opcode bytes RIP points to
when a fault happens: be it to rule out RIP corruption, to dump info
early during boot, when doing core dumps is impossible due to not having
a writable filesystem yet.

Sometimes it is useful if debugging an issue and one doesn't have access
to the executable which caused the fault in order to disassemble it.

That last aspect might have some security implications so
show_unhandled_signals could be revisited for that or a new config option
added.
Signed-off-by: default avatarBorislav Petkov <bp@suse.de>
Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Josh Poimboeuf <jpoimboe@redhat.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Andy Lutomirski <luto@amacapital.net>
Link: https://lkml.kernel.org/r/20180417161124.5294-7-bp@alien8.de
parent e8b6f984
...@@ -828,6 +828,8 @@ static inline void ...@@ -828,6 +828,8 @@ static inline void
show_signal_msg(struct pt_regs *regs, unsigned long error_code, show_signal_msg(struct pt_regs *regs, unsigned long error_code,
unsigned long address, struct task_struct *tsk) unsigned long address, struct task_struct *tsk)
{ {
const char *loglvl = task_pid_nr(tsk) > 1 ? KERN_INFO : KERN_EMERG;
if (!unhandled_signal(tsk, SIGSEGV)) if (!unhandled_signal(tsk, SIGSEGV))
return; return;
...@@ -835,13 +837,14 @@ show_signal_msg(struct pt_regs *regs, unsigned long error_code, ...@@ -835,13 +837,14 @@ show_signal_msg(struct pt_regs *regs, unsigned long error_code,
return; return;
printk("%s%s[%d]: segfault at %lx ip %px sp %px error %lx", printk("%s%s[%d]: segfault at %lx ip %px sp %px error %lx",
task_pid_nr(tsk) > 1 ? KERN_INFO : KERN_EMERG, loglvl, tsk->comm, task_pid_nr(tsk), address,
tsk->comm, task_pid_nr(tsk), address,
(void *)regs->ip, (void *)regs->sp, error_code); (void *)regs->ip, (void *)regs->sp, error_code);
print_vma_addr(KERN_CONT " in ", regs->ip); print_vma_addr(KERN_CONT " in ", regs->ip);
printk(KERN_CONT "\n"); printk(KERN_CONT "\n");
show_opcodes((u8 *)regs->ip, loglvl);
} }
static void static void
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment