From: "Du, Changbin" <changbin...@gmail.com>

On most platforms, there is only one device controller available.
In this case, we desn't care the UDC's name. So let's ignore the
name by setting 'UDC' to 'any'. And also we can change UDC name
at any time if it is not binded (no need set to "" first).

Signed-off-by: Du, Changbin <changbin...@gmail.com>
Signed-off-by: Du, Changbin <changbin...@intel.com>
---
 drivers/usb/gadget/configfs.c | 22 ++++++++++++++--------
 1 file changed, 14 insertions(+), 8 deletions(-)

diff --git a/drivers/usb/gadget/configfs.c b/drivers/usb/gadget/configfs.c
index b6f60ca..5da2991 100644
--- a/drivers/usb/gadget/configfs.c
+++ b/drivers/usb/gadget/configfs.c
@@ -230,16 +230,18 @@ 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)
 {
-       char *udc_name = to_gadget_info(item)->composite.gadget_driver.udc_name;
+       struct gadget_info *gi = to_gadget_info(item);
+       char *udc_name = gi->composite.gadget_driver.udc_name;
 
-       return sprintf(page, "%s\n", udc_name ?: "");
+       return sprintf(page, "%s\n", udc_name ?:
+                       (gi->cdev.gadget ? "any" : ""));
 }
 
 static int unregister_gadget(struct gadget_info *gi)
 {
        int ret;
 
-       if (!gi->composite.gadget_driver.udc_name)
+       if (!gi->cdev.gadget)
                return -ENODEV;
 
        ret = usb_gadget_unregister_driver(&gi->composite.gadget_driver);
@@ -270,10 +272,14 @@ static ssize_t gadget_dev_desc_UDC_store(struct 
config_item *item,
                if (ret)
                        goto err;
        } else {
-               if (gi->composite.gadget_driver.udc_name) {
+               if (gi->cdev.gadget) {
                        ret = -EBUSY;
                        goto err;
                }
+               if (!strcmp(name, "any")) {
+                       kfree(name);
+                       name = NULL;
+               }
                gi->composite.gadget_driver.udc_name = name;
                ret = usb_gadget_probe_driver(&gi->composite.gadget_driver);
                if (ret) {
@@ -428,9 +434,9 @@ static int config_usb_cfg_unlink(
         * remove the function.
         */
        mutex_lock(&gi->lock);
-       if (gi->composite.gadget_driver.udc_name)
+       if (gi->cdev.gadget)
                unregister_gadget(gi);
-       WARN_ON(gi->composite.gadget_driver.udc_name);
+       WARN_ON(gi->cdev.gadget);
 
        list_for_each_entry(f, &cfg->func_list, list) {
                if (f->fi == fi) {
@@ -873,10 +879,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->composite.gadget_driver.udc_name)
+       if (gi->cdev.gadget)
                unregister_gadget(gi);
        cdev->os_desc_config = NULL;
-       WARN_ON(gi->composite.gadget_driver.udc_name);
+       WARN_ON(gi->cdev.gadget);
        mutex_unlock(&gi->lock);
        return 0;
 }
-- 
2.7.4

--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to