diff options
Diffstat (limited to 'sys')
-rw-r--r-- | sys/arch/mac68k/mac68k/locore.s | 44 | ||||
-rw-r--r-- | sys/arch/mac68k/mac68k/machdep.c | 13 |
2 files changed, 4 insertions, 53 deletions
diff --git a/sys/arch/mac68k/mac68k/locore.s b/sys/arch/mac68k/mac68k/locore.s index 0ca1ef77e02..51e98e059f9 100644 --- a/sys/arch/mac68k/mac68k/locore.s +++ b/sys/arch/mac68k/mac68k/locore.s @@ -1,4 +1,4 @@ -/* $OpenBSD: locore.s,v 1.51 2006/01/21 12:27:58 miod Exp $ */ +/* $OpenBSD: locore.s,v 1.52 2006/06/11 20:49:27 miod Exp $ */ /* $NetBSD: locore.s,v 1.103 1998/07/09 06:02:50 scottr Exp $ */ /* @@ -384,7 +384,7 @@ GLOBAL(proc_trampoline) GLOBAL(m68k_fault_addr) .long 0 -#if defined(M68040) || defined(M68060) +#if defined(M68040) ENTRY_NOPROFILE(addrerr4060) clrl sp@- | stack adjust count moveml #0xFFFF,sp@- | save user registers @@ -396,46 +396,6 @@ ENTRY_NOPROFILE(addrerr4060) jra _ASM_LABEL(faultstkadj) | and deal with it #endif -#if defined(M68060) -ENTRY_NOPROFILE(buserr60) - clrl sp@- | stack adjust count - moveml #0xFFFF,sp@- | save user registers - movl usp,a0 | save the user SP - movl a0,sp@(FR_SP) | in the savearea - movel sp@(FR_HW+12),d0 | FSLW - btst #2,d0 | branch prediction error? - jeq Lnobpe - movc cacr,d2 - orl #IC60_CABC,d2 | clear all branch cache entries - movc d2,cacr - movl d0,d1 - addql #1,L60bpe - andl #0x7ffd,d1 - jeq _ASM_LABEL(faultstkadjnotrap2) -Lnobpe: -| we need to adjust for misaligned addresses - movl sp@(FR_HW+8),d1 | grab VA - btst #27,d0 | check for mis-aligned access - jeq Lberr3 | no, skip - addl #28,d1 | yes, get into next page - | operand case: 3, - | instruction case: 4+12+12 - andl #PG_FRAME,d1 | and truncate -Lberr3: - movl d1,sp@- - movl d0,sp@- | code is FSLW now. - andw #0x1f80,d0 - jeq Lberr60 | it is a bus error - movl #T_MMUFLT,sp@- | show that we are an MMU fault - jra _ASM_LABEL(faultstkadj) | and deal with it -Lberr60: - tstl _C_LABEL(nofault) | catch bus error? - jeq Lisberr | no, handle as usual - movl sp@(FR_HW+8+8),_C_LABEL(m68k_fault_addr) | save fault addr - movl _C_LABEL(nofault),sp@- | yes, - jbsr _C_LABEL(longjmp) | longjmp(nofault) - /* NOTREACHED */ -#endif #if defined(M68040) ENTRY_NOPROFILE(buserr40) clrl sp@- | stack adjust count diff --git a/sys/arch/mac68k/mac68k/machdep.c b/sys/arch/mac68k/mac68k/machdep.c index 5aaf9701196..615844225eb 100644 --- a/sys/arch/mac68k/mac68k/machdep.c +++ b/sys/arch/mac68k/mac68k/machdep.c @@ -1,4 +1,4 @@ -/* $OpenBSD: machdep.c,v 1.132 2006/06/11 20:48:13 miod Exp $ */ +/* $OpenBSD: machdep.c,v 1.133 2006/06/11 20:49:27 miod Exp $ */ /* $NetBSD: machdep.c,v 1.207 1998/07/08 04:39:34 thorpej Exp $ */ /* @@ -554,13 +554,10 @@ allocsys(v) void initcpu() { -#if defined(M68040) || defined(M68060) +#if defined(M68040) extern void (*vectab[256])(void); void addrerr4060(void); #endif -#ifdef M68060 - void buserr60(void); -#endif #ifdef M68040 void buserr40(void); #endif @@ -569,12 +566,6 @@ initcpu() #endif switch (cputype) { -#ifdef M68060 - case CPU_68060: - vectab[2] = buserr60; - vectab[3] = addrerr4060; - break; -#endif #ifdef M68040 case CPU_68040: vectab[2] = buserr40; |