diff options
Diffstat (limited to 'sys/arch/amd64')
-rw-r--r-- | sys/arch/amd64/amd64/intr.c | 56 | ||||
-rw-r--r-- | sys/arch/amd64/include/intr.h | 64 |
2 files changed, 59 insertions, 61 deletions
diff --git a/sys/arch/amd64/amd64/intr.c b/sys/arch/amd64/amd64/intr.c index f5f929cbbd2..d3bbfa778dc 100644 --- a/sys/arch/amd64/amd64/intr.c +++ b/sys/arch/amd64/amd64/intr.c @@ -1,4 +1,4 @@ -/* $OpenBSD: intr.c,v 1.2 2004/06/25 11:03:27 art Exp $ */ +/* $OpenBSD: intr.c,v 1.3 2004/06/26 05:29:17 art Exp $ */ /* $NetBSD: intr.c,v 1.3 2003/03/03 22:16:20 fvdl Exp $ */ /* @@ -705,3 +705,57 @@ intr_printconfig(void) } #endif } + +/* + * Add a mask to cpl, and return the old value of cpl. + */ +int +splraise(int nlevel) +{ + int olevel; + struct cpu_info *ci = curcpu(); + + olevel = ci->ci_ilevel; + if (nlevel > olevel) + ci->ci_ilevel = nlevel; + return (olevel); +} + +/* + * Restore a value to cpl (unmasking interrupts). If any unmasked + * interrupts are pending, call Xspllower() to process them. + */ +int +spllower(int nlevel) +{ + int olevel; + struct cpu_info *ci = curcpu(); + + /* + * 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); +} + +/* + * Software interrupt registration + * + * We hand-code this to ensure that it's atomic. + * + * XXX always scheduled on the current CPU. + */ +void +softintr(int sir) +{ + struct cpu_info *ci = curcpu(); + + __asm __volatile("lock ; orl %1, %0" : + "=m"(ci->ci_ipending) : "ir" (1 << sir)); +} 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) |