Under heavy traffic, unpluging and pluging fiber optic cables may cause Tx
failure. The reason is that there is still traffic passing through at PCS
VR reset, during txgbe_set_link_to_*. So totally disable Rx and Tx before
PCS VR reset to fix it.

Fixes: 01c3cf5c85a7 ("net/txgbe: add autoneg control read and write")
Cc: sta...@dpdk.org

Signed-off-by: Jiawen Wu <jiawe...@trustnetic.com>
---
 drivers/net/txgbe/base/txgbe_phy.c | 18 ++++++++++++------
 1 file changed, 12 insertions(+), 6 deletions(-)

diff --git a/drivers/net/txgbe/base/txgbe_phy.c 
b/drivers/net/txgbe/base/txgbe_phy.c
index f4cadcc510..1eb45b068a 100644
--- a/drivers/net/txgbe/base/txgbe_phy.c
+++ b/drivers/net/txgbe/base/txgbe_phy.c
@@ -1541,8 +1541,9 @@ txgbe_set_link_to_kx4(struct txgbe_hw *hw, bool autoneg)
                goto out;
        }
 
-       wr32m(hw, TXGBE_MACTXCFG, TXGBE_MACTXCFG_TXE,
-                       ~TXGBE_MACTXCFG_TXE);
+       wr32m(hw, TXGBE_MACTXCFG, TXGBE_MACTXCFG_TXE, ~TXGBE_MACTXCFG_TXE);
+       wr32m(hw, TXGBE_MACRXCFG, TXGBE_MACRXCFG_ENA, ~TXGBE_MACRXCFG_ENA);
+       hw->mac.disable_sec_tx_path(hw);
 
        /* 2. Disable xpcs AN-73 */
        if (!autoneg)
@@ -1756,8 +1757,9 @@ txgbe_set_link_to_kx(struct txgbe_hw *hw,
                goto out;
        }
 
-       wr32m(hw, TXGBE_MACTXCFG, TXGBE_MACTXCFG_TXE,
-                               ~TXGBE_MACTXCFG_TXE);
+       wr32m(hw, TXGBE_MACTXCFG, TXGBE_MACTXCFG_TXE, ~TXGBE_MACTXCFG_TXE);
+       wr32m(hw, TXGBE_MACRXCFG, TXGBE_MACRXCFG_ENA, ~TXGBE_MACRXCFG_ENA);
+       hw->mac.disable_sec_tx_path(hw);
 
        /* 2. Disable xpcs AN-73 */
        if (!autoneg)
@@ -1963,8 +1965,9 @@ txgbe_set_link_to_sfi(struct txgbe_hw *hw,
                goto out;
        }
 
-       wr32m(hw, TXGBE_MACTXCFG, TXGBE_MACTXCFG_TXE,
-                       ~TXGBE_MACTXCFG_TXE);
+       wr32m(hw, TXGBE_MACTXCFG, TXGBE_MACTXCFG_TXE, ~TXGBE_MACTXCFG_TXE);
+       wr32m(hw, TXGBE_MACRXCFG, TXGBE_MACRXCFG_ENA, ~TXGBE_MACRXCFG_ENA);
+       hw->mac.disable_sec_tx_path(hw);
 
        /* 2. Disable xpcs AN-73 */
        wr32_epcs(hw, SR_AN_CTRL, 0x0);
@@ -2315,6 +2318,8 @@ void txgbe_autoc_write(struct txgbe_hw *hw, u64 autoc)
                        txgbe_set_sgmii_an37_ability(hw);
        }
 
+       hw->mac.enable_sec_tx_path(hw);
+
        if (speed == TXGBE_LINK_SPEED_10GB_FULL)
                mactxcfg = TXGBE_MACTXCFG_SPEED_10G;
        else if (speed == TXGBE_LINK_SPEED_1GB_FULL)
@@ -2324,6 +2329,7 @@ void txgbe_autoc_write(struct txgbe_hw *hw, u64 autoc)
        wr32m(hw, TXGBE_MACTXCFG,
                TXGBE_MACTXCFG_SPEED_MASK | TXGBE_MACTXCFG_TXE,
                mactxcfg | TXGBE_MACTXCFG_TXE);
+       wr32m(hw, TXGBE_MACRXCFG, TXGBE_MACRXCFG_ENA, TXGBE_MACRXCFG_ENA);
 }
 
 void txgbe_bp_down_event(struct txgbe_hw *hw)
-- 
2.27.0

Reply via email to