cvs commit: src/sys/kern kern_umtx.c

David Xu davidxu at freebsd.org
Tue Nov 30 04:24:35 PST 2004


Thanks to jhb@, he had reviewed earlier version for me.

David Xu wrote:

>davidxu     2004-11-30 12:02:53 UTC
>
>  FreeBSD src repository
>
>  Modified files:
>    sys/kern             kern_umtx.c 
>  Log:
>  1. use per-chain mutex instead of global mutex to reduce
>     lock collision.
>  2. Fix two race conditions. One is between _umtx_unlock and signal,
>     also a thread was marked TDF_UMTXWAKEUP by _umtx_unlock, it is
>     possible a signal delivered to the thread will cause msleep
>     returns EINTR, and the thread breaks out of loop, this causes
>     umtx ownership is not transfered to the thread. Another is in
>     _umtx_unlock itself, when the function sets the umtx to
>     UMTX_UNOWNED state, a new thread can come in and lock the umtx,
>     also the function tries to set contested bit flag, but it will
>     fail. Although the function will wake a blocked thread, if that
>     thread breaks out of loop by signal, no contested bit will be set.
>  
>  Revision  Changes    Path
>  1.17      +212 -115  src/sys/kern/kern_umtx.c
>
>
>  
>



More information about the cvs-all mailing list