aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
authorMichael Ellerman <michael@ellerman.id.au>2009-04-22 11:31:37 -0400
committerBenjamin Herrenschmidt <benh@kernel.crashing.org>2009-05-21 01:43:58 -0400
commitd7cb10d6d23f451eec3d1f0f4e4e8862333fa152 (patch)
tree0deb8c084116fdafabbc35074533c9b2b23071cb /arch
parentf2694ba56808a3a0fa45d9bb45289575f31e48d2 (diff)
powerpc/irq: Move stack overflow check into a separate function
Makes do_IRQ() shorter and clearer. Signed-off-by: Michael Ellerman <michael@ellerman.id.au> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Diffstat (limited to 'arch')
-rw-r--r--arch/powerpc/kernel/irq.c31
1 files changed, 17 insertions, 14 deletions
diff --git a/arch/powerpc/kernel/irq.c b/arch/powerpc/kernel/irq.c
index 3d3658d0b7b9..463b6ab9d6b9 100644
--- a/arch/powerpc/kernel/irq.c
+++ b/arch/powerpc/kernel/irq.c
@@ -301,6 +301,22 @@ static inline void handle_one_irq(unsigned int irq)
301} 301}
302#endif 302#endif
303 303
304static inline void check_stack_overflow(void)
305{
306#ifdef CONFIG_DEBUG_STACKOVERFLOW
307 long sp;
308
309 sp = __get_SP() & (THREAD_SIZE-1);
310
311 /* check for stack overflow: is there less than 2KB free? */
312 if (unlikely(sp < (sizeof(struct thread_info) + 2048))) {
313 printk("do_IRQ: stack overflow: %ld\n",
314 sp - sizeof(struct thread_info));
315 dump_stack();
316 }
317#endif
318}
319
304void do_IRQ(struct pt_regs *regs) 320void do_IRQ(struct pt_regs *regs)
305{ 321{
306 struct pt_regs *old_regs = set_irq_regs(regs); 322 struct pt_regs *old_regs = set_irq_regs(regs);
@@ -308,20 +324,7 @@ void do_IRQ(struct pt_regs *regs)
308 324
309 irq_enter(); 325 irq_enter();
310 326
311#ifdef CONFIG_DEBUG_STACKOVERFLOW 327 check_stack_overflow();
312 /* Debugging check for stack overflow: is there less than 2KB free? */
313 {
314 long sp;
315
316 sp = __get_SP() & (THREAD_SIZE-1);
317
318 if (unlikely(sp < (sizeof(struct thread_info) + 2048))) {
319 printk("do_IRQ: stack overflow: %ld\n",
320 sp - sizeof(struct thread_info));
321 dump_stack();
322 }
323 }
324#endif
325 328
326 /* 329 /*
327 * Every platform is required to implement ppc_md.get_irq. 330 * Every platform is required to implement ppc_md.get_irq.