summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/mips64/mips64/exception.S28
-rw-r--r--sys/arch/mips64/mips64/interrupt.c6
2 files changed, 20 insertions, 14 deletions
diff --git a/sys/arch/mips64/mips64/exception.S b/sys/arch/mips64/mips64/exception.S
index fa0f6a1bca6..df4dafdbcd6 100644
--- a/sys/arch/mips64/mips64/exception.S
+++ b/sys/arch/mips64/mips64/exception.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: exception.S,v 1.18 2009/05/22 20:37:53 miod Exp $ */
+/* $OpenBSD: exception.S,v 1.19 2009/05/27 18:58:15 miod Exp $ */
/*
* Copyright (c) 2002-2003 Opsycon AB (www.opsycon.se / www.opsycon.com)
@@ -182,6 +182,7 @@ NNON_LEAF(k_intr, FRAMESZ(KERN_EXC_FRAME_SIZE), ra)
LA gp, _gp
and t0, a1, ~(SR_COP_1_BIT | SR_EXL | SR_INT_ENAB | SR_KSU_MASK)
mtc0 t0, COP_0_STATUS_REG
+ ITLBNOPFIX
LA t1, int_nest_cntr
lw t2, (t1)
addiu t2, 1
@@ -191,11 +192,6 @@ NNON_LEAF(k_intr, FRAMESZ(KERN_EXC_FRAME_SIZE), ra)
jal interrupt
PTR_S a3, CF_RA_OFFS + KERN_REG_SIZE(sp)
- mfc0 t0, COP_0_STATUS_REG # dis int preserve settings.
- li t1, ~SR_INT_ENAB
- and t0, t0, t1
- mtc0 t0, COP_0_STATUS_REG
-
LA t1, int_nest_cntr
lw t2, (t1)
addiu t2, -1
@@ -234,6 +230,7 @@ NNON_LEAF(u_intr, FRAMESZ(CF_SZ), ra)
.set at
and t0, a1, ~(SR_COP_1_BIT | SR_EXL | SR_INT_ENAB | SR_KSU_MASK)
mtc0 t0, COP_0_STATUS_REG
+ ITLBNOPFIX
LA t1, int_nest_cntr
lw t2, (t1)
addiu t2, 1
@@ -243,6 +240,11 @@ NNON_LEAF(u_intr, FRAMESZ(CF_SZ), ra)
jal interrupt
PTR_S a3, CF_RA_OFFS(sp) # for debugging
+ mfc0 t0, COP_0_STATUS_REG # enable interrupts before checking
+ ori t0, SR_INT_ENAB # for ast.
+ mtc0 t0, COP_0_STATUS_REG
+ ITLBNOPFIX
+
0:
lw v0, astpending # any pending interrupts?
beq v0, zero, 4f
@@ -272,8 +274,9 @@ NNON_LEAF(u_intr, FRAMESZ(CF_SZ), ra)
nop;nop;nop;nop
1:
#endif
- jal softintr
+ jal ast
nop
+
/*
* Restore user registers and return. NOTE: interrupts are enabled.
*/
@@ -304,10 +307,11 @@ NNON_LEAF(u_intr, FRAMESZ(CF_SZ), ra)
nop
4:
- mfc0 t0, COP_0_STATUS_REG # dis int preserve settings.
+ mfc0 t0, COP_0_STATUS_REG # disable interrupts
li t1, ~SR_INT_ENAB
and t0, t0, t1
mtc0 t0, COP_0_STATUS_REG
+ ITLBNOPFIX
LA t1, int_nest_cntr
lw t2, (t1)
@@ -316,6 +320,7 @@ NNON_LEAF(u_intr, FRAMESZ(CF_SZ), ra)
ori t0, SR_EXL # restoring to user mode.
mtc0 t0, COP_0_STATUS_REG # must set exception level bit.
+ ITLBNOPFIX
PTR_L k0, curprocpaddr
RESTORE_REG(a3, CPL, k0, 0)
@@ -362,10 +367,11 @@ NNON_LEAF(k_general, FRAMESZ(KERN_EXC_FRAME_SIZE), ra)
jal trap
PTR_S a3, CF_RA_OFFS + KERN_REG_SIZE(sp)
- mfc0 t0, COP_0_STATUS_REG # dis int preserve settings.
+ mfc0 t0, COP_0_STATUS_REG # disable interrupts
li t1, ~SR_INT_ENAB
and t0, t0, t1
mtc0 t0, COP_0_STATUS_REG
+ ITLBNOPFIX
.set noat
#if 0
@@ -432,7 +438,7 @@ NNON_LEAF(u_general, FRAMESZ(CF_SZ), ra)
PTR_L t0, curprocpaddr
SAVE_CPU_SREG(t0, 0)
- jal softintr
+ jal ast
nop
PTR_L t0, curprocpaddr
@@ -462,7 +468,7 @@ NNON_LEAF(u_general, FRAMESZ(CF_SZ), ra)
nop;nop;nop;nop
1:
#endif
- mfc0 t0, COP_0_STATUS_REG # dis int preserve settings.
+ mfc0 t0, COP_0_STATUS_REG # disable interrupts
li t1, ~SR_INT_ENAB
and t0, t0, t1
mtc0 t0, COP_0_STATUS_REG
diff --git a/sys/arch/mips64/mips64/interrupt.c b/sys/arch/mips64/mips64/interrupt.c
index 1ca5fda6c2f..e431f2f9a6f 100644
--- a/sys/arch/mips64/mips64/interrupt.c
+++ b/sys/arch/mips64/mips64/interrupt.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: interrupt.c,v 1.38 2009/05/22 20:37:53 miod Exp $ */
+/* $OpenBSD: interrupt.c,v 1.39 2009/05/27 18:58:15 miod Exp $ */
/*
* Copyright (c) 2001-2004 Opsycon AB (www.opsycon.se / www.opsycon.com)
@@ -121,7 +121,7 @@ int_f *pending_hand = &dummy_do_pending_int;
*/
void interrupt(struct trap_frame *);
-void softintr(void);
+void ast(void);
/*
* Handle an interrupt. Both kernel and user mode is handled here.
@@ -236,7 +236,7 @@ set_intr(int pri, intrmask_t mask,
* This is called from MipsUserIntr() if astpending is set.
*/
void
-softintr()
+ast()
{
struct proc *p = curproc;
int sig;