Commit 764a099a authored by Doug Berger's avatar Doug Berger Committed by Kleber Sacilotto de Souza

net: bcmgenet: power down internal phy if open or resume fails

BugLink: http://bugs.launchpad.net/bugs/1745052

[ Upstream commit 7627409c ]

Since the internal PHY is powered up during the open and resume
functions it should be powered back down if the functions fail.

Fixes: 1c1008c7 ("net: bcmgenet: add main driver file")
Signed-off-by: default avatarDoug Berger <opendmb@gmail.com>
Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarSasha Levin <alexander.levin@verizon.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarKhalid Elmously <khalid.elmously@canonical.com>
Signed-off-by: default avatarStefan Bader <stefan.bader@canonical.com>
parent 6607bb3b
...@@ -2950,6 +2950,8 @@ static int bcmgenet_open(struct net_device *dev) ...@@ -2950,6 +2950,8 @@ static int bcmgenet_open(struct net_device *dev)
err_fini_dma: err_fini_dma:
bcmgenet_fini_dma(priv); bcmgenet_fini_dma(priv);
err_clk_disable: err_clk_disable:
if (priv->internal_phy)
bcmgenet_power_down(priv, GENET_POWER_PASSIVE);
clk_disable_unprepare(priv->clk); clk_disable_unprepare(priv->clk);
return ret; return ret;
} }
...@@ -3653,6 +3655,8 @@ static int bcmgenet_resume(struct device *d) ...@@ -3653,6 +3655,8 @@ static int bcmgenet_resume(struct device *d)
return 0; return 0;
out_clk_disable: out_clk_disable:
if (priv->internal_phy)
bcmgenet_power_down(priv, GENET_POWER_PASSIVE);
clk_disable_unprepare(priv->clk); clk_disable_unprepare(priv->clk);
return ret; return ret;
} }
......
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