提交 e0458518 编写于 作者: M Miquel Raynal 提交者: Greg Kroah-Hartman

usb: ehci-orion: avoid double PHY initialization

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: NMiquel Raynal <miquel.raynal@bootlin.com>
Acked-by: NAlan Stern <stern@rowland.harvard.edu>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 12453a89
...@@ -257,15 +257,7 @@ static int ehci_orion_drv_probe(struct platform_device *pdev) ...@@ -257,15 +257,7 @@ static int ehci_orion_drv_probe(struct platform_device *pdev)
if (IS_ERR(priv->phy)) { if (IS_ERR(priv->phy)) {
err = PTR_ERR(priv->phy); err = PTR_ERR(priv->phy);
if (err != -ENOSYS) if (err != -ENOSYS)
goto err_phy_get; goto err_dis_clk;
} 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;
} }
/* /*
...@@ -297,19 +289,12 @@ static int ehci_orion_drv_probe(struct platform_device *pdev) ...@@ -297,19 +289,12 @@ static int ehci_orion_drv_probe(struct platform_device *pdev)
err = usb_add_hcd(hcd, irq, IRQF_SHARED); err = usb_add_hcd(hcd, irq, IRQF_SHARED);
if (err) if (err)
goto err_add_hcd; goto err_dis_clk;
device_wakeup_enable(hcd->self.controller); device_wakeup_enable(hcd->self.controller);
return 0; return 0;
err_add_hcd: err_dis_clk:
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:
if (!IS_ERR(priv->clk)) if (!IS_ERR(priv->clk))
clk_disable_unprepare(priv->clk); clk_disable_unprepare(priv->clk);
usb_put_hcd(hcd); usb_put_hcd(hcd);
...@@ -327,11 +312,6 @@ static int ehci_orion_drv_remove(struct platform_device *pdev) ...@@ -327,11 +312,6 @@ static int ehci_orion_drv_remove(struct platform_device *pdev)
usb_remove_hcd(hcd); usb_remove_hcd(hcd);
if (!IS_ERR(priv->phy)) {
phy_power_off(priv->phy);
phy_exit(priv->phy);
}
if (!IS_ERR(priv->clk)) if (!IS_ERR(priv->clk))
clk_disable_unprepare(priv->clk); clk_disable_unprepare(priv->clk);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册