Skip to content

Commit 48cc638

Browse files
Marek Vasutgregkh
authored andcommitted
net: fec: Fix PHY init after phy_reset_after_clk_enable()
[ Upstream commit 0da1ccb ] The phy_reset_after_clk_enable() does a PHY reset, which means the PHY loses its register settings. The fec_enet_mii_probe() starts the PHY and does the necessary calls to configure the PHY via PHY framework, and loads the correct register settings into the PHY. Therefore, fec_enet_mii_probe() should be called only after the PHY has been reset, not before as it is now. Fixes: 1b0a83a ("net: fec: add phy_reset_after_clk_enable() support") Reviewed-by: Andrew Lunn <andrew@lunn.ch> Tested-by: Richard Leitner <richard.leitner@skidata.com> Signed-off-by: Marek Vasut <marex@denx.de> Cc: Christoph Niedermaier <cniedermaier@dh-electronics.com> Cc: David S. Miller <davem@davemloft.net> Cc: NXP Linux Team <linux-imx@nxp.com> Cc: Shawn Guo <shawnguo@kernel.org> Signed-off-by: Jakub Kicinski <kuba@kernel.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
1 parent ce88b5f commit 48cc638

1 file changed

Lines changed: 5 additions & 5 deletions

File tree

drivers/net/ethernet/freescale/fec_main.c

Lines changed: 5 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -3005,17 +3005,17 @@ fec_enet_open(struct net_device *ndev)
30053005
/* Init MAC prior to mii bus probe */
30063006
fec_restart(ndev);
30073007

3008-
/* Probe and connect to PHY when open the interface */
3009-
ret = fec_enet_mii_probe(ndev);
3010-
if (ret)
3011-
goto err_enet_mii_probe;
3012-
30133008
/* Call phy_reset_after_clk_enable() again if it failed during
30143009
* phy_reset_after_clk_enable() before because the PHY wasn't probed.
30153010
*/
30163011
if (reset_again)
30173012
fec_enet_phy_reset_after_clk_enable(ndev);
30183013

3014+
/* Probe and connect to PHY when open the interface */
3015+
ret = fec_enet_mii_probe(ndev);
3016+
if (ret)
3017+
goto err_enet_mii_probe;
3018+
30193019
if (fep->quirks & FEC_QUIRK_ERR006687)
30203020
imx6q_cpuidle_fec_irqs_used();
30213021

0 commit comments

Comments
 (0)