Special schedulers, one CPU only kernel, one only userland
Brooks Davis
brooks at one-eyed-alien.net
Thu Aug 18 19:06:26 GMT 2005
On Thu, Aug 18, 2005 at 01:12:20PM -0400, John Baldwin wrote:
> On Thursday 18 August 2005 12:55 pm, Luigi Rizzo wrote:
> > On Thu, Aug 18, 2005 at 10:23:04AM -0400, John Baldwin wrote:
> > ...
> >
> > > > However I am still unclear on what happens if a detach() is racing with
> > > > the output path (leading to fxp_start()).
> > >
> > > Note that we first down the interface via fxp_stop() and then we unhook
> > > it from the network stack using ether_ifdetach(). Once we've done
> > > ether_ifdetach() the network stack can't get to the fxp device anymore.
> >
> > It might have gotten there before, then this sequence might occur:
> >
> > thread 'fxp_detach' thread 'fxp_start'
> >
> > acquire fxp lock wait for lock (goes to sleep maybe ?)
> > fxp_stop
> > release fxp lock
> > destroy everything
> > including the lock
> > resume, mtx_lock -> boom
> >
> > hmmm... it's really tricky to follow. Maybe this does not happen,
> > but i wouldn't know why as fxp_detach() is under giant but the
> > path leading to fxp_start is not...
>
> ether_ifdetach() should be handling this for us I think by blocking until any
> known top-half threads are out of the driver. It may not be doing that yet,
> but I think that is where it should happen similar to how we use
> bus_teardown_intr() and callout_drain() in detach to block until other
> threads are out of our driver if necessary.
Certainly we need assurance that nothing is going to try and touch
the driver before the driver's detach function calls if_free. After
if_free returns, no aspect of the driver should touch the ifnet. Other
parts of the networking system might still have refrence to it should we
end up with a refcouting scheme where the final free of ifnets comes
some time later. All refrences to the softc need to be pruged prior to
exit from the detach routine.
-- Brooks
--
Any statement of the form "X is the one, true Y" is FALSE.
PGP fingerprint 655D 519C 26A7 82E7 2529 9BF0 5D8E 8BE9 F238 1AD4
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 189 bytes
Desc: not available
Url : http://lists.freebsd.org/pipermail/freebsd-arch/attachments/20050818/8fbfdc8f/attachment.bin
More information about the freebsd-arch
mailing list