cvs commit: src/sys/vm vm_zeroidle.c
Don Lewis
truckman at FreeBSD.org
Mon Nov 8 16:49:37 PST 2004
On 8 Nov, John Baldwin wrote:
> It is no longer required to hold the mutex over cv_wait() and cv_signal(). I
> intentionally changed that so that you can do:
>
> lock()
> blah()
> unlock()
> cv_signal()
>
> and reduce the number of context switches if you preempt in cv_signal().
cv_wait() unlocks and relocks the mutex, so it is necessary to hold the
mutex before calling cv_wait(). It is also likely that the mutex would
have to be held to avoid having the condition being waited on going away
after the mutex was dropped and before the cv_wait() call, which could
cause the thread to miss a wakeup and sleep forever.
If the caller holds the mutex across the call to cv_signal(), the caller
may be able to avoid calls to cv_signal() if it knows that there are no
waiters. In most cases, the caller will want to release the mutex when
it calls cv_signal(). A version of cv_signal() that releases the mutex
after calling sleepq_lock() and before calling sleepq_signal() or
sleepq_release() would allow unnecessary calls to sleepq_signal() to be
optimized out, while avoiding the extra context switches that could be
caused by holding the mutex until after cv_signal().
More information about the cvs-all
mailing list