Commit 51392a18 authored by Johan Hovold's avatar Johan Hovold Committed by Greg Kroah-Hartman

USB: dwc3: qcom: fix resource leaks on probe deferral

The driver needs to deregister and free the newly allocated dwc3 core
platform device on ACPI probe errors (e.g. probe deferral) and on driver
unbind but instead it leaked those resources while erroneously dropping
a reference to the parent platform device which is still in use.

For OF probing the driver takes a reference to the dwc3 core platform
device which has also always been leaked.

Fix the broken ACPI tear down and make sure to drop the dwc3 core
reference for both OF and ACPI.

Fixes: 8fd95da2 ("usb: dwc3: qcom: Release the correct resources in dwc3_qcom_remove()")
Fixes: 2bc02355 ("usb: dwc3: qcom: Add support for booting with ACPI")
Fixes: a4333c3a ("usb: dwc3: Add Qualcomm DWC3 glue driver")
Cc: stable@vger.kernel.org      # 4.18
Cc: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Cc: Lee Jones <lee@kernel.org>
Signed-off-by: default avatarJohan Hovold <johan+linaro@kernel.org>
Acked-by: default avatarAndrew Halaney <ahalaney@redhat.com>
Link: https://lore.kernel.org/r/20231117173650.21161-2-johan+linaro@kernel.orgSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent aee70a1d
...@@ -754,6 +754,7 @@ static int dwc3_qcom_of_register_core(struct platform_device *pdev) ...@@ -754,6 +754,7 @@ static int dwc3_qcom_of_register_core(struct platform_device *pdev)
if (!qcom->dwc3) { if (!qcom->dwc3) {
ret = -ENODEV; ret = -ENODEV;
dev_err(dev, "failed to get dwc3 platform device\n"); dev_err(dev, "failed to get dwc3 platform device\n");
of_platform_depopulate(dev);
} }
node_put: node_put:
...@@ -895,7 +896,7 @@ static int dwc3_qcom_probe(struct platform_device *pdev) ...@@ -895,7 +896,7 @@ static int dwc3_qcom_probe(struct platform_device *pdev)
if (ret) { if (ret) {
dev_err(dev, "failed to register DWC3 Core, err=%d\n", ret); dev_err(dev, "failed to register DWC3 Core, err=%d\n", ret);
goto depopulate; goto clk_disable;
} }
ret = dwc3_qcom_interconnect_init(qcom); ret = dwc3_qcom_interconnect_init(qcom);
...@@ -930,7 +931,8 @@ static int dwc3_qcom_probe(struct platform_device *pdev) ...@@ -930,7 +931,8 @@ static int dwc3_qcom_probe(struct platform_device *pdev)
if (np) if (np)
of_platform_depopulate(&pdev->dev); of_platform_depopulate(&pdev->dev);
else else
platform_device_put(pdev); platform_device_del(qcom->dwc3);
platform_device_put(qcom->dwc3);
clk_disable: clk_disable:
for (i = qcom->num_clocks - 1; i >= 0; i--) { for (i = qcom->num_clocks - 1; i >= 0; i--) {
clk_disable_unprepare(qcom->clks[i]); clk_disable_unprepare(qcom->clks[i]);
...@@ -953,7 +955,8 @@ static void dwc3_qcom_remove(struct platform_device *pdev) ...@@ -953,7 +955,8 @@ static void dwc3_qcom_remove(struct platform_device *pdev)
if (np) if (np)
of_platform_depopulate(&pdev->dev); of_platform_depopulate(&pdev->dev);
else else
platform_device_put(pdev); platform_device_del(qcom->dwc3);
platform_device_put(qcom->dwc3);
for (i = qcom->num_clocks - 1; i >= 0; i--) { for (i = qcom->num_clocks - 1; i >= 0; i--) {
clk_disable_unprepare(qcom->clks[i]); clk_disable_unprepare(qcom->clks[i]);
......
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