Re: [PATCH RESEND v7 2/2] usb: gadget: f_fs: virtual endpoint address mapping

From: Felipe Balbi
Date: Tue Sep 09 2014 - 10:43:32 EST


On Tue, Sep 09, 2014 at 08:02:16AM +0200, Robert Baldyga wrote:
> On 09/08/2014 03:47 PM, Felipe Balbi wrote:
> > Hi,
> >
> > On Mon, Sep 08, 2014 at 09:57:00AM +0200, Robert Baldyga wrote:
> >> This patch introduces virtual endpoint address mapping. It separates
> >> function logic form physical endpoint addresses making it more hardware
> >> independent.
> >>
> >> Following modifications changes user space API, so to enable them user
> >> have to switch on the FUNCTIONFS_VIRTUAL_ADDR flag in descriptors.
> >>
> >> Endpoints are now refered using virtual endpoint addresses chosen by
> >> user in endpoint descpriptors. This applies to each context when endpoint
> >> address can be used:
> >> - when accessing endpoint files in FunctionFS filesystemi (in file name),
> >> - in setup requests directed to specific endpoint (in wIndex field),
> >> - in descriptors returned by FUNCTIONFS_ENDPOINT_DESC ioctl.
> >>
> >> In endpoint file names the endpoint address number is formatted as
> >> double-digit hexadecimal value ("ep%02x") which has few advantages -
> >> it is easy to parse, allows to easly recognize endpoint direction basing
> >> on its name (IN endpoint number starts with digit 8, and OUT with 0)
> >> which can be useful for debugging purpose, and it makes easier to introduce
> >> further features allowing to use each endpoint number in both directions
> >> to have more endpoints available for function if hardware supports this
> >> (for example we could have ep01 which is endpoint 1 with OUT direction,
> >> and ep81 which is endpoint 1 with IN direction).
> >>
> >> Physical endpoint address can be still obtained using ioctl named
> >> FUNCTIONFS_ENDPOINT_REVMAP, but now it's not neccesary to handle
> >> USB transactions properly.
> >>
> >> Signed-off-by: Robert Baldyga <r.baldyga@xxxxxxxxxxx>
> >> Acked-by: Michal Nazarewicz <mina86@xxxxxxxxxx>
> >
> > after this patch I get build errors:
> >
> > drivers/usb/gadget/function/f_fs.c: In function âffs_epfiles_createâ:
> > drivers/usb/gadget/function/f_fs.c:1555:40: error: âstruct ffs_dataâ has no member named âeps_addrmapâ
> > sprintf(epfiles->name, "ep%02x", ffs->eps_addrmap[i]);
> > ^
> > drivers/usb/gadget/function/f_fs.c: In function âffs_func_setupâ:
> > drivers/usb/gadget/function/f_fs.c:2900:19: error: âstruct ffs_dataâ has no member named âeps_addrmapâ
> > ret = func->ffs->eps_addrmap[ret];
> > ^
> > make[3]: *** [drivers/usb/gadget/function/f_fs.o] Error 1
> > make[3]: *** Waiting for unfinished jobs....
> > make[2]: *** [drivers/usb/gadget/function] Error 2
> > make[1]: *** [drivers/usb/gadget] Error 2
> > make[1]: *** Waiting for unfinished jobs....
> > make: *** [drivers/usb/] Error 2
> >
>
> Array "eps_addrmap" was introduced in patch "usb: gadget: f_fs: fix the
> redundant ep files problem". I have received mails from you and Greg
> that it's already applied to usb tree, so I have assumed that there is
> no need to include it to this patchset. I can resend this patch if it's
> needed.

No, no, I was didn't have -rc4 merged on my next. Now I do.

--
balbi

Attachment: signature.asc
Description: Digital signature