735-net-mediatek-mtk_eth_soc-release-MAC_MCR_FORCE_LINK-.patch 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. From ef5976ae4e117fae9a61bb3c0f8319a917a425ea Mon Sep 17 00:00:00 2001
  2. From: Daniel Golle <[email protected]>
  3. Date: Mon, 11 Mar 2024 17:43:28 +0000
  4. Subject: [PATCH] net: mediatek: mtk_eth_soc: release MAC_MCR_FORCE_LINK only when MAC is up
  5. MIME-Version: 1.0
  6. Content-Type: text/plain; charset=UTF-8
  7. Content-Transfer-Encoding: 8bit
  8. Clearing bit MAC_MCR_FORCE_LINK which forces the link down too early
  9. can result in MAC ending up in a broken/blocked state.
  10. Fix this by handling this bit in the .mac_link_up and .mac_link_down
  11. calls instead of in .mac_finish.
  12. Fixes: b8fc9f30821ec ("net: ethernet: mediatek: Add basic PHYLINK support")
  13. Signed-off-by: Daniel Golle <[email protected]>
  14. ---
  15. drivers/net/ethernet/mediatek/mtk_eth_soc.c | 7 +++----
  16. 1 file changed, 3 insertions(+), 4 deletions(-)
  17. --- a/drivers/net/ethernet/mediatek/mtk_eth_soc.c
  18. +++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
  19. @@ -678,8 +678,7 @@ static int mtk_mac_finish(struct phylink
  20. mcr_cur = mtk_r32(mac->hw, MTK_MAC_MCR(mac->id));
  21. mcr_new = mcr_cur;
  22. mcr_new |= MAC_MCR_IPG_CFG | MAC_MCR_FORCE_MODE |
  23. - MAC_MCR_BACKOFF_EN | MAC_MCR_BACKPR_EN | MAC_MCR_FORCE_LINK |
  24. - MAC_MCR_RX_FIFO_CLR_DIS;
  25. + MAC_MCR_BACKOFF_EN | MAC_MCR_BACKPR_EN | MAC_MCR_RX_FIFO_CLR_DIS;
  26. /* Only update control register when needed! */
  27. if (mcr_new != mcr_cur)
  28. @@ -695,7 +694,7 @@ static void mtk_mac_link_down(struct phy
  29. phylink_config);
  30. u32 mcr = mtk_r32(mac->hw, MTK_MAC_MCR(mac->id));
  31. - mcr &= ~(MAC_MCR_TX_EN | MAC_MCR_RX_EN);
  32. + mcr &= ~(MAC_MCR_TX_EN | MAC_MCR_RX_EN | MAC_MCR_FORCE_LINK);
  33. mtk_w32(mac->hw, mcr, MTK_MAC_MCR(mac->id));
  34. }
  35. @@ -804,7 +803,7 @@ static void mtk_mac_link_up(struct phyli
  36. if (rx_pause)
  37. mcr |= MAC_MCR_FORCE_RX_FC;
  38. - mcr |= MAC_MCR_TX_EN | MAC_MCR_RX_EN;
  39. + mcr |= MAC_MCR_TX_EN | MAC_MCR_RX_EN | MAC_MCR_FORCE_LINK;
  40. mtk_w32(mac->hw, mcr, MTK_MAC_MCR(mac->id));
  41. }