Would be technically possible that the function uas_use_uas_driver
checks if the uas driver is loaded (not just configured) before
telling the usb-storage to leave the device to the uas module?
Bye

2018-03-22 16:16 GMT+01:00 Alan Stern <st...@rowland.harvard.edu>:
> On Wed, 21 Mar 2018, Menion wrote:
>
>> Well, still, my two cents here, is it really that if you have UAS in a
>> module and you don't load it but connect an UAS capable device, this
>> device is not enumerated rather than downgraded to usb-storage?
>
> Let's be precise.  The device _is_ enumerated, because the kernel can't
> tell what driver is appropriate without first reading the device's
> descriptors, which happens during enumeration.  Once the enumeration is
> over, the kernel tries to bind the device to an appropriate driver; if
> the binding fails then the device won't be used.
>
> If a device is UAS-capable and the kernel was built with UAS support,
> then the appropriate driver is uas.  In fact, there is a special check
> inside usb-storage for precisely this situation:
>
>         /* If uas is enabled and this device can do uas then ignore it. */
> #if IS_ENABLED(CONFIG_USB_UAS)
>         if (uas_use_uas_driver(intf, id, NULL))
>                 return -ENXIO;
> #endif
>
> There are some special cases embedded in the uas_use_uas_driver()
> routine.  For instance, if the US_FL_IGNORE_UAS quirk flag is set then
> uas_use_uas_driver() will return 0, and then usb-storage will bind to
> the device.
>
> But assuming none of the special cases apply, if the uas driver was
> built as a module and the module can't be loaded then the binding to
> uas will fail.  As a result, the device will not be used.
>
> Alan Stern
>
--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to