cvs commit: src/sys/kern kern_umtx.c src/sys/sys umtx.h

Alexey Dokuchaev danfe at nsu.ru
Tue Apr 1 00:04:38 PST 2003


On Mon, Mar 31, 2003 at 05:38:13PM -0800, Julian Elischer wrote:
> 
> On Mon, 31 Mar 2003, Nate Lawson wrote:
> 
> > On Mon, 31 Mar 2003, Jeff Roberson wrote:
> > >   Added files:
> > >     sys/kern             kern_umtx.c 
> > >     sys/sys              umtx.h 
> > >   Log:
> > >    - Add an api for doing smp safe locks in userland.
> > >    - umtx_lock() is defined as an inline in umtx.h.  It tries to do an
> > >      uncontested acquire of a lock which falls back to the _umtx_lock()
> > >      system-call if that fails.
> > >    - umtx_unlock() is also an inline which falls back to _umtx_unlock() if the
> > >      uncontested unlock fails.
> > >    - Locks are keyed off of the thr_id_t of the currently running thread which
> > >      is currently just the pointer to the 'struct thread' in kernel.
> > >    - _umtx_lock() uses the proc pointer to synchronize access to blocked thread
> > >      queues which are stored in the first blocked thread.
> > >   
> > >   Revision  Changes    Path
> > >   1.1       +303 -0    src/sys/kern/kern_umtx.c (new)
> > >   1.1       +87 -0     src/sys/sys/umtx.h (new)
> > 
> > It's great to be getting this.  Can you point me to a document indicating
> > how this will be used by KSE?  Are we going to have "native threads"
> > (thr), KSE, and pthreads?
> 
> We will have 3 threads schemes..
> userland threads
> thr threads.. Useable by the majority of threaded apps
> KSE threads.. Useable by threaded apps that have thousands of threads
> 
> (i.e. KSE is a hybrid if userland and thr threads..)

Does this follow from your words that creating of "thousands of threads"
is better to be done in userland, versus kernel?  Because of M:N model
KSE will eventually utilize?  Pardon my unawareness; pointing me to some
document explaining all of this will also be appreciated.

./danfe



More information about the cvs-src mailing list