|
@@ -735,8 +735,11 @@ _STATIC(do_hash_page)
|
|
|
std r3,_DAR(r1)
|
|
|
std r4,_DSISR(r1)
|
|
|
|
|
|
- andis. r0,r4,0xa450 /* weird error? */
|
|
|
+ andis. r0,r4,0xa410 /* weird error? */
|
|
|
bne- handle_page_fault /* if not, try to insert a HPTE */
|
|
|
+ andis. r0,r4,DSISR_DABRMATCH@h
|
|
|
+ bne- handle_dabr_fault
|
|
|
+
|
|
|
BEGIN_FTR_SECTION
|
|
|
andis. r0,r4,0x0020 /* Is it a segment table fault? */
|
|
|
bne- do_ste_alloc /* If so handle it */
|
|
@@ -823,6 +826,14 @@ END_FW_FTR_SECTION_IFCLR(FW_FEATURE_ISERIES)
|
|
|
bl .raw_local_irq_restore
|
|
|
b 11f
|
|
|
|
|
|
+/* We have a data breakpoint exception - handle it */
|
|
|
+handle_dabr_fault:
|
|
|
+ ld r4,_DAR(r1)
|
|
|
+ ld r5,_DSISR(r1)
|
|
|
+ addi r3,r1,STACK_FRAME_OVERHEAD
|
|
|
+ bl .do_dabr
|
|
|
+ b .ret_from_except_lite
|
|
|
+
|
|
|
/* Here we have a page fault that hash_page can't handle. */
|
|
|
handle_page_fault:
|
|
|
ENABLE_INTS
|