Re: [linux-usb] USB Gadget drivers Windows 7/8 support and .bAlternateSetting in interface descriptor

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Community,

I finally fix the UAC1 on Windows 7 host issue. Thanks for your help. I will submit patches after more testing.


On 08/22/2014 10:43 AM, Xuebing Wang wrote:

On 08/21/2014 04:24 PM, Sebastian Andrzej Siewior wrote:
On 08/20/2014 02:13 AM, Peter Chen wrote:
Thanks, so Xunbing, the imx6 hardware (chipidea core) have 8 endpoints,
and support all four transfer type, it should be no problem to support
RNDIS.
But you shouldn't use RNDIS on Windows 7 or 8. As far as I recall they
do not bring the RNDIS driver which is deprecated and only "supported"
by Windows XP which is EOL by now.

Windows 7 and 8 support CDC [0] and this is what you should look for.

[0]
http://msdn.microsoft.com/en-us/library/windows/hardware/ff538820%28v=vs.85%29.aspx

Sebastian


Sebastian, Peter, Andrzej,

Thank you for your help.

1) Are you aware of any devices (based on Freescale i.MX or ChipIdea USB IP) with a gadget driver which uses .bAlternateSetting that support Windows 7/8?

2) The reason I am asking this is that USB 1.1 Spec (section 9.2.6.4 Standard Device Requests) says: For standard device requests that require no Data stage, a device *must* be able to complete the request and be able to successfully complete the Status stage of the request *within 50 ms* of receipt of the request. This limitation applies to requests to the device, interface, or endpoint.

I am debugging this Windows support for UAC1, thus I am referring to USB 1.1 spec.

3) For any gadget which uses .bAlternateSetting, Host will send USB_REQ_SET_INTERFACE Standard Device Request which requires no Data State. I am not sure if Windows drivers strictly adhere to USB spec, thus strictly require device to respond to USB_REQ_SET_INTERFACE within 50ms???

4) In gadget driver set_alt functions (to handle USB_REQ_SET_INTERFACE), ep_enable/ep_disable will be called, and timing of this differs from hardware platform to platform (and UDC drivers), does this explain why below function exists???

4.1) /**
 * gadget_supports_altsettings - return true if altsettings work
 * @gadget: the gadget in question
 */
static inline bool gadget_supports_altsettings(struct usb_gadget *gadget)
{
        /* PXA 21x/25x/26x has no altsettings at all */
        if (gadget_is_pxa(gadget))
                return false;

        /* PXA 27x and 3xx have *broken* altsetting support */
        if (gadget_is_pxa27x(gadget))
                return false;

        /* Everything else is *presumably* fine ... */
        return true;
}

4.2) /* Some controllers can't support CDC Ethernet (ECM) ... */
static inline bool can_support_ecm(struct usb_gadget *gadget)
{
        if (!gadget_supports_altsettings(gadget))
                return false;

        /* Everything else is *presumably* fine ... but this is a bit
         * chancy, so be **CERTAIN** there are no hardware issues with
         * your controller.  Add it above if it can't handle CDC.
         */
        return true;
}


Thanks again.


--
Thanks,
Xuebing Wang

--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux Media]     [Linux Input]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Old Linux USB Devel Archive]

  Powered by Linux