diff options
-rw-r--r-- | sys/arch/vax/include/intr.h | 23 | ||||
-rw-r--r-- | sys/arch/vax/vax/machdep.c | 19 |
2 files changed, 37 insertions, 5 deletions
diff --git a/sys/arch/vax/include/intr.h b/sys/arch/vax/include/intr.h index 34736bc40ae..6a7ce4d4094 100644 --- a/sys/arch/vax/include/intr.h +++ b/sys/arch/vax/include/intr.h @@ -1,4 +1,4 @@ -/* $OpenBSD: intr.h,v 1.4 2006/06/01 06:01:28 miod Exp $ */ +/* $OpenBSD: intr.h,v 1.5 2006/06/02 17:39:58 miod Exp $ */ /* $NetBSD: intr.h,v 1.1 1998/08/18 23:55:00 matt Exp $ */ /* @@ -55,9 +55,6 @@ #define IST_EDGE 2 /* edge-triggered */ #define IST_LEVEL 3 /* level-triggered */ -/* SPL asserts */ -#define splassert(wantipl) /* nothing */ - #ifndef lint #define splx(reg) \ ({ \ @@ -100,4 +97,22 @@ #define spl6() _splraise(0x16) #define spl7() _splraise(0x17) +/* SPL asserts */ +#ifdef DIAGNOSTIC +/* + * Although this function is implemented in MI code, it must be in this MD + * header because we don't want this header to include MI includes. + */ +void splassert_fail(int, int, const char *); +extern int splassert_ctl; +void splassert_check(int, const char *); +#define splassert(__wantipl) do { \ + if (__predict_false(splassert_ctl > 0)) { \ + splassert_check(__wantipl, __func__); \ + } \ +} while (0) +#else +#define splassert(wantipl) do { /* nothing */ } while (0) +#endif + #endif /* _VAX_INTR_H */ diff --git a/sys/arch/vax/vax/machdep.c b/sys/arch/vax/vax/machdep.c index e0b3166b406..0d471a89bf5 100644 --- a/sys/arch/vax/vax/machdep.c +++ b/sys/arch/vax/vax/machdep.c @@ -1,4 +1,4 @@ -/* $OpenBSD: machdep.c,v 1.78 2006/05/30 21:24:28 miod Exp $ */ +/* $OpenBSD: machdep.c,v 1.79 2006/06/02 17:39:59 miod Exp $ */ /* $NetBSD: machdep.c,v 1.108 2000/09/13 15:00:23 thorpej Exp $ */ /* @@ -985,3 +985,20 @@ generic_reboot(int arg) asm("halt"); } + +#ifdef DIAGNOSTIC +void +splassert_check(int wantipl, const char *func) +{ + int oldipl = mfpr(PR_IPL); + + if (oldipl < wantipl) { + splassert_fail(wantipl, oldipl, func); + /* + * If the splassert_ctl is set to not panic, raise the ipl + * in a feeble attempt to reduce damage. + */ + mtpr(wantipl, PR_IPL); + } +} +#endif |