[U-Boot] [PATCH v3 4/5] usb/gadget: add the fastboot gadget
Lukasz Majewski
l.majewski at samsung.com
Mon Apr 14 08:51:55 CEST 2014
Hi Marek,
> On Friday, April 11, 2014 at 02:55:31 PM, Rob Herring wrote:
> > On Fri, Apr 11, 2014 at 2:14 AM, Bo Shen <voice.shen at atmel.com>
> > wrote:
> > > Hi Rob Herring,
> > >
> > > I am just do a function testing on Atmel sama5d3xek board. And
> > > a small
> > >
> > > comment as following.
> > >
> > > Btw, do you test to transfer big size file. I try a file bigger
> > > than
> > >
> > > 100MiB, it will hang. However use DFU or RNDIS don't meet this
> > > issue.
> >
> > How much RAM do you have? It will happily download into the end of
> > RAM overwriting u-boot if loadsize is not set. DFU at least has its
> > own buffer size configuration.
>
> I really have to wonder ... why does android not use DFU
Unfortunately the DFU has its own limitations. The most notable one is
using only EP0 for transmission. As a result the transmission speed is
slow when compared with other solutions, which are using other EPs.
> instead and
> instead forces us to take in yet another (fourth ? ... CDC ethernet,
> DFU, Thor, Fastboot)
A little explanation:
1. UMS (CDC Ethernet) - export the content of the whole flash. It should
be regarded as a convenient debug option. It is somewhat clumsy
to use dd if=/u-boot.bin of=/dev/sda1 .... to store u-boot.
2. DFU it is the standard - devised at 2004 - rather outdated now. It is
slow but reliable - targeted to uC flashing.
3. Thor, fastboot - protocols devised to provide faster transmission
rates (they use other EPs for transmission).
> usb image download protocol someone invented
> without cooperating with the rest of the community on a common and
> functional solution? Sigh :'-(
I think, that this problem emerged because of the lack of DFU standard
update - adding better checksumming and possibility for using other EPs
would solve the problem.
In u-boot it is not a big problem, since we are using one backend
(dfu_write()) to store data on the medium. Moreover common gadget code
- g_dnl.c is available to reduce code duplication.
To add support for other gadget one needs to implement proper function
(like f_thor.c, f_dfu.c, f_fastboot.c).
>
> Best regards,
> Marek Vasut
--
Best regards,
Lukasz Majewski
Samsung R&D Institute Poland (SRPOL) | Linux Platform Group
More information about the U-Boot
mailing list