mirror of
https://github.com/adulau/aha.git
synced 2025-01-01 05:36:24 +00:00
sh: Fixup sh_bios() trap handling.
This was inadvertently broken when the entry.S code split up, restore the missing branch and get subsequent traps working under debug again. This manifested itself as a lockup when attempting to reload the VBR base. Signed-off-by: Paul Mundt <lethal@linux-sh.org>
This commit is contained in:
parent
41504c3972
commit
1dc417d039
1 changed files with 13 additions and 2 deletions
|
@ -79,18 +79,29 @@ debug_kernel_sw:
|
|||
.align 2
|
||||
3: .long kgdb_handle_exception
|
||||
#endif /* CONFIG_SH_KGDB */
|
||||
|
||||
#ifdef CONFIG_SH_STANDARD_BIOS
|
||||
bra debug_kernel_fw
|
||||
nop
|
||||
#endif
|
||||
#endif /* CONFIG_SH_STANDARD_BIOS || CONFIG_SH_KGDB */
|
||||
|
||||
|
||||
.align 2
|
||||
debug_trap:
|
||||
#if defined(CONFIG_SH_STANDARD_BIOS) || defined(CONFIG_SH_KGDB)
|
||||
mov r8, r0
|
||||
shlr2 r0
|
||||
cmp/eq #0x3f, r0 ! sh_bios() trap
|
||||
bf 1f
|
||||
#ifdef CONFIG_SH_KGDB
|
||||
cmp/eq #0xff, r0 ! XXX: KGDB trap, fix for SH-2.
|
||||
bf 1f
|
||||
#endif
|
||||
mov #OFF_SR, r0
|
||||
mov.l @(r0,r15), r0 ! get status register
|
||||
shll r0
|
||||
shll r0 ! kernel space?
|
||||
bt/s debug_kernel
|
||||
1:
|
||||
#endif
|
||||
mov.l @r15, r0 ! Restore R0 value
|
||||
mov.l 1f, r8
|
||||
|
|
Loading…
Reference in a new issue