summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/arch/mvme88k/mvme88k/eh.S330
1 files changed, 162 insertions, 168 deletions
diff --git a/sys/arch/mvme88k/mvme88k/eh.S b/sys/arch/mvme88k/mvme88k/eh.S
index 0784e15f34b..e8178194dba 100644
--- a/sys/arch/mvme88k/mvme88k/eh.S
+++ b/sys/arch/mvme88k/mvme88k/eh.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: eh.S,v 1.52 2004/06/22 05:02:35 miod Exp $ */
+/* $OpenBSD: eh.S,v 1.53 2004/06/22 18:27:08 miod Exp $ */
/*
* Mach Operating System
* Copyright (c) 1993-1991 Carnegie Mellon University
@@ -301,18 +301,18 @@ ASLOCAL(Lbadcpupanic)
/*
*
- * #define PREP(NAME, NUM, BIT, SSBR_STUFF, FLAG_CHECK)
+ * #define PREP881x0(NAME, NUM, BIT, SSBR_STUFF, FLAG_CHECK)
*
- * This is the "exception processing preparaton" common to all exception
+ * This is the "exception processing preparation" common to all exception
* processing. It is used in the following manner:
*
* ASGLOBAL(foo_handler)
- * PREP("foo", 11, DEBUG_FOO_BIT, SSBR_Stuff, Precheck_Stuff)
+ * PREP88100("foo", 11, DEBUG_FOO_BIT, SSBR_Stuff, Precheck_Stuff)
* CALL(_C_LABEL(trapXXX), T_FOO_FAULT, r31)
- * DONE(DEBUG_FOO_BIT)
+ * DONE88100(DEBUG_FOO_BIT)
*
* This defines the exception handler for the "foo" exception.
- * The arguments ro PREP():
+ * The arguments are:
* NAME
* String for debugging (more info later)
* NUM
@@ -326,14 +326,14 @@ ASLOCAL(Lbadcpupanic)
* This is for the data access exception only. See it for
* more info.
*
- * What's in between PREP() and DONE() (usually a CALL) is the actual
- * servicing of the interrupt. During this time, any register may
- * be used freely as they've all been saved in the exception frame
- * (which is pointed-to by r31).
+ * What's in between PREP881x0() and DONE881x0() (usually a CALL)
+ * is the actual servicing of the interrupt. During this time, any
+ * register may be used freely as they've all been saved in the
+ * exception frame (which is pointed to by r31).
*/
#ifdef M88100
-#define PREP(NAME, NUM, BIT, SSBR_STUFF, FLAG_PRECHECK) \
+#define PREP88100(NAME, NUM, BIT, SSBR_STUFF, FLAG_PRECHECK) \
xcr FLAGS, FLAGS, SR1 ; \
FLAG_PRECHECK ; \
/* the bsr later clobbers r1, so save now */ \
@@ -344,7 +344,7 @@ ASLOCAL(Lbadcpupanic)
clr FLAGS, FLAGS, 1<FLAG_FROM_KERNEL> ; \
set FLAGS, FLAGS, 1<FLAG_FROM_KERNEL> ; \
/* get a stack (exception frame) */ \
-1: bsr _ASM_LABEL(setup_phase_one) ; \
+1: bsr _ASM_LABEL(m88100_setup_phase_one) ; \
/* TMP2 now free -- use to set EF_VECTOR */ \
or TMP2, r0, NUM ; \
st TMP2, r31, REG_OFF(EF_VECTOR) ; \
@@ -353,13 +353,13 @@ ASLOCAL(Lbadcpupanic)
SSBR_STUFF ; \
/* call setup_phase_two to restart the FPU */ \
/* and to save all general registers. */ \
- bsr _ASM_LABEL(setup_phase_two) ; \
+ bsr _ASM_LABEL(m88100_setup_phase_two) ; \
/* All general regs free -- do any debugging */ \
PREP_DEBUG(BIT, NAME)
#endif
#ifdef M88110
-#define PREP2(NAME, NUM, BIT, FLAG_PRECHECK) \
+#define PREP88110(NAME, NUM, BIT, FLAG_PRECHECK) \
SAVE_CTX ; \
xcr FLAGS, FLAGS, SR1 ; \
FLAG_PRECHECK ; \
@@ -382,15 +382,15 @@ ASLOCAL(Lbadcpupanic)
PREP_DEBUG(BIT, NAME)
#endif
-/* Some defines for use with PREP() */
+/* Some defines for use with PREP88100() */
#define Clear_SSBR_Dest \
bsr _ASM_LABEL(clear_dest_ssbr_bit)
-#define Data_Precheck \
+#define M88100_Data_Precheck \
bb1.n FLAG_IGNORE_DATA_EXCEPTION, FLAGS, \
- _ASM_LABEL(ignore_data_exception)
+ _ASM_LABEL(m88100_ignore_data_exception)
#define M88110_Data_Precheck \
bb1.n FLAG_IGNORE_DATA_EXCEPTION, FLAGS, \
- _ASM_LABEL(m88110_ignore_data_exception)
+ _ASM_LABEL(m88110_ignore_data_exception)
#ifdef EH_DEBUG
/*
@@ -439,14 +439,14 @@ ASGLOBAL(eh_debug)
*
* Then, return from the interrupt handler.
*/
-#define DONE(DebugNumber) \
+#define DONE88100(DebugNumber) \
or.u r2, r0, hi16(_ASM_LABEL(eh_debug)) ; \
ld r3, r2, lo16(_ASM_LABEL(eh_debug)) ; \
bb0 DebugNumber, r3, 2f ; \
ldcr r4, SR1 ; \
CALL(_C_LABEL(MY_info_done), r31, r4) ; \
-2: br _ASM_LABEL(return_from_exception_handler)
-#define DONE2(DebugNumber) \
+2: br _ASM_LABEL(m88100_return_code)
+#define DONE88110(DebugNumber) \
or.u r2, r0, hi16(_ASM_LABEL(eh_debug)) ; \
ld r3, r2, lo16(_ASM_LABEL(eh_debug)) ; \
bb0 DebugNumber, r3, 2f ; \
@@ -459,9 +459,9 @@ ASGLOBAL(eh_debug)
* Also, when you're done, you're done! (no debug check).
*/
#define PREP_DEBUG(bit, name)
-#define DONE(num) \
- br _ASM_LABEL(return_from_exception_handler)
-#define DONE2(num) \
+#define DONE88100(num) \
+ br _ASM_LABEL(m88100_return_code)
+#define DONE88110(num) \
br _ASM_LABEL(m88110_return_code)
#endif /* EH_DEBUG */
@@ -472,42 +472,42 @@ ASGLOBAL(eh_debug)
/* unknown exception handler */
GLOBAL(unknown_handler)
- PREP("unknown", 0, DEBUG_UNKNOWN_BIT,,)
+ PREP88100("unknown", 0, DEBUG_UNKNOWN_BIT,,)
CALL(_C_LABEL(m88100_trap), T_UNKNOWNFLT, r30)
- DONE(DEBUG_UNKNOWN_BIT)
+ DONE88100(DEBUG_UNKNOWN_BIT)
/* interrupt exception handler */
GLOBAL(interrupt_handler)
- PREP("interrupt", 1, DEBUG_INTERRUPT_BIT,,)
+ PREP88100("interrupt", 1, DEBUG_INTERRUPT_BIT,,)
CALL(_C_LABEL(m88100_trap), T_INT, r30)
- DONE(DEBUG_INTERRUPT_BIT)
+ DONE88100(DEBUG_INTERRUPT_BIT)
/* instruction access exception handler */
GLOBAL(instruction_access_handler)
- PREP("inst", 2, DEBUG_INSTRUCTION_BIT,,)
+ PREP88100("inst", 2, DEBUG_INSTRUCTION_BIT,,)
CALL(_C_LABEL(m88100_trap), T_INSTFLT, r30)
- DONE(DEBUG_INSTRUCTION_BIT)
+ DONE88100(DEBUG_INSTRUCTION_BIT)
/*
* data access exception handler --
* See badaddr() below for info about Data_Precheck.
*/
GLOBAL(data_exception_handler)
- PREP("data", 3, DEBUG_DATA_BIT,, Data_Precheck)
+ PREP88100("data", 3, DEBUG_DATA_BIT,, M88100_Data_Precheck)
/* No need to call m88100_trap(T_DATAFLT) as PREP will do this for us */
- DONE(DEBUG_DATA_BIT)
+ DONE88100(DEBUG_DATA_BIT)
/* misaligned access exception handler */
GLOBAL(misaligned_handler)
- PREP("misalign", 4, DEBUG_MISALIGN_BIT, Clear_SSBR_Dest,)
+ PREP88100("misalign", 4, DEBUG_MISALIGN_BIT, Clear_SSBR_Dest,)
CALL(_C_LABEL(m88100_trap), T_MISALGNFLT, r30)
- DONE(DEBUG_MISALIGN_BIT)
+ DONE88100(DEBUG_MISALIGN_BIT)
/* unimplemented opcode exception handler */
GLOBAL(unimplemented_handler)
- PREP("unimp", 5, DEBUG_UNIMPLEMENTED_BIT,,)
+ PREP88100("unimp", 5, DEBUG_UNIMPLEMENTED_BIT,,)
CALL(_C_LABEL(m88100_trap), T_ILLFLT, r30)
- DONE(DEBUG_UNIMPLEMENTED_BIT)
+ DONE88100(DEBUG_UNIMPLEMENTED_BIT)
/*
* Some versions of the chip have a bug whereby false privilege
@@ -520,108 +520,108 @@ GLOBAL(privilege_handler)
bb1.n RTE_VALID_BIT, r1, 1f /* skip over if a valid exception */
ldcr r1, SR2 /* restore r1 */
RTE
-1: PREP("privilege", 6, DEBUG_PRIVILEGE_BIT, Clear_SSBR_Dest,)
+1: PREP88100("privilege", 6, DEBUG_PRIVILEGE_BIT, Clear_SSBR_Dest,)
CALL(_C_LABEL(m88100_trap), T_PRIVINFLT, r30)
- DONE(DEBUG_PRIVILEGE_BIT)
+ DONE88100(DEBUG_PRIVILEGE_BIT)
/* bounds checking exception handler */
GLOBAL(bounds_handler)
- PREP("bounds", 7, DEBUG_BOUNDS_BIT, Clear_SSBR_Dest,)
+ PREP88100("bounds", 7, DEBUG_BOUNDS_BIT, Clear_SSBR_Dest,)
CALL(_C_LABEL(m88100_trap), T_BNDFLT, r30)
- DONE(DEBUG_BOUNDS_BIT)
+ DONE88100(DEBUG_BOUNDS_BIT)
/* integer divide-by-zero exception handler */
GLOBAL(divide_handler)
- PREP("divide", 8, DEBUG_DIVIDE_BIT, Clear_SSBR_Dest,)
+ PREP88100("divide", 8, DEBUG_DIVIDE_BIT, Clear_SSBR_Dest,)
CALL(_C_LABEL(m88100_trap), T_ZERODIV, r30)
- DONE(DEBUG_DIVIDE_BIT)
+ DONE88100(DEBUG_DIVIDE_BIT)
/* integer overflow exception handler */
GLOBAL(overflow_handler)
- PREP("overflow", 9, DEBUG_OVERFLOW_BIT,,)
+ PREP88100("overflow", 9, DEBUG_OVERFLOW_BIT,,)
CALL(_C_LABEL(m88100_trap), T_OVFFLT, r30)
- DONE(DEBUG_OVERFLOW_BIT)
+ DONE88100(DEBUG_OVERFLOW_BIT)
/* Floating-point precise handler */
#define FPp_SSBR_STUFF \
bsr _ASM_LABEL(clear_FPp_ssbr_bit)
GLOBAL(fp_precise_handler)
- PREP("FPU precise", 114, DEBUG_FPp_BIT, FPp_SSBR_STUFF,)
+ PREP88100("FPU precise", 114, DEBUG_FPp_BIT, FPp_SSBR_STUFF,)
CALL(_ASM_LABEL(m88100_Xfp_precise), r0, r30)
- DONE(DEBUG_FPp_BIT)
+ DONE88100(DEBUG_FPp_BIT)
/* Floating-point imprecise handler */
#define FPi_SSBR_STUFF \
bsr _ASM_LABEL(clear_FPi_ssbr_bit)
GLOBAL(fp_imprecise_handler)
- PREP("FPU imprecise", 115, DEBUG_FPi_BIT, FPi_SSBR_STUFF,)
+ PREP88100("FPU imprecise", 115, DEBUG_FPi_BIT, FPi_SSBR_STUFF,)
CALL(_ASM_LABEL(Xfp_imprecise), r0, r30)
- DONE(DEBUG_FPi_BIT)
+ DONE88100(DEBUG_FPi_BIT)
/* All standard system calls. */
GLOBAL(syscall_handler)
- PREP("syscall", 128, DEBUG_SYSCALL_BIT,,)
+ PREP88100("syscall", 128, DEBUG_SYSCALL_BIT,,)
ld r13, r30, GENREG_OFF(13)
CALL(_C_LABEL(m88100_syscall), r13, r30)
- DONE(DEBUG_SYSCALL_BIT)
+ DONE88100(DEBUG_SYSCALL_BIT)
/* trap 496 comes here */
GLOBAL(bugtrap)
- PREP("bugsyscall", 496, DEBUG_BUGCALL_BIT,,)
+ PREP88100("bugsyscall", 496, DEBUG_BUGCALL_BIT,,)
ld r9, r30, GENREG_OFF(9)
CALL(_C_LABEL(bugsyscall), r9, r30)
- DONE(DEBUG_BUGCALL_BIT)
+ DONE88100(DEBUG_BUGCALL_BIT)
GLOBAL(sigsys)
- PREP("sigsys", 501, DEBUG_SIGSYS_BIT,,)
+ PREP88100("sigsys", 501, DEBUG_SIGSYS_BIT,,)
CALL(_C_LABEL(m88100_trap), T_SIGSYS, r30)
- DONE(DEBUG_SIGSYS_BIT)
+ DONE88100(DEBUG_SIGSYS_BIT)
GLOBAL(sigtrap)
- PREP("sigtrap", 510, DEBUG_SIGTRAP_BIT,,)
+ PREP88100("sigtrap", 510, DEBUG_SIGTRAP_BIT,,)
CALL(_C_LABEL(m88100_trap), T_SIGTRAP, r30)
- DONE(DEBUG_SIGTRAP_BIT)
+ DONE88100(DEBUG_SIGTRAP_BIT)
GLOBAL(stepbpt)
- PREP("stepbpt", 504, DEBUG_SIGTRAP_BIT,,)
+ PREP88100("stepbpt", 504, DEBUG_SIGTRAP_BIT,,)
CALL(_C_LABEL(m88100_trap), T_STEPBPT, r30)
- DONE(DEBUG_SIGTRAP_BIT)
+ DONE88100(DEBUG_SIGTRAP_BIT)
GLOBAL(userbpt)
- PREP("userbpt", 511, DEBUG_SIGTRAP_BIT,,)
+ PREP88100("userbpt", 511, DEBUG_SIGTRAP_BIT,,)
CALL(_C_LABEL(m88100_trap), T_USERBPT, r30)
- DONE(DEBUG_SIGTRAP_BIT)
+ DONE88100(DEBUG_SIGTRAP_BIT)
#ifdef DDB
GLOBAL(break)
- PREP("break", 130, DEBUG_BREAK_BIT,,)
+ PREP88100("break", 130, DEBUG_BREAK_BIT,,)
CALL(_C_LABEL(m88100_trap), T_KDB_BREAK, r30)
- DONE(DEBUG_BREAK_BIT)
+ DONE88100(DEBUG_BREAK_BIT)
GLOBAL(trace)
- PREP("trace", 131, DEBUG_TRACE_BIT,,)
+ PREP88100("trace", 131, DEBUG_TRACE_BIT,,)
CALL(_C_LABEL(m88100_trap), T_KDB_TRACE, r30)
- DONE(DEBUG_TRACE_BIT)
+ DONE88100(DEBUG_TRACE_BIT)
GLOBAL(entry)
- PREP("kdb", 132, DEBUG_KDB_BIT,,)
+ PREP88100("kdb", 132, DEBUG_KDB_BIT,,)
CALL(_C_LABEL(m88100_trap), T_KDB_ENTRY, r30)
- DONE(DEBUG_KDB_BIT)
+ DONE88100(DEBUG_KDB_BIT)
#else
GLOBAL(break)
- PREP("break", 130, DEBUG_BREAK_BIT,,)
+ PREP88100("break", 130, DEBUG_BREAK_BIT,,)
CALL(_C_LABEL(m88100_trap), T_UNKNOWNFLT, r30)
- DONE(DEBUG_BREAK_BIT)
+ DONE88100(DEBUG_BREAK_BIT)
GLOBAL(trace)
- PREP("trace", 131, DEBUG_TRACE_BIT,,)
+ PREP88100("trace", 131, DEBUG_TRACE_BIT,,)
CALL(_C_LABEL(m88100_trap), T_UNKNOWNFLT, r30)
- DONE(DEBUG_TRACE_BIT)
+ DONE88100(DEBUG_TRACE_BIT)
GLOBAL(entry)
- PREP("unknown", 132, DEBUG_KDB_BIT,,)
+ PREP88100("unknown", 132, DEBUG_KDB_BIT,,)
CALL(_C_LABEL(m88100_trap), T_UNKNOWNFLT, r30)
- DONE(DEBUG_KDB_BIT)
+ DONE88100(DEBUG_KDB_BIT)
#endif
/*
@@ -776,7 +776,7 @@ GLOBAL(reset_handler)
* This is part of baddadr (below).
*/
#ifdef M88100
-ASLOCAL(ignore_data_exception)
+ASLOCAL(m88100_ignore_data_exception)
/*
* SR1: previous FLAGS reg
* SR2: free
@@ -966,7 +966,7 @@ ASLOCAL(badaddr__return)
jmp r1
#ifdef M88100
-ASLOCAL(setup_phase_one)
+ASLOCAL(m88100_setup_phase_one)
/*
* SR1: saved copy of exception-time register now holding FLAGS
* SR2: saved copy of exception-time r1
@@ -976,7 +976,7 @@ ASLOCAL(setup_phase_one)
*
* immediate goal:
* Decide where we're going to put the exception frame.
- * Might be at the end of R31, SR3, or the thread's pcb.
+ * Might be at the end of R31, SR3, or the process pcb.
*/
/* Check if we are coming in from a FPU restart exception.
@@ -987,9 +987,9 @@ ASLOCAL(setup_phase_one)
NOP
NOP
- bb1 FLAG_ENABLING_FPU, FLAGS, _ASM_LABEL(use_SR3_pcb)
- /* are we coming in from user mode? If so, pick up thread pcb */
- bb0 FLAG_FROM_KERNEL, FLAGS, _ASM_LABEL(pickup_stack)
+ bb1 FLAG_ENABLING_FPU, FLAGS, _ASM_LABEL(m88100_use_SR3_pcb)
+ /* are we coming in from user mode? If so, pick up process pcb */
+ bb0 FLAG_FROM_KERNEL, FLAGS, _ASM_LABEL(m88100_pickup_stack)
/* Interrupt in kernel mode, not FPU restart */
/*
@@ -1011,10 +1011,10 @@ ASLOCAL(setup_phase_one)
st r1, r31, REG_OFF(EF_SR3)
addu r1, r31, SIZEOF_EF /* save previous r31 */
- br.n _ASM_LABEL(have_pcb)
+ br.n _ASM_LABEL(m88100_have_pcb)
st r1, r31, GENREG_OFF(31)
-ASLOCAL(use_SR3_pcb)
+ASLOCAL(m88100_use_SR3_pcb)
/*
* SR1: saved copy of exception-time register now holding FLAGS
* SR2: return address to the calling exception handler
@@ -1050,7 +1050,7 @@ ASLOCAL(use_SR3_pcb)
or r31, r0, r30 /* make r31 our pointer. */
addu r30, r30, SIZEOF_EF /* r30 now has previous SR3 */
st r30, r31, REG_OFF(EF_SR3) /* save previous SR3 */
- br.n _ASM_LABEL(have_pcb)
+ br.n _ASM_LABEL(m88100_have_pcb)
xcr r30, r30, SR3 /* restore r30 */
1:
/* we took an exception while restarting the FPU from user space.
@@ -1067,10 +1067,10 @@ ASLOCAL(use_SR3_pcb)
ld r1, r30, GENREG_OFF(0) /* restore old r1 */
st r0, r30, GENREG_OFF(0) /* repair that frame */
st r1, r31, GENREG_OFF(1) /* store r1 */
- br.n _ASM_LABEL(have_pcb)
+ br.n _ASM_LABEL(m88100_have_pcb)
xcr r30, r30, SR3 /* restore r30 */
-ASLOCAL(pickup_stack)
+ASLOCAL(m88100_pickup_stack)
/*
* SR1: saved copy of exception-time register now holding FLAGS
* SR2: return address to the calling exception handler
@@ -1080,11 +1080,11 @@ ASLOCAL(pickup_stack)
* immediate goal:
* Since we're servicing an exception from user mode, we
* know that SR3 is free. We use it to free up a temp.
- * register to be used in getting the thread's pcb
+ * register to be used in getting the process pcb
*/
stcr r31, SR3 /* save previous r31 */
- /* switch to the thread's kernel stack. */
+ /* switch to the process kernel stack. */
or.u r31, r0, hi16(_C_LABEL(curpcb))
ld r31, r31, lo16(_C_LABEL(curpcb))
addu r31, r31, PCB_USER_STATE /* point to user save area */
@@ -1094,7 +1094,7 @@ ASLOCAL(pickup_stack)
st r1, r31, GENREG_OFF(31)
/* FALLTHROUGH */
-ASLOCAL(have_pcb)
+ASLOCAL(m88100_have_pcb)
/*
* SR1: saved copy of exception-time register now holding FLAGS
* SR2: return address to the calling exception handler
@@ -1295,8 +1295,6 @@ ASLOCAL(pfsr_done)
ldcr r1, SR2
jmp r1 /* allow the handler to clear more SSBR bits */
-#endif /* M88100 */
-
ASLOCAL(clear_FPi_ssbr_bit)
/*
* Clear floatingpoint-imprecise ssbr bits.
@@ -1476,9 +1474,7 @@ ASLOCAL(clear_dest_ssbr_bit)
jmp.n r1
clr TMP, TMP, TMP2 /* clear bit(s) in ssbr. */
-#ifdef M88100
-
-ASLOCAL(setup_phase_two)
+ASLOCAL(m88100_setup_phase_two)
/*
* SR1: saved copy of exception-time register now holding FLAGS
* SR2: free
@@ -1515,11 +1511,11 @@ ASLOCAL(setup_phase_two)
stcr TMP, EPSR
/* the "+2" below is to set the VALID_BIT */
- or.u TMP, r0, hi16(_ASM_LABEL(fpu_enable) + 2)
- or TMP, TMP, lo16(_ASM_LABEL(fpu_enable) + 2)
- stcr TMP, SNIP /* jump to here fpu_enable */
+ or.u TMP, r0, hi16(_ASM_LABEL(m88100_fpu_enable) + 2)
+ or TMP, TMP, lo16(_ASM_LABEL(m88100_fpu_enable) + 2)
+ stcr TMP, SNIP
addu TMP, TMP, 4
- stcr TMP, SFIP /* and then continue after that */
+ stcr TMP, SFIP
set FLAGS, FLAGS, 1<FLAG_ENABLING_FPU>
xcr FLAGS, FLAGS, SR1
@@ -1552,9 +1548,9 @@ ASLOCAL(setup_phase_two)
* this, which is why FLAG_ENABLING_FPU is set in SR1.
*/
- RTE /* jumps to "fpu_enable" on the next line to enable the FPU. */
+ RTE /* jumps to "m88100_fpu_enable" to enable the FPU. */
-ASLOCAL(fpu_enable)
+ASLOCAL(m88100_fpu_enable)
FLUSH_PIPELINE
xcr TMP, TMP, SR3 /* get E.F. pointer */
st r30, TMP, GENREG_OFF(30) /* save previous r30, r31 */
@@ -1721,8 +1717,7 @@ ENTRY(proc_trampoline)
* proc_do_uret
* this is called as proc_do_uret(proc) from proc_trampoline(). This function
* loads r31 with a pointer to the trap frame for the given proc and calls
- * return_from_exception_handler which loads all the registers and does an
- * rte.
+ * return_code which loads all the registers and does an RTE.
*/
ENTRY(proc_do_uret)
@@ -1735,7 +1730,7 @@ ENTRY(proc_do_uret)
ld r3, r2, lo16(_C_LABEL(cputyp))
cmp r2, r3, CPU_88110
bb1 eq, r2, _ASM_LABEL(m88110_return_code)
- /* br _ASM_LABEL(return_from_exception_handler) */
+ /* br _ASM_LABEL(m88100_return_code) */
#endif
#endif
@@ -1755,7 +1750,7 @@ ENTRY(proc_do_uret)
*/
#ifdef M88100
-ASLOCAL(return_from_exception_handler)
+ASLOCAL(m88100_return_code)
/*
* if there happens to be a data fault that hasn't been serviced yet,
* go off and service that...
@@ -1982,163 +1977,163 @@ ASLOCAL(no_ast)
/* unknown exception handler */
GLOBAL(m88110_unknown_handler)
- PREP2("unknown", 0, DEBUG_UNKNOWN_BIT,)
+ PREP88110("unknown", 0, DEBUG_UNKNOWN_BIT,)
CALL(_C_LABEL(m88110_trap), T_UNKNOWNFLT, r30)
- DONE2(DEBUG_UNKNOWN_BIT)
+ DONE88110(DEBUG_UNKNOWN_BIT)
/* interrupt exception handler */
GLOBAL(m88110_interrupt_handler)
- PREP2("interrupt", 1, DEBUG_INTERRUPT_BIT,)
+ PREP88110("interrupt", 1, DEBUG_INTERRUPT_BIT,)
CALL(_C_LABEL(m88110_trap), T_INT, r30)
- DONE2(DEBUG_INTERRUPT_BIT)
+ DONE88110(DEBUG_INTERRUPT_BIT)
/* instruction access exception handler */
GLOBAL(m88110_instruction_access_handler)
- PREP2("inst", 2, DEBUG_INSTRUCTION_BIT,)
+ PREP88110("inst", 2, DEBUG_INSTRUCTION_BIT,)
CALL(_C_LABEL(m88110_trap), T_INSTFLT, r30)
- DONE2(DEBUG_INSTRUCTION_BIT)
+ DONE88110(DEBUG_INSTRUCTION_BIT)
/*
* data access exception handler --
* See badaddr() below for info about Data_Precheck.
*/
GLOBAL(m88110_data_exception_handler)
- PREP2("data", 3, DEBUG_DATA_BIT, M88110_Data_Precheck)
+ PREP88110("data", 3, DEBUG_DATA_BIT, M88110_Data_Precheck)
CALL(_C_LABEL(m88110_trap), T_DATAFLT, r30)
- DONE2(DEBUG_DATA_BIT)
+ DONE88110(DEBUG_DATA_BIT)
/* misaligned access exception handler */
GLOBAL(m88110_misaligned_handler)
- PREP2("misalign", 4, DEBUG_MISALIGN_BIT,)
+ PREP88110("misalign", 4, DEBUG_MISALIGN_BIT,)
CALL(_C_LABEL(m88110_trap), T_MISALGNFLT, r30)
- DONE2(DEBUG_MISALIGN_BIT)
+ DONE88110(DEBUG_MISALIGN_BIT)
/* unimplemented opcode exception handler */
GLOBAL(m88110_unimplemented_handler)
- PREP2("unimp", 5, DEBUG_UNIMPLEMENTED_BIT,)
+ PREP88110("unimp", 5, DEBUG_UNIMPLEMENTED_BIT,)
CALL(_C_LABEL(m88110_trap), T_ILLFLT, r30)
- DONE2(DEBUG_UNIMPLEMENTED_BIT)
+ DONE88110(DEBUG_UNIMPLEMENTED_BIT)
/* privilege exception handler */
GLOBAL(m88110_privilege_handler)
- PREP2("privilege", 6, DEBUG_PRIVILEGE_BIT,)
+ PREP88110("privilege", 6, DEBUG_PRIVILEGE_BIT,)
CALL(_C_LABEL(m88110_trap), T_PRIVINFLT, r30)
- DONE2(DEBUG_PRIVILEGE_BIT)
+ DONE88110(DEBUG_PRIVILEGE_BIT)
/*
* I'm not sure what the trap(T_BNDFLT,...) does, but it doesn't send
* a signal to the process...
*/
GLOBAL(m88110_bounds_handler)
- PREP2("bounds", 7, DEBUG_BOUNDS_BIT,)
+ PREP88110("bounds", 7, DEBUG_BOUNDS_BIT,)
CALL(_C_LABEL(m88110_trap), T_BNDFLT, r30)
- DONE2(DEBUG_BOUNDS_BIT)
+ DONE88110(DEBUG_BOUNDS_BIT)
/* integer divide-by-zero exception handler */
GLOBAL(m88110_divide_handler)
- PREP2("divide", 8, DEBUG_DIVIDE_BIT,)
+ PREP88110("divide", 8, DEBUG_DIVIDE_BIT,)
CALL(_C_LABEL(m88110_trap), T_ZERODIV, r30)
- DONE2(DEBUG_DIVIDE_BIT)
+ DONE88110(DEBUG_DIVIDE_BIT)
/* integer overflow exception handler */
GLOBAL(m88110_overflow_handler)
- PREP2("overflow", 9, DEBUG_OVERFLOW_BIT,)
+ PREP88110("overflow", 9, DEBUG_OVERFLOW_BIT,)
CALL(_C_LABEL(m88110_trap), T_OVFFLT, r30)
- DONE2(DEBUG_OVERFLOW_BIT)
+ DONE88110(DEBUG_OVERFLOW_BIT)
/* Floating-point precise handler */
GLOBAL(m88110_fp_precise_handler)
- PREP2("FPU precise", 114, DEBUG_FPp_BIT,)
+ PREP88110("FPU precise", 114, DEBUG_FPp_BIT,)
CALL(_ASM_LABEL(m88110_Xfp_precise), r0, r30)
- DONE2(DEBUG_FPp_BIT)
+ DONE88110(DEBUG_FPp_BIT)
/* MVME197 non-maskable interrupt handler (ABORT button) */
GLOBAL(m88110_nonmaskable)
- PREP2("MVME197 non-mask", 11, DEBUG_NON_MASK_BIT,)
+ PREP88110("MVME197 non-mask", 11, DEBUG_NON_MASK_BIT,)
CALL(_C_LABEL(m88110_trap), T_NON_MASK, r30)
- DONE2(DEBUG_NON_MASK_BIT)
+ DONE88110(DEBUG_NON_MASK_BIT)
/* MVME197 data MMU read miss handler */
GLOBAL(m88110_data_read_miss)
- PREP2("MVME197 read miss", 12, DEBUG_197_READ_BIT,)
+ PREP88110("MVME197 read miss", 12, DEBUG_197_READ_BIT,)
CALL(_C_LABEL(m88110_trap), T_197_READ, r30)
- DONE2(DEBUG_197_READ_BIT)
+ DONE88110(DEBUG_197_READ_BIT)
/* MVME197 data MMU write miss handler */
GLOBAL(m88110_data_write_miss)
- PREP2("MVME197 write miss", 13, DEBUG_197_WRITE_BIT,)
+ PREP88110("MVME197 write miss", 13, DEBUG_197_WRITE_BIT,)
CALL(_C_LABEL(m88110_trap), T_197_WRITE, r30)
- DONE2(DEBUG_197_WRITE_BIT)
+ DONE88110(DEBUG_197_WRITE_BIT)
/* MVME197 inst MMU ATC miss handler */
GLOBAL(m88110_inst_atc_miss)
- PREP2("MVME197 inst miss", 14, DEBUG_197_INST_BIT,)
+ PREP88110("MVME197 inst miss", 14, DEBUG_197_INST_BIT,)
CALL(_C_LABEL(m88110_trap), T_197_INST, r30)
- DONE2(DEBUG_197_INST_BIT)
+ DONE88110(DEBUG_197_INST_BIT)
/* All standard system calls. */
GLOBAL(m88110_syscall_handler)
- PREP2("syscall", 128, DEBUG_SYSCALL_BIT,)
+ PREP88110("syscall", 128, DEBUG_SYSCALL_BIT,)
ld r13, r30, GENREG_OFF(13)
CALL(_C_LABEL(m88110_syscall), r13, r30)
- DONE2(DEBUG_SYSCALL_BIT)
+ DONE88110(DEBUG_SYSCALL_BIT)
/* trap 496 comes here */
GLOBAL(m88110_bugtrap)
- PREP2("bugsyscall", 496, DEBUG_BUGCALL_BIT,)
+ PREP88110("bugsyscall", 496, DEBUG_BUGCALL_BIT,)
ld r9, r30, GENREG_OFF(9)
CALL(_C_LABEL(bugsyscall), r9, r30)
- DONE2(DEBUG_BUGCALL_BIT)
+ DONE88110(DEBUG_BUGCALL_BIT)
GLOBAL(m88110_sigsys)
- PREP2("sigsys", 501, DEBUG_SIGSYS_BIT,)
+ PREP88110("sigsys", 501, DEBUG_SIGSYS_BIT,)
CALL(_C_LABEL(m88110_trap), T_SIGSYS, r30)
- DONE2(DEBUG_SIGSYS_BIT)
+ DONE88110(DEBUG_SIGSYS_BIT)
GLOBAL(m88110_sigtrap)
- PREP2("sigtrap", 510, DEBUG_SIGTRAP_BIT,)
+ PREP88110("sigtrap", 510, DEBUG_SIGTRAP_BIT,)
CALL(_C_LABEL(m88110_trap), T_SIGTRAP, r30)
- DONE2(DEBUG_SIGTRAP_BIT)
+ DONE88110(DEBUG_SIGTRAP_BIT)
GLOBAL(m88110_stepbpt)
- PREP2("stepbpt", 504, DEBUG_SIGTRAP_BIT,)
+ PREP88110("stepbpt", 504, DEBUG_SIGTRAP_BIT,)
CALL(_C_LABEL(m88110_trap), T_STEPBPT, r30)
- DONE2(DEBUG_SIGTRAP_BIT)
+ DONE88110(DEBUG_SIGTRAP_BIT)
GLOBAL(m88110_userbpt)
- PREP2("userbpt", 511, DEBUG_SIGTRAP_BIT,)
+ PREP88110("userbpt", 511, DEBUG_SIGTRAP_BIT,)
CALL(_C_LABEL(m88110_trap), T_USERBPT, r30)
- DONE2(DEBUG_SIGTRAP_BIT)
+ DONE88110(DEBUG_SIGTRAP_BIT)
#ifdef DDB
GLOBAL(m88110_break)
- PREP2("break", 130, DEBUG_BREAK_BIT,)
+ PREP88110("break", 130, DEBUG_BREAK_BIT,)
CALL(_C_LABEL(m88110_trap), T_KDB_BREAK, r30)
- DONE2(DEBUG_BREAK_BIT)
+ DONE88110(DEBUG_BREAK_BIT)
GLOBAL(m88110_trace)
- PREP2("trace", 131, DEBUG_TRACE_BIT,)
+ PREP88110("trace", 131, DEBUG_TRACE_BIT,)
CALL(_C_LABEL(m88110_trap), T_KDB_TRACE, r30)
- DONE2(DEBUG_TRACE_BIT)
+ DONE88110(DEBUG_TRACE_BIT)
GLOBAL(m88110_entry)
- PREP2("kdb", 132, DEBUG_KDB_BIT,)
+ PREP88110("kdb", 132, DEBUG_KDB_BIT,)
CALL(_C_LABEL(m88110_trap), T_KDB_ENTRY, r30)
- DONE2(DEBUG_KDB_BIT)
+ DONE88110(DEBUG_KDB_BIT)
#else
GLOBAL(m88110_break)
- PREP2("break", 130, DEBUG_BREAK_BIT,)
+ PREP88110("break", 130, DEBUG_BREAK_BIT,)
CALL(_C_LABEL(m88110_trap), T_UNKNOWNFLT, r30)
- DONE2(DEBUG_BREAK_BIT)
+ DONE88110(DEBUG_BREAK_BIT)
GLOBAL(m88110_trace)
- PREP2("trace", 131, DEBUG_TRACE_BIT,)
+ PREP88110("trace", 131, DEBUG_TRACE_BIT,)
CALL(_C_LABEL(m88110_trap), T_UNKNOWNFLT, r30)
- DONE2(DEBUG_TRACE_BIT)
+ DONE88110(DEBUG_TRACE_BIT)
GLOBAL(m88110_entry)
- PREP2("unknown", 132, DEBUG_KDB_BIT,)
+ PREP88110("unknown", 132, DEBUG_KDB_BIT,)
CALL(_C_LABEL(m88110_trap), T_UNKNOWNFLT, r30)
- DONE2(DEBUG_KDB_BIT)
+ DONE88110(DEBUG_KDB_BIT)
#endif
/*
@@ -2317,7 +2312,7 @@ ASLOCAL(m88110_setup_phase_one)
*
* immediate goal:
* Decide where we're going to put the exception frame.
- * Might be at the end of R31, SR3, or the thread's pcb.
+ * Might be at the end of R31, SR3, or the process pcb.
*/
/* Check if we are coming in from a FPU restart exception.
@@ -2427,11 +2422,11 @@ ASLOCAL(m88110_pickup_stack)
* immediate goal:
* Since we're servicing an exception from user mode, we
* know that SR3 is free. We use it to free up a temporary
- * register to be used in getting the thread's pcb.
+ * register to be used in getting the process pcb.
*/
stcr r31, SR3 /* save previous r31 */
- /* switch to the thread's kernel stack. */
+ /* switch to the process kernel stack. */
or.u r31, r0, hi16(_C_LABEL(curpcb))
ld r31, r31, lo16(_C_LABEL(curpcb))
addu r31, r31, PCB_USER_STATE /* point to user save area */
@@ -2474,7 +2469,7 @@ ASLOCAL(m88110_have_pcb)
st TMP, r31, REG_OFF(EF_CPU)
/*
- * Save Pbus fault status register from data and inst CMMU.
+ * Save fault status registers from CMMU.
*/
ldcr TMP, ISR
ldcr TMP2, ILAR
@@ -2506,7 +2501,6 @@ ASLOCAL(m88110_setup_phase_two)
* SR2: free
* SR3: saved TMP
* r1: return address to calling exception handler
- * TMP: possibly revised SSBR
* TMP2: free
* TMP3: free
* FLAGS: CPU status flags
@@ -2536,15 +2530,14 @@ ASLOCAL(m88110_setup_phase_two)
or.u TMP, r0, hi16(_ASM_LABEL(m88110_fpu_enable))
or TMP, TMP, lo16(_ASM_LABEL(m88110_fpu_enable))
- stcr TMP, EXIP /* jump to m88110_fpu_enable upon RTE */
+ stcr TMP, EXIP
set FLAGS, FLAGS, 1<FLAG_ENABLING_FPU>
xcr FLAGS, FLAGS, SR1
st r1, r31, REG_OFF(EF_RET) /* save the return address */
ld r1, r31, GENREG_OFF(1) /* get original r1 */
- ldcr TMP, SR3
- stcr r31, SR3 /* TMP now restored. R31 now saved in SR3 */
+ xcr TMP, r31, SR3 /* TMP now restored. R31 now saved in SR3 */
ld r31, r31, GENREG_OFF(31) /* get original r31 */
/*
@@ -2565,18 +2558,19 @@ ASLOCAL(m88110_setup_phase_two)
* Return address to the calling exception handler.
*
* immediate goal:
- * Do an RTE to restart the fpu and jump to "m88110_fpu_enable"
+ * Do an RTE to restart the fpu and jump to "fpu_enable"
* Another exception (or exceptions) may be raised in
* this, which is why FLAG_ENABLING_FPU is set in SR1.
*/
- NOP
- RTE /* jumps to "m88110_fpu_enable" on the next line to enable the FPU. */
+ RTE /* jumps to "m88110_fpu_enable" to enable the FPU. */
ASLOCAL(m88110_fpu_enable)
FLUSH_PIPELINE
- /* Now we can handle another exception!!! */
- /* Now that EFRZ is cleared, we can clear these */
+ /*
+ * Now that EFRZ is cleared, we can clear DSR and ISR.
+ * This will allow other data exceptions to happen.
+ */
stcr r0, ISR
stcr r0, DSR