From 123f152d81d69f64cacd4e8a0ea9a816b0024a46 Mon Sep 17 00:00:00 2001 From: Michael Shalayeff Date: Wed, 23 Dec 1998 17:53:55 +0000 Subject: 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) --- sys/arch/hppa/include/intr.h | 48 ++++++++++++++++++++++++++------------------ 1 file changed, 28 insertions(+), 20 deletions(-) (limited to 'sys') 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 + #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; -- cgit v1.2.3