usb: ehci-orion: avoid double PHY initialization
authorMiquel Raynal <miquel.raynal@bootlin.com>
Tue, 29 Jan 2019 09:23:42 +0000 (10:23 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 30 Jan 2019 08:22:35 +0000 (09:22 +0100)
No need to initialize the PHY from the driver's probe. It is done by
the core automatically and doing it twice would increment the
phy->powercount counter to 2 instead of 1. During later suspend
operation, the counter will be decremented to one, no phy->power_off()
will occur and worse than that, the following phy->power_on() at
resume time will also be skipped, failing the whole S2RAM operation.

Signed-off-by: Miquel Raynal <miquel.raynal@bootlin.com>
Acked-by: Alan Stern <stern@rowland.harvard.edu>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/usb/host/ehci-orion.c

index 1ad72647a06917786a0331f896ead8b9597ab3ba..3109f082949e43ac376f6f226fb98173f447a09c 100644 (file)
@@ -257,15 +257,7 @@ static int ehci_orion_drv_probe(struct platform_device *pdev)
        if (IS_ERR(priv->phy)) {
                err = PTR_ERR(priv->phy);
                if (err != -ENOSYS)
-                       goto err_phy_get;
-       } else {
-               err = phy_init(priv->phy);
-               if (err)
-                       goto err_phy_init;
-
-               err = phy_power_on(priv->phy);
-               if (err)
-                       goto err_phy_power_on;
+                       goto err_dis_clk;
        }
 
        /*
@@ -297,19 +289,12 @@ static int ehci_orion_drv_probe(struct platform_device *pdev)
 
        err = usb_add_hcd(hcd, irq, IRQF_SHARED);
        if (err)
-               goto err_add_hcd;
+               goto err_dis_clk;
 
        device_wakeup_enable(hcd->self.controller);
        return 0;
 
-err_add_hcd:
-       if (!IS_ERR(priv->phy))
-               phy_power_off(priv->phy);
-err_phy_power_on:
-       if (!IS_ERR(priv->phy))
-               phy_exit(priv->phy);
-err_phy_init:
-err_phy_get:
+err_dis_clk:
        if (!IS_ERR(priv->clk))
                clk_disable_unprepare(priv->clk);
        usb_put_hcd(hcd);
@@ -327,11 +312,6 @@ static int ehci_orion_drv_remove(struct platform_device *pdev)
 
        usb_remove_hcd(hcd);
 
-       if (!IS_ERR(priv->phy)) {
-               phy_power_off(priv->phy);
-               phy_exit(priv->phy);
-       }
-
        if (!IS_ERR(priv->clk))
                clk_disable_unprepare(priv->clk);