Bernard van Gastel wrote:
But the descheduling of threads if the mutex is not available is done by the 
library. And especially the order of rescheduling of the threads (thats what 
I'm interested in). Or am I missing something in the sys/kern/sched files (btw 
I don't have the umtx file).

Regards,
        Bernard
The libthr mutex wait-queue is FIFO in kernel, however, the decision whether a thread should be preempted or not is made by scheduler, when mutex owner unlocks the mutex, it just wakes up a waiter thread from head of the queue, if the thread has been blocked for enough long time, kernel scheduler may decide to raises its priority, and if the mutex owner has spent too much cpu time, the scheduler may
decides to low its priority, so when the mutex owner unlocks the mutex,
preemption may happen if the waiter has higher priority, and the waiter thread
can lock the mutex, otherwise the waiter still has to wait for some time to
gain higher thread priority. It looks like round-robin fashion, and the round-robin
quantum is made by kernel scheduler. In theory, this has best performance,
and directly hand-off seems hurt performance drastically.

_______________________________________________
freebsd-hackers@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/freebsd-hackers
To unsubscribe, send any mail to "freebsd-hackers-unsubscr...@freebsd.org"

Reply via email to