On Fri, Nov 20, 2015 at 09:54:10AM +0100, Marek Szyprowski wrote: > From: Ruslan Bilovol <ruslan.bilovol@xxxxxxxxx> > > Now when udc-core supports binding to specific UDC by passing > its name via 'udc_name' member of usb_gadget_driver struct, > switch to this generic approach. > > Tested-by: Maxime Ripard <maxime.ripard@xxxxxxxxxxxxxxxxxx> > Signed-off-by: Ruslan Bilovol <ruslan.bilovol@xxxxxxxxx> > Signed-off-by: Marek Szyprowski <m.szyprowski@xxxxxxxxxxx> > --- > drivers/usb/gadget/configfs.c | 27 ++++++++++++++------------- > 1 file changed, 14 insertions(+), 13 deletions(-) > > diff --git a/drivers/usb/gadget/configfs.c b/drivers/usb/gadget/configfs.c > index 163d305..0bc6865 100644 > --- a/drivers/usb/gadget/configfs.c > +++ b/drivers/usb/gadget/configfs.c > @@ -56,7 +56,6 @@ struct gadget_info { > struct list_head string_list; > struct list_head available_func; > > - const char *udc_name; > struct usb_composite_driver composite; > struct usb_composite_dev cdev; > bool use_os_desc; > @@ -233,21 +232,21 @@ static ssize_t gadget_dev_desc_bcdUSB_store(struct config_item *item, > > static ssize_t gadget_dev_desc_UDC_show(struct config_item *item, char *page) > { > - return sprintf(page, "%s\n", to_gadget_info(item)->udc_name ?: ""); > + return sprintf(page, "%s\n", to_gadget_info(item)->composite.gadget_driver.udc_name ?: ""); > } > > static int unregister_gadget(struct gadget_info *gi) > { > int ret; > > - if (!gi->udc_name) > + if (!gi->composite.gadget_driver.udc_name) > return -ENODEV; > > ret = usb_gadget_unregister_driver(&gi->composite.gadget_driver); > if (ret) > return ret; > - kfree(gi->udc_name); > - gi->udc_name = NULL; > + kfree(gi->composite.gadget_driver.udc_name); > + gi->composite.gadget_driver.udc_name = NULL; > return 0; > } > > @@ -271,14 +270,16 @@ static ssize_t gadget_dev_desc_UDC_store(struct config_item *item, > if (ret) > goto err; > } else { > - if (gi->udc_name) { > + if (gi->composite.gadget_driver.udc_name) { > ret = -EBUSY; > goto err; > } > - ret = usb_udc_attach_driver(name, &gi->composite.gadget_driver); > - if (ret) > + gi->composite.gadget_driver.udc_name = name; > + ret = usb_gadget_probe_driver(&gi->composite.gadget_driver); > + if (ret) { > + gi->composite.gadget_driver.udc_name = NULL; > goto err; > - gi->udc_name = name; > + } > } > mutex_unlock(&gi->lock); > return len; > @@ -427,9 +428,9 @@ static int config_usb_cfg_unlink( > * remove the function. > */ > mutex_lock(&gi->lock); > - if (gi->udc_name) > + if (gi->composite.gadget_driver.udc_name) > unregister_gadget(gi); > - WARN_ON(gi->udc_name); > + WARN_ON(gi->composite.gadget_driver.udc_name); > > list_for_each_entry(f, &cfg->func_list, list) { > if (f->fi == fi) { > @@ -873,10 +874,10 @@ static int os_desc_unlink(struct config_item *os_desc_ci, > struct usb_composite_dev *cdev = &gi->cdev; > > mutex_lock(&gi->lock); > - if (gi->udc_name) > + if (gi->composite.gadget_driver.udc_name) > unregister_gadget(gi); > cdev->os_desc_config = NULL; > - WARN_ON(gi->udc_name); > + WARN_ON(gi->composite.gadget_driver.udc_name); > mutex_unlock(&gi->lock); > return 0; > } > -- Applying: usb: gadget: configfs: pass UDC name via usb_gadget_driver struct WARNING: line over 80 characters #18: FILE: drivers/usb/gadget/configfs.c:235: + return sprintf(page, "%s\n", to_gadget_info(item)->composite.gadget_driver.udc_name ?: ""); -- Best Regards, Peter Chen -- To unsubscribe from this list: send the line "unsubscribe linux-usb" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html