[U-Boot] [PATCH] usb: ci_udc: fix interaction with CONFIG_USB_ETH_CDC

Jörg Krause jkrause at posteo.de
Fri Jun 27 23:37:22 CEST 2014


I added the last series of patches beginning from 2014-06-10 for testing 
purposes. The patches from 2014-05-29 were already applied.

First series of patches:

    Applying: usb: ci_udc: call udc_disconnect() from ci_pullup()
    Applying: usb: ci_udc: fix freeing of ep0 req
    Applying: usb: ci_udc: fix probe error cleanup
    Applying: usb: ci_udc: clean up all allocations in unregister

Calling tftp the first time after a reset runs fine, but calling it a 
second time ends always in a crash. I have to reset the device.

Next patch:

    Applying: usb: ci_udc: terminate ep0 INs with a zlp when required

Did not help.

Next patch:

    Applying: usb: ci_udc: fix interaction with CONFIG_USB_ETH_CDC

This helps! U-Boot does not crash anymore. But there is still a problem: 
I have to wait some seconds before I can run a second time tftp. This is 
the output from U-Boot:

    => run update_rootfs
    Updating rootfs ...
    using ci_udc, OUT ep- IN ep- STATUS ep-
    high speed config #1: 2 mA, Ethernet Gadget, using CDC Ethernet
    USB network up!
    Using usb_ether device
    [snip]

    => run update_rootfs
    Updating rootfs ...
    using ci_udc, OUT ep- IN ep- STATUS ep-
    high speed config #1: 2 mA, Ethernet Gadget, using CDC Ethernet
    ERROR: The remote end did not respond in time.
    at drivers/usb/gadget/ether.c:2388/usb_eth_init()

Wait some seconds ...

    => run update_rootfs
    Updating rootfs ...
    using ci_udc, OUT ep- IN ep- STATUS ep-
    high speed config #1: 2 mA, Ethernet Gadget, using CDC Ethernet
    USB network up!
    Using usb_ether device
    [snip]

Best regards
Jörg Krause

On 06/25/2014 06:06 PM, Stephen Warren wrote:
> On 06/25/2014 07:51 AM, Marek Vasut wrote:
>> On Monday, June 23, 2014 at 08:02:48 PM, Stephen Warren wrote:
>>
>> +CC Jorg, rest of email is intact. Jorg, does this patch fix your issue?
> Jorg's issue was timeouts during transfers, whereas this patch addresses
> cleanup issues once the device isn't being used any more. I can't
> imagine how this patch could influence the issue Jorg is seeing.
>
>>> From: Stephen Warren <swarren at nvidia.com>
>>>
>>> ci_udc.c's usb_gadget_unregister_driver() doesn't call driver->unbind()
>>> unlike other USB gadget drivers. Fix it to do this.
>>>
>>> Without this, when ether.c's CDC Ethernet device is torn down,
>>> eth_unbind() is never called, so dev->gadget is never set to NULL.
>>> For some reason, usb_eth_halt() is called both at the end of the first
>>> use of the Ethernet device, and prior to any subsequent use. Since
>>> dev->gadget is never cleared, all calls to usb_eth_halt() attempt to
>>> stop, disconnect, and clean up the device, resulting in double cleanup,
>>> which hangs U-Boot on my Tegra device at least.
>>>
>>> ci_udc allocates its own singleton EP0 request object, and cleans it up
>>> during usb_gadget_unregister_driver(). This appears necessary when using
>>> the USB gadget framework in U-Boot, since that does not allocate/free
>>> the EP0 request. However, the CDC Ethernet driver *does* allocate and
>>> free its own EP0 requests. Consequently, we must protect
>>> ci_ep_free_request() against double-freeing the request.



More information about the U-Boot mailing list