1 // SPDX-License-Identifier: GPL-2.0+
2 /* Realtek Simple Management Interface (SMI) driver
3 * It can be discussed how "simple" this interface is.
5 * The SMI protocol piggy-backs the MDIO MDC and MDIO signals levels
6 * but the protocol is not MDIO at all. Instead it is a Realtek
7 * pecularity that need to bit-bang the lines in a special way to
8 * communicate with the switch.
10 * ASICs we intend to support with this driver:
12 * RTL8366 - The original version, apparently
13 * RTL8369 - Similar enough to have the same datsheet as RTL8366
14 * RTL8366RB - Probably reads out "RTL8366 revision B", has a quite
15 * different register layout from the other two
16 * RTL8366S - Is this "RTL8366 super"?
17 * RTL8367 - Has an OpenWRT driver as well
18 * RTL8368S - Seems to be an alternative name for RTL8366RB
19 * RTL8370 - Also uses SMI
21 * Copyright (C) 2017 Linus Walleij <linus.walleij@linaro.org>
22 * Copyright (C) 2010 Antti Seppälä <a.seppala@gmail.com>
23 * Copyright (C) 2010 Roman Yeryomin <roman@advem.lv>
24 * Copyright (C) 2011 Colin Leitner <colin.leitner@googlemail.com>
25 * Copyright (C) 2009-2010 Gabor Juhos <juhosg@openwrt.org>
28 #include <linux/kernel.h>
29 #include <linux/module.h>
30 #include <linux/device.h>
31 #include <linux/spinlock.h>
32 #include <linux/skbuff.h>
34 #include <linux/of_device.h>
35 #include <linux/of_mdio.h>
36 #include <linux/delay.h>
37 #include <linux/gpio/consumer.h>
38 #include <linux/platform_device.h>
39 #include <linux/regmap.h>
40 #include <linux/bitops.h>
41 #include <linux/if_bridge.h>
43 #include "realtek-smi.h"
45 #define REALTEK_SMI_ACK_RETRY_COUNT 5
46 #define REALTEK_SMI_HW_STOP_DELAY 25 /* msecs */
47 #define REALTEK_SMI_HW_START_DELAY 100 /* msecs */
49 static inline void realtek_smi_clk_delay(struct realtek_smi
*smi
)
51 ndelay(smi
->clk_delay
);
54 static void realtek_smi_start(struct realtek_smi
*smi
)
56 /* Set GPIO pins to output mode, with initial state:
59 gpiod_direction_output(smi
->mdc
, 0);
60 gpiod_direction_output(smi
->mdio
, 1);
61 realtek_smi_clk_delay(smi
);
63 /* CLK 1: 0 -> 1, 1 -> 0 */
64 gpiod_set_value(smi
->mdc
, 1);
65 realtek_smi_clk_delay(smi
);
66 gpiod_set_value(smi
->mdc
, 0);
67 realtek_smi_clk_delay(smi
);
70 gpiod_set_value(smi
->mdc
, 1);
71 realtek_smi_clk_delay(smi
);
72 gpiod_set_value(smi
->mdio
, 0);
73 realtek_smi_clk_delay(smi
);
74 gpiod_set_value(smi
->mdc
, 0);
75 realtek_smi_clk_delay(smi
);
76 gpiod_set_value(smi
->mdio
, 1);
79 static void realtek_smi_stop(struct realtek_smi
*smi
)
81 realtek_smi_clk_delay(smi
);
82 gpiod_set_value(smi
->mdio
, 0);
83 gpiod_set_value(smi
->mdc
, 1);
84 realtek_smi_clk_delay(smi
);
85 gpiod_set_value(smi
->mdio
, 1);
86 realtek_smi_clk_delay(smi
);
87 gpiod_set_value(smi
->mdc
, 1);
88 realtek_smi_clk_delay(smi
);
89 gpiod_set_value(smi
->mdc
, 0);
90 realtek_smi_clk_delay(smi
);
91 gpiod_set_value(smi
->mdc
, 1);
94 realtek_smi_clk_delay(smi
);
95 gpiod_set_value(smi
->mdc
, 0);
96 realtek_smi_clk_delay(smi
);
97 gpiod_set_value(smi
->mdc
, 1);
99 /* Set GPIO pins to input mode */
100 gpiod_direction_input(smi
->mdio
);
101 gpiod_direction_input(smi
->mdc
);
104 static void realtek_smi_write_bits(struct realtek_smi
*smi
, u32 data
, u32 len
)
106 for (; len
> 0; len
--) {
107 realtek_smi_clk_delay(smi
);
110 gpiod_set_value(smi
->mdio
, !!(data
& (1 << (len
- 1))));
111 realtek_smi_clk_delay(smi
);
114 gpiod_set_value(smi
->mdc
, 1);
115 realtek_smi_clk_delay(smi
);
116 gpiod_set_value(smi
->mdc
, 0);
120 static void realtek_smi_read_bits(struct realtek_smi
*smi
, u32 len
, u32
*data
)
122 gpiod_direction_input(smi
->mdio
);
124 for (*data
= 0; len
> 0; len
--) {
127 realtek_smi_clk_delay(smi
);
130 gpiod_set_value(smi
->mdc
, 1);
131 realtek_smi_clk_delay(smi
);
132 u
= !!gpiod_get_value(smi
->mdio
);
133 gpiod_set_value(smi
->mdc
, 0);
135 *data
|= (u
<< (len
- 1));
138 gpiod_direction_output(smi
->mdio
, 0);
141 static int realtek_smi_wait_for_ack(struct realtek_smi
*smi
)
149 realtek_smi_read_bits(smi
, 1, &ack
);
153 if (++retry_cnt
> REALTEK_SMI_ACK_RETRY_COUNT
) {
154 dev_err(smi
->dev
, "ACK timeout\n");
162 static int realtek_smi_write_byte(struct realtek_smi
*smi
, u8 data
)
164 realtek_smi_write_bits(smi
, data
, 8);
165 return realtek_smi_wait_for_ack(smi
);
168 static int realtek_smi_write_byte_noack(struct realtek_smi
*smi
, u8 data
)
170 realtek_smi_write_bits(smi
, data
, 8);
174 static int realtek_smi_read_byte0(struct realtek_smi
*smi
, u8
*data
)
179 realtek_smi_read_bits(smi
, 8, &t
);
183 realtek_smi_write_bits(smi
, 0x00, 1);
188 static int realtek_smi_read_byte1(struct realtek_smi
*smi
, u8
*data
)
193 realtek_smi_read_bits(smi
, 8, &t
);
197 realtek_smi_write_bits(smi
, 0x01, 1);
202 static int realtek_smi_read_reg(struct realtek_smi
*smi
, u32 addr
, u32
*data
)
209 spin_lock_irqsave(&smi
->lock
, flags
);
211 realtek_smi_start(smi
);
213 /* Send READ command */
214 ret
= realtek_smi_write_byte(smi
, smi
->cmd_read
);
219 ret
= realtek_smi_write_byte(smi
, addr
& 0xff);
224 ret
= realtek_smi_write_byte(smi
, addr
>> 8);
229 realtek_smi_read_byte0(smi
, &lo
);
230 /* Read DATA[15:8] */
231 realtek_smi_read_byte1(smi
, &hi
);
233 *data
= ((u32
)lo
) | (((u32
)hi
) << 8);
238 realtek_smi_stop(smi
);
239 spin_unlock_irqrestore(&smi
->lock
, flags
);
244 static int realtek_smi_write_reg(struct realtek_smi
*smi
,
245 u32 addr
, u32 data
, bool ack
)
250 spin_lock_irqsave(&smi
->lock
, flags
);
252 realtek_smi_start(smi
);
254 /* Send WRITE command */
255 ret
= realtek_smi_write_byte(smi
, smi
->cmd_write
);
260 ret
= realtek_smi_write_byte(smi
, addr
& 0xff);
265 ret
= realtek_smi_write_byte(smi
, addr
>> 8);
269 /* Write DATA[7:0] */
270 ret
= realtek_smi_write_byte(smi
, data
& 0xff);
274 /* Write DATA[15:8] */
276 ret
= realtek_smi_write_byte(smi
, data
>> 8);
278 ret
= realtek_smi_write_byte_noack(smi
, data
>> 8);
285 realtek_smi_stop(smi
);
286 spin_unlock_irqrestore(&smi
->lock
, flags
);
291 /* There is one single case when we need to use this accessor and that
292 * is when issueing soft reset. Since the device reset as soon as we write
293 * that bit, no ACK will come back for natural reasons.
295 int realtek_smi_write_reg_noack(struct realtek_smi
*smi
, u32 addr
,
298 return realtek_smi_write_reg(smi
, addr
, data
, false);
300 EXPORT_SYMBOL_GPL(realtek_smi_write_reg_noack
);
302 /* Regmap accessors */
304 static int realtek_smi_write(void *ctx
, u32 reg
, u32 val
)
306 struct realtek_smi
*smi
= ctx
;
308 return realtek_smi_write_reg(smi
, reg
, val
, true);
311 static int realtek_smi_read(void *ctx
, u32 reg
, u32
*val
)
313 struct realtek_smi
*smi
= ctx
;
315 return realtek_smi_read_reg(smi
, reg
, val
);
318 static const struct regmap_config realtek_smi_mdio_regmap_config
= {
319 .reg_bits
= 10, /* A4..A0 R4..R0 */
322 /* PHY regs are at 0x8000 */
323 .max_register
= 0xffff,
324 .reg_format_endian
= REGMAP_ENDIAN_BIG
,
325 .reg_read
= realtek_smi_read
,
326 .reg_write
= realtek_smi_write
,
327 .cache_type
= REGCACHE_NONE
,
330 static int realtek_smi_mdio_read(struct mii_bus
*bus
, int addr
, int regnum
)
332 struct realtek_smi
*smi
= bus
->priv
;
334 return smi
->ops
->phy_read(smi
, addr
, regnum
);
337 static int realtek_smi_mdio_write(struct mii_bus
*bus
, int addr
, int regnum
,
340 struct realtek_smi
*smi
= bus
->priv
;
342 return smi
->ops
->phy_write(smi
, addr
, regnum
, val
);
345 int realtek_smi_setup_mdio(struct realtek_smi
*smi
)
347 struct device_node
*mdio_np
;
350 mdio_np
= of_find_compatible_node(smi
->dev
->of_node
, NULL
,
353 dev_err(smi
->dev
, "no MDIO bus node\n");
357 smi
->slave_mii_bus
= devm_mdiobus_alloc(smi
->dev
);
358 if (!smi
->slave_mii_bus
)
360 smi
->slave_mii_bus
->priv
= smi
;
361 smi
->slave_mii_bus
->name
= "SMI slave MII";
362 smi
->slave_mii_bus
->read
= realtek_smi_mdio_read
;
363 smi
->slave_mii_bus
->write
= realtek_smi_mdio_write
;
364 snprintf(smi
->slave_mii_bus
->id
, MII_BUS_ID_SIZE
, "SMI-%d",
366 smi
->slave_mii_bus
->dev
.of_node
= mdio_np
;
367 smi
->slave_mii_bus
->parent
= smi
->dev
;
368 smi
->ds
->slave_mii_bus
= smi
->slave_mii_bus
;
370 ret
= of_mdiobus_register(smi
->slave_mii_bus
, mdio_np
);
372 dev_err(smi
->dev
, "unable to register MDIO bus %s\n",
373 smi
->slave_mii_bus
->id
);
374 of_node_put(mdio_np
);
380 static int realtek_smi_probe(struct platform_device
*pdev
)
382 const struct realtek_smi_variant
*var
;
383 struct device
*dev
= &pdev
->dev
;
384 struct realtek_smi
*smi
;
385 struct device_node
*np
;
388 var
= of_device_get_match_data(dev
);
391 smi
= devm_kzalloc(dev
, sizeof(*smi
), GFP_KERNEL
);
394 smi
->map
= devm_regmap_init(dev
, NULL
, smi
,
395 &realtek_smi_mdio_regmap_config
);
396 if (IS_ERR(smi
->map
)) {
397 ret
= PTR_ERR(smi
->map
);
398 dev_err(dev
, "regmap init failed: %d\n", ret
);
402 /* Link forward and backward */
404 smi
->clk_delay
= var
->clk_delay
;
405 smi
->cmd_read
= var
->cmd_read
;
406 smi
->cmd_write
= var
->cmd_write
;
409 dev_set_drvdata(dev
, smi
);
410 spin_lock_init(&smi
->lock
);
412 /* TODO: if power is software controlled, set up any regulators here */
414 /* Assert then deassert RESET */
415 smi
->reset
= devm_gpiod_get_optional(dev
, "reset", GPIOD_OUT_HIGH
);
416 if (IS_ERR(smi
->reset
)) {
417 dev_err(dev
, "failed to get RESET GPIO\n");
418 return PTR_ERR(smi
->reset
);
420 msleep(REALTEK_SMI_HW_STOP_DELAY
);
421 gpiod_set_value(smi
->reset
, 0);
422 msleep(REALTEK_SMI_HW_START_DELAY
);
423 dev_info(dev
, "deasserted RESET\n");
425 /* Fetch MDIO pins */
426 smi
->mdc
= devm_gpiod_get_optional(dev
, "mdc", GPIOD_OUT_LOW
);
427 if (IS_ERR(smi
->mdc
))
428 return PTR_ERR(smi
->mdc
);
429 smi
->mdio
= devm_gpiod_get_optional(dev
, "mdio", GPIOD_OUT_LOW
);
430 if (IS_ERR(smi
->mdio
))
431 return PTR_ERR(smi
->mdio
);
433 smi
->leds_disabled
= of_property_read_bool(np
, "realtek,disable-leds");
435 ret
= smi
->ops
->detect(smi
);
437 dev_err(dev
, "unable to detect switch\n");
441 smi
->ds
= dsa_switch_alloc(dev
, smi
->num_ports
);
446 smi
->ds
->ops
= var
->ds_ops
;
447 ret
= dsa_register_switch(smi
->ds
);
449 dev_err(dev
, "unable to register switch ret = %d\n", ret
);
455 static int realtek_smi_remove(struct platform_device
*pdev
)
457 struct realtek_smi
*smi
= dev_get_drvdata(&pdev
->dev
);
459 dsa_unregister_switch(smi
->ds
);
460 gpiod_set_value(smi
->reset
, 1);
465 static const struct of_device_id realtek_smi_of_match
[] = {
467 .compatible
= "realtek,rtl8366rb",
468 .data
= &rtl8366rb_variant
,
471 /* FIXME: add support for RTL8366S and more */
472 .compatible
= "realtek,rtl8366s",
477 MODULE_DEVICE_TABLE(of
, realtek_smi_of_match
);
479 static struct platform_driver realtek_smi_driver
= {
481 .name
= "realtek-smi",
482 .of_match_table
= of_match_ptr(realtek_smi_of_match
),
484 .probe
= realtek_smi_probe
,
485 .remove
= realtek_smi_remove
,
487 module_platform_driver(realtek_smi_driver
);
489 MODULE_LICENSE("GPL");