yield() in kernel CAN'T yield control for MOD_LOAD thread
John Baldwin
jhb at FreeBSD.org
Mon Aug 30 13:58:27 PDT 2004
On Thursday 26 August 2004 02:36 am, yangshazhou at hotmail.com wrote:
> Now "tsleep(&ident,PRIBIO,NULL,1)" solved the problem. Maybe yield() can't
> do the job in kernel. And mi_switch() is not enough to.Thank you.On
yield() can just switch back to you immediately since you (the current thread)
are still runnable. Use a sleep, either via sleep/wakeup, or doing a tsleep
with a timeout forces the current thread to not be runnable for a while
giving the other thread time to run. Note that your tsleep(..., 1) is still
racey, you really need to use sleep/wakeup to truly close the race.
> Wednesday 25 August 2004 03:06 am, yangshazhou at hotmail.com wrote:
> > Hi all,
> > This problem delay me for quite a long time.
> > I've built two klds, I'd like to see the result one's running to the
> > other's. In one kld's MOD_LOAD subroutine, I make a long 'for' loop, in
> > which it DELAY(1000) and then call yield(curthread,NULL). When the module
> > was loaded by kldload, the system failed to response until the loop quit.
> > The loop seems like that:
> > for(i=0;i<8000;i++){
> > ......
> > DELAY(1000);
> > yield(curthread,NULL);
> > }
> >
> > My system is 5.2.1-release. Thanks.
>
> You could try having the first one wait on a condition variable that the
> second module's MOD_LOAD does a wakeup on.
--
John Baldwin <jhb at FreeBSD.org> <>< http://www.FreeBSD.org/~jhb/
"Power Users Use the Power to Serve" = http://www.FreeBSD.org
More information about the freebsd-hackers
mailing list