Re: [linux-usb-devel] ehci calling put_device from irq handler

From: David Brownell
Date: Wed Jan 18 2006 - 17:19:12 EST


On Wednesday 18 January 2006 1:54 pm, Alan Stern wrote:
> On Wed, 18 Jan 2006, Greg KH wrote:
>
> > We can not call put_device() from irq context :(
> >
> > I added a "might_sleep()" to the driver core and get the following from
> > the ehci driver. Any thoughts?
>
> In principle the put_device and corresponding get_device calls aren't
> needed. We don't release a usb_device structure until after disabling all
> its endpoints, and disabling an endpoint will wait until all the URBs for
> that endpoint have completed. So there's no reason to keep a reference to
> the device structure for each URB.
>
> I see that uhci-hcd is guilty of the same thing (reference acquired for
> each QH, released while holding a spinlock). Probably each of the
> host controller drivers is.

I think it dated from the days before we had any mechanism for
disabling endpoints properly, and was (important!) insurance
against the inevitable "driver disconnect() didn't work right"
class of bugs.

So it should be safe to remove those calls now.

- Dave
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/