Commit c2cd3452 authored by Martin Kepplinger's avatar Martin Kepplinger Committed by Felipe Balbi

usb: dwc3: support continuous runtime PM with dual role

The DRD module calls dwc3_set_mode() on role switches, i.e. when a device is
being plugged in. In order to support continuous runtime power management when
plugging in / unplugging a cable, we need to call pm_runtime_get_sync() in
this path.
Signed-off-by: default avatarMartin Kepplinger <martin.kepplinger@puri.sm>
Signed-off-by: default avatarFelipe Balbi <balbi@kernel.org>
parent e2e77a94
...@@ -121,17 +121,19 @@ static void __dwc3_set_mode(struct work_struct *work) ...@@ -121,17 +121,19 @@ static void __dwc3_set_mode(struct work_struct *work)
if (dwc->dr_mode != USB_DR_MODE_OTG) if (dwc->dr_mode != USB_DR_MODE_OTG)
return; return;
pm_runtime_get_sync(dwc->dev);
if (dwc->current_dr_role == DWC3_GCTL_PRTCAP_OTG) if (dwc->current_dr_role == DWC3_GCTL_PRTCAP_OTG)
dwc3_otg_update(dwc, 0); dwc3_otg_update(dwc, 0);
if (!dwc->desired_dr_role) if (!dwc->desired_dr_role)
return; goto out;
if (dwc->desired_dr_role == dwc->current_dr_role) if (dwc->desired_dr_role == dwc->current_dr_role)
return; goto out;
if (dwc->desired_dr_role == DWC3_GCTL_PRTCAP_OTG && dwc->edev) if (dwc->desired_dr_role == DWC3_GCTL_PRTCAP_OTG && dwc->edev)
return; goto out;
switch (dwc->current_dr_role) { switch (dwc->current_dr_role) {
case DWC3_GCTL_PRTCAP_HOST: case DWC3_GCTL_PRTCAP_HOST:
...@@ -190,6 +192,9 @@ static void __dwc3_set_mode(struct work_struct *work) ...@@ -190,6 +192,9 @@ static void __dwc3_set_mode(struct work_struct *work)
break; break;
} }
out:
pm_runtime_mark_last_busy(dwc->dev);
pm_runtime_put_autosuspend(dwc->dev);
} }
void dwc3_set_mode(struct dwc3 *dwc, u32 mode) void dwc3_set_mode(struct dwc3 *dwc, u32 mode)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment