Fast user Space Mutexes (aka Futexes)
Hiten Pandya
hmp at backplane.com
Tue Oct 21 13:13:37 PDT 2003
Matthew Dillon wrote:
Remember everyone that we are talking about two layers in userland
here... the core layer is intended to be the LWKT port and will
include a messaging implementation for all system calls. Then a POSIX
layer will be placed on top of that.
futexes could be integrated into the higher layer (something at the same
level as the POSIX layer). The userland LWKT, with kernel support, will
provide IPC mechanisms if the futex needs it, but this would not prevent
the futex code from spinning or spin/switching (in userland) on a mutex
if it wants to.
Also remember that I would eventually like to move the messaging
implementation for system calls into an intermediate layer that is run
in userland but loaded by the kernel. For now I'm not worried about
that, we can just have the system call messaging layer directly in libcr.
Just for twinkles, I got half of the futex kernel part done
today in the afternoon when I was bored out of my skull. I am
finding the kernel part much more simpler to do, and have put
it into something called libfutex. I shall work on this more,
later on in the week.
Btw, what did you think about adding a lib/ under sys/ ?
Regards,
--
Hiten Pandya
hmp at xxxxxxxxxxxxx
More information about the Kernel
mailing list