mirror of
https://github.com/freebsd/freebsd-src.git
synced 2024-12-04 05:58:57 +00:00
Fix a bug with the ael1006 PHY. The bug shows up as persistent but incomplete
packet loss, of between 10-30%. The fix is to put the PHY into and take it out of local loopback mode when resetting the interface. Obtained from: Chelsio Inc. MFC after: 3 days
This commit is contained in:
parent
78bc7eec0d
commit
9036240993
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=185620
@ -205,6 +205,16 @@ static int ael1006_reset(struct cphy *phy, int wait)
|
||||
t3_write_reg(phy->adapter, A_T3DBG_GPIO_EN, gpio_out);
|
||||
msleep(125);
|
||||
t3_phy_reset(phy, MDIO_DEV_PMA_PMD, wait);
|
||||
|
||||
/* Phy loopback work around for ael1006 */
|
||||
/* Soft reset phy by toggling loopback */
|
||||
msleep(125);
|
||||
/* Put phy into local loopback */
|
||||
t3_mdio_change_bits(phy, MDIO_DEV_PMA_PMD, MII_BMCR, 0, 1);
|
||||
msleep(125);
|
||||
/* Take phy out of local loopback */
|
||||
t3_mdio_change_bits(phy, MDIO_DEV_PMA_PMD, MII_BMCR, 1, 0);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user