converting IMX6 board to DM_ETH and DM_USB - usb_ether gadget support

Tim Harvey tharvey at gateworks.com
Fri Jan 28 01:20:12 CET 2022


On Fri, Jan 14, 2022 at 6:55 AM Heiko Schocher <hs at denx.de> wrote:
>
> Hello Tim,
>
> On 25.02.21 02:21, Tim Harvey wrote:
> > Greetings,
> >
> > I'm trying to convert the gwventana board support to DM_ETH and DM_USB
> > and one item I have not resolved yet is USB Ethernet gadget support.
> >
> > For non-dm a call to 'usb_eth_initialize' creates a usb_ether gadget
> > that can be used for ethernet communication between the IMX6 OTG
> > controller in device mode to a USB host. How is that accomplished via
> > dm?
> >
> > I find that drivers/usb/gadget/ether.c has dm support but it would
> > appear that a controller of UCLASS_USB_GADGET_GENERIC must bind for it
> > to work yet I don't see how this works with CI_UDC.
> >
> > Other IMX6 boards that have gone through dm conversion have simply
> > dropped the call to usb_eth_initialize and I don't see what else they
> > enable that provides this functionality.
> >
> > Any ideas?
>
> Late ... but I stumbled just over the same problem... do you have solved
> it?
>
> I just tried this on an imx6ull based board and get it not fully working,
> but usb ethernet with DM_ETH enabled at least starts for me...
>
>
> => setenv ethact usb_ether
> => setenv ipaddr 192.168.7.2
>
> The magic call for me is:
>
> => bind usb 0 usb_ether
>
>
> After this I see in "dm tree" output:
>
>  simple_bus    5  [ + ]   simple_bus            |   |-- aips-bus at 2100000
>  usb           0  [   ]   ehci_mx6              |   |   |-- usb at 2184000
>  eth           1  [   ]   usb_ether             |   |   |   `-- usb_ether
>
> And issuing a ping starts usb_ether with (some DBG are enabled)
>
> => ping 192.168.71.
> using ci_udc, OUT ep2out-bulk IN ep1in-bulk STATUS ep3in-int
> MAC 8e:79:6a:94:5f:09
> HOST MAC 5a:d1:77:da:0e:7a
> RNDIS ready
> -- suspend --
> -- reset --
> -- portchange 2 High
> handle setup GET_DESCRIPTOR, 80, 6 index 0 value 100 length 40
> handle_setup: Set ep0 to IN for Data Stage
> [...]
> -- reset --
> -- portchange 2 High
> [...]
> ci_ep_enable: from 512 to 16
> ci_ep_enable: num=3 maxpacket=16
> ci_ep_enable: num=1 maxpacket=512
> ci_ep_enable: num=2 maxpacket=512
> high speed config #2: 2 mA, Ethernet Gadget, using RNDIS
> [...]
>
> [remark] until here same log as for the case with DM_ETH not enabled
>
> [...]
> ept0 out req 9bf78be0, complete 0
> handle setup GET_STATUS, 21, 0 index 0 value 0 length 18
> handle_setup: Set ep0 to OUT for Data Stage
> ept0 out pre-queue req 9bf78be0, buffer 9bf91e80
> ept0 out queue len 18, req 9bf78be0, buffer 9bf91e80
> handle_setup: end status: 0
> ept0 out req 9bf78be0, complete 0
>
>
> And than the board makes a reset (no crash dump)
>
> on the other side I see:
>
> [2114399.914244] usb 1-1.3.1.2: new high-speed USB device number 46 using dwc_otg
> [2114400.311239] usb 1-1.3.1.2: config 1 has 0 interfaces, different from the descriptor's value: 1
> [2114400.436155] usb 1-1.3.1.2: New USB device found, idVendor=0525, idProduct=a4a5, bcdDevice= 3.21
> [2114400.436175] usb 1-1.3.1.2: New USB device strings: Mfr=1, Product=2, SerialNumber=0
> [2114400.436190] usb 1-1.3.1.2: Product: RNDIS/Ethernet Gadget
> [2114400.436204] usb 1-1.3.1.2: Manufacturer: U-Boot
> [2114400.569248] usb-storage 1-1.3.1.2:2.0: USB Mass Storage device detected
> [2114400.569721] usb-storage 1-1.3.1.2:2.0: Quirks match for vid 0525 pid a4a5: 10000
> [2114400.597702] rndis_host 1-1.3.1.2:2.0: RNDIS init failed, -71
> [2114400.597799] rndis_host: probe of 1-1.3.1.2:2.0 failed with error -71
> [2114400.598336] rndis_wlan 1-1.3.1.2:2.0: RNDIS init failed, -71
> [2114400.598591] rndis_wlan: probe of 1-1.3.1.2:2.0 failed with error -71
> [2114400.599839] usb-storage 1-1.3.1.2:2.1: USB Mass Storage device detected
> [2114400.600254] usb-storage 1-1.3.1.2:2.1: Quirks match for vid 0525 pid a4a5: 10000
> [2114400.656387] usb 1-1.3.1.2: USB disconnect, device number 46
>
> If I disable DM_ETH... usb_ether works fine on the board ...
>
> Any ideas?
>

Heiko,

Sorry for the late reply - I've been out of the office and unable to
test. I don't know if/how I got around this issue but would love to
compare notes.

On a gwventana IMX6 board with emmc and a USB OTG connector
USB_MASS_STORAGE gadget works via 'ums 0 mmc 0'.

I'm not familiar with the bind method you are using but reading about
it in doc/develop/driver-model/bind.rst it seems like a nice generic
way to bind to various USB gadget devices. What configs do you need
enabled for the usb_ether class and did you end up getting this to
work? What other gadgets are available like this?

Best Regards,

Tim


More information about the U-Boot mailing list