summaryrefslogtreecommitdiff
path: root/sys/arch/hppa/include/intr.h
diff options
context:
space:
mode:
authorMichael Shalayeff <mickey@cvs.openbsd.org>1998-12-23 17:53:55 +0000
committerMichael Shalayeff <mickey@cvs.openbsd.org>1998-12-23 17:53:55 +0000
commit123f152d81d69f64cacd4e8a0ea9a816b0024a46 (patch)
treea0665c8fb85da9b216428e13a785122bcbae90cc /sys/arch/hppa/include/intr.h
parent3bcf0c014e2fa6fd2ce10a7deaf9e618b47f64a0 (diff)
remove bogus comments
better inline for spl{hign,low} inline splx(), which is 5 insn long, and call would add 2-3 more, which is 50% loss (not that "small or none" as it was in those (see above) comments)
Diffstat (limited to 'sys/arch/hppa/include/intr.h')
-rw-r--r--sys/arch/hppa/include/intr.h48
1 files changed, 28 insertions, 20 deletions
diff --git a/sys/arch/hppa/include/intr.h b/sys/arch/hppa/include/intr.h
index 92a2c7a59f6..301ee34605e 100644
--- a/sys/arch/hppa/include/intr.h
+++ b/sys/arch/hppa/include/intr.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: intr.h,v 1.5 1998/12/05 17:42:10 mickey Exp $ */
+/* $OpenBSD: intr.h,v 1.6 1998/12/23 17:53:54 mickey Exp $ */
/*
* Copyright (c) 1990,1991,1992,1994 The University of Utah and
@@ -27,6 +27,8 @@
#ifndef _MACHINE_INTR_H_
#define _MACHINE_INTR_H_
+#include <machine/psl.h>
+
#define CPU_NINTS 32
/* hardwired clock int line */
@@ -50,27 +52,34 @@
#if !defined(_LOCORE)
/*
* Define the machine-independent SPL routines in terms of splx().
- * To prevent cluttering the global spl() namespace, routines that
- * need machine-dependent SPLs should roll their own.
- *
- * If compiling with GCC, it's easy to inline spl's with constant
- * arguments. However, when the argument can be variable, there
- * is little or no win; as a result, splx() is not inline'd.
*/
-#define __splhigh(splhval) ({ \
- register u_int _ctl_r; \
- __asm __volatile("mfctl %%cr15,%0" : "=r" (_ctl_r)); \
- __asm __volatile("mtctl %0,%%cr15" :: "r" (splhval)); \
- __asm __volatile("rsm 1, %%r0"::); \
- _ctl_r; \
+#define __splhigh(splhval) ({ \
+ register u_int _ctl_r; \
+ __asm __volatile("mfctl %%cr15,%0\n\t" \
+ "mtctl %1,%%cr15\n\t" \
+ "rsm %2, %%r0" \
+ : "=r" (_ctl_r): "r" (splhval), "i" (PSW_I)); \
+ _ctl_r; \
+})
+
+#define __spllow(spllval) ({ \
+ register u_int _ctl_r; \
+ __asm __volatile("mfctl %%cr15,%0\n\t" \
+ "mtctl %1,%%cr15\n\t" \
+ "ssm %2, %%r0" \
+ : "=r" (_ctl_r): "r" (spllval), "i" (PSW_I)); \
+ _ctl_r; \
})
-#define __spllow(spllval) ({ \
- register u_int _ctl_r; \
- __asm __volatile("mfctl %%cr15,%0" : "=r" (_ctl_r)); \
- __asm __volatile("mtctl %0,%%cr15" :: "r" (spllval)); \
- __asm __volatile("ssm 1, %%r0"::); \
- _ctl_r; \
+#define splx(splval) ({ \
+ register u_int _ctl_r; \
+ __asm __volatile("rsm %2,%%r0\n\t" \
+ "mfctl %%cr15,%0\n\t" \
+ "mtctl %1,%%cr15\n\t" \
+ "comiclr,= 0,%1,0\n\t" \
+ "ssm %2,%%r0" \
+ : "=r" (_ctl_r): "r" (splval), "i" (PSW_I)); \
+ _ctl_r; \
})
#define spl0() __spllow(INT_ALL)
@@ -84,7 +93,6 @@
#define splclock() __spllow(0)
#define splstatclock() __spllow(0)
#define splhigh() __splhigh(0)
-int splx __P((int));
/* software interrupt register */
extern u_int32_t sir;