aboutsummaryrefslogtreecommitdiff
path: root/sys/kern/subr_sleepqueue.c
Commit message (Collapse)AuthorAgeFilesLines
* Fixed some common printf format errors. Don't assume that "struct foo *"Bruce Evans2004-05-141-14/+13
| | | | | | | | | | | is "void *" (it isn't) or that the default promotion of pid_t is int. Instead, assume that casting "struct foo *" to "void *" and printing the result with %p is useful, and that all pid_t's are representable as longs. Fixed some minor style bugs (mainly spelling errors in comments). Notes: svn path=/head/; revision=129241
* Split sleepq_wakeup_thread() into two functions. sleepq_remove_thread()John Baldwin2004-05-131-13/+50
| | | | | | | | | | | | | | | | | removes a specific thread from a sleep queue. sleepq_resume_thread() resumes scheduling of a thread that has been previously removed from a sleep queue. - sleepq_catch_signals() just removes a thread from the queue it was just added to when a pending signal is found. - sleepq_signal() and sleepq_broadcast() remove threads from a queue, drop the queue lock, and then resume all the previously removed threads. This doesn't completely fix the sched_lock <-> sleepq chain LOR, but it makes it a little better as we no longer call setrunnble() with a sleep queue lock held meaning if setrunnable() tries to wakeup the swapper we don't try to lock two sleep queue chains at the same time. Notes: svn path=/head/; revision=129188
* Keep track of threads waiting in kse_release() to avoid a raceDaniel Eischen2004-04-281-1/+5
| | | | | | | | | | | | | | condition where kse_wakeup() doesn't yet see them in (interruptible) sleep queues. Also add an upcall check to sleepqueue_catch_signals() suggested by jhb. This commit should fix recent mysql hangs. Reviewed by: jhb, davidxu Mysql'd by: Robin P. Blanchard <robin.blanchard at gactr uga edu> Notes: svn path=/head/; revision=128721
* Remove a bogus assertion and readd it in a more correct location. A threadJohn Baldwin2004-03-161-1/+1
| | | | | | | | | | | | might be enqueued on a sleep queue but not be asleep when the timeout fires if it is blocked on a lock trying to check for pending signals before going to sleep. In the case of fixing up the TDF_TIMEOUT race, however, the thread must be marked asleep. Reported by: kan (the bogus one) Notes: svn path=/head/; revision=127085
* - Remove old sleep queues.John Baldwin2004-03-121-1/+1
| | | | | | | | - Remove sleepqueue argument from sleepq_set_timeout() since it is not used. Notes: svn path=/head/; revision=126885
* Always assert that the passed in lock is the same as the saved lock in theJohn Baldwin2004-03-021-19/+1
| | | | | | | sleep queue now that the one abnormal case has been fixed. Notes: svn path=/head/; revision=126488
* Add an implementation of a generic sleep queue abstraction that is usedJohn Baldwin2004-02-271-0/+776
to queue threads sleeping on a wait channel similar to how turnstiles are used to queue threads waiting for a lock. This subsystem will be used as the backend for sleep/wakeup and condition variables initially. Eventually it will also be used to replace the ithread-specific iwait thread inhibitor. Sleep queues are also not locked by sched_lock, so this splits sched_lock up a bit further increasing concurrency within the scheduler. Sleep queues also natively support timeouts on sleeps and interruptible sleeps allowing for the reduction of a lot of duplicated code between the sleep/wakeup and condition variable implementations. For more details on the sleep queue implementation, check the comments in sys/sleepqueue.h and kern/subr_sleepqueue.c. Notes: svn path=/head/; revision=126324