diff options
Diffstat (limited to 'sys/arch/amd64/include/intr.h')
-rw-r--r-- | sys/arch/amd64/include/intr.h | 64 |
1 files changed, 4 insertions, 60 deletions
diff --git a/sys/arch/amd64/include/intr.h b/sys/arch/amd64/include/intr.h index f468f1a0b27..69d6247e700 100644 --- a/sys/arch/amd64/include/intr.h +++ b/sys/arch/amd64/include/intr.h @@ -1,4 +1,4 @@ -/* $OpenBSD: intr.h,v 1.3 2004/06/25 11:03:28 art Exp $ */ +/* $OpenBSD: intr.h,v 1.4 2004/06/26 05:29:17 art Exp $ */ /* $NetBSD: intr.h,v 1.2 2003/05/04 22:01:56 fvdl Exp $ */ /*- @@ -111,9 +111,9 @@ struct intrhand { extern void Xspllower(int); -static __inline int splraise(int); -static __inline int spllower(int); -static __inline void softintr(int); +int splraise(int); +int spllower(int); +void softintr(int); /* * Convert spl level to local APIC level @@ -131,46 +131,6 @@ static __inline void softintr(int); #define __splbarrier() __asm __volatile("":::"memory") /* - * Add a mask to cpl, and return the old value of cpl. - */ -static __inline int -splraise(int nlevel) -{ - int olevel; - struct cpu_info *ci = curcpu(); - - olevel = ci->ci_ilevel; - if (nlevel > olevel) - ci->ci_ilevel = nlevel; - __splbarrier(); - return (olevel); -} - -/* - * Restore a value to cpl (unmasking interrupts). If any unmasked - * interrupts are pending, call Xspllower() to process them. - */ -static __inline int -spllower(int nlevel) -{ - int olevel; - struct cpu_info *ci = curcpu(); - - __splbarrier(); - /* - * Since this should only lower the interrupt level, - * the XOR below should only show interrupts that - * are being unmasked. - */ - olevel = ci->ci_ilevel; - if (ci->ci_ipending & IUNMASK(ci,nlevel)) - Xspllower(nlevel); - else - ci->ci_ilevel = nlevel; - return (olevel); -} - -/* * Hardware interrupt masks */ #define splbio() splraise(IPL_BIO) @@ -228,22 +188,6 @@ void splassert_check(int, const char *); #endif /* - * Software interrupt registration - * - * We hand-code this to ensure that it's atomic. - * - * XXX always scheduled on the current CPU. - */ -static __inline void -softintr(int sir) -{ - struct cpu_info *ci = curcpu(); - - __asm __volatile("lock ; orl %1, %0" : - "=m"(ci->ci_ipending) : "ir" (1 << sir)); -} - -/* * XXX */ #define setsoftnet() softintr(SIR_NET) |