1 // SPDX-License-Identifier: GPL-2.0
2 /* Realtek SMI subdriver for the Realtek RTL8365MB-VC ethernet switch.
4 * Copyright (C) 2021 Alvin Šipraga <alsi@bang-olufsen.dk>
5 * Copyright (C) 2021 Michael Rasmussen <mir@bang-olufsen.dk>
7 * The RTL8365MB-VC is a 4+1 port 10/100/1000M switch controller. It includes 4
8 * integrated PHYs for the user facing ports, and an extension interface which
9 * can be connected to the CPU - or another PHY - via either MII, RMII, or
10 * RGMII. The switch is configured via the Realtek Simple Management Interface
11 * (SMI), which uses the MDIO/MDC lines.
13 * Below is a simplified block diagram of the chip and its relevant interfaces.
15 * .-----------------------------------.
17 * UTP <---------------> Giga PHY <-> PCS <-> P0 GMAC |
18 * UTP <---------------> Giga PHY <-> PCS <-> P1 GMAC |
19 * UTP <---------------> Giga PHY <-> PCS <-> P2 GMAC |
20 * UTP <---------------> Giga PHY <-> PCS <-> P3 GMAC |
22 * CPU/PHY <-MII/RMII/RGMII---> Extension <---> Extension |
23 * | interface 1 GMAC 1 |
25 * SMI driver/ <-MDC/SCL---> Management ~~~~~~~~~~~~~~ |
26 * EEPROM <-MDIO/SDA--> interface ~REALTEK ~~~~~ |
29 * GPIO <--------------> Reset ~~~~~~~~~~~~~~ |
31 * Interrupt <----------> Link UP/DOWN events |
33 * '-----------------------------------'
35 * The driver uses DSA to integrate the 4 user and 1 extension ports into the
36 * kernel. Netdevices are created for the user ports, as are PHY devices for
37 * their integrated PHYs. The device tree firmware should also specify the link
38 * partner of the extension port - either via a fixed-link or other phy-handle.
39 * See the device tree bindings for more detailed information. Note that the
40 * driver has only been tested with a fixed-link, but in principle it should not
43 * NOTE: Currently, only the RGMII interface is implemented in this driver.
45 * The interrupt line is asserted on link UP/DOWN events. The driver creates a
46 * custom irqchip to handle this interrupt and demultiplex the events by reading
47 * the status registers via SMI. Interrupts are then propagated to the relevant
50 * The EEPROM contains initial register values which the chip will read over I2C
51 * upon hardware reset. It is also possible to omit the EEPROM. In both cases,
52 * the driver will manually reprogram some registers using jam tables to reach
53 * an initial state defined by the vendor driver.
55 * This Linux driver is written based on an OS-agnostic vendor driver from
56 * Realtek. The reference GPL-licensed sources can be found in the OpenWrt
57 * source tree under the name rtl8367c. The vendor driver claims to support a
58 * number of similar switch controllers from Realtek, but the only hardware we
59 * have is the RTL8365MB-VC. Moreover, there does not seem to be any chip under
60 * the name RTL8367C. Although one wishes that the 'C' stood for some kind of
61 * common hardware revision, there exist examples of chips with the suffix -VC
62 * which are explicitly not supported by the rtl8367c driver and which instead
63 * require the rtl8367d vendor driver. With all this uncertainty, the driver has
64 * been modestly named rtl8365mb. Future implementors may wish to rename things
67 * In the same family of chips, some carry up to 8 user ports and up to 2
68 * extension ports. Where possible this driver tries to make things generic, but
69 * more work must be done to support these configurations. According to
70 * documentation from Realtek, the family should include the following chips:
86 * Some of the register logic for these additional chips has been skipped over
87 * while implementing this driver. It is therefore not possible to assume that
88 * things will work out-of-the-box for other chips, and a careful review of the
89 * vendor driver may be needed to expand support. The RTL8365MB-VC seems to be
90 * one of the simpler chips.
93 #include <linux/bitfield.h>
94 #include <linux/bitops.h>
95 #include <linux/interrupt.h>
96 #include <linux/irqdomain.h>
97 #include <linux/mutex.h>
98 #include <linux/of_irq.h>
99 #include <linux/regmap.h>
100 #include <linux/if_bridge.h>
104 /* Chip-specific data and limits */
105 #define RTL8365MB_CHIP_ID_8365MB_VC 0x6367
106 #define RTL8365MB_CHIP_VER_8365MB_VC 0x0040
108 #define RTL8365MB_CHIP_ID_8367S 0x6367
109 #define RTL8365MB_CHIP_VER_8367S 0x00A0
111 #define RTL8365MB_CHIP_ID_8367RB 0x6367
112 #define RTL8365MB_CHIP_VER_8367RB 0x0020
114 /* Family-specific data and limits */
115 #define RTL8365MB_PHYADDRMAX 7
116 #define RTL8365MB_NUM_PHYREGS 32
117 #define RTL8365MB_PHYREGMAX (RTL8365MB_NUM_PHYREGS - 1)
118 /* RTL8370MB and RTL8310SR, possibly suportable by this driver, have 10 ports */
119 #define RTL8365MB_MAX_NUM_PORTS 10
120 #define RTL8365MB_LEARN_LIMIT_MAX 2112
122 /* valid for all 6-port or less variants */
123 static const int rtl8365mb_extint_port_map[] = { -1, -1, -1, -1, -1, -1, 1, 2, -1, -1};
125 /* Chip identification registers */
126 #define RTL8365MB_CHIP_ID_REG 0x1300
128 #define RTL8365MB_CHIP_VER_REG 0x1301
130 #define RTL8365MB_MAGIC_REG 0x13C2
131 #define RTL8365MB_MAGIC_VALUE 0x0249
133 /* Chip reset register */
134 #define RTL8365MB_CHIP_RESET_REG 0x1322
135 #define RTL8365MB_CHIP_RESET_SW_MASK 0x0002
136 #define RTL8365MB_CHIP_RESET_HW_MASK 0x0001
138 /* Interrupt polarity register */
139 #define RTL8365MB_INTR_POLARITY_REG 0x1100
140 #define RTL8365MB_INTR_POLARITY_MASK 0x0001
141 #define RTL8365MB_INTR_POLARITY_HIGH 0
142 #define RTL8365MB_INTR_POLARITY_LOW 1
144 /* Interrupt control/status register - enable/check specific interrupt types */
145 #define RTL8365MB_INTR_CTRL_REG 0x1101
146 #define RTL8365MB_INTR_STATUS_REG 0x1102
147 #define RTL8365MB_INTR_SLIENT_START_2_MASK 0x1000
148 #define RTL8365MB_INTR_SLIENT_START_MASK 0x0800
149 #define RTL8365MB_INTR_ACL_ACTION_MASK 0x0200
150 #define RTL8365MB_INTR_CABLE_DIAG_FIN_MASK 0x0100
151 #define RTL8365MB_INTR_INTERRUPT_8051_MASK 0x0080
152 #define RTL8365MB_INTR_LOOP_DETECTION_MASK 0x0040
153 #define RTL8365MB_INTR_GREEN_TIMER_MASK 0x0020
154 #define RTL8365MB_INTR_SPECIAL_CONGEST_MASK 0x0010
155 #define RTL8365MB_INTR_SPEED_CHANGE_MASK 0x0008
156 #define RTL8365MB_INTR_LEARN_OVER_MASK 0x0004
157 #define RTL8365MB_INTR_METER_EXCEEDED_MASK 0x0002
158 #define RTL8365MB_INTR_LINK_CHANGE_MASK 0x0001
159 #define RTL8365MB_INTR_ALL_MASK \
160 (RTL8365MB_INTR_SLIENT_START_2_MASK | \
161 RTL8365MB_INTR_SLIENT_START_MASK | \
162 RTL8365MB_INTR_ACL_ACTION_MASK | \
163 RTL8365MB_INTR_CABLE_DIAG_FIN_MASK | \
164 RTL8365MB_INTR_INTERRUPT_8051_MASK | \
165 RTL8365MB_INTR_LOOP_DETECTION_MASK | \
166 RTL8365MB_INTR_GREEN_TIMER_MASK | \
167 RTL8365MB_INTR_SPECIAL_CONGEST_MASK | \
168 RTL8365MB_INTR_SPEED_CHANGE_MASK | \
169 RTL8365MB_INTR_LEARN_OVER_MASK | \
170 RTL8365MB_INTR_METER_EXCEEDED_MASK | \
171 RTL8365MB_INTR_LINK_CHANGE_MASK)
173 /* Per-port interrupt type status registers */
174 #define RTL8365MB_PORT_LINKDOWN_IND_REG 0x1106
175 #define RTL8365MB_PORT_LINKDOWN_IND_MASK 0x07FF
177 #define RTL8365MB_PORT_LINKUP_IND_REG 0x1107
178 #define RTL8365MB_PORT_LINKUP_IND_MASK 0x07FF
180 /* PHY indirect access registers */
181 #define RTL8365MB_INDIRECT_ACCESS_CTRL_REG 0x1F00
182 #define RTL8365MB_INDIRECT_ACCESS_CTRL_RW_MASK 0x0002
183 #define RTL8365MB_INDIRECT_ACCESS_CTRL_RW_READ 0
184 #define RTL8365MB_INDIRECT_ACCESS_CTRL_RW_WRITE 1
185 #define RTL8365MB_INDIRECT_ACCESS_CTRL_CMD_MASK 0x0001
186 #define RTL8365MB_INDIRECT_ACCESS_CTRL_CMD_VALUE 1
187 #define RTL8365MB_INDIRECT_ACCESS_STATUS_REG 0x1F01
188 #define RTL8365MB_INDIRECT_ACCESS_ADDRESS_REG 0x1F02
189 #define RTL8365MB_INDIRECT_ACCESS_ADDRESS_OCPADR_5_1_MASK GENMASK(4, 0)
190 #define RTL8365MB_INDIRECT_ACCESS_ADDRESS_PHYNUM_MASK GENMASK(7, 5)
191 #define RTL8365MB_INDIRECT_ACCESS_ADDRESS_OCPADR_9_6_MASK GENMASK(11, 8)
192 #define RTL8365MB_PHY_BASE 0x2000
193 #define RTL8365MB_INDIRECT_ACCESS_WRITE_DATA_REG 0x1F03
194 #define RTL8365MB_INDIRECT_ACCESS_READ_DATA_REG 0x1F04
196 /* PHY OCP address prefix register */
197 #define RTL8365MB_GPHY_OCP_MSB_0_REG 0x1D15
198 #define RTL8365MB_GPHY_OCP_MSB_0_CFG_CPU_OCPADR_MASK 0x0FC0
199 #define RTL8365MB_PHY_OCP_ADDR_PREFIX_MASK 0xFC00
201 /* The PHY OCP addresses of PHY registers 0~31 start here */
202 #define RTL8365MB_PHY_OCP_ADDR_PHYREG_BASE 0xA400
204 /* EXT interface port mode values - used in DIGITAL_INTERFACE_SELECT */
205 #define RTL8365MB_EXT_PORT_MODE_DISABLE 0
206 #define RTL8365MB_EXT_PORT_MODE_RGMII 1
207 #define RTL8365MB_EXT_PORT_MODE_MII_MAC 2
208 #define RTL8365MB_EXT_PORT_MODE_MII_PHY 3
209 #define RTL8365MB_EXT_PORT_MODE_TMII_MAC 4
210 #define RTL8365MB_EXT_PORT_MODE_TMII_PHY 5
211 #define RTL8365MB_EXT_PORT_MODE_GMII 6
212 #define RTL8365MB_EXT_PORT_MODE_RMII_MAC 7
213 #define RTL8365MB_EXT_PORT_MODE_RMII_PHY 8
214 #define RTL8365MB_EXT_PORT_MODE_SGMII 9
215 #define RTL8365MB_EXT_PORT_MODE_HSGMII 10
216 #define RTL8365MB_EXT_PORT_MODE_1000X_100FX 11
217 #define RTL8365MB_EXT_PORT_MODE_1000X 12
218 #define RTL8365MB_EXT_PORT_MODE_100FX 13
220 /* Realtek docs and driver uses logic number as EXT_PORT0=16, EXT_PORT1=17,
221 * EXT_PORT2=18, to interact with switch ports. That logic number is internally
222 * converted to either a physical port number (0..9) or an external interface id (0..2),
223 * depending on which function was called. The external interface id is calculated as
224 * (ext_id=logic_port-15), while the logical to physical map depends on the chip id/version.
226 * EXT_PORT0 mentioned in datasheets and rtl8367c driver is used in this driver
227 * as extid==1, EXT_PORT2, mentioned in Realtek rtl8367c driver for 10-port switches,
228 * would have an ext_id of 3 (out of range for most extint macros) and ext_id 0 does
229 * not seem to be used as well for this family.
232 /* EXT interface mode configuration registers 0~1 */
233 #define RTL8365MB_DIGITAL_INTERFACE_SELECT_REG0 0x1305 /* EXT1 */
234 #define RTL8365MB_DIGITAL_INTERFACE_SELECT_REG1 0x13C3 /* EXT2 */
235 #define RTL8365MB_DIGITAL_INTERFACE_SELECT_REG(_extint) \
236 ((_extint) == 1 ? RTL8365MB_DIGITAL_INTERFACE_SELECT_REG0 : \
237 (_extint) == 2 ? RTL8365MB_DIGITAL_INTERFACE_SELECT_REG1 : \
239 #define RTL8365MB_DIGITAL_INTERFACE_SELECT_MODE_MASK(_extint) \
240 (0xF << (((_extint) % 2)))
241 #define RTL8365MB_DIGITAL_INTERFACE_SELECT_MODE_OFFSET(_extint) \
242 (((_extint) % 2) * 4)
244 /* EXT interface RGMII TX/RX delay configuration registers 0~2 */
245 #define RTL8365MB_EXT_RGMXF_REG0 0x1306 /* EXT0 */
246 #define RTL8365MB_EXT_RGMXF_REG1 0x1307 /* EXT1 */
247 #define RTL8365MB_EXT_RGMXF_REG2 0x13C5 /* EXT2 */
248 #define RTL8365MB_EXT_RGMXF_REG(_extint) \
249 ((_extint) == 0 ? RTL8365MB_EXT_RGMXF_REG0 : \
250 (_extint) == 1 ? RTL8365MB_EXT_RGMXF_REG1 : \
251 (_extint) == 2 ? RTL8365MB_EXT_RGMXF_REG2 : \
253 #define RTL8365MB_EXT_RGMXF_RXDELAY_MASK 0x0007
254 #define RTL8365MB_EXT_RGMXF_TXDELAY_MASK 0x0008
256 /* External interface port speed values - used in DIGITAL_INTERFACE_FORCE */
257 #define RTL8365MB_PORT_SPEED_10M 0
258 #define RTL8365MB_PORT_SPEED_100M 1
259 #define RTL8365MB_PORT_SPEED_1000M 2
261 /* EXT interface force configuration registers 0~2 */
262 #define RTL8365MB_DIGITAL_INTERFACE_FORCE_REG0 0x1310 /* EXT0 */
263 #define RTL8365MB_DIGITAL_INTERFACE_FORCE_REG1 0x1311 /* EXT1 */
264 #define RTL8365MB_DIGITAL_INTERFACE_FORCE_REG2 0x13C4 /* EXT2 */
265 #define RTL8365MB_DIGITAL_INTERFACE_FORCE_REG(_extint) \
266 ((_extint) == 0 ? RTL8365MB_DIGITAL_INTERFACE_FORCE_REG0 : \
267 (_extint) == 1 ? RTL8365MB_DIGITAL_INTERFACE_FORCE_REG1 : \
268 (_extint) == 2 ? RTL8365MB_DIGITAL_INTERFACE_FORCE_REG2 : \
270 #define RTL8365MB_DIGITAL_INTERFACE_FORCE_EN_MASK 0x1000
271 #define RTL8365MB_DIGITAL_INTERFACE_FORCE_NWAY_MASK 0x0080
272 #define RTL8365MB_DIGITAL_INTERFACE_FORCE_TXPAUSE_MASK 0x0040
273 #define RTL8365MB_DIGITAL_INTERFACE_FORCE_RXPAUSE_MASK 0x0020
274 #define RTL8365MB_DIGITAL_INTERFACE_FORCE_LINK_MASK 0x0010
275 #define RTL8365MB_DIGITAL_INTERFACE_FORCE_DUPLEX_MASK 0x0004
276 #define RTL8365MB_DIGITAL_INTERFACE_FORCE_SPEED_MASK 0x0003
278 /* CPU port mask register - controls which ports are treated as CPU ports */
279 #define RTL8365MB_CPU_PORT_MASK_REG 0x1219
280 #define RTL8365MB_CPU_PORT_MASK_MASK 0x07FF
282 /* CPU control register */
283 #define RTL8365MB_CPU_CTRL_REG 0x121A
284 #define RTL8365MB_CPU_CTRL_TRAP_PORT_EXT_MASK 0x0400
285 #define RTL8365MB_CPU_CTRL_TAG_FORMAT_MASK 0x0200
286 #define RTL8365MB_CPU_CTRL_RXBYTECOUNT_MASK 0x0080
287 #define RTL8365MB_CPU_CTRL_TAG_POSITION_MASK 0x0040
288 #define RTL8365MB_CPU_CTRL_TRAP_PORT_MASK 0x0038
289 #define RTL8365MB_CPU_CTRL_INSERTMODE_MASK 0x0006
290 #define RTL8365MB_CPU_CTRL_EN_MASK 0x0001
292 /* Maximum packet length register */
293 #define RTL8365MB_CFG0_MAX_LEN_REG 0x088C
294 #define RTL8365MB_CFG0_MAX_LEN_MASK 0x3FFF
296 /* Port learning limit registers */
297 #define RTL8365MB_LUT_PORT_LEARN_LIMIT_BASE 0x0A20
298 #define RTL8365MB_LUT_PORT_LEARN_LIMIT_REG(_physport) \
299 (RTL8365MB_LUT_PORT_LEARN_LIMIT_BASE + (_physport))
301 /* Port isolation (forwarding mask) registers */
302 #define RTL8365MB_PORT_ISOLATION_REG_BASE 0x08A2
303 #define RTL8365MB_PORT_ISOLATION_REG(_physport) \
304 (RTL8365MB_PORT_ISOLATION_REG_BASE + (_physport))
305 #define RTL8365MB_PORT_ISOLATION_MASK 0x07FF
307 /* MSTP port state registers - indexed by tree instance */
308 #define RTL8365MB_MSTI_CTRL_BASE 0x0A00
309 #define RTL8365MB_MSTI_CTRL_REG(_msti, _physport) \
310 (RTL8365MB_MSTI_CTRL_BASE + ((_msti) << 1) + ((_physport) >> 3))
311 #define RTL8365MB_MSTI_CTRL_PORT_STATE_OFFSET(_physport) ((_physport) << 1)
312 #define RTL8365MB_MSTI_CTRL_PORT_STATE_MASK(_physport) \
313 (0x3 << RTL8365MB_MSTI_CTRL_PORT_STATE_OFFSET((_physport)))
315 /* MIB counter value registers */
316 #define RTL8365MB_MIB_COUNTER_BASE 0x1000
317 #define RTL8365MB_MIB_COUNTER_REG(_x) (RTL8365MB_MIB_COUNTER_BASE + (_x))
319 /* MIB counter address register */
320 #define RTL8365MB_MIB_ADDRESS_REG 0x1004
321 #define RTL8365MB_MIB_ADDRESS_PORT_OFFSET 0x007C
322 #define RTL8365MB_MIB_ADDRESS(_p, _x) \
323 (((RTL8365MB_MIB_ADDRESS_PORT_OFFSET) * (_p) + (_x)) >> 2)
325 #define RTL8365MB_MIB_CTRL0_REG 0x1005
326 #define RTL8365MB_MIB_CTRL0_RESET_MASK 0x0002
327 #define RTL8365MB_MIB_CTRL0_BUSY_MASK 0x0001
329 /* The DSA callback .get_stats64 runs in atomic context, so we are not allowed
330 * to block. On the other hand, accessing MIB counters absolutely requires us to
331 * block. The solution is thus to schedule work which polls the MIB counters
332 * asynchronously and updates some private data, which the callback can then
333 * fetch atomically. Three seconds should be a good enough polling interval.
335 #define RTL8365MB_STATS_INTERVAL_JIFFIES (3 * HZ)
337 enum rtl8365mb_mib_counter_index {
338 RTL8365MB_MIB_ifInOctets,
339 RTL8365MB_MIB_dot3StatsFCSErrors,
340 RTL8365MB_MIB_dot3StatsSymbolErrors,
341 RTL8365MB_MIB_dot3InPauseFrames,
342 RTL8365MB_MIB_dot3ControlInUnknownOpcodes,
343 RTL8365MB_MIB_etherStatsFragments,
344 RTL8365MB_MIB_etherStatsJabbers,
345 RTL8365MB_MIB_ifInUcastPkts,
346 RTL8365MB_MIB_etherStatsDropEvents,
347 RTL8365MB_MIB_ifInMulticastPkts,
348 RTL8365MB_MIB_ifInBroadcastPkts,
349 RTL8365MB_MIB_inMldChecksumError,
350 RTL8365MB_MIB_inIgmpChecksumError,
351 RTL8365MB_MIB_inMldSpecificQuery,
352 RTL8365MB_MIB_inMldGeneralQuery,
353 RTL8365MB_MIB_inIgmpSpecificQuery,
354 RTL8365MB_MIB_inIgmpGeneralQuery,
355 RTL8365MB_MIB_inMldLeaves,
356 RTL8365MB_MIB_inIgmpLeaves,
357 RTL8365MB_MIB_etherStatsOctets,
358 RTL8365MB_MIB_etherStatsUnderSizePkts,
359 RTL8365MB_MIB_etherOversizeStats,
360 RTL8365MB_MIB_etherStatsPkts64Octets,
361 RTL8365MB_MIB_etherStatsPkts65to127Octets,
362 RTL8365MB_MIB_etherStatsPkts128to255Octets,
363 RTL8365MB_MIB_etherStatsPkts256to511Octets,
364 RTL8365MB_MIB_etherStatsPkts512to1023Octets,
365 RTL8365MB_MIB_etherStatsPkts1024to1518Octets,
366 RTL8365MB_MIB_ifOutOctets,
367 RTL8365MB_MIB_dot3StatsSingleCollisionFrames,
368 RTL8365MB_MIB_dot3StatsMultipleCollisionFrames,
369 RTL8365MB_MIB_dot3StatsDeferredTransmissions,
370 RTL8365MB_MIB_dot3StatsLateCollisions,
371 RTL8365MB_MIB_etherStatsCollisions,
372 RTL8365MB_MIB_dot3StatsExcessiveCollisions,
373 RTL8365MB_MIB_dot3OutPauseFrames,
374 RTL8365MB_MIB_ifOutDiscards,
375 RTL8365MB_MIB_dot1dTpPortInDiscards,
376 RTL8365MB_MIB_ifOutUcastPkts,
377 RTL8365MB_MIB_ifOutMulticastPkts,
378 RTL8365MB_MIB_ifOutBroadcastPkts,
379 RTL8365MB_MIB_outOampduPkts,
380 RTL8365MB_MIB_inOampduPkts,
381 RTL8365MB_MIB_inIgmpJoinsSuccess,
382 RTL8365MB_MIB_inIgmpJoinsFail,
383 RTL8365MB_MIB_inMldJoinsSuccess,
384 RTL8365MB_MIB_inMldJoinsFail,
385 RTL8365MB_MIB_inReportSuppressionDrop,
386 RTL8365MB_MIB_inLeaveSuppressionDrop,
387 RTL8365MB_MIB_outIgmpReports,
388 RTL8365MB_MIB_outIgmpLeaves,
389 RTL8365MB_MIB_outIgmpGeneralQuery,
390 RTL8365MB_MIB_outIgmpSpecificQuery,
391 RTL8365MB_MIB_outMldReports,
392 RTL8365MB_MIB_outMldLeaves,
393 RTL8365MB_MIB_outMldGeneralQuery,
394 RTL8365MB_MIB_outMldSpecificQuery,
395 RTL8365MB_MIB_inKnownMulticastPkts,
399 struct rtl8365mb_mib_counter {
405 #define RTL8365MB_MAKE_MIB_COUNTER(_offset, _length, _name) \
406 [RTL8365MB_MIB_ ## _name] = { _offset, _length, #_name }
408 static struct rtl8365mb_mib_counter rtl8365mb_mib_counters[] = {
409 RTL8365MB_MAKE_MIB_COUNTER(0, 4, ifInOctets),
410 RTL8365MB_MAKE_MIB_COUNTER(4, 2, dot3StatsFCSErrors),
411 RTL8365MB_MAKE_MIB_COUNTER(6, 2, dot3StatsSymbolErrors),
412 RTL8365MB_MAKE_MIB_COUNTER(8, 2, dot3InPauseFrames),
413 RTL8365MB_MAKE_MIB_COUNTER(10, 2, dot3ControlInUnknownOpcodes),
414 RTL8365MB_MAKE_MIB_COUNTER(12, 2, etherStatsFragments),
415 RTL8365MB_MAKE_MIB_COUNTER(14, 2, etherStatsJabbers),
416 RTL8365MB_MAKE_MIB_COUNTER(16, 2, ifInUcastPkts),
417 RTL8365MB_MAKE_MIB_COUNTER(18, 2, etherStatsDropEvents),
418 RTL8365MB_MAKE_MIB_COUNTER(20, 2, ifInMulticastPkts),
419 RTL8365MB_MAKE_MIB_COUNTER(22, 2, ifInBroadcastPkts),
420 RTL8365MB_MAKE_MIB_COUNTER(24, 2, inMldChecksumError),
421 RTL8365MB_MAKE_MIB_COUNTER(26, 2, inIgmpChecksumError),
422 RTL8365MB_MAKE_MIB_COUNTER(28, 2, inMldSpecificQuery),
423 RTL8365MB_MAKE_MIB_COUNTER(30, 2, inMldGeneralQuery),
424 RTL8365MB_MAKE_MIB_COUNTER(32, 2, inIgmpSpecificQuery),
425 RTL8365MB_MAKE_MIB_COUNTER(34, 2, inIgmpGeneralQuery),
426 RTL8365MB_MAKE_MIB_COUNTER(36, 2, inMldLeaves),
427 RTL8365MB_MAKE_MIB_COUNTER(38, 2, inIgmpLeaves),
428 RTL8365MB_MAKE_MIB_COUNTER(40, 4, etherStatsOctets),
429 RTL8365MB_MAKE_MIB_COUNTER(44, 2, etherStatsUnderSizePkts),
430 RTL8365MB_MAKE_MIB_COUNTER(46, 2, etherOversizeStats),
431 RTL8365MB_MAKE_MIB_COUNTER(48, 2, etherStatsPkts64Octets),
432 RTL8365MB_MAKE_MIB_COUNTER(50, 2, etherStatsPkts65to127Octets),
433 RTL8365MB_MAKE_MIB_COUNTER(52, 2, etherStatsPkts128to255Octets),
434 RTL8365MB_MAKE_MIB_COUNTER(54, 2, etherStatsPkts256to511Octets),
435 RTL8365MB_MAKE_MIB_COUNTER(56, 2, etherStatsPkts512to1023Octets),
436 RTL8365MB_MAKE_MIB_COUNTER(58, 2, etherStatsPkts1024to1518Octets),
437 RTL8365MB_MAKE_MIB_COUNTER(60, 4, ifOutOctets),
438 RTL8365MB_MAKE_MIB_COUNTER(64, 2, dot3StatsSingleCollisionFrames),
439 RTL8365MB_MAKE_MIB_COUNTER(66, 2, dot3StatsMultipleCollisionFrames),
440 RTL8365MB_MAKE_MIB_COUNTER(68, 2, dot3StatsDeferredTransmissions),
441 RTL8365MB_MAKE_MIB_COUNTER(70, 2, dot3StatsLateCollisions),
442 RTL8365MB_MAKE_MIB_COUNTER(72, 2, etherStatsCollisions),
443 RTL8365MB_MAKE_MIB_COUNTER(74, 2, dot3StatsExcessiveCollisions),
444 RTL8365MB_MAKE_MIB_COUNTER(76, 2, dot3OutPauseFrames),
445 RTL8365MB_MAKE_MIB_COUNTER(78, 2, ifOutDiscards),
446 RTL8365MB_MAKE_MIB_COUNTER(80, 2, dot1dTpPortInDiscards),
447 RTL8365MB_MAKE_MIB_COUNTER(82, 2, ifOutUcastPkts),
448 RTL8365MB_MAKE_MIB_COUNTER(84, 2, ifOutMulticastPkts),
449 RTL8365MB_MAKE_MIB_COUNTER(86, 2, ifOutBroadcastPkts),
450 RTL8365MB_MAKE_MIB_COUNTER(88, 2, outOampduPkts),
451 RTL8365MB_MAKE_MIB_COUNTER(90, 2, inOampduPkts),
452 RTL8365MB_MAKE_MIB_COUNTER(92, 4, inIgmpJoinsSuccess),
453 RTL8365MB_MAKE_MIB_COUNTER(96, 2, inIgmpJoinsFail),
454 RTL8365MB_MAKE_MIB_COUNTER(98, 2, inMldJoinsSuccess),
455 RTL8365MB_MAKE_MIB_COUNTER(100, 2, inMldJoinsFail),
456 RTL8365MB_MAKE_MIB_COUNTER(102, 2, inReportSuppressionDrop),
457 RTL8365MB_MAKE_MIB_COUNTER(104, 2, inLeaveSuppressionDrop),
458 RTL8365MB_MAKE_MIB_COUNTER(106, 2, outIgmpReports),
459 RTL8365MB_MAKE_MIB_COUNTER(108, 2, outIgmpLeaves),
460 RTL8365MB_MAKE_MIB_COUNTER(110, 2, outIgmpGeneralQuery),
461 RTL8365MB_MAKE_MIB_COUNTER(112, 2, outIgmpSpecificQuery),
462 RTL8365MB_MAKE_MIB_COUNTER(114, 2, outMldReports),
463 RTL8365MB_MAKE_MIB_COUNTER(116, 2, outMldLeaves),
464 RTL8365MB_MAKE_MIB_COUNTER(118, 2, outMldGeneralQuery),
465 RTL8365MB_MAKE_MIB_COUNTER(120, 2, outMldSpecificQuery),
466 RTL8365MB_MAKE_MIB_COUNTER(122, 2, inKnownMulticastPkts),
469 static_assert(ARRAY_SIZE(rtl8365mb_mib_counters) == RTL8365MB_MIB_END);
471 struct rtl8365mb_jam_tbl_entry {
476 /* Lifted from the vendor driver sources */
477 static const struct rtl8365mb_jam_tbl_entry rtl8365mb_init_jam_8365mb_vc[] = {
478 { 0x13EB, 0x15BB }, { 0x1303, 0x06D6 }, { 0x1304, 0x0700 },
479 { 0x13E2, 0x003F }, { 0x13F9, 0x0090 }, { 0x121E, 0x03CA },
480 { 0x1233, 0x0352 }, { 0x1237, 0x00A0 }, { 0x123A, 0x0030 },
481 { 0x1239, 0x0084 }, { 0x0301, 0x1000 }, { 0x1349, 0x001F },
482 { 0x18E0, 0x4004 }, { 0x122B, 0x241C }, { 0x1305, 0xC000 },
486 static const struct rtl8365mb_jam_tbl_entry rtl8365mb_init_jam_common[] = {
487 { 0x1200, 0x7FCB }, { 0x0884, 0x0003 }, { 0x06EB, 0x0001 },
488 { 0x03Fa, 0x0007 }, { 0x08C8, 0x00C0 }, { 0x0A30, 0x020E },
489 { 0x0800, 0x0000 }, { 0x0802, 0x0000 }, { 0x09DA, 0x0013 },
493 enum rtl8365mb_stp_state {
494 RTL8365MB_STP_STATE_DISABLED = 0,
495 RTL8365MB_STP_STATE_BLOCKING = 1,
496 RTL8365MB_STP_STATE_LEARNING = 2,
497 RTL8365MB_STP_STATE_FORWARDING = 3,
500 enum rtl8365mb_cpu_insert {
501 RTL8365MB_CPU_INSERT_TO_ALL = 0,
502 RTL8365MB_CPU_INSERT_TO_TRAPPING = 1,
503 RTL8365MB_CPU_INSERT_TO_NONE = 2,
506 enum rtl8365mb_cpu_position {
507 RTL8365MB_CPU_POS_AFTER_SA = 0,
508 RTL8365MB_CPU_POS_BEFORE_CRC = 1,
511 enum rtl8365mb_cpu_format {
512 RTL8365MB_CPU_FORMAT_8BYTES = 0,
513 RTL8365MB_CPU_FORMAT_4BYTES = 1,
516 enum rtl8365mb_cpu_rxlen {
517 RTL8365MB_CPU_RXLEN_72BYTES = 0,
518 RTL8365MB_CPU_RXLEN_64BYTES = 1,
522 * struct rtl8365mb_cpu - CPU port configuration
523 * @enable: enable/disable hardware insertion of CPU tag in switch->CPU frames
524 * @mask: port mask of ports that parse should parse CPU tags
525 * @trap_port: forward trapped frames to this port
526 * @insert: CPU tag insertion mode in switch->CPU frames
527 * @position: position of CPU tag in frame
528 * @rx_length: minimum CPU RX length
529 * @format: CPU tag format
531 * Represents the CPU tagging and CPU port configuration of the switch. These
532 * settings are configurable at runtime.
534 struct rtl8365mb_cpu {
538 enum rtl8365mb_cpu_insert insert;
539 enum rtl8365mb_cpu_position position;
540 enum rtl8365mb_cpu_rxlen rx_length;
541 enum rtl8365mb_cpu_format format;
545 * struct rtl8365mb_port - private per-port data
546 * @priv: pointer to parent realtek_priv data
547 * @index: DSA port index, same as dsa_port::index
548 * @stats: link statistics populated by rtl8365mb_stats_poll, ready for atomic
549 * access via rtl8365mb_get_stats64
550 * @stats_lock: protect the stats structure during read/update
551 * @mib_work: delayed work for polling MIB counters
553 struct rtl8365mb_port {
554 struct realtek_priv *priv;
556 struct rtnl_link_stats64 stats;
557 spinlock_t stats_lock;
558 struct delayed_work mib_work;
562 * struct rtl8365mb - private chip-specific driver data
563 * @priv: pointer to parent realtek_priv data
564 * @irq: registered IRQ or zero
565 * @chip_id: chip identifier
566 * @chip_ver: chip silicon revision
567 * @port_mask: mask of all ports
568 * @learn_limit_max: maximum number of L2 addresses the chip can learn
569 * @cpu: CPU tagging and CPU port configuration for this chip
570 * @mib_lock: prevent concurrent reads of MIB counters
571 * @ports: per-port data
572 * @jam_table: chip-specific initialization jam table
573 * @jam_size: size of the chip's jam table
575 * Private data for this driver.
578 struct realtek_priv *priv;
584 struct rtl8365mb_cpu cpu;
585 struct mutex mib_lock;
586 struct rtl8365mb_port ports[RTL8365MB_MAX_NUM_PORTS];
587 const struct rtl8365mb_jam_tbl_entry *jam_table;
591 static int rtl8365mb_phy_poll_busy(struct realtek_priv *priv)
595 return regmap_read_poll_timeout(priv->map_nolock,
596 RTL8365MB_INDIRECT_ACCESS_STATUS_REG,
600 static int rtl8365mb_phy_ocp_prepare(struct realtek_priv *priv, int phy,
607 val = FIELD_GET(RTL8365MB_PHY_OCP_ADDR_PREFIX_MASK, ocp_addr);
608 ret = regmap_update_bits(
609 priv->map_nolock, RTL8365MB_GPHY_OCP_MSB_0_REG,
610 RTL8365MB_GPHY_OCP_MSB_0_CFG_CPU_OCPADR_MASK,
611 FIELD_PREP(RTL8365MB_GPHY_OCP_MSB_0_CFG_CPU_OCPADR_MASK, val));
615 /* Set PHY register address */
616 val = RTL8365MB_PHY_BASE;
617 val |= FIELD_PREP(RTL8365MB_INDIRECT_ACCESS_ADDRESS_PHYNUM_MASK, phy);
618 val |= FIELD_PREP(RTL8365MB_INDIRECT_ACCESS_ADDRESS_OCPADR_5_1_MASK,
620 val |= FIELD_PREP(RTL8365MB_INDIRECT_ACCESS_ADDRESS_OCPADR_9_6_MASK,
622 ret = regmap_write(priv->map_nolock,
623 RTL8365MB_INDIRECT_ACCESS_ADDRESS_REG, val);
630 static int rtl8365mb_phy_ocp_read(struct realtek_priv *priv, int phy,
631 u32 ocp_addr, u16 *data)
636 mutex_lock(&priv->map_lock);
638 ret = rtl8365mb_phy_poll_busy(priv);
642 ret = rtl8365mb_phy_ocp_prepare(priv, phy, ocp_addr);
646 /* Execute read operation */
647 val = FIELD_PREP(RTL8365MB_INDIRECT_ACCESS_CTRL_CMD_MASK,
648 RTL8365MB_INDIRECT_ACCESS_CTRL_CMD_VALUE) |
649 FIELD_PREP(RTL8365MB_INDIRECT_ACCESS_CTRL_RW_MASK,
650 RTL8365MB_INDIRECT_ACCESS_CTRL_RW_READ);
651 ret = regmap_write(priv->map_nolock, RTL8365MB_INDIRECT_ACCESS_CTRL_REG,
656 ret = rtl8365mb_phy_poll_busy(priv);
660 /* Get PHY register data */
661 ret = regmap_read(priv->map_nolock,
662 RTL8365MB_INDIRECT_ACCESS_READ_DATA_REG, &val);
666 *data = val & 0xFFFF;
669 mutex_unlock(&priv->map_lock);
674 static int rtl8365mb_phy_ocp_write(struct realtek_priv *priv, int phy,
675 u32 ocp_addr, u16 data)
680 mutex_lock(&priv->map_lock);
682 ret = rtl8365mb_phy_poll_busy(priv);
686 ret = rtl8365mb_phy_ocp_prepare(priv, phy, ocp_addr);
690 /* Set PHY register data */
691 ret = regmap_write(priv->map_nolock,
692 RTL8365MB_INDIRECT_ACCESS_WRITE_DATA_REG, data);
696 /* Execute write operation */
697 val = FIELD_PREP(RTL8365MB_INDIRECT_ACCESS_CTRL_CMD_MASK,
698 RTL8365MB_INDIRECT_ACCESS_CTRL_CMD_VALUE) |
699 FIELD_PREP(RTL8365MB_INDIRECT_ACCESS_CTRL_RW_MASK,
700 RTL8365MB_INDIRECT_ACCESS_CTRL_RW_WRITE);
701 ret = regmap_write(priv->map_nolock, RTL8365MB_INDIRECT_ACCESS_CTRL_REG,
706 ret = rtl8365mb_phy_poll_busy(priv);
711 mutex_unlock(&priv->map_lock);
716 static int rtl8365mb_phy_read(struct realtek_priv *priv, int phy, int regnum)
722 if (phy > RTL8365MB_PHYADDRMAX)
725 if (regnum > RTL8365MB_PHYREGMAX)
728 ocp_addr = RTL8365MB_PHY_OCP_ADDR_PHYREG_BASE + regnum * 2;
730 ret = rtl8365mb_phy_ocp_read(priv, phy, ocp_addr, &val);
733 "failed to read PHY%d reg %02x @ %04x, ret %d\n", phy,
734 regnum, ocp_addr, ret);
738 dev_dbg(priv->dev, "read PHY%d register 0x%02x @ %04x, val <- %04x\n",
739 phy, regnum, ocp_addr, val);
744 static int rtl8365mb_phy_write(struct realtek_priv *priv, int phy, int regnum,
750 if (phy > RTL8365MB_PHYADDRMAX)
753 if (regnum > RTL8365MB_PHYREGMAX)
756 ocp_addr = RTL8365MB_PHY_OCP_ADDR_PHYREG_BASE + regnum * 2;
758 ret = rtl8365mb_phy_ocp_write(priv, phy, ocp_addr, val);
761 "failed to write PHY%d reg %02x @ %04x, ret %d\n", phy,
762 regnum, ocp_addr, ret);
766 dev_dbg(priv->dev, "write PHY%d register 0x%02x @ %04x, val -> %04x\n",
767 phy, regnum, ocp_addr, val);
772 static int rtl8365mb_dsa_phy_read(struct dsa_switch *ds, int phy, int regnum)
774 return rtl8365mb_phy_read(ds->priv, phy, regnum);
777 static int rtl8365mb_dsa_phy_write(struct dsa_switch *ds, int phy, int regnum,
780 return rtl8365mb_phy_write(ds->priv, phy, regnum, val);
783 static enum dsa_tag_protocol
784 rtl8365mb_get_tag_protocol(struct dsa_switch *ds, int port,
785 enum dsa_tag_protocol mp)
787 struct realtek_priv *priv = ds->priv;
788 struct rtl8365mb_cpu *cpu;
789 struct rtl8365mb *mb;
791 mb = priv->chip_data;
794 if (cpu->position == RTL8365MB_CPU_POS_BEFORE_CRC)
795 return DSA_TAG_PROTO_RTL8_4T;
797 return DSA_TAG_PROTO_RTL8_4;
800 static int rtl8365mb_ext_config_rgmii(struct realtek_priv *priv, int port,
801 phy_interface_t interface)
803 struct device_node *dn;
811 ext_int = rtl8365mb_extint_port_map[port];
814 dev_err(priv->dev, "Port %d is not an external interface port\n", port);
818 dp = dsa_to_port(priv->ds, port);
821 /* Set the RGMII TX/RX delay
823 * The Realtek vendor driver indicates the following possible
824 * configuration settings:
827 * 0 = no delay, 1 = 2 ns delay
829 * 0 = no delay, 7 = maximum delay
830 * Each step is approximately 0.3 ns, so the maximum delay is about
833 * The vendor driver also states that this must be configured *before*
834 * forcing the external interface into a particular mode, which is done
835 * in the rtl8365mb_phylink_mac_link_{up,down} functions.
837 * Only configure an RGMII TX (resp. RX) delay if the
838 * tx-internal-delay-ps (resp. rx-internal-delay-ps) OF property is
839 * specified. We ignore the detail of the RGMII interface mode
840 * (RGMII_{RXID, TXID, etc.}), as this is considered to be a PHY-only
843 if (!of_property_read_u32(dn, "tx-internal-delay-ps", &val)) {
844 val = val / 1000; /* convert to ns */
846 if (val == 0 || val == 2)
850 "EXT interface TX delay must be 0 or 2 ns\n");
853 if (!of_property_read_u32(dn, "rx-internal-delay-ps", &val)) {
854 val = DIV_ROUND_CLOSEST(val, 300); /* convert to 0.3 ns step */
860 "EXT interface RX delay must be 0 to 2.1 ns\n");
863 ret = regmap_update_bits(
864 priv->map, RTL8365MB_EXT_RGMXF_REG(ext_int),
865 RTL8365MB_EXT_RGMXF_TXDELAY_MASK |
866 RTL8365MB_EXT_RGMXF_RXDELAY_MASK,
867 FIELD_PREP(RTL8365MB_EXT_RGMXF_TXDELAY_MASK, tx_delay) |
868 FIELD_PREP(RTL8365MB_EXT_RGMXF_RXDELAY_MASK, rx_delay));
872 ret = regmap_update_bits(
873 priv->map, RTL8365MB_DIGITAL_INTERFACE_SELECT_REG(ext_int),
874 RTL8365MB_DIGITAL_INTERFACE_SELECT_MODE_MASK(ext_int),
875 RTL8365MB_EXT_PORT_MODE_RGMII
876 << RTL8365MB_DIGITAL_INTERFACE_SELECT_MODE_OFFSET(
884 static int rtl8365mb_ext_config_forcemode(struct realtek_priv *priv, int port,
885 bool link, int speed, int duplex,
886 bool tx_pause, bool rx_pause)
897 ext_int = rtl8365mb_extint_port_map[port];
900 dev_err(priv->dev, "Port %d is not an external interface port\n", port);
905 /* Force the link up with the desired configuration */
907 r_rx_pause = rx_pause ? 1 : 0;
908 r_tx_pause = tx_pause ? 1 : 0;
910 if (speed == SPEED_1000) {
911 r_speed = RTL8365MB_PORT_SPEED_1000M;
912 } else if (speed == SPEED_100) {
913 r_speed = RTL8365MB_PORT_SPEED_100M;
914 } else if (speed == SPEED_10) {
915 r_speed = RTL8365MB_PORT_SPEED_10M;
917 dev_err(priv->dev, "unsupported port speed %s\n",
918 phy_speed_to_str(speed));
922 if (duplex == DUPLEX_FULL) {
924 } else if (duplex == DUPLEX_HALF) {
927 dev_err(priv->dev, "unsupported duplex %s\n",
928 phy_duplex_to_str(duplex));
932 /* Force the link down and reset any programmed configuration */
940 val = FIELD_PREP(RTL8365MB_DIGITAL_INTERFACE_FORCE_EN_MASK, 1) |
941 FIELD_PREP(RTL8365MB_DIGITAL_INTERFACE_FORCE_TXPAUSE_MASK,
943 FIELD_PREP(RTL8365MB_DIGITAL_INTERFACE_FORCE_RXPAUSE_MASK,
945 FIELD_PREP(RTL8365MB_DIGITAL_INTERFACE_FORCE_LINK_MASK, r_link) |
946 FIELD_PREP(RTL8365MB_DIGITAL_INTERFACE_FORCE_DUPLEX_MASK,
948 FIELD_PREP(RTL8365MB_DIGITAL_INTERFACE_FORCE_SPEED_MASK, r_speed);
949 ret = regmap_write(priv->map,
950 RTL8365MB_DIGITAL_INTERFACE_FORCE_REG(ext_int),
958 static bool rtl8365mb_phy_mode_supported(struct dsa_switch *ds, int port,
959 phy_interface_t interface)
963 ext_int = rtl8365mb_extint_port_map[port];
966 (interface == PHY_INTERFACE_MODE_NA ||
967 interface == PHY_INTERFACE_MODE_INTERNAL ||
968 interface == PHY_INTERFACE_MODE_GMII))
971 else if ((ext_int >= 1) &&
972 phy_interface_mode_is_rgmii(interface))
979 static void rtl8365mb_phylink_get_caps(struct dsa_switch *ds, int port,
980 struct phylink_config *config)
982 if (dsa_is_user_port(ds, port))
983 __set_bit(PHY_INTERFACE_MODE_INTERNAL,
984 config->supported_interfaces);
985 else if (dsa_is_cpu_port(ds, port))
986 phy_interface_set_rgmii(config->supported_interfaces);
988 config->mac_capabilities = MAC_SYM_PAUSE | MAC_ASYM_PAUSE |
989 MAC_10 | MAC_100 | MAC_1000FD;
992 static void rtl8365mb_phylink_mac_config(struct dsa_switch *ds, int port,
994 const struct phylink_link_state *state)
996 struct realtek_priv *priv = ds->priv;
999 if (!rtl8365mb_phy_mode_supported(ds, port, state->interface)) {
1000 dev_err(priv->dev, "phy mode %s is unsupported on port %d\n",
1001 phy_modes(state->interface), port);
1005 if (mode != MLO_AN_PHY && mode != MLO_AN_FIXED) {
1007 "port %d supports only conventional PHY or fixed-link\n",
1012 if (phy_interface_mode_is_rgmii(state->interface)) {
1013 ret = rtl8365mb_ext_config_rgmii(priv, port, state->interface);
1016 "failed to configure RGMII mode on port %d: %d\n",
1021 /* TODO: Implement MII and RMII modes, which the RTL8365MB-VC also
1026 static void rtl8365mb_phylink_mac_link_down(struct dsa_switch *ds, int port,
1028 phy_interface_t interface)
1030 struct realtek_priv *priv = ds->priv;
1031 struct rtl8365mb_port *p;
1032 struct rtl8365mb *mb;
1035 mb = priv->chip_data;
1036 p = &mb->ports[port];
1037 cancel_delayed_work_sync(&p->mib_work);
1039 if (phy_interface_mode_is_rgmii(interface)) {
1040 ret = rtl8365mb_ext_config_forcemode(priv, port, false, 0, 0,
1044 "failed to reset forced mode on port %d: %d\n",
1051 static void rtl8365mb_phylink_mac_link_up(struct dsa_switch *ds, int port,
1053 phy_interface_t interface,
1054 struct phy_device *phydev, int speed,
1055 int duplex, bool tx_pause,
1058 struct realtek_priv *priv = ds->priv;
1059 struct rtl8365mb_port *p;
1060 struct rtl8365mb *mb;
1063 mb = priv->chip_data;
1064 p = &mb->ports[port];
1065 schedule_delayed_work(&p->mib_work, 0);
1067 if (phy_interface_mode_is_rgmii(interface)) {
1068 ret = rtl8365mb_ext_config_forcemode(priv, port, true, speed,
1073 "failed to force mode on port %d: %d\n", port,
1080 static void rtl8365mb_port_stp_state_set(struct dsa_switch *ds, int port,
1083 struct realtek_priv *priv = ds->priv;
1084 enum rtl8365mb_stp_state val;
1088 case BR_STATE_DISABLED:
1089 val = RTL8365MB_STP_STATE_DISABLED;
1091 case BR_STATE_BLOCKING:
1092 case BR_STATE_LISTENING:
1093 val = RTL8365MB_STP_STATE_BLOCKING;
1095 case BR_STATE_LEARNING:
1096 val = RTL8365MB_STP_STATE_LEARNING;
1098 case BR_STATE_FORWARDING:
1099 val = RTL8365MB_STP_STATE_FORWARDING;
1102 dev_err(priv->dev, "invalid STP state: %u\n", state);
1106 regmap_update_bits(priv->map, RTL8365MB_MSTI_CTRL_REG(msti, port),
1107 RTL8365MB_MSTI_CTRL_PORT_STATE_MASK(port),
1108 val << RTL8365MB_MSTI_CTRL_PORT_STATE_OFFSET(port));
1111 static int rtl8365mb_port_set_learning(struct realtek_priv *priv, int port,
1114 struct rtl8365mb *mb = priv->chip_data;
1116 /* Enable/disable learning by limiting the number of L2 addresses the
1117 * port can learn. Realtek documentation states that a limit of zero
1118 * disables learning. When enabling learning, set it to the chip's
1121 return regmap_write(priv->map, RTL8365MB_LUT_PORT_LEARN_LIMIT_REG(port),
1122 enable ? mb->learn_limit_max : 0);
1125 static int rtl8365mb_port_set_isolation(struct realtek_priv *priv, int port,
1128 return regmap_write(priv->map, RTL8365MB_PORT_ISOLATION_REG(port), mask);
1131 static int rtl8365mb_mib_counter_read(struct realtek_priv *priv, int port,
1132 u32 offset, u32 length, u64 *mibvalue)
1139 /* The MIB address is an SRAM address. We request a particular address
1140 * and then poll the control register before reading the value from some
1141 * counter registers.
1143 ret = regmap_write(priv->map, RTL8365MB_MIB_ADDRESS_REG,
1144 RTL8365MB_MIB_ADDRESS(port, offset));
1148 /* Poll for completion */
1149 ret = regmap_read_poll_timeout(priv->map, RTL8365MB_MIB_CTRL0_REG, val,
1150 !(val & RTL8365MB_MIB_CTRL0_BUSY_MASK),
1155 /* Presumably this indicates a MIB counter read failure */
1156 if (val & RTL8365MB_MIB_CTRL0_RESET_MASK)
1159 /* There are four MIB counter registers each holding a 16 bit word of a
1160 * MIB counter. Depending on the offset, we should read from the upper
1161 * two or lower two registers. In case the MIB counter is 4 words, we
1162 * read from all four registers.
1167 offset = (offset + 1) % 4;
1169 /* Read the MIB counter 16 bits at a time */
1170 for (i = 0; i < length; i++) {
1171 ret = regmap_read(priv->map,
1172 RTL8365MB_MIB_COUNTER_REG(offset - i), &val);
1176 tmpvalue = ((tmpvalue) << 16) | (val & 0xFFFF);
1179 /* Only commit the result if no error occurred */
1180 *mibvalue = tmpvalue;
1185 static void rtl8365mb_get_ethtool_stats(struct dsa_switch *ds, int port, u64 *data)
1187 struct realtek_priv *priv = ds->priv;
1188 struct rtl8365mb *mb;
1192 mb = priv->chip_data;
1194 mutex_lock(&mb->mib_lock);
1195 for (i = 0; i < RTL8365MB_MIB_END; i++) {
1196 struct rtl8365mb_mib_counter *mib = &rtl8365mb_mib_counters[i];
1198 ret = rtl8365mb_mib_counter_read(priv, port, mib->offset,
1199 mib->length, &data[i]);
1202 "failed to read port %d counters: %d\n", port,
1207 mutex_unlock(&mb->mib_lock);
1210 static void rtl8365mb_get_strings(struct dsa_switch *ds, int port, u32 stringset, u8 *data)
1214 if (stringset != ETH_SS_STATS)
1217 for (i = 0; i < RTL8365MB_MIB_END; i++) {
1218 struct rtl8365mb_mib_counter *mib = &rtl8365mb_mib_counters[i];
1220 strncpy(data + i * ETH_GSTRING_LEN, mib->name, ETH_GSTRING_LEN);
1224 static int rtl8365mb_get_sset_count(struct dsa_switch *ds, int port, int sset)
1226 if (sset != ETH_SS_STATS)
1229 return RTL8365MB_MIB_END;
1232 static void rtl8365mb_get_phy_stats(struct dsa_switch *ds, int port,
1233 struct ethtool_eth_phy_stats *phy_stats)
1235 struct realtek_priv *priv = ds->priv;
1236 struct rtl8365mb_mib_counter *mib;
1237 struct rtl8365mb *mb;
1239 mb = priv->chip_data;
1240 mib = &rtl8365mb_mib_counters[RTL8365MB_MIB_dot3StatsSymbolErrors];
1242 mutex_lock(&mb->mib_lock);
1243 rtl8365mb_mib_counter_read(priv, port, mib->offset, mib->length,
1244 &phy_stats->SymbolErrorDuringCarrier);
1245 mutex_unlock(&mb->mib_lock);
1248 static void rtl8365mb_get_mac_stats(struct dsa_switch *ds, int port,
1249 struct ethtool_eth_mac_stats *mac_stats)
1251 u64 cnt[RTL8365MB_MIB_END] = {
1252 [RTL8365MB_MIB_ifOutOctets] = 1,
1253 [RTL8365MB_MIB_ifOutUcastPkts] = 1,
1254 [RTL8365MB_MIB_ifOutMulticastPkts] = 1,
1255 [RTL8365MB_MIB_ifOutBroadcastPkts] = 1,
1256 [RTL8365MB_MIB_dot3OutPauseFrames] = 1,
1257 [RTL8365MB_MIB_ifOutDiscards] = 1,
1258 [RTL8365MB_MIB_ifInOctets] = 1,
1259 [RTL8365MB_MIB_ifInUcastPkts] = 1,
1260 [RTL8365MB_MIB_ifInMulticastPkts] = 1,
1261 [RTL8365MB_MIB_ifInBroadcastPkts] = 1,
1262 [RTL8365MB_MIB_dot3InPauseFrames] = 1,
1263 [RTL8365MB_MIB_dot3StatsSingleCollisionFrames] = 1,
1264 [RTL8365MB_MIB_dot3StatsMultipleCollisionFrames] = 1,
1265 [RTL8365MB_MIB_dot3StatsFCSErrors] = 1,
1266 [RTL8365MB_MIB_dot3StatsDeferredTransmissions] = 1,
1267 [RTL8365MB_MIB_dot3StatsLateCollisions] = 1,
1268 [RTL8365MB_MIB_dot3StatsExcessiveCollisions] = 1,
1271 struct realtek_priv *priv = ds->priv;
1272 struct rtl8365mb *mb;
1276 mb = priv->chip_data;
1278 mutex_lock(&mb->mib_lock);
1279 for (i = 0; i < RTL8365MB_MIB_END; i++) {
1280 struct rtl8365mb_mib_counter *mib = &rtl8365mb_mib_counters[i];
1282 /* Only fetch required MIB counters (marked = 1 above) */
1286 ret = rtl8365mb_mib_counter_read(priv, port, mib->offset,
1287 mib->length, &cnt[i]);
1291 mutex_unlock(&mb->mib_lock);
1293 /* The RTL8365MB-VC exposes MIB objects, which we have to translate into
1294 * IEEE 802.3 Managed Objects. This is not always completely faithful,
1295 * but we try out best. See RFC 3635 for a detailed treatment of the
1299 mac_stats->FramesTransmittedOK = cnt[RTL8365MB_MIB_ifOutUcastPkts] +
1300 cnt[RTL8365MB_MIB_ifOutMulticastPkts] +
1301 cnt[RTL8365MB_MIB_ifOutBroadcastPkts] +
1302 cnt[RTL8365MB_MIB_dot3OutPauseFrames] -
1303 cnt[RTL8365MB_MIB_ifOutDiscards];
1304 mac_stats->SingleCollisionFrames =
1305 cnt[RTL8365MB_MIB_dot3StatsSingleCollisionFrames];
1306 mac_stats->MultipleCollisionFrames =
1307 cnt[RTL8365MB_MIB_dot3StatsMultipleCollisionFrames];
1308 mac_stats->FramesReceivedOK = cnt[RTL8365MB_MIB_ifInUcastPkts] +
1309 cnt[RTL8365MB_MIB_ifInMulticastPkts] +
1310 cnt[RTL8365MB_MIB_ifInBroadcastPkts] +
1311 cnt[RTL8365MB_MIB_dot3InPauseFrames];
1312 mac_stats->FrameCheckSequenceErrors =
1313 cnt[RTL8365MB_MIB_dot3StatsFCSErrors];
1314 mac_stats->OctetsTransmittedOK = cnt[RTL8365MB_MIB_ifOutOctets] -
1315 18 * mac_stats->FramesTransmittedOK;
1316 mac_stats->FramesWithDeferredXmissions =
1317 cnt[RTL8365MB_MIB_dot3StatsDeferredTransmissions];
1318 mac_stats->LateCollisions = cnt[RTL8365MB_MIB_dot3StatsLateCollisions];
1319 mac_stats->FramesAbortedDueToXSColls =
1320 cnt[RTL8365MB_MIB_dot3StatsExcessiveCollisions];
1321 mac_stats->OctetsReceivedOK = cnt[RTL8365MB_MIB_ifInOctets] -
1322 18 * mac_stats->FramesReceivedOK;
1323 mac_stats->MulticastFramesXmittedOK =
1324 cnt[RTL8365MB_MIB_ifOutMulticastPkts];
1325 mac_stats->BroadcastFramesXmittedOK =
1326 cnt[RTL8365MB_MIB_ifOutBroadcastPkts];
1327 mac_stats->MulticastFramesReceivedOK =
1328 cnt[RTL8365MB_MIB_ifInMulticastPkts];
1329 mac_stats->BroadcastFramesReceivedOK =
1330 cnt[RTL8365MB_MIB_ifInBroadcastPkts];
1333 static void rtl8365mb_get_ctrl_stats(struct dsa_switch *ds, int port,
1334 struct ethtool_eth_ctrl_stats *ctrl_stats)
1336 struct realtek_priv *priv = ds->priv;
1337 struct rtl8365mb_mib_counter *mib;
1338 struct rtl8365mb *mb;
1340 mb = priv->chip_data;
1341 mib = &rtl8365mb_mib_counters[RTL8365MB_MIB_dot3ControlInUnknownOpcodes];
1343 mutex_lock(&mb->mib_lock);
1344 rtl8365mb_mib_counter_read(priv, port, mib->offset, mib->length,
1345 &ctrl_stats->UnsupportedOpcodesReceived);
1346 mutex_unlock(&mb->mib_lock);
1349 static void rtl8365mb_stats_update(struct realtek_priv *priv, int port)
1351 u64 cnt[RTL8365MB_MIB_END] = {
1352 [RTL8365MB_MIB_ifOutOctets] = 1,
1353 [RTL8365MB_MIB_ifOutUcastPkts] = 1,
1354 [RTL8365MB_MIB_ifOutMulticastPkts] = 1,
1355 [RTL8365MB_MIB_ifOutBroadcastPkts] = 1,
1356 [RTL8365MB_MIB_ifOutDiscards] = 1,
1357 [RTL8365MB_MIB_ifInOctets] = 1,
1358 [RTL8365MB_MIB_ifInUcastPkts] = 1,
1359 [RTL8365MB_MIB_ifInMulticastPkts] = 1,
1360 [RTL8365MB_MIB_ifInBroadcastPkts] = 1,
1361 [RTL8365MB_MIB_etherStatsDropEvents] = 1,
1362 [RTL8365MB_MIB_etherStatsCollisions] = 1,
1363 [RTL8365MB_MIB_etherStatsFragments] = 1,
1364 [RTL8365MB_MIB_etherStatsJabbers] = 1,
1365 [RTL8365MB_MIB_dot3StatsFCSErrors] = 1,
1366 [RTL8365MB_MIB_dot3StatsLateCollisions] = 1,
1368 struct rtl8365mb *mb = priv->chip_data;
1369 struct rtnl_link_stats64 *stats;
1373 stats = &mb->ports[port].stats;
1375 mutex_lock(&mb->mib_lock);
1376 for (i = 0; i < RTL8365MB_MIB_END; i++) {
1377 struct rtl8365mb_mib_counter *c = &rtl8365mb_mib_counters[i];
1379 /* Only fetch required MIB counters (marked = 1 above) */
1383 ret = rtl8365mb_mib_counter_read(priv, port, c->offset,
1384 c->length, &cnt[i]);
1388 mutex_unlock(&mb->mib_lock);
1390 /* Don't update statistics if there was an error reading the counters */
1394 spin_lock(&mb->ports[port].stats_lock);
1396 stats->rx_packets = cnt[RTL8365MB_MIB_ifInUcastPkts] +
1397 cnt[RTL8365MB_MIB_ifInMulticastPkts] +
1398 cnt[RTL8365MB_MIB_ifInBroadcastPkts] -
1399 cnt[RTL8365MB_MIB_ifOutDiscards];
1401 stats->tx_packets = cnt[RTL8365MB_MIB_ifOutUcastPkts] +
1402 cnt[RTL8365MB_MIB_ifOutMulticastPkts] +
1403 cnt[RTL8365MB_MIB_ifOutBroadcastPkts];
1405 /* if{In,Out}Octets includes FCS - remove it */
1406 stats->rx_bytes = cnt[RTL8365MB_MIB_ifInOctets] - 4 * stats->rx_packets;
1408 cnt[RTL8365MB_MIB_ifOutOctets] - 4 * stats->tx_packets;
1410 stats->rx_dropped = cnt[RTL8365MB_MIB_etherStatsDropEvents];
1411 stats->tx_dropped = cnt[RTL8365MB_MIB_ifOutDiscards];
1413 stats->multicast = cnt[RTL8365MB_MIB_ifInMulticastPkts];
1414 stats->collisions = cnt[RTL8365MB_MIB_etherStatsCollisions];
1416 stats->rx_length_errors = cnt[RTL8365MB_MIB_etherStatsFragments] +
1417 cnt[RTL8365MB_MIB_etherStatsJabbers];
1418 stats->rx_crc_errors = cnt[RTL8365MB_MIB_dot3StatsFCSErrors];
1419 stats->rx_errors = stats->rx_length_errors + stats->rx_crc_errors;
1421 stats->tx_aborted_errors = cnt[RTL8365MB_MIB_ifOutDiscards];
1422 stats->tx_window_errors = cnt[RTL8365MB_MIB_dot3StatsLateCollisions];
1423 stats->tx_errors = stats->tx_aborted_errors + stats->tx_window_errors;
1425 spin_unlock(&mb->ports[port].stats_lock);
1428 static void rtl8365mb_stats_poll(struct work_struct *work)
1430 struct rtl8365mb_port *p = container_of(to_delayed_work(work),
1431 struct rtl8365mb_port,
1433 struct realtek_priv *priv = p->priv;
1435 rtl8365mb_stats_update(priv, p->index);
1437 schedule_delayed_work(&p->mib_work, RTL8365MB_STATS_INTERVAL_JIFFIES);
1440 static void rtl8365mb_get_stats64(struct dsa_switch *ds, int port,
1441 struct rtnl_link_stats64 *s)
1443 struct realtek_priv *priv = ds->priv;
1444 struct rtl8365mb_port *p;
1445 struct rtl8365mb *mb;
1447 mb = priv->chip_data;
1448 p = &mb->ports[port];
1450 spin_lock(&p->stats_lock);
1451 memcpy(s, &p->stats, sizeof(*s));
1452 spin_unlock(&p->stats_lock);
1455 static void rtl8365mb_stats_setup(struct realtek_priv *priv)
1457 struct rtl8365mb *mb = priv->chip_data;
1460 /* Per-chip global mutex to protect MIB counter access, since doing
1461 * so requires accessing a series of registers in a particular order.
1463 mutex_init(&mb->mib_lock);
1465 for (i = 0; i < priv->num_ports; i++) {
1466 struct rtl8365mb_port *p = &mb->ports[i];
1468 if (dsa_is_unused_port(priv->ds, i))
1471 /* Per-port spinlock to protect the stats64 data */
1472 spin_lock_init(&p->stats_lock);
1474 /* This work polls the MIB counters and keeps the stats64 data
1477 INIT_DELAYED_WORK(&p->mib_work, rtl8365mb_stats_poll);
1481 static void rtl8365mb_stats_teardown(struct realtek_priv *priv)
1483 struct rtl8365mb *mb = priv->chip_data;
1486 for (i = 0; i < priv->num_ports; i++) {
1487 struct rtl8365mb_port *p = &mb->ports[i];
1489 if (dsa_is_unused_port(priv->ds, i))
1492 cancel_delayed_work_sync(&p->mib_work);
1496 static int rtl8365mb_get_and_clear_status_reg(struct realtek_priv *priv, u32 reg,
1501 ret = regmap_read(priv->map, reg, val);
1505 return regmap_write(priv->map, reg, *val);
1508 static irqreturn_t rtl8365mb_irq(int irq, void *data)
1510 struct realtek_priv *priv = data;
1511 unsigned long line_changes = 0;
1512 struct rtl8365mb *mb;
1517 mb = priv->chip_data;
1519 ret = rtl8365mb_get_and_clear_status_reg(priv, RTL8365MB_INTR_STATUS_REG,
1524 if (stat & RTL8365MB_INTR_LINK_CHANGE_MASK) {
1529 ret = rtl8365mb_get_and_clear_status_reg(
1530 priv, RTL8365MB_PORT_LINKUP_IND_REG, &val);
1534 linkup_ind = FIELD_GET(RTL8365MB_PORT_LINKUP_IND_MASK, val);
1536 ret = rtl8365mb_get_and_clear_status_reg(
1537 priv, RTL8365MB_PORT_LINKDOWN_IND_REG, &val);
1541 linkdown_ind = FIELD_GET(RTL8365MB_PORT_LINKDOWN_IND_MASK, val);
1543 line_changes = (linkup_ind | linkdown_ind) & mb->port_mask;
1549 for_each_set_bit(line, &line_changes, priv->num_ports) {
1550 int child_irq = irq_find_mapping(priv->irqdomain, line);
1552 handle_nested_irq(child_irq);
1558 dev_err(priv->dev, "failed to read interrupt status: %d\n", ret);
1564 static struct irq_chip rtl8365mb_irq_chip = {
1565 .name = "rtl8365mb",
1566 /* The hardware doesn't support masking IRQs on a per-port basis */
1569 static int rtl8365mb_irq_map(struct irq_domain *domain, unsigned int irq,
1570 irq_hw_number_t hwirq)
1572 irq_set_chip_data(irq, domain->host_data);
1573 irq_set_chip_and_handler(irq, &rtl8365mb_irq_chip, handle_simple_irq);
1574 irq_set_nested_thread(irq, 1);
1575 irq_set_noprobe(irq);
1580 static void rtl8365mb_irq_unmap(struct irq_domain *d, unsigned int irq)
1582 irq_set_nested_thread(irq, 0);
1583 irq_set_chip_and_handler(irq, NULL, NULL);
1584 irq_set_chip_data(irq, NULL);
1587 static const struct irq_domain_ops rtl8365mb_irqdomain_ops = {
1588 .map = rtl8365mb_irq_map,
1589 .unmap = rtl8365mb_irq_unmap,
1590 .xlate = irq_domain_xlate_onecell,
1593 static int rtl8365mb_set_irq_enable(struct realtek_priv *priv, bool enable)
1595 return regmap_update_bits(priv->map, RTL8365MB_INTR_CTRL_REG,
1596 RTL8365MB_INTR_LINK_CHANGE_MASK,
1597 FIELD_PREP(RTL8365MB_INTR_LINK_CHANGE_MASK,
1601 static int rtl8365mb_irq_enable(struct realtek_priv *priv)
1603 return rtl8365mb_set_irq_enable(priv, true);
1606 static int rtl8365mb_irq_disable(struct realtek_priv *priv)
1608 return rtl8365mb_set_irq_enable(priv, false);
1611 static int rtl8365mb_irq_setup(struct realtek_priv *priv)
1613 struct rtl8365mb *mb = priv->chip_data;
1614 struct device_node *intc;
1622 intc = of_get_child_by_name(priv->dev->of_node, "interrupt-controller");
1624 dev_err(priv->dev, "missing child interrupt-controller node\n");
1628 /* rtl8365mb IRQs cascade off this one */
1629 irq = of_irq_get(intc, 0);
1631 if (irq != -EPROBE_DEFER)
1632 dev_err(priv->dev, "failed to get parent irq: %d\n",
1634 ret = irq ? irq : -EINVAL;
1638 priv->irqdomain = irq_domain_add_linear(intc, priv->num_ports,
1639 &rtl8365mb_irqdomain_ops, priv);
1640 if (!priv->irqdomain) {
1641 dev_err(priv->dev, "failed to add irq domain\n");
1646 for (i = 0; i < priv->num_ports; i++) {
1647 virq = irq_create_mapping(priv->irqdomain, i);
1650 "failed to create irq domain mapping\n");
1652 goto out_remove_irqdomain;
1655 irq_set_parent(virq, irq);
1658 /* Configure chip interrupt signal polarity */
1659 irq_trig = irqd_get_trigger_type(irq_get_irq_data(irq));
1661 case IRQF_TRIGGER_RISING:
1662 case IRQF_TRIGGER_HIGH:
1663 val = RTL8365MB_INTR_POLARITY_HIGH;
1665 case IRQF_TRIGGER_FALLING:
1666 case IRQF_TRIGGER_LOW:
1667 val = RTL8365MB_INTR_POLARITY_LOW;
1670 dev_err(priv->dev, "unsupported irq trigger type %u\n",
1673 goto out_remove_irqdomain;
1676 ret = regmap_update_bits(priv->map, RTL8365MB_INTR_POLARITY_REG,
1677 RTL8365MB_INTR_POLARITY_MASK,
1678 FIELD_PREP(RTL8365MB_INTR_POLARITY_MASK, val));
1680 goto out_remove_irqdomain;
1682 /* Disable the interrupt in case the chip has it enabled on reset */
1683 ret = rtl8365mb_irq_disable(priv);
1685 goto out_remove_irqdomain;
1687 /* Clear the interrupt status register */
1688 ret = regmap_write(priv->map, RTL8365MB_INTR_STATUS_REG,
1689 RTL8365MB_INTR_ALL_MASK);
1691 goto out_remove_irqdomain;
1693 ret = request_threaded_irq(irq, NULL, rtl8365mb_irq, IRQF_ONESHOT,
1696 dev_err(priv->dev, "failed to request irq: %d\n", ret);
1697 goto out_remove_irqdomain;
1700 /* Store the irq so that we know to free it during teardown */
1703 ret = rtl8365mb_irq_enable(priv);
1712 free_irq(mb->irq, priv);
1715 out_remove_irqdomain:
1716 for (i = 0; i < priv->num_ports; i++) {
1717 virq = irq_find_mapping(priv->irqdomain, i);
1718 irq_dispose_mapping(virq);
1721 irq_domain_remove(priv->irqdomain);
1722 priv->irqdomain = NULL;
1730 static void rtl8365mb_irq_teardown(struct realtek_priv *priv)
1732 struct rtl8365mb *mb = priv->chip_data;
1737 free_irq(mb->irq, priv);
1741 if (priv->irqdomain) {
1742 for (i = 0; i < priv->num_ports; i++) {
1743 virq = irq_find_mapping(priv->irqdomain, i);
1744 irq_dispose_mapping(virq);
1747 irq_domain_remove(priv->irqdomain);
1748 priv->irqdomain = NULL;
1752 static int rtl8365mb_cpu_config(struct realtek_priv *priv)
1754 struct rtl8365mb *mb = priv->chip_data;
1755 struct rtl8365mb_cpu *cpu = &mb->cpu;
1759 ret = regmap_update_bits(priv->map, RTL8365MB_CPU_PORT_MASK_REG,
1760 RTL8365MB_CPU_PORT_MASK_MASK,
1761 FIELD_PREP(RTL8365MB_CPU_PORT_MASK_MASK,
1766 val = FIELD_PREP(RTL8365MB_CPU_CTRL_EN_MASK, cpu->enable ? 1 : 0) |
1767 FIELD_PREP(RTL8365MB_CPU_CTRL_INSERTMODE_MASK, cpu->insert) |
1768 FIELD_PREP(RTL8365MB_CPU_CTRL_TAG_POSITION_MASK, cpu->position) |
1769 FIELD_PREP(RTL8365MB_CPU_CTRL_RXBYTECOUNT_MASK, cpu->rx_length) |
1770 FIELD_PREP(RTL8365MB_CPU_CTRL_TAG_FORMAT_MASK, cpu->format) |
1771 FIELD_PREP(RTL8365MB_CPU_CTRL_TRAP_PORT_MASK, cpu->trap_port & 0x7) |
1772 FIELD_PREP(RTL8365MB_CPU_CTRL_TRAP_PORT_EXT_MASK,
1773 cpu->trap_port >> 3 & 0x1);
1774 ret = regmap_write(priv->map, RTL8365MB_CPU_CTRL_REG, val);
1781 static int rtl8365mb_change_tag_protocol(struct dsa_switch *ds,
1782 enum dsa_tag_protocol proto)
1784 struct realtek_priv *priv = ds->priv;
1785 struct rtl8365mb_cpu *cpu;
1786 struct rtl8365mb *mb;
1788 mb = priv->chip_data;
1792 case DSA_TAG_PROTO_RTL8_4:
1793 cpu->format = RTL8365MB_CPU_FORMAT_8BYTES;
1794 cpu->position = RTL8365MB_CPU_POS_AFTER_SA;
1796 case DSA_TAG_PROTO_RTL8_4T:
1797 cpu->format = RTL8365MB_CPU_FORMAT_8BYTES;
1798 cpu->position = RTL8365MB_CPU_POS_BEFORE_CRC;
1800 /* The switch also supports a 4-byte format, similar to rtl4a but with
1801 * the same 0x04 8-bit version and probably 8-bit port source/dest.
1802 * There is no public doc about it. Not supported yet and it will probably
1806 return -EPROTONOSUPPORT;
1809 return rtl8365mb_cpu_config(priv);
1812 static int rtl8365mb_switch_init(struct realtek_priv *priv)
1814 struct rtl8365mb *mb = priv->chip_data;
1818 /* Do any chip-specific init jam before getting to the common stuff */
1819 if (mb->jam_table) {
1820 for (i = 0; i < mb->jam_size; i++) {
1821 ret = regmap_write(priv->map, mb->jam_table[i].reg,
1822 mb->jam_table[i].val);
1828 /* Common init jam */
1829 for (i = 0; i < ARRAY_SIZE(rtl8365mb_init_jam_common); i++) {
1830 ret = regmap_write(priv->map, rtl8365mb_init_jam_common[i].reg,
1831 rtl8365mb_init_jam_common[i].val);
1839 static int rtl8365mb_reset_chip(struct realtek_priv *priv)
1843 priv->write_reg_noack(priv, RTL8365MB_CHIP_RESET_REG,
1844 FIELD_PREP(RTL8365MB_CHIP_RESET_HW_MASK, 1));
1846 /* Realtek documentation says the chip needs 1 second to reset. Sleep
1847 * for 100 ms before accessing any registers to prevent ACK timeouts.
1850 return regmap_read_poll_timeout(priv->map, RTL8365MB_CHIP_RESET_REG, val,
1851 !(val & RTL8365MB_CHIP_RESET_HW_MASK),
1855 static int rtl8365mb_setup(struct dsa_switch *ds)
1857 struct realtek_priv *priv = ds->priv;
1858 struct rtl8365mb_cpu *cpu;
1859 struct dsa_port *cpu_dp;
1860 struct rtl8365mb *mb;
1864 mb = priv->chip_data;
1867 ret = rtl8365mb_reset_chip(priv);
1869 dev_err(priv->dev, "failed to reset chip: %d\n", ret);
1873 /* Configure switch to vendor-defined initial state */
1874 ret = rtl8365mb_switch_init(priv);
1876 dev_err(priv->dev, "failed to initialize switch: %d\n", ret);
1880 /* Set up cascading IRQs */
1881 ret = rtl8365mb_irq_setup(priv);
1882 if (ret == -EPROBE_DEFER)
1885 dev_info(priv->dev, "no interrupt support\n");
1887 /* Configure CPU tagging */
1888 dsa_switch_for_each_cpu_port(cpu_dp, priv->ds) {
1889 cpu->mask |= BIT(cpu_dp->index);
1891 if (cpu->trap_port == RTL8365MB_MAX_NUM_PORTS)
1892 cpu->trap_port = cpu_dp->index;
1894 cpu->enable = cpu->mask > 0;
1895 ret = rtl8365mb_cpu_config(priv);
1897 goto out_teardown_irq;
1899 /* Configure ports */
1900 for (i = 0; i < priv->num_ports; i++) {
1901 struct rtl8365mb_port *p = &mb->ports[i];
1903 if (dsa_is_unused_port(priv->ds, i))
1906 /* Forward only to the CPU */
1907 ret = rtl8365mb_port_set_isolation(priv, i, cpu->mask);
1909 goto out_teardown_irq;
1911 /* Disable learning */
1912 ret = rtl8365mb_port_set_learning(priv, i, false);
1914 goto out_teardown_irq;
1916 /* Set the initial STP state of all ports to DISABLED, otherwise
1917 * ports will still forward frames to the CPU despite being
1918 * administratively down by default.
1920 rtl8365mb_port_stp_state_set(priv->ds, i, BR_STATE_DISABLED);
1922 /* Set up per-port private data */
1927 /* Set maximum packet length to 1536 bytes */
1928 ret = regmap_update_bits(priv->map, RTL8365MB_CFG0_MAX_LEN_REG,
1929 RTL8365MB_CFG0_MAX_LEN_MASK,
1930 FIELD_PREP(RTL8365MB_CFG0_MAX_LEN_MASK, 1536));
1932 goto out_teardown_irq;
1934 if (priv->setup_interface) {
1935 ret = priv->setup_interface(ds);
1937 dev_err(priv->dev, "could not set up MDIO bus\n");
1938 goto out_teardown_irq;
1942 /* Start statistics counter polling */
1943 rtl8365mb_stats_setup(priv);
1948 rtl8365mb_irq_teardown(priv);
1954 static void rtl8365mb_teardown(struct dsa_switch *ds)
1956 struct realtek_priv *priv = ds->priv;
1958 rtl8365mb_stats_teardown(priv);
1959 rtl8365mb_irq_teardown(priv);
1962 static int rtl8365mb_get_chip_id_and_ver(struct regmap *map, u32 *id, u32 *ver)
1966 /* For some reason we have to write a magic value to an arbitrary
1967 * register whenever accessing the chip ID/version registers.
1969 ret = regmap_write(map, RTL8365MB_MAGIC_REG, RTL8365MB_MAGIC_VALUE);
1973 ret = regmap_read(map, RTL8365MB_CHIP_ID_REG, id);
1977 ret = regmap_read(map, RTL8365MB_CHIP_VER_REG, ver);
1981 /* Reset magic register */
1982 ret = regmap_write(map, RTL8365MB_MAGIC_REG, 0);
1989 static int rtl8365mb_detect(struct realtek_priv *priv)
1991 struct rtl8365mb *mb = priv->chip_data;
1996 ret = rtl8365mb_get_chip_id_and_ver(priv->map, &chip_id, &chip_ver);
1998 dev_err(priv->dev, "failed to read chip id and version: %d\n",
2004 case RTL8365MB_CHIP_ID_8365MB_VC:
2006 case RTL8365MB_CHIP_VER_8365MB_VC:
2008 "found an RTL8365MB-VC switch (ver=0x%04x)\n",
2011 case RTL8365MB_CHIP_VER_8367RB:
2013 "found an RTL8367RB-VB switch (ver=0x%04x)\n",
2016 case RTL8365MB_CHIP_VER_8367S:
2018 "found an RTL8367S switch (ver=0x%04x)\n",
2022 dev_err(priv->dev, "unrecognized switch version (ver=0x%04x)",
2027 priv->num_ports = RTL8365MB_MAX_NUM_PORTS;
2030 mb->chip_id = chip_id;
2031 mb->chip_ver = chip_ver;
2032 mb->port_mask = GENMASK(priv->num_ports - 1, 0);
2033 mb->learn_limit_max = RTL8365MB_LEARN_LIMIT_MAX;
2034 mb->jam_table = rtl8365mb_init_jam_8365mb_vc;
2035 mb->jam_size = ARRAY_SIZE(rtl8365mb_init_jam_8365mb_vc);
2037 mb->cpu.trap_port = RTL8365MB_MAX_NUM_PORTS;
2038 mb->cpu.insert = RTL8365MB_CPU_INSERT_TO_ALL;
2039 mb->cpu.position = RTL8365MB_CPU_POS_AFTER_SA;
2040 mb->cpu.rx_length = RTL8365MB_CPU_RXLEN_64BYTES;
2041 mb->cpu.format = RTL8365MB_CPU_FORMAT_8BYTES;
2046 "found an unknown Realtek switch (id=0x%04x, ver=0x%04x)\n",
2054 static const struct dsa_switch_ops rtl8365mb_switch_ops_smi = {
2055 .get_tag_protocol = rtl8365mb_get_tag_protocol,
2056 .change_tag_protocol = rtl8365mb_change_tag_protocol,
2057 .setup = rtl8365mb_setup,
2058 .teardown = rtl8365mb_teardown,
2059 .phylink_get_caps = rtl8365mb_phylink_get_caps,
2060 .phylink_mac_config = rtl8365mb_phylink_mac_config,
2061 .phylink_mac_link_down = rtl8365mb_phylink_mac_link_down,
2062 .phylink_mac_link_up = rtl8365mb_phylink_mac_link_up,
2063 .port_stp_state_set = rtl8365mb_port_stp_state_set,
2064 .get_strings = rtl8365mb_get_strings,
2065 .get_ethtool_stats = rtl8365mb_get_ethtool_stats,
2066 .get_sset_count = rtl8365mb_get_sset_count,
2067 .get_eth_phy_stats = rtl8365mb_get_phy_stats,
2068 .get_eth_mac_stats = rtl8365mb_get_mac_stats,
2069 .get_eth_ctrl_stats = rtl8365mb_get_ctrl_stats,
2070 .get_stats64 = rtl8365mb_get_stats64,
2073 static const struct dsa_switch_ops rtl8365mb_switch_ops_mdio = {
2074 .get_tag_protocol = rtl8365mb_get_tag_protocol,
2075 .change_tag_protocol = rtl8365mb_change_tag_protocol,
2076 .setup = rtl8365mb_setup,
2077 .teardown = rtl8365mb_teardown,
2078 .phylink_get_caps = rtl8365mb_phylink_get_caps,
2079 .phylink_mac_config = rtl8365mb_phylink_mac_config,
2080 .phylink_mac_link_down = rtl8365mb_phylink_mac_link_down,
2081 .phylink_mac_link_up = rtl8365mb_phylink_mac_link_up,
2082 .phy_read = rtl8365mb_dsa_phy_read,
2083 .phy_write = rtl8365mb_dsa_phy_write,
2084 .port_stp_state_set = rtl8365mb_port_stp_state_set,
2085 .get_strings = rtl8365mb_get_strings,
2086 .get_ethtool_stats = rtl8365mb_get_ethtool_stats,
2087 .get_sset_count = rtl8365mb_get_sset_count,
2088 .get_eth_phy_stats = rtl8365mb_get_phy_stats,
2089 .get_eth_mac_stats = rtl8365mb_get_mac_stats,
2090 .get_eth_ctrl_stats = rtl8365mb_get_ctrl_stats,
2091 .get_stats64 = rtl8365mb_get_stats64,
2094 static const struct realtek_ops rtl8365mb_ops = {
2095 .detect = rtl8365mb_detect,
2096 .phy_read = rtl8365mb_phy_read,
2097 .phy_write = rtl8365mb_phy_write,
2100 const struct realtek_variant rtl8365mb_variant = {
2101 .ds_ops_smi = &rtl8365mb_switch_ops_smi,
2102 .ds_ops_mdio = &rtl8365mb_switch_ops_mdio,
2103 .ops = &rtl8365mb_ops,
2107 .chip_data_sz = sizeof(struct rtl8365mb),
2109 EXPORT_SYMBOL_GPL(rtl8365mb_variant);
2111 MODULE_AUTHOR("Alvin Šipraga <alsi@bang-olufsen.dk>");
2112 MODULE_DESCRIPTION("Driver for RTL8365MB-VC ethernet switch");
2113 MODULE_LICENSE("GPL");