usb: musb: only remove host/udc if it has been added
authorSebastian Andrzej Siewior <bigeasy@linutronix.de>
Tue, 20 Aug 2013 16:35:44 +0000 (18:35 +0200)
committerFelipe Balbi <balbi@ti.com>
Tue, 27 Aug 2013 19:18:14 +0000 (14:18 -0500)
musb_shutdown() removes always USB host and device.
musb_init_controller() adds host and device depending on port_mode. If
port mode is set to HOST then the removal of UDC leads only to:
|(NULL device *): gadget not registered.
and nothing else happens. If port mode is set to DEVICE and we remove
the host then we oops in usb_remove_hcd().
This patch ensures that we only remove host in OTG/host mode and device
only in OTG/device mode to avoid any trouble.

Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
Signed-off-by: Felipe Balbi <balbi@ti.com>
drivers/usb/musb/musb_gadget.c
drivers/usb/musb/musb_host.c

index b7b8b2b..9a08679 100644 (file)
@@ -1812,6 +1812,8 @@ err:
 
 void musb_gadget_cleanup(struct musb *musb)
 {
+       if (musb->port_mode == MUSB_PORT_MODE_HOST)
+               return;
        usb_del_gadget_udc(&musb->g);
 }
 
index a9695f5..9a2b8c8 100644 (file)
@@ -2628,6 +2628,8 @@ int musb_host_alloc(struct musb *musb)
 
 void musb_host_cleanup(struct musb *musb)
 {
+       if (musb->port_mode == MUSB_PORT_MODE_GADGET)
+               return;
        usb_remove_hcd(musb->hcd);
        musb->hcd = NULL;
 }