提交 18c532e4 编写于 作者: A Aminuddin Jamaluddin 提交者: Paolo Abeni

net: phy: marvell: add sleep time after enabling the loopback bit

Sleep time is added to ensure the phy to be ready after loopback
bit was set. This to prevent the phy loopback test from failing.

Fixes: 020a45af ("net: phy: marvell: add Marvell specific PHY loopback")
Cc: <stable@vger.kernel.org> # 5.15.x
Signed-off-by: NMuhammad Husaini Zulkifli <muhammad.husaini.zulkifli@intel.com>
Signed-off-by: NAminuddin Jamaluddin <aminuddin.jamaluddin@intel.com>
Link: https://lore.kernel.org/r/20221114065302.10625-1-aminuddin.jamaluddin@intel.comSigned-off-by: NPaolo Abeni <pabeni@redhat.com>
上级 d349e9be
...@@ -2015,14 +2015,16 @@ static int m88e1510_loopback(struct phy_device *phydev, bool enable) ...@@ -2015,14 +2015,16 @@ static int m88e1510_loopback(struct phy_device *phydev, bool enable)
if (err < 0) if (err < 0)
return err; return err;
/* FIXME: Based on trial and error test, it seem 1G need to have err = phy_modify(phydev, MII_BMCR, BMCR_LOOPBACK,
* delay between soft reset and loopback enablement. BMCR_LOOPBACK);
*/
if (phydev->speed == SPEED_1000)
msleep(1000);
return phy_modify(phydev, MII_BMCR, BMCR_LOOPBACK, if (!err) {
BMCR_LOOPBACK); /* It takes some time for PHY device to switch
* into/out-of loopback mode.
*/
msleep(1000);
}
return err;
} else { } else {
err = phy_modify(phydev, MII_BMCR, BMCR_LOOPBACK, 0); err = phy_modify(phydev, MII_BMCR, BMCR_LOOPBACK, 0);
if (err < 0) if (err < 0)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册