]> Git Repo - linux.git/commitdiff
usb: musb: fix hanging when rmmod gadget driver
authorFelipe Balbi <[email protected]>
Mon, 4 Aug 2008 10:53:52 +0000 (13:53 +0300)
committerGreg Kroah-Hartman <[email protected]>
Thu, 14 Aug 2008 00:33:00 +0000 (17:33 -0700)
If we try to modprobe a second gadget driver before
rmmoding the first one, the reference for the first
gadget driver would get NULLed avoiding usb to change
gadget drivers later.

Cc: David Brownell <[email protected]>
Cc: Tony Lindgren <[email protected]>
Signed-off-by: Felipe Balbi <[email protected]>
Signed-off-by: Greg Kroah-Hartman <[email protected]>
drivers/usb/musb/musb_gadget.c

index b3773f13ee0a8f2473de09768425acc0e6615ad4..d6a802c224fa8d2f7be9ba7fab7fe68db9b4202f 100644 (file)
@@ -1710,17 +1710,15 @@ int usb_gadget_register_driver(struct usb_gadget_driver *driver)
 
        spin_unlock_irqrestore(&musb->lock, flags);
 
-       if (retval == 0)
+       if (retval == 0) {
                retval = driver->bind(&musb->g);
-       if (retval != 0) {
-               DBG(3, "bind to driver %s failed --> %d\n",
-                       driver->driver.name, retval);
-               musb->gadget_driver = NULL;
-               musb->g.dev.driver = NULL;
-       }
+               if (retval != 0) {
+                       DBG(3, "bind to driver %s failed --> %d\n",
+                                       driver->driver.name, retval);
+                       musb->gadget_driver = NULL;
+                       musb->g.dev.driver = NULL;
+               }
 
-       /* start peripheral and/or OTG engines */
-       if (retval == 0) {
                spin_lock_irqsave(&musb->lock, flags);
 
                /* REVISIT always use otg_set_peripheral(), handling
This page took 0.049243 seconds and 4 git commands to generate.