aboutsummaryrefslogtreecommitdiffstats
path: root/arch/powerpc/kernel/exceptions-64e.S
diff options
context:
space:
mode:
authorBenjamin Herrenschmidt <benh@kernel.crashing.org>2010-07-09 01:31:28 -0400
committerBenjamin Herrenschmidt <benh@kernel.crashing.org>2010-07-09 02:11:17 -0400
commit89c81797d4a0779a957f4ea1f0c676cda203615b (patch)
tree1c1e175ea4dd2c8aeb1816a7e6e39062e24ae860 /arch/powerpc/kernel/exceptions-64e.S
parente8775d4aa17d70d123814e68a6a51bbea50e5c16 (diff)
powerpc/book3e: Hookup doorbells exceptions on 64-bit Book3E
Note that critical doorbells are an unimplemented stub just like other critical or machine check handlers, since we haven't done support for "levelled" exceptions yet. Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Diffstat (limited to 'arch/powerpc/kernel/exceptions-64e.S')
-rw-r--r--arch/powerpc/kernel/exceptions-64e.S21
1 files changed, 17 insertions, 4 deletions
diff --git a/arch/powerpc/kernel/exceptions-64e.S b/arch/powerpc/kernel/exceptions-64e.S
index 24dcc0ecf24..a42637c3a72 100644
--- a/arch/powerpc/kernel/exceptions-64e.S
+++ b/arch/powerpc/kernel/exceptions-64e.S
@@ -246,11 +246,9 @@ interrupt_base_book3e: /* fake trap */
246 EXCEPTION_STUB(0x1a0, watchdog) /* 0x09f0 */ 246 EXCEPTION_STUB(0x1a0, watchdog) /* 0x09f0 */
247 EXCEPTION_STUB(0x1c0, data_tlb_miss) 247 EXCEPTION_STUB(0x1c0, data_tlb_miss)
248 EXCEPTION_STUB(0x1e0, instruction_tlb_miss) 248 EXCEPTION_STUB(0x1e0, instruction_tlb_miss)
249 EXCEPTION_STUB(0x280, doorbell)
250 EXCEPTION_STUB(0x2a0, doorbell_crit)
249 251
250#if 0
251 EXCEPTION_STUB(0x280, processor_doorbell)
252 EXCEPTION_STUB(0x220, processor_doorbell_crit)
253#endif
254 .globl interrupt_end_book3e 252 .globl interrupt_end_book3e
255interrupt_end_book3e: 253interrupt_end_book3e:
256 254
@@ -428,6 +426,19 @@ interrupt_end_book3e:
428kernel_dbg_exc: 426kernel_dbg_exc:
429 b . /* NYI */ 427 b . /* NYI */
430 428
429/* Doorbell interrupt */
430 MASKABLE_EXCEPTION(0x2070, doorbell, .doorbell_exception, ACK_NONE)
431
432/* Doorbell critical Interrupt */
433 START_EXCEPTION(doorbell_crit);
434 CRIT_EXCEPTION_PROLOG(0x2080, PROLOG_ADDITION_NONE)
435// EXCEPTION_COMMON(0x2080, PACA_EXCRIT, INTS_DISABLE_ALL)
436// bl special_reg_save_crit
437// addi r3,r1,STACK_FRAME_OVERHEAD
438// bl .doorbell_critical_exception
439// b ret_from_crit_except
440 b .
441
431 442
432/* 443/*
433 * An interrupt came in while soft-disabled; clear EE in SRR1, 444 * An interrupt came in while soft-disabled; clear EE in SRR1,
@@ -563,6 +574,8 @@ BAD_STACK_TRAMPOLINE(0xd00)
563BAD_STACK_TRAMPOLINE(0xe00) 574BAD_STACK_TRAMPOLINE(0xe00)
564BAD_STACK_TRAMPOLINE(0xf00) 575BAD_STACK_TRAMPOLINE(0xf00)
565BAD_STACK_TRAMPOLINE(0xf20) 576BAD_STACK_TRAMPOLINE(0xf20)
577BAD_STACK_TRAMPOLINE(0x2070)
578BAD_STACK_TRAMPOLINE(0x2080)
566 579
567 .globl bad_stack_book3e 580 .globl bad_stack_book3e
568bad_stack_book3e: 581bad_stack_book3e: