735-v5.14-13-net-dsa-qca8k-add-GLOBAL_FC-settings-needed-for-qca8.patch 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. From 0fc57e4b5e39461fc0a54aae0afe4241363a7267 Mon Sep 17 00:00:00 2001
  2. From: Ansuel Smith <[email protected]>
  3. Date: Fri, 14 May 2021 23:00:03 +0200
  4. Subject: [PATCH] net: dsa: qca8k: add GLOBAL_FC settings needed for qca8327
  5. Switch qca8327 needs special settings for the GLOBAL_FC_THRES regs.
  6. Signed-off-by: Ansuel Smith <[email protected]>
  7. Signed-off-by: David S. Miller <[email protected]>
  8. ---
  9. drivers/net/dsa/qca8k.c | 10 ++++++++++
  10. drivers/net/dsa/qca8k.h | 6 ++++++
  11. 2 files changed, 16 insertions(+)
  12. --- a/drivers/net/dsa/qca8k.c
  13. +++ b/drivers/net/dsa/qca8k.c
  14. @@ -930,6 +930,16 @@ qca8k_setup(struct dsa_switch *ds)
  15. }
  16. }
  17. + /* Special GLOBAL_FC_THRESH value are needed for ar8327 switch */
  18. + if (priv->switch_id == QCA8K_ID_QCA8327) {
  19. + mask = QCA8K_GLOBAL_FC_GOL_XON_THRES(288) |
  20. + QCA8K_GLOBAL_FC_GOL_XOFF_THRES(496);
  21. + qca8k_rmw(priv, QCA8K_REG_GLOBAL_FC_THRESH,
  22. + QCA8K_GLOBAL_FC_GOL_XON_THRES_S |
  23. + QCA8K_GLOBAL_FC_GOL_XOFF_THRES_S,
  24. + mask);
  25. + }
  26. +
  27. /* Setup our port MTUs to match power on defaults */
  28. for (i = 0; i < QCA8K_NUM_PORTS; i++)
  29. priv->port_mtu[i] = ETH_FRAME_LEN + ETH_FCS_LEN;
  30. --- a/drivers/net/dsa/qca8k.h
  31. +++ b/drivers/net/dsa/qca8k.h
  32. @@ -168,6 +168,12 @@
  33. #define QCA8K_PORT_LOOKUP_STATE GENMASK(18, 16)
  34. #define QCA8K_PORT_LOOKUP_LEARN BIT(20)
  35. +#define QCA8K_REG_GLOBAL_FC_THRESH 0x800
  36. +#define QCA8K_GLOBAL_FC_GOL_XON_THRES(x) ((x) << 16)
  37. +#define QCA8K_GLOBAL_FC_GOL_XON_THRES_S GENMASK(24, 16)
  38. +#define QCA8K_GLOBAL_FC_GOL_XOFF_THRES(x) ((x) << 0)
  39. +#define QCA8K_GLOBAL_FC_GOL_XOFF_THRES_S GENMASK(8, 0)
  40. +
  41. #define QCA8K_REG_PORT_HOL_CTRL0(_i) (0x970 + (_i) * 0x8)
  42. #define QCA8K_PORT_HOL_CTRL0_EG_PRI0_BUF GENMASK(3, 0)
  43. #define QCA8K_PORT_HOL_CTRL0_EG_PRI0(x) ((x) << 0)