mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
powerpc: Check end of stack canary at oops time
Add a check for the stack canary when we oops, similar to x86. This should make it clear that we overran our stack: Unable to handle kernel paging request for data at address 0x24652f63700ac689 Faulting instruction address: 0xc000000000063d24 Thread overran stack, or stack corrupted Signed-off-by: Anton Blanchard <anton@samba.org> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
This commit is contained in:
parent
f89451fbd2
commit
28b549905b
1 changed files with 6 additions and 0 deletions
|
@ -30,6 +30,7 @@
|
||||||
#include <linux/kprobes.h>
|
#include <linux/kprobes.h>
|
||||||
#include <linux/kdebug.h>
|
#include <linux/kdebug.h>
|
||||||
#include <linux/perf_event.h>
|
#include <linux/perf_event.h>
|
||||||
|
#include <linux/magic.h>
|
||||||
|
|
||||||
#include <asm/firmware.h>
|
#include <asm/firmware.h>
|
||||||
#include <asm/page.h>
|
#include <asm/page.h>
|
||||||
|
@ -385,6 +386,7 @@ do_sigbus:
|
||||||
void bad_page_fault(struct pt_regs *regs, unsigned long address, int sig)
|
void bad_page_fault(struct pt_regs *regs, unsigned long address, int sig)
|
||||||
{
|
{
|
||||||
const struct exception_table_entry *entry;
|
const struct exception_table_entry *entry;
|
||||||
|
unsigned long *stackend;
|
||||||
|
|
||||||
/* Are we prepared to handle this fault? */
|
/* Are we prepared to handle this fault? */
|
||||||
if ((entry = search_exception_tables(regs->nip)) != NULL) {
|
if ((entry = search_exception_tables(regs->nip)) != NULL) {
|
||||||
|
@ -413,5 +415,9 @@ void bad_page_fault(struct pt_regs *regs, unsigned long address, int sig)
|
||||||
printk(KERN_ALERT "Faulting instruction address: 0x%08lx\n",
|
printk(KERN_ALERT "Faulting instruction address: 0x%08lx\n",
|
||||||
regs->nip);
|
regs->nip);
|
||||||
|
|
||||||
|
stackend = end_of_stack(current);
|
||||||
|
if (current != &init_task && *stackend != STACK_END_MAGIC)
|
||||||
|
printk(KERN_ALERT "Thread overran stack, or stack corrupted\n");
|
||||||
|
|
||||||
die("Kernel access of bad area", regs, sig);
|
die("Kernel access of bad area", regs, sig);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue