cvs commit: src/sys/kern kern_intr.c
Nate Lawson
nate at root.org
Tue Jan 13 16:12:23 PST 2004
On Tue, 13 Jan 2004, Don Lewis wrote:
> Modified files:
> sys/kern kern_intr.c
> Log:
> If a device attach routine fails during boot and calls bus_teardown_intr(),
> ithread_remove_handler() may fail to remove the interrupt handler if
> it decides to let the ithread do the removal. The problem is that during
> boot "cold" is set, which causes msleep() to return immediately. This
> will cause ithread_remove_handler() to fail to wait for the ithread
> to do the removal from the handler TAILQ before freeing the handler
> back to the heap. Bad things will happen when some other user of the
> TAILQ, such as ithread_add_handler() or the actual ithread attempts to use
> the freed handler. Fix the problem by forcing ithread_remove_handler()
> to do the actual removal itself if the "cold" flag is set.
>
> Reviewed by: jhb
>
> Revision Changes Path
> 1.104 +5 -1 src/sys/kern/kern_intr.c
tjr@ and truckman@ are leading the MVBF club (most valuable bug fixers).
-Nate
More information about the cvs-all
mailing list