Date: Tue, 22 Apr 1997 21:45:31 +0200 From: j@uriah.heep.sax.de (J Wunsch) To: hackers@freebsd.org Subject: Re: concurrent calls to device drivers Message-ID: <19970422214531.BX39690@uriah.heep.sax.de> In-Reply-To: <199704220425.NAA12940@genesis.atrad.adelaide.edu.au>; from Michael Smith on Apr 22, 1997 13:55:07 %2B0930 References: <199704210727.JAA15119@labinfo.iet.unipi.it> <199704220425.NAA12940@genesis.atrad.adelaide.edu.au>
next in thread | previous in thread | raw e-mail | index | archive | help
As Michael Smith wrote: > That's ususally the best way to go; something like : > > > sc_busy; > > ... > > fooread(...) > { > ... > > s = splfoo(); > while(sc->sc_busy) { What's the splfoo() for? Unless the interrupt service can modify sc_busy, you don't need to protect it. You gotta do a obtain_mp_lock(); while(sc->sc_busy) { ... } release_mp_lock(); however. :-) On a uniprocessor however, only one process can be in the kernel at a time. -- cheers, J"org joerg_wunsch@uriah.heep.sax.de -- http://www.sax.de/~joerg/ -- NIC: JW11-RIPE Never trust an operating system you don't have sources for. ;-)
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?19970422214531.BX39690>