Commit 19f0dda9 authored by Harvey Harrison's avatar Harvey Harrison Committed by Ingo Molnar

x86: unify page fault oops printing

This changes the oops dumping format for page faults to
be similar between X86_32 and 64.

This is the first user of printk_address on X86_32.
Signed-off-by: default avatarHarvey Harrison <harvey.harrison@gmail.com>
Signed-off-by: default avatarIngo Molnar <mingo@elte.hu>
Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
parent b3279c7f
...@@ -340,15 +340,15 @@ static void show_fault_oops(struct pt_regs *regs, unsigned long error_code, ...@@ -340,15 +340,15 @@ static void show_fault_oops(struct pt_regs *regs, unsigned long error_code,
"(uid: %d)\n", current->uid); "(uid: %d)\n", current->uid);
} }
#endif #endif
printk(KERN_ALERT "BUG: unable to handle kernel ");
if (address < PAGE_SIZE) if (address < PAGE_SIZE)
printk(KERN_ALERT "BUG: unable to handle kernel NULL " printk(KERN_CONT "NULL pointer dereference");
"pointer dereference");
else else
printk(KERN_ALERT "BUG: unable to handle kernel paging" printk(KERN_CONT "paging request");
" request"); printk(KERN_CONT " at %08lx\n", address);
printk(" at virtual address %08lx\n", address);
printk(KERN_ALERT "printing ip: %08lx ", regs->ip);
printk(KERN_ALERT "IP:");
printk_address(regs->ip, 1);
dump_pagetable(address); dump_pagetable(address);
} }
......
...@@ -296,11 +296,14 @@ static int is_f00f_bug(struct pt_regs *regs, unsigned long address) ...@@ -296,11 +296,14 @@ static int is_f00f_bug(struct pt_regs *regs, unsigned long address)
static void show_fault_oops(struct pt_regs *regs, unsigned long error_code, static void show_fault_oops(struct pt_regs *regs, unsigned long error_code,
unsigned long address) unsigned long address)
{ {
printk(KERN_ALERT "BUG: unable to handle kernel ");
if (address < PAGE_SIZE) if (address < PAGE_SIZE)
printk(KERN_ALERT "Unable to handle kernel NULL pointer dereference"); printk(KERN_CONT "NULL pointer dereference");
else else
printk(KERN_ALERT "Unable to handle kernel paging request"); printk(KERN_CONT "paging request");
printk(" at %016lx RIP: \n" KERN_ALERT, address); printk(KERN_CONT " at %016lx\n", address);
printk(KERN_ALERT "IP:");
printk_address(regs->ip, 1); printk_address(regs->ip, 1);
dump_pagetable(address); dump_pagetable(address);
} }
......
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