Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 065d3931 authored by Gregory Herrero's avatar Gregory Herrero Committed by Felipe Balbi
Browse files

usb: dwc2: gadget: ensure lx_state corresponds to current state



Correctly update lx_state on gadget connection and disconnection.
When usb cable is disconnected, lx_state must be updated to L3 as
controller could be in power off state.
When usb cable is connected, lx_state must be updated to L0 as
controller is powered.

Signed-off-by: default avatarGregory Herrero <gregory.herrero@intel.com>
Signed-off-by: default avatarMian Yousaf Kaukab <yousaf.kaukab@intel.com>
Tested-by: default avatarRobert Baldyga <r.baldyga@samsung.com>
Tested-by: default avatarDinh Nguyen <dinguyen@opensource.altera.com>
Tested-by: default avatarJohn Youn <johnyoun@synopsys.com>
Acked-by: default avatarJohn Youn <johnyoun@synopsys.com>
Signed-off-by: default avatarFelipe Balbi <balbi@ti.com>
parent 2e84da6e
Loading
Loading
Loading
Loading
+4 −4
Original line number Diff line number Diff line
@@ -2189,6 +2189,7 @@ void dwc2_hsotg_disconnect(struct dwc2_hsotg *hsotg)
	}

	call_gadget(hsotg, disconnect);
	hsotg->lx_state = DWC2_L3;
}

/**
@@ -2415,6 +2416,7 @@ void dwc2_hsotg_core_init_disconnected(struct dwc2_hsotg *hsotg,
	mdelay(3);

	hsotg->last_rst = jiffies;
	hsotg->lx_state = DWC2_L0;
}

static void dwc2_hsotg_core_disconnect(struct dwc2_hsotg *hsotg)
@@ -2514,7 +2516,6 @@ static irqreturn_t dwc2_hsotg_irq(int irq, void *pw)
				kill_all_requests(hsotg, hsotg->eps_out[0],
							  -ECONNRESET);

				hsotg->lx_state = DWC2_L0;
				dwc2_hsotg_core_init_disconnected(hsotg, true);
			}
		}
@@ -3205,10 +3206,9 @@ static int dwc2_hsotg_vbus_session(struct usb_gadget *gadget, int is_active)
		 * If controller is hibernated, it must exit from hibernation
		 * before being initialized
		 */
		if (hsotg->lx_state == DWC2_L2) {
		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);
		dwc2_hsotg_core_init_disconnected(hsotg, false);