From e8bb33d8a52501da2c03bbcb5fddf3239b74ad8c Mon Sep 17 00:00:00 2001 From: Colin Yi Date: Mon, 25 May 2009 10:17:17 +0800 Subject: 6826573 System crashing while installing snv_111 --- usr/src/uts/common/sys/cpuvar.h | 14 ++++++++++++++ 1 file changed, 14 insertions(+) (limited to 'usr/src/uts/common/sys/cpuvar.h') diff --git a/usr/src/uts/common/sys/cpuvar.h b/usr/src/uts/common/sys/cpuvar.h index 99829bbb03..1493aa6a33 100644 --- a/usr/src/uts/common/sys/cpuvar.h +++ b/usr/src/uts/common/sys/cpuvar.h @@ -267,6 +267,20 @@ extern cpu_core_t cpu_core[]; */ #define CPU_ON_INTR(cpup) ((cpup)->cpu_intr_actv >> (LOCK_LEVEL + 1)) +/* + * Check to see if an interrupt thread might be active at a given ipl. + * If so return true. + * We must be conservative--it is ok to give a false yes, but a false no + * will cause disaster. (But if the situation changes after we check it is + * ok--the caller is trying to ensure that an interrupt routine has been + * exited). + * This is used when trying to remove an interrupt handler from an autovector + * list in avintr.c. + */ +#define INTR_ACTIVE(cpup, level) \ + ((level) <= LOCK_LEVEL ? \ + ((cpup)->cpu_intr_actv & (1 << (level))) : (CPU_ON_INTR(cpup))) + /* * CPU_PSEUDO_RANDOM() returns a per CPU value that changes each time one * looks at it. It's meant as a cheap mechanism to be incorporated in routines -- cgit v1.2.3