cvs commit: src/sys/kern subr_power.c
Nate Lawson
nate at root.org
Wed Nov 9 10:34:40 GMT 2005
Bruce Evans wrote:
> On Wed, 9 Nov 2005, Warner Losh wrote:
>
>> Modified files:
>> sys/kern subr_power.c
>> Log:
>> Kick off the suspend sequence from the keyboard in a SWI rather than
>> in the hardware interrupt context (even if it is likely just an
>> ithread). We don't document that suspend/resume routines are run from
>> such a context and some of the things that happen in those routines
>> aren't interrupt safe. Since there's no real need to run from that
>> context, this restores assumptions that suspend routines have made.
>>
>> This fixes Thierry Herbelot's 'Trying to sleep while sleeping is
>> prohibited' problem.
>
>
> Er, SWIs are interrupts too. Trying to sleep in a SWI handler should
> cause the same message. This commit uses the general taskqueue SWI
> handler. taskqueue(9) implicitly says that only the taskqueue thread
> handler can sleep (it gives malloc(M_WAITOK) as an example of something
> that can only be done in thread context).
I agree. You should use a generic thread taskqueue.
--
Nate
More information about the cvs-src
mailing list