070-v5.17-net-dsa-bcm_sf2-refactor-LED-regs-access.patch 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  1. From af30f8eaa8fe4ff1987280f716309711997bd979 Mon Sep 17 00:00:00 2001
  2. From: =?UTF-8?q?Rafa=C5=82=20Mi=C5=82ecki?= <[email protected]>
  3. Date: Wed, 29 Dec 2021 18:16:42 +0100
  4. Subject: [PATCH] net: dsa: bcm_sf2: refactor LED regs access
  5. MIME-Version: 1.0
  6. Content-Type: text/plain; charset=UTF-8
  7. Content-Transfer-Encoding: 8bit
  8. 1. Define more regs. Some switches (e.g. BCM4908) have up to 6 regs.
  9. 2. Add helper for handling non-lineral port <-> reg mappings.
  10. 3. Add support for 12 B LED reg blocks on BCM4908 (different layout)
  11. Complete support for LEDs setup will be implemented once Linux receives
  12. a proper design & implementation for "hardware" LEDs.
  13. Signed-off-by: Rafał Miłecki <[email protected]>
  14. Acked-by: Florian Fainelli <[email protected]>
  15. Link: https://lore.kernel.org/r/[email protected]
  16. Signed-off-by: Jakub Kicinski <[email protected]>
  17. ---
  18. drivers/net/dsa/bcm_sf2.c | 54 ++++++++++++++++++++++++----
  19. drivers/net/dsa/bcm_sf2.h | 10 ++++++
  20. drivers/net/dsa/bcm_sf2_regs.h | 65 +++++++++++++++++++++++++++++++---
  21. 3 files changed, 119 insertions(+), 10 deletions(-)
  22. --- a/drivers/net/dsa/bcm_sf2.c
  23. +++ b/drivers/net/dsa/bcm_sf2.c
  24. @@ -62,6 +62,38 @@ static u16 bcm_sf2_reg_rgmii_cntrl(struc
  25. return REG_SWITCH_STATUS;
  26. }
  27. +static u16 bcm_sf2_reg_led_base(struct bcm_sf2_priv *priv, int port)
  28. +{
  29. + switch (port) {
  30. + case 0:
  31. + return REG_LED_0_CNTRL;
  32. + case 1:
  33. + return REG_LED_1_CNTRL;
  34. + case 2:
  35. + return REG_LED_2_CNTRL;
  36. + }
  37. +
  38. + switch (priv->type) {
  39. + case BCM4908_DEVICE_ID:
  40. + switch (port) {
  41. + case 3:
  42. + return REG_LED_3_CNTRL;
  43. + case 7:
  44. + return REG_LED_4_CNTRL;
  45. + default:
  46. + break;
  47. + }
  48. + break;
  49. + default:
  50. + break;
  51. + }
  52. +
  53. + WARN_ONCE(1, "Unsupported port %d\n", port);
  54. +
  55. + /* RO fallback reg */
  56. + return REG_SWITCH_STATUS;
  57. +}
  58. +
  59. /* Return the number of active ports, not counting the IMP (CPU) port */
  60. static unsigned int bcm_sf2_num_active_ports(struct dsa_switch *ds)
  61. {
  62. @@ -187,9 +219,14 @@ static void bcm_sf2_gphy_enable_set(stru
  63. /* Use PHY-driven LED signaling */
  64. if (!enable) {
  65. - reg = reg_readl(priv, REG_LED_CNTRL(0));
  66. - reg |= SPDLNK_SRC_SEL;
  67. - reg_writel(priv, reg, REG_LED_CNTRL(0));
  68. + u16 led_ctrl = bcm_sf2_reg_led_base(priv, 0);
  69. +
  70. + if (priv->type == BCM7278_DEVICE_ID ||
  71. + priv->type == BCM7445_DEVICE_ID) {
  72. + reg = reg_led_readl(priv, led_ctrl, 0);
  73. + reg |= LED_CNTRL_SPDLNK_SRC_SEL;
  74. + reg_led_writel(priv, reg, led_ctrl, 0);
  75. + }
  76. }
  77. }
  78. @@ -1247,9 +1284,14 @@ static const u16 bcm_sf2_4908_reg_offset
  79. [REG_SPHY_CNTRL] = 0x24,
  80. [REG_CROSSBAR] = 0xc8,
  81. [REG_RGMII_11_CNTRL] = 0x014c,
  82. - [REG_LED_0_CNTRL] = 0x40,
  83. - [REG_LED_1_CNTRL] = 0x4c,
  84. - [REG_LED_2_CNTRL] = 0x58,
  85. + [REG_LED_0_CNTRL] = 0x40,
  86. + [REG_LED_1_CNTRL] = 0x4c,
  87. + [REG_LED_2_CNTRL] = 0x58,
  88. + [REG_LED_3_CNTRL] = 0x64,
  89. + [REG_LED_4_CNTRL] = 0x88,
  90. + [REG_LED_5_CNTRL] = 0xa0,
  91. + [REG_LED_AGGREGATE_CTRL] = 0xb8,
  92. +
  93. };
  94. static const struct bcm_sf2_of_data bcm_sf2_4908_data = {
  95. --- a/drivers/net/dsa/bcm_sf2.h
  96. +++ b/drivers/net/dsa/bcm_sf2.h
  97. @@ -210,6 +210,16 @@ SF2_IO_MACRO(acb);
  98. SWITCH_INTR_L2(0);
  99. SWITCH_INTR_L2(1);
  100. +static inline u32 reg_led_readl(struct bcm_sf2_priv *priv, u16 off, u16 reg)
  101. +{
  102. + return readl_relaxed(priv->reg + priv->reg_offsets[off] + reg);
  103. +}
  104. +
  105. +static inline void reg_led_writel(struct bcm_sf2_priv *priv, u32 val, u16 off, u16 reg)
  106. +{
  107. + writel_relaxed(val, priv->reg + priv->reg_offsets[off] + reg);
  108. +}
  109. +
  110. /* RXNFC */
  111. int bcm_sf2_get_rxnfc(struct dsa_switch *ds, int port,
  112. struct ethtool_rxnfc *nfc, u32 *rule_locs);
  113. --- a/drivers/net/dsa/bcm_sf2_regs.h
  114. +++ b/drivers/net/dsa/bcm_sf2_regs.h
  115. @@ -25,6 +25,10 @@ enum bcm_sf2_reg_offs {
  116. REG_LED_0_CNTRL,
  117. REG_LED_1_CNTRL,
  118. REG_LED_2_CNTRL,
  119. + REG_LED_3_CNTRL,
  120. + REG_LED_4_CNTRL,
  121. + REG_LED_5_CNTRL,
  122. + REG_LED_AGGREGATE_CTRL,
  123. REG_SWITCH_REG_MAX,
  124. };
  125. @@ -56,6 +60,63 @@ enum bcm_sf2_reg_offs {
  126. #define CROSSBAR_BCM4908_EXT_GPHY4 1
  127. #define CROSSBAR_BCM4908_EXT_RGMII 2
  128. +/* Relative to REG_LED_*_CNTRL (BCM7278, BCM7445) */
  129. +#define LED_CNTRL_NO_LINK_ENCODE_SHIFT 0
  130. +#define LED_CNTRL_M10_ENCODE_SHIFT 2
  131. +#define LED_CNTRL_M100_ENCODE_SHIFT 4
  132. +#define LED_CNTRL_M1000_ENCODE_SHIFT 6
  133. +#define LED_CNTRL_SEL_NO_LINK_ENCODE_SHIFT 8
  134. +#define LED_CNTRL_SEL_10M_ENCODE_SHIFT 10
  135. +#define LED_CNTRL_SEL_100M_ENCODE_SHIFT 12
  136. +#define LED_CNTRL_SEL_1000M_ENCODE_SHIFT 14
  137. +#define LED_CNTRL_RX_DV_EN (1 << 16)
  138. +#define LED_CNTRL_TX_EN_EN (1 << 17)
  139. +#define LED_CNTRL_SPDLNK_LED0_ACT_SEL_SHIFT 18
  140. +#define LED_CNTRL_SPDLNK_LED1_ACT_SEL_SHIFT 20
  141. +#define LED_CNTRL_ACT_LED_ACT_SEL_SHIFT 22
  142. +#define LED_CNTRL_SPDLNK_SRC_SEL (1 << 24)
  143. +#define LED_CNTRL_SPDLNK_LED0_ACT_POL_SEL (1 << 25)
  144. +#define LED_CNTRL_SPDLNK_LED1_ACT_POL_SEL (1 << 26)
  145. +#define LED_CNTRL_ACT_LED_POL_SEL (1 << 27)
  146. +#define LED_CNTRL_MASK 0x3
  147. +
  148. +/* Register relative to REG_LED_*_CNTRL (BCM4908) */
  149. +#define REG_LED_CTRL 0x0
  150. +#define LED_CTRL_RX_ACT_EN 0x00000001
  151. +#define LED_CTRL_TX_ACT_EN 0x00000002
  152. +#define LED_CTRL_SPDLNK_LED0_ACT_SEL 0x00000004
  153. +#define LED_CTRL_SPDLNK_LED1_ACT_SEL 0x00000008
  154. +#define LED_CTRL_SPDLNK_LED2_ACT_SEL 0x00000010
  155. +#define LED_CTRL_ACT_LED_ACT_SEL 0x00000020
  156. +#define LED_CTRL_SPDLNK_LED0_ACT_POL_SEL 0x00000040
  157. +#define LED_CTRL_SPDLNK_LED1_ACT_POL_SEL 0x00000080
  158. +#define LED_CTRL_SPDLNK_LED2_ACT_POL_SEL 0x00000100
  159. +#define LED_CTRL_ACT_LED_POL_SEL 0x00000200
  160. +#define LED_CTRL_LED_SPD_OVRD 0x00001c00
  161. +#define LED_CTRL_LNK_STATUS_OVRD 0x00002000
  162. +#define LED_CTRL_SPD_OVRD_EN 0x00004000
  163. +#define LED_CTRL_LNK_OVRD_EN 0x00008000
  164. +
  165. +/* Register relative to REG_LED_*_CNTRL (BCM4908) */
  166. +#define REG_LED_LINK_SPEED_ENC_SEL 0x4
  167. +#define LED_LINK_SPEED_ENC_SEL_NO_LINK_SHIFT 0
  168. +#define LED_LINK_SPEED_ENC_SEL_10M_SHIFT 3
  169. +#define LED_LINK_SPEED_ENC_SEL_100M_SHIFT 6
  170. +#define LED_LINK_SPEED_ENC_SEL_1000M_SHIFT 9
  171. +#define LED_LINK_SPEED_ENC_SEL_2500M_SHIFT 12
  172. +#define LED_LINK_SPEED_ENC_SEL_10G_SHIFT 15
  173. +#define LED_LINK_SPEED_ENC_SEL_MASK 0x7
  174. +
  175. +/* Register relative to REG_LED_*_CNTRL (BCM4908) */
  176. +#define REG_LED_LINK_SPEED_ENC 0x8
  177. +#define LED_LINK_SPEED_ENC_NO_LINK_SHIFT 0
  178. +#define LED_LINK_SPEED_ENC_M10_SHIFT 3
  179. +#define LED_LINK_SPEED_ENC_M100_SHIFT 6
  180. +#define LED_LINK_SPEED_ENC_M1000_SHIFT 9
  181. +#define LED_LINK_SPEED_ENC_M2500_SHIFT 12
  182. +#define LED_LINK_SPEED_ENC_M10G_SHIFT 15
  183. +#define LED_LINK_SPEED_ENC_MASK 0x7
  184. +
  185. /* Relative to REG_RGMII_CNTRL */
  186. #define RGMII_MODE_EN (1 << 0)
  187. #define ID_MODE_DIS (1 << 1)
  188. @@ -73,10 +134,6 @@ enum bcm_sf2_reg_offs {
  189. #define LPI_COUNT_SHIFT 9
  190. #define LPI_COUNT_MASK 0x3F
  191. -#define REG_LED_CNTRL(x) (REG_LED_0_CNTRL + (x))
  192. -
  193. -#define SPDLNK_SRC_SEL (1 << 24)
  194. -
  195. /* Register set relative to 'INTRL2_0' and 'INTRL2_1' */
  196. #define INTRL2_CPU_STATUS 0x00
  197. #define INTRL2_CPU_SET 0x04