mirror of https://gitee.com/openkylin/linux.git
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: Miquel Raynal <miquel.raynal@bootlin.com> Acked-by: Alan Stern <stern@rowland.harvard.edu> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
12453a897e
commit
e04585184d
|
@ -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);
|
||||
|
||||
|
|
Loading…
Reference in New Issue