[U-Boot] dfu: some wrong usb_qualifier_descriptor settings?
Lukasz Majewski
l.majewski at samsung.com
Fri Aug 22 14:11:09 CEST 2014
Hi Heiko,
> Hello Lukasz,
>
> In the dfu spez [1] chapter 4.2.1 the following fields are specified:
>
> bDeviceClass = 00h (Description: „see interface“), currently set in
> U-Boot to 2.
>
> bDeviceSubClass = 00h (Description: „see interface“), currently set in
> U-Boot to 2.
>
> bcdUSB = xxxxh (Description: USB specification release number in
> binary coded decimal -> 0110h) Currently set to 0x200
>
> If I look in ./drivers/usb/gadget/f_dfu.c:
>
> static const struct usb_qualifier_descriptor dev_qualifier = {
> .bLength = sizeof dev_qualifier,
> .bDescriptorType = USB_DT_DEVICE_QUALIFIER,
> .bcdUSB = __constant_cpu_to_le16(0x0200),
> .bDeviceClass = USB_CLASS_VENDOR_SPEC,
> .bNumConfigurations = 1,
> };
>
> bDeviceClass = USB_CLASS_VENDOR_SPEC = 0xff ?
>
> Hmm... why states the doc this should be set to 0 =
> USB_CLASS_PER_INTERFACE? 2 is USB_CLASS_COMM ... which seems more
> appropriate ...
The bDeviceClass seems to be set to wrong value. I think that it should
have values as they are specified by the standard.
>
> bDeviceSubClass is not defined ...
> bcdUSB = 0x0200 which should be 0x0110 ... oh, as [1] is the dfu 1.1
> specification it should be 0x0110 but the spec [1] says 0100 ... is
> the spec here buggy? is there a dfu 2.0 specification availiable?
The 2.0 value is a reminiscent of the original DFU code (once prepared
for Linux) and was wrongly set to indicate USB 2.0.
I think that we should have 0x0110, which indicates supported DFU
version 1.1.
>
> Has this differences to the spec some reason? Or can we change them
> to the values specified in the spec?
I think that values which you have pointed out are wrong and should be
changed to the one from spec.
>
> Thanks!
>
> bye,
> Heiko
>
> [1]: http://www.usb.org/developers/devclass_docs/DFU_1.1.pdf
--
Best regards,
Lukasz Majewski
Samsung R&D Institute Poland (SRPOL) | Linux Platform Group
More information about the U-Boot
mailing list