From owner-cvs-all Sun Mar 4 10:13: 5 2001 Delivered-To: cvs-all@freebsd.org Received: from aslan.scsiguy.com (aslan.scsiguy.com [63.229.232.106]) by hub.freebsd.org (Postfix) with ESMTP id 471B637B719; Sun, 4 Mar 2001 10:12:52 -0800 (PST) (envelope-from gibbs@scsiguy.com) Received: from scsiguy.com (localhost [127.0.0.1]) by aslan.scsiguy.com (8.11.2/8.9.3) with ESMTP id f24ICoO80977; Sun, 4 Mar 2001 11:12:51 -0700 (MST) (envelope-from gibbs@scsiguy.com) Message-Id: <200103041812.f24ICoO80977@aslan.scsiguy.com> X-Mailer: exmh version 2.2 06/23/2000 with nmh-1.0.4 To: John Baldwin Cc: cvs-all@FreeBSD.org, cvs-committers@FreeBSD.org Subject: Re: cvs commit: src/sys/kern kern_intr.c src/sys/sys interrupt.h In-Reply-To: Your message of "Sat, 03 Mar 2001 17:32:51 PST." Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Date: Sun, 04 Mar 2001 11:12:50 -0700 From: "Justin T. Gibbs" Sender: owner-cvs-all@FreeBSD.ORG Precedence: bulk X-Loop: FreeBSD.ORG >When an interrupt handler is removed, we mark the handler as dead if the thread >is runnable. We do this with a spin lock held to prevent new interrupts from >coming in while we do this. If the thread is runnable, then on a UP system >the ithread isn't running. When the ithread wakes up, it has either already >run the handler (in which case we don't care), it is running the handler, or it >is about to run the handler. If it is about to run the handler, then we will >see the IH_DEAD flag and remove the handler. If it is in the handler, there's >nothing we can really do. Sure there is. You can block the "releaser" until the interrupt routine exits. There is no other way to resolve the race condition. Since registering and de-registering interrupt handlers should be an uncommon occurance, it would be nice to avoid having to have a spin-lock acquired just to protect the list of handlers serviced by the ithread that needs to be acquired every time it is placed in the run state. Perhaps you should just change the handler's entry point to the removal function and set the ithread runable. The new entry point would remove the handler and wakeup the thread waiting for the entry to be removed. Something very similar could be used to add new entries onto the queue so long as the ithread's list of handlers has a sentinal node that usually is NULL. -- Justin To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe cvs-all" in the body of the message