Commit 762e7449 authored by Johan Hovold's avatar Johan Hovold Committed by Greg Kroah-Hartman
Browse files

Revert "usb: dwc3: qcom: Keep power domain on to retain controller status"



This reverts commit d9be8d5c.

Generic power-domain flags must be set before the power-domain is
initialised and must specifically not be modified by drivers for devices
that happen to be in the domain.

To make sure that USB power-domains are left enabled during system
suspend when a device in the domain is in the wakeup path, the
GENPD_FLAG_ACTIVE_WAKEUP flag should instead be set for the domain
unconditionally when it is registered.

Note that this also avoids keeping power-domains on during suspend when
wakeup has not been enabled (e.g. through sysfs).

For the runtime PM case, making sure that the PHYs are not suspended and
that they are in the same domain as the controller prevents the domain
from being suspended. If there are cases where this is not possible or
desirable, the genpd implementation may need to be extended.

Fixes: d9be8d5c ("usb: dwc3: qcom: Keep power domain on to retain controller status")
Reviewed-by: default avatarManivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
Signed-off-by: default avatarJohan Hovold <johan+linaro@kernel.org>
Link: https://lore.kernel.org/r/20220804151001.23612-3-johan+linaro@kernel.org


Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent d2ac7bef
Loading
Loading
Loading
Loading
+7 −21
Original line number Diff line number Diff line
@@ -17,7 +17,6 @@
#include <linux/of_platform.h>
#include <linux/platform_device.h>
#include <linux/phy/phy.h>
#include <linux/pm_domain.h>
#include <linux/usb/of.h>
#include <linux/reset.h>
#include <linux/iopoll.h>
@@ -763,7 +762,6 @@ static int dwc3_qcom_probe(struct platform_device *pdev)
	struct resource		*res, *parent_res = NULL;
	int			ret, i;
	bool			ignore_pipe_clk;
	struct generic_pm_domain *genpd;

	qcom = devm_kzalloc(&pdev->dev, sizeof(*qcom), GFP_KERNEL);
	if (!qcom)
@@ -772,8 +770,6 @@ static int dwc3_qcom_probe(struct platform_device *pdev)
	platform_set_drvdata(pdev, qcom);
	qcom->dev = &pdev->dev;

	genpd = pd_to_genpd(qcom->dev->pm_domain);

	if (has_acpi_companion(dev)) {
		qcom->acpi_pdata = acpi_device_get_match_data(dev);
		if (!qcom->acpi_pdata) {
@@ -881,17 +877,7 @@ static int dwc3_qcom_probe(struct platform_device *pdev)
	if (ret)
		goto interconnect_exit;

	if (device_can_wakeup(&qcom->dwc3->dev)) {
		/*
		 * Setting GENPD_FLAG_ALWAYS_ON flag takes care of keeping
		 * genpd on in both runtime suspend and system suspend cases.
		 */
		genpd->flags |= GENPD_FLAG_ALWAYS_ON;
		device_init_wakeup(&pdev->dev, true);
	} else {
		genpd->flags |= GENPD_FLAG_RPM_ALWAYS_ON;
	}

	device_init_wakeup(&pdev->dev, 1);
	qcom->is_suspended = false;
	pm_runtime_set_active(dev);
	pm_runtime_enable(dev);