On Wed, 20 Apr 2005 11:28:39 -0700, Greg KH <[EMAIL PROTECTED]> wrote:
> On Wed, Apr 20, 2005 at 08:26:29PM +0200, Oliver Neukum wrote:
> >     /* shutdown our bulk reads and writes */
> >     spin_lock_irqsave(&info->lock, flags);
> >     list_for_each_safe(tmp, tmp2, &info->rx_urbs_submitted) {
> >             wrap = list_entry(tmp, struct whiteheat_urb_wrap, list);
> >             urb = wrap->urb;
> >             usb_kill_urb(urb);
> >             list_del(tmp);
> >             list_add(tmp, &info->rx_urbs_free);
> >     }
> > 
> > This, from whiteheat.c, is wrong. Usb_kill_urb() with a spinlock
> > held is illegal.
> 
> This driver is marked BROKEN on SMP, as it does lots of bad things while
> holding spinlocks :(
> 
> Anyone wanting to fix this all up?

This is probably something for Stuart to check out (on bcc: - I suspect he
may be afraid of spam). I meant to, but never have a moment (how typical).

-- Pete


-------------------------------------------------------
This SF.Net email is sponsored by Oracle Space Sweepstakes
Want to be the first software developer in space?
Enter now for the Oracle Space Sweepstakes!
http://ads.osdn.com/?ad_id=7393&alloc_id=16281&op=click
_______________________________________________
[email protected]
To unsubscribe, use the last form field at:
https://lists.sourceforge.net/lists/listinfo/linux-usb-devel

Reply via email to