usb: dwc2: gadget: powerup controller if needed
authorGregory Herrero <gregory.herrero@intel.com>
Wed, 29 Apr 2015 20:09:09 +0000 (22:09 +0200)
committerFelipe Balbi <balbi@ti.com>
Wed, 29 Apr 2015 20:19:24 +0000 (15:19 -0500)
During vbus session, usb controller needs to exit hibernation if it was
previously in suspend state.
Since controller will be resetted and configured, there is no need
to restore registers.

Moreover, set lx_state to L0 on B session. vbus_session callback may
not be used by all platforms. Thus, controller software state needs
to be set to L0 if the controller detects a valid B session.
Otherwise, lx_state will remain L2 and prevent any request submission.

Acked-by: John Youn <johnyoun@synopsys.com>
Signed-off-by: Gregory Herrero <gregory.herrero@intel.com>
Signed-off-by: Felipe Balbi <balbi@ti.com>
drivers/usb/dwc2/gadget.c

index 732761f9466b9e8be5cc962c8e77eda8b65200d2..56a08ac3849ab4713f7c6a568338b0a2f158350e 100644 (file)
@@ -2515,6 +2515,7 @@ irq_retry:
                                kill_all_requests(hsotg, hsotg->eps_out[0],
                                                          -ECONNRESET);
 
+                               hsotg->lx_state = DWC2_L0;
                                s3c_hsotg_core_init_disconnected(hsotg, true);
                        }
                }
@@ -3205,6 +3206,14 @@ static int s3c_hsotg_vbus_session(struct usb_gadget *gadget, int is_active)
        spin_lock_irqsave(&hsotg->lock, flags);
 
        if (is_active) {
+               /*
+                * If controller is hibernated, it must exit from hibernation
+                * before being initialized
+                */
+               if (hsotg->lx_state == DWC2_L2) {
+                       dwc2_exit_hibernation(hsotg, false);
+                       hsotg->lx_state = DWC2_L0;
+               }
                /* Kill any ep0 requests as controller will be reinitialized */
                kill_all_requests(hsotg, hsotg->eps_out[0], -ECONNRESET);
                s3c_hsotg_core_init_disconnected(hsotg, false);