611-v5.12-net-ethernet-mediatek-support-setting-MTU.patch 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. From 4fd59792097a6b2fb949d41264386a7ecade469e Mon Sep 17 00:00:00 2001
  2. From: DENG Qingfang <[email protected]>
  3. Date: Mon, 25 Jan 2021 12:20:46 +0800
  4. Subject: [PATCH] net: ethernet: mediatek: support setting MTU
  5. MT762x HW, except for MT7628, supports frame length up to 2048
  6. (maximum length on GDM), so allow setting MTU up to 2030.
  7. Also set the default frame length to the hardware default 1518.
  8. Signed-off-by: DENG Qingfang <[email protected]>
  9. Reviewed-by: Andrew Lunn <[email protected]>
  10. Link: https://lore.kernel.org/r/[email protected]
  11. Signed-off-by: Jakub Kicinski <[email protected]>
  12. ---
  13. drivers/net/ethernet/mediatek/mtk_eth_soc.c | 43 ++++++++++++++++++---
  14. drivers/net/ethernet/mediatek/mtk_eth_soc.h | 12 ++++--
  15. 2 files changed, 47 insertions(+), 8 deletions(-)
  16. --- a/drivers/net/ethernet/mediatek/mtk_eth_soc.c
  17. +++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
  18. @@ -355,7 +355,7 @@ static void mtk_mac_config(struct phylin
  19. /* Setup gmac */
  20. mcr_cur = mtk_r32(mac->hw, MTK_MAC_MCR(mac->id));
  21. mcr_new = mcr_cur;
  22. - mcr_new |= MAC_MCR_MAX_RX_1536 | MAC_MCR_IPG_CFG | MAC_MCR_FORCE_MODE |
  23. + mcr_new |= MAC_MCR_IPG_CFG | MAC_MCR_FORCE_MODE |
  24. MAC_MCR_BACKOFF_EN | MAC_MCR_BACKPR_EN | MAC_MCR_FORCE_LINK;
  25. /* Only update control register when needed! */
  26. @@ -782,8 +782,8 @@ static void mtk_get_stats64(struct net_d
  27. static inline int mtk_max_frag_size(int mtu)
  28. {
  29. /* make sure buf_size will be at least MTK_MAX_RX_LENGTH */
  30. - if (mtu + MTK_RX_ETH_HLEN < MTK_MAX_RX_LENGTH)
  31. - mtu = MTK_MAX_RX_LENGTH - MTK_RX_ETH_HLEN;
  32. + if (mtu + MTK_RX_ETH_HLEN < MTK_MAX_RX_LENGTH_2K)
  33. + mtu = MTK_MAX_RX_LENGTH_2K - MTK_RX_ETH_HLEN;
  34. return SKB_DATA_ALIGN(MTK_RX_HLEN + mtu) +
  35. SKB_DATA_ALIGN(sizeof(struct skb_shared_info));
  36. @@ -794,7 +794,7 @@ static inline int mtk_max_buf_size(int f
  37. int buf_size = frag_size - NET_SKB_PAD - NET_IP_ALIGN -
  38. SKB_DATA_ALIGN(sizeof(struct skb_shared_info));
  39. - WARN_ON(buf_size < MTK_MAX_RX_LENGTH);
  40. + WARN_ON(buf_size < MTK_MAX_RX_LENGTH_2K);
  41. return buf_size;
  42. }
  43. @@ -2606,6 +2606,35 @@ static void mtk_uninit(struct net_device
  44. mtk_rx_irq_disable(eth, ~0);
  45. }
  46. +static int mtk_change_mtu(struct net_device *dev, int new_mtu)
  47. +{
  48. + int length = new_mtu + MTK_RX_ETH_HLEN;
  49. + struct mtk_mac *mac = netdev_priv(dev);
  50. + struct mtk_eth *eth = mac->hw;
  51. + u32 mcr_cur, mcr_new;
  52. +
  53. + if (!MTK_HAS_CAPS(eth->soc->caps, MTK_SOC_MT7628)) {
  54. + mcr_cur = mtk_r32(mac->hw, MTK_MAC_MCR(mac->id));
  55. + mcr_new = mcr_cur & ~MAC_MCR_MAX_RX_MASK;
  56. +
  57. + if (length <= 1518)
  58. + mcr_new |= MAC_MCR_MAX_RX(MAC_MCR_MAX_RX_1518);
  59. + else if (length <= 1536)
  60. + mcr_new |= MAC_MCR_MAX_RX(MAC_MCR_MAX_RX_1536);
  61. + else if (length <= 1552)
  62. + mcr_new |= MAC_MCR_MAX_RX(MAC_MCR_MAX_RX_1552);
  63. + else
  64. + mcr_new |= MAC_MCR_MAX_RX(MAC_MCR_MAX_RX_2048);
  65. +
  66. + if (mcr_new != mcr_cur)
  67. + mtk_w32(mac->hw, mcr_new, MTK_MAC_MCR(mac->id));
  68. + }
  69. +
  70. + dev->mtu = new_mtu;
  71. +
  72. + return 0;
  73. +}
  74. +
  75. static int mtk_do_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
  76. {
  77. struct mtk_mac *mac = netdev_priv(dev);
  78. @@ -2902,6 +2931,7 @@ static const struct net_device_ops mtk_n
  79. .ndo_set_mac_address = mtk_set_mac_address,
  80. .ndo_validate_addr = eth_validate_addr,
  81. .ndo_do_ioctl = mtk_do_ioctl,
  82. + .ndo_change_mtu = mtk_change_mtu,
  83. .ndo_tx_timeout = mtk_tx_timeout,
  84. .ndo_get_stats64 = mtk_get_stats64,
  85. .ndo_fix_features = mtk_fix_features,
  86. @@ -3004,7 +3034,10 @@ static int mtk_add_mac(struct mtk_eth *e
  87. eth->netdev[id]->irq = eth->irq[0];
  88. eth->netdev[id]->dev.of_node = np;
  89. - eth->netdev[id]->max_mtu = MTK_MAX_RX_LENGTH - MTK_RX_ETH_HLEN;
  90. + if (MTK_HAS_CAPS(eth->soc->caps, MTK_SOC_MT7628))
  91. + eth->netdev[id]->max_mtu = MTK_MAX_RX_LENGTH - MTK_RX_ETH_HLEN;
  92. + else
  93. + eth->netdev[id]->max_mtu = MTK_MAX_RX_LENGTH_2K - MTK_RX_ETH_HLEN;
  94. return 0;
  95. --- a/drivers/net/ethernet/mediatek/mtk_eth_soc.h
  96. +++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.h
  97. @@ -20,12 +20,13 @@
  98. #include "mtk_ppe.h"
  99. #define MTK_QDMA_PAGE_SIZE 2048
  100. -#define MTK_MAX_RX_LENGTH 1536
  101. +#define MTK_MAX_RX_LENGTH 1536
  102. +#define MTK_MAX_RX_LENGTH_2K 2048
  103. #define MTK_TX_DMA_BUF_LEN 0x3fff
  104. #define MTK_DMA_SIZE 512
  105. #define MTK_NAPI_WEIGHT 64
  106. #define MTK_MAC_COUNT 2
  107. -#define MTK_RX_ETH_HLEN (VLAN_ETH_HLEN + VLAN_HLEN + ETH_FCS_LEN)
  108. +#define MTK_RX_ETH_HLEN (ETH_HLEN + ETH_FCS_LEN)
  109. #define MTK_RX_HLEN (NET_SKB_PAD + MTK_RX_ETH_HLEN + NET_IP_ALIGN)
  110. #define MTK_DMA_DUMMY_DESC 0xffffffff
  111. #define MTK_DEFAULT_MSG_ENABLE (NETIF_MSG_DRV | \
  112. @@ -352,7 +353,12 @@
  113. /* Mac control registers */
  114. #define MTK_MAC_MCR(x) (0x10100 + (x * 0x100))
  115. -#define MAC_MCR_MAX_RX_1536 BIT(24)
  116. +#define MAC_MCR_MAX_RX_MASK GENMASK(25, 24)
  117. +#define MAC_MCR_MAX_RX(_x) (MAC_MCR_MAX_RX_MASK & ((_x) << 24))
  118. +#define MAC_MCR_MAX_RX_1518 0x0
  119. +#define MAC_MCR_MAX_RX_1536 0x1
  120. +#define MAC_MCR_MAX_RX_1552 0x2
  121. +#define MAC_MCR_MAX_RX_2048 0x3
  122. #define MAC_MCR_IPG_CFG (BIT(18) | BIT(16))
  123. #define MAC_MCR_FORCE_MODE BIT(15)
  124. #define MAC_MCR_TX_EN BIT(14)