summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorMiod Vallat <miod@cvs.openbsd.org>2005-11-28 22:22:56 +0000
committerMiod Vallat <miod@cvs.openbsd.org>2005-11-28 22:22:56 +0000
commitef49b62f208d1fd26918bebe3130a438212dedda (patch)
tree1111970af7f7fc869e40d20f847e1f1b5a809039 /sys
parent9407a589e754c164aa72b047d01fb5e153c17425 (diff)
Maintain an interrupt depth counter for CLKF_INTR to be correct.
Tested aoyama@ martin@ and I.
Diffstat (limited to 'sys')
-rw-r--r--sys/arch/m88k/include/cpu.h5
-rw-r--r--sys/arch/m88k/m88k/m88k_machdep.c4
-rw-r--r--sys/arch/m88k/m88k/trap.c8
3 files changed, 13 insertions, 4 deletions
diff --git a/sys/arch/m88k/include/cpu.h b/sys/arch/m88k/include/cpu.h
index fc3a85cfba1..a69737ff09a 100644
--- a/sys/arch/m88k/include/cpu.h
+++ b/sys/arch/m88k/include/cpu.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: cpu.h,v 1.8 2005/11/28 22:21:15 miod Exp $ */
+/* $OpenBSD: cpu.h,v 1.9 2005/11/28 22:22:51 miod Exp $ */
/*
* Copyright (c) 1996 Nivas Madhur
* Copyright (c) 1992, 1993
@@ -97,7 +97,8 @@ struct clockframe {
#define CLKF_USERMODE(framep) (((framep)->tf.tf_epsr & PSR_MODE) == 0)
#define CLKF_PC(framep) ((framep)->tf.tf_sxip & XIP_ADDR)
-#define CLKF_INTR(framep) (0) /* XXX temporary */
+extern int intrdepth;
+#define CLKF_INTR(framep) (intrdepth > 1)
/*
* Get interrupt glue.
diff --git a/sys/arch/m88k/m88k/m88k_machdep.c b/sys/arch/m88k/m88k/m88k_machdep.c
index 2b0db929c41..0c9b6d2fdc9 100644
--- a/sys/arch/m88k/m88k/m88k_machdep.c
+++ b/sys/arch/m88k/m88k/m88k_machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: m88k_machdep.c,v 1.8 2005/11/06 17:58:20 miod Exp $ */
+/* $OpenBSD: m88k_machdep.c,v 1.9 2005/11/28 22:22:55 miod Exp $ */
/*
* Copyright (c) 1998, 1999, 2000, 2001 Steve Murphree, Jr.
* Copyright (c) 1996 Nivas Madhur
@@ -75,6 +75,8 @@ void dumpconf(void);
int longformat = 1; /* for regdump() */
+int intrdepth;
+
/*
* safepri is a safe priority for sleep to set for a spin-wait
* during autoconfiguration or after a panic.
diff --git a/sys/arch/m88k/m88k/trap.c b/sys/arch/m88k/m88k/trap.c
index 2491feb36b6..dae2b10eb6c 100644
--- a/sys/arch/m88k/m88k/trap.c
+++ b/sys/arch/m88k/m88k/trap.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: trap.c,v 1.22 2005/11/28 22:21:15 miod Exp $ */
+/* $OpenBSD: trap.c,v 1.23 2005/11/28 22:22:55 miod Exp $ */
/*
* Copyright (c) 2004, Miodrag Vallat.
* Copyright (c) 1998 Steve Murphree, Jr.
@@ -260,7 +260,9 @@ m88100_trap(unsigned type, struct trapframe *frame)
/* This function pointer is set in machdep.c
It calls m188_ext_int or sbc_ext_int depending
on the value of brdtyp - smurph */
+ intrdepth++;
md_interrupt_func(T_INT, frame);
+ intrdepth--;
return;
case T_MISALGNFLT:
@@ -693,11 +695,15 @@ m88110_trap(unsigned type, struct trapframe *frame)
break;
case T_NON_MASK:
case T_NON_MASK+T_USER:
+ intrdepth++;
md_interrupt_func(T_NON_MASK, frame);
+ intrdepth--;
return;
case T_INT:
case T_INT+T_USER:
+ intrdepth++;
md_interrupt_func(T_INT, frame);
+ intrdepth--;
return;
case T_MISALGNFLT:
printf("kernel mode misaligned access exception @ 0x%08x\n",