[ldv-project] [PATCH] usb/core/devio.c: Don't use GFP_KERNEL while we cannot reset a storage device
Ming Lei
tom.leiming at gmail.com
Mon Mar 11 20:34:44 MSK 2013
On Tue, Mar 12, 2013 at 12:08 AM, Alan Stern <stern at rowland.harvard.edu> wrote:
> On Mon, 11 Mar 2013, Ming Lei wrote:
>
>> On Mon, Mar 11, 2013 at 11:32 PM, Alan Stern <stern at rowland.harvard.edu> wrote:
>> >
>> > Of course you have to lock the device before changing its driver. What
>> > would happen if two different threads tried to change a device's driver
>> > at the same time?
>>
>> Yes, claim/release interface need device lock, but the patch doesn't
>> touch claim/release command handling.
>
> Then why did you ask? You wrote: "Looks device lock isn't required for
> USB transfer of kernel driver."
Maybe I didn't expressed clearly, sorry. Here the USB transfer means
URBs submitting.
>
>
>> > usbdev_do_ioctl() needs to acquire the device lock in order to prevent
>> > races with driver_disconnect() and usbdev_remove().
>>
>> Looks the patch basically converts the allocation inside URB submit path,
>> and actually I mean why we need to hold device lock in submitting
>> URB path? Device lock isn't required before submitting URBs
>> in kernel driver.
>
> In general it isn't, no. But usbfs uses the lock to prevent races with
> driver_disconnect() -- it is invalid to submit URBs after the
> disconnect routine has returned.
If so, we may introduce another lock to avoid the race.
So I think we may figure out to decrease the device lock
scope in devio.c, and most of ioctl commands might not require it
at all, then the problem addressed by the patch can be fixed too.
Thanks,
--
Ming Lei
More information about the ldv-project
mailing list