Update the AFE_TX_CONFIG value to solve marginal rise/fall issues
observed when the link is operating in 100BaseT. This workaround applies
to GPHY revisions D0, E0 and newer.

Signed-off-by: Florian Fainelli <f.faine...@gmail.com>
---
 drivers/net/phy/bcm7xxx.c | 7 +++++--
 1 file changed, 5 insertions(+), 2 deletions(-)

diff --git a/drivers/net/phy/bcm7xxx.c b/drivers/net/phy/bcm7xxx.c
index b5dc59de094e..4dea85bfc545 100644
--- a/drivers/net/phy/bcm7xxx.c
+++ b/drivers/net/phy/bcm7xxx.c
@@ -136,8 +136,8 @@ static int bcm7xxx_28nm_d0_afe_config_init(struct 
phy_device *phydev)
        /* AFE_RX_LP_COUNTER, set RX bandwidth to maximum */
        phy_write_misc(phydev, AFE_RX_LP_COUNTER, 0x7fc0);
 
-       /* AFE_TX_CONFIG, set 1000BT Cfeed=110 for all ports */
-       phy_write_misc(phydev, AFE_TX_CONFIG, 0x0061);
+       /* AFE_TX_CONFIG, set 100BT Cfeed=011 to improve rise/fall time */
+       phy_write_misc(phydev, AFE_TX_CONFIG, 0x431);
 
        /* AFE_VDCA_ICTRL_0, set Iq=1101 instead of 0111 for AB symmetry */
        phy_write_misc(phydev, AFE_VDCA_ICTRL_0, 0xa7da);
@@ -167,6 +167,9 @@ static int bcm7xxx_28nm_e0_plus_afe_config_init(struct 
phy_device *phydev)
        /* AFE_RXCONFIG_1, provide more margin for INL/DNL measurement */
        phy_write_misc(phydev, AFE_RXCONFIG_1, 0x9b2f);
 
+       /* AFE_TX_CONFIG, set 100BT Cfeed=011 to improve rise/fall time */
+       phy_write_misc(phydev, AFE_TX_CONFIG, 0x431);
+
        /* AFE_VDCA_ICTRL_0, set Iq=1101 instead of 0111 for AB symmetry */
        phy_write_misc(phydev, AFE_VDCA_ICTRL_0, 0xa7da);
 
-- 
2.1.0

--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to