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