On Tue, Jun 09, 2015 at 09:27:51PM +0800, Roger Quadros wrote:
> On Mon, 8 Jun 2015 23:02:04 +0800
> Li Jun <[email protected]> wrote:
>
> > Allocate usb_otg_descriptor and initialize it according to gadget otg
> > options, if none of options is not set, keep bmAttributes setting as
> > current gadget drivers, with this new interface, usb_otg_descriptor can
> > include bcdOTG if OTG 2.0 or later, and otg features can be decided by
> > the combination of usb hardware property and driver config.
> >
> > Signed-off-by: Li Jun <[email protected]>
> > ---
> > drivers/usb/gadget/config.c | 37 +++++++++++++++++++++++++++++++++++++
> > include/linux/usb/gadget.h | 1 +
> > 2 files changed, 38 insertions(+)
> >
> > diff --git a/drivers/usb/gadget/config.c b/drivers/usb/gadget/config.c
> > index 34e12fc..a86e079 100644
> > --- a/drivers/usb/gadget/config.c
> > +++ b/drivers/usb/gadget/config.c
> > @@ -195,3 +195,40 @@ void usb_free_all_descriptors(struct usb_function *f)
> > usb_free_descriptors(f->ss_descriptors);
> > }
> > EXPORT_SYMBOL_GPL(usb_free_all_descriptors);
> > +
> > +struct usb_otg_descriptor *usb_otg_descriptor_add(struct usb_gadget
> > *gadget)
> > +{
> > + struct usb_otg_descriptor *otg_desc;
> > + unsigned otg_desc_length;
> > +
> > + if (gadget->otg_rev >= 0x0200)
> > + otg_desc_length = sizeof(*otg_desc) + sizeof(struct bcdOTG);
> > + else
> > + otg_desc_length = sizeof(*otg_desc);
> > +
> > + otg_desc = (struct usb_otg_descriptor *)kzalloc(otg_desc_length,
> > + GFP_KERNEL);
>
> You are allocating memory here and expecting users will free it.
> I suggest that you pass pointer to otg_desc as function argument and leave it
> upto
> the caller to allocate/deallocate memory for it.
Agreed, I will update accordingly.
>
> Most likely users will be a static allocation like they do now and it is a
> lot simpler.
>
I need allocate different size memory at runtime, that static
allocation should be changed, I will try Alan's suggestion with
2 different structures to make it simpler.
> > + if (!otg_desc)
> > + return otg_desc;
> > +
> > + otg_desc->bLength = otg_desc_length;
> > + otg_desc->bDescriptorType = USB_DT_OTG;
> > +
> > + if (gadget->adp_support || gadget->hnp_support ||
> > + gadget->srp_support) {
> > + if (gadget->adp_support)
> > + otg_desc->bmAttributes |= USB_OTG_ADP;
> > + if (gadget->hnp_support)
> > + otg_desc->bmAttributes |= USB_OTG_HNP;
> > + if (gadget->srp_support)
> > + otg_desc->bmAttributes |= USB_OTG_SRP;
> > + } else {
> > + otg_desc->bmAttributes = USB_OTG_SRP | USB_OTG_HNP;
> > + }
> > +
> > + if (gadget->otg_rev >= 0x0200)
> > + otg_desc->otg_rev[0].bcdOTG = cpu_to_le16(gadget->otg_rev);
> > +
> > + return otg_desc;
> > +}
> > +EXPORT_SYMBOL_GPL(usb_otg_descriptor_add);
> > diff --git a/include/linux/usb/gadget.h b/include/linux/usb/gadget.h
> > index 2f4f39c..e210466 100644
> > --- a/include/linux/usb/gadget.h
> > +++ b/include/linux/usb/gadget.h
> > @@ -1013,6 +1013,7 @@ int usb_assign_descriptors(struct usb_function *f,
> > struct usb_descriptor_header **ss);
> > void usb_free_all_descriptors(struct usb_function *f);
> >
> > +struct usb_otg_descriptor *usb_otg_descriptor_add(struct usb_gadget
> > *gadget);
> >
> > /*-------------------------------------------------------------------------*/
> >
> > /* utility to simplify map/unmap of usb_requests to/from DMA */
>
> cheers,
> -roger
--
To unsubscribe from this list: send the line "unsubscribe devicetree" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html