[PATCH] libertas: fix spinlock recursion bug

Dan Williams dcbw at redhat.com
Thu Mar 27 10:31:54 EDT 2008


On Thu, 2008-03-27 at 12:57 +0100, Holger Schurig wrote:
> > The problem with using upld_buf (and therefore zero-copy in
> > the CF driver) is that you have no idea how long a read from
> > the card will really take, and what errors might happen during
> > the read from the card.
> 
> Yes, this can take a long time. And, BTW, I don't want to use 
> upld_buf.
> 
> 
> My idea is this:
> 
> > > struct lbs_event *lbs_get_free_event(struct lbs_private
> > > *priv);
> 
> This will take out an lbs_event from the event_free_list and 
> return it.
> Taking out has to be done under spinlock, but this is very fast.
> 
> Once the lbs_event is no longer in any of the two event list, 
> we "own" it and can handle it as long as we want, without the 
> need of an additional spinlock.
> 
> Then
> 
> > > void lbs_handle_event(struct lbs_private *priv, struct
> > > lbs_event *event);
> 
> would again take the spinlock, insert the event in the 
> event_list, and release the spinlock. Which again takes only a 
> short time.

well, if this is being done in lbs_thread() then the call from
lbs_get_free_event() is going to be right above lbs_handle_event()
anyway, so you might as well hold the spinlock over both, right?  I'm
just basing that assumption off the existing structure of lbs_thread(),
maybe you've re-ordered it a lot or something.

But it sounds OK.

Dan

> This approach can make receiption of command responses from card 
> zero-copy like, at least insofar the event processing is 
> considered. 
> 
> 
> 
> > I'd argue that the CF driver should also have an internal
> > buffer like the SDIO and USB drivers do, and then there's still
> > only one copy.
> 
> Yeah, but I can reduce easily to a 0-copy-scheme.
> 
> 
> I hope all of this sounds sane.
> 




More information about the libertas-dev mailing list