diff options
author | John Williams <john.williams@petalogix.com> | 2009-07-29 14:08:40 +0200 |
---|---|---|
committer | Michal Simek <monstr@monstr.eu> | 2009-08-18 10:33:30 +0200 |
commit | 892ee92b81b6e7fa5f6147c96e11c6c1b9802fc6 (patch) | |
tree | 8ae8086fe126192fb4fd68a37811db24599048a3 /arch/microblaze/kernel/intc.c | |
parent | microblaze: use the generic ack_bad_irq implementation (diff) | |
download | linux-892ee92b81b6e7fa5f6147c96e11c6c1b9802fc6.tar.xz linux-892ee92b81b6e7fa5f6147c96e11c6c1b9802fc6.zip |
microblaze: Sane handling of missing timer/intc in device tree
This code path doesn't test any returned pointers for NULL, leading to a bad
kernel page fault if there's no timer/intc found.
Slightly better is to BUG(), but even better still would be a printk beforehand.
Signed-off-by: John Williams <john.williams@petalogix.com>
Signed-off-by: Michal Simek <monstr@monstr.eu>
Diffstat (limited to 'arch/microblaze/kernel/intc.c')
-rw-r--r-- | arch/microblaze/kernel/intc.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/arch/microblaze/kernel/intc.c b/arch/microblaze/kernel/intc.c index b15605299a57..6eea6f92b84e 100644 --- a/arch/microblaze/kernel/intc.c +++ b/arch/microblaze/kernel/intc.c @@ -12,6 +12,7 @@ #include <linux/irq.h> #include <asm/page.h> #include <linux/io.h> +#include <linux/bug.h> #include <asm/prom.h> #include <asm/irq.h> @@ -130,6 +131,7 @@ void __init init_IRQ(void) if (intc) break; } + BUG_ON(!intc); intc_baseaddr = *(int *) of_get_property(intc, "reg", NULL); intc_baseaddr = (unsigned long) ioremap(intc_baseaddr, PAGE_SIZE); |