Date: Sat, 26 Apr 2003 11:33:18 -0700 From: Terry Lambert <tlambert2@mindspring.com> To: David Xu <davidxu@viatech.com.cn> Cc: freebsd-threads@freebsd.org Subject: Re: SMPing libpthread Message-ID: <3EAAD0EE.49EDA0D@mindspring.com> References: <Pine.GSO.4.10.10304260043470.25254-100000@pcnet1.pcnet.com> <004001c30bef$648ff0b0$0701a8c0@tiger>
next in thread | previous in thread | raw e-mail | index | archive | help
David Xu wrote: > From: "Daniel Eischen" <eischen@pcnet1.pcnet.com> > > David, I noticed that we hold the scheduling lock before and > > after calling the scheduler. Is this necessary? And if so, > > is it necessary to hold hold it after return from the > > scheduling switch? One you're in the scheduler, and choose > > another thread (releasing the lock after doing so), shouldn't > > you be able to switch to it without having the lock? > > I am trying to do things in atomic way. because I found on SMP, thread > state is always out of synchronized in current code. I want to make > state change and context switch in an atomic operation, when thread is > in state transit, no other threads can use _thr_setrunnable_unlocked() etc > to change its state, this avoids lots of "thread already in priority queue" > messages, and if I test the "in priority queue" flag every where, I sometimes > lose chance to wakeup a thread because of some unknown races, whole > process just suddenly stops there. I am just copying the idea from > current kernel code, I don't intend to inventing new things. :-) Note that I think you want idempotence, not atomicity, in this case, anyway. Jeff and Julian should comment; but my gut feeling is that you should be passing a function to the scheduler for it to call on your behalf, while it holds any locks it feels are necessary. This is probably an interface layering violation for the scheduler API. I can't help feeling, though, that this should be seperated out. I don't know how to deal with the idempotence issues "correctly", and still maintain a seperation between threads implementation and scheduler implementation off the top of my head (at least, without changing the scheduler API), but I'm sure it's doable, with a little thought. -- Terry
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?3EAAD0EE.49EDA0D>
