1 From b4bd77971f3c290c4694ed710cc6967593b10bc2 Mon Sep 17 00:00:00 2001
2 From: Luiz Angelo Daros de Luca <luizluca@gmail.com>
3 Date: Fri, 9 Feb 2024 02:03:45 -0300
4 Subject: net: dsa: realtek: migrate slave_mii_bus setup to
7 In the user MDIO driver, despite numerous references to SMI, including
8 its compatible string, there's nothing inherently specific about the SMI
9 interface in the user MDIO bus. Consequently, the code has been migrated
10 to the rtl83xx module. All references to SMI have been eliminated.
12 The MDIO bus id was changed from Realtek-<switch id> to the switch
13 devname suffixed with :slave_mii, giving more information about the bus
16 Signed-off-by: Luiz Angelo Daros de Luca <luizluca@gmail.com>
17 Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
18 Signed-off-by: David S. Miller <davem@davemloft.net>
20 drivers/net/dsa/realtek/realtek-smi.c | 57 +---------------------
21 drivers/net/dsa/realtek/rtl83xx.c | 68 +++++++++++++++++++++++++++
22 drivers/net/dsa/realtek/rtl83xx.h | 1 +
23 3 files changed, 70 insertions(+), 56 deletions(-)
25 --- a/drivers/net/dsa/realtek/realtek-smi.c
26 +++ b/drivers/net/dsa/realtek/realtek-smi.c
28 #include <linux/spinlock.h>
29 #include <linux/skbuff.h>
31 -#include <linux/of_mdio.h>
32 #include <linux/delay.h>
33 #include <linux/gpio/consumer.h>
34 #include <linux/platform_device.h>
35 @@ -312,60 +311,6 @@ static int realtek_smi_read(void *ctx, u
36 return realtek_smi_read_reg(priv, reg, val);
39 -static int realtek_smi_mdio_read(struct mii_bus *bus, int addr, int regnum)
41 - struct realtek_priv *priv = bus->priv;
43 - return priv->ops->phy_read(priv, addr, regnum);
46 -static int realtek_smi_mdio_write(struct mii_bus *bus, int addr, int regnum,
49 - struct realtek_priv *priv = bus->priv;
51 - return priv->ops->phy_write(priv, addr, regnum, val);
54 -static int realtek_smi_setup_mdio(struct dsa_switch *ds)
56 - struct realtek_priv *priv = ds->priv;
57 - struct device_node *mdio_np;
60 - mdio_np = of_get_child_by_name(priv->dev->of_node, "mdio");
62 - dev_err(priv->dev, "no MDIO bus node\n");
66 - priv->slave_mii_bus = devm_mdiobus_alloc(priv->dev);
67 - if (!priv->slave_mii_bus) {
72 - priv->slave_mii_bus->priv = priv;
73 - priv->slave_mii_bus->name = "SMI slave MII";
74 - priv->slave_mii_bus->read = realtek_smi_mdio_read;
75 - priv->slave_mii_bus->write = realtek_smi_mdio_write;
76 - snprintf(priv->slave_mii_bus->id, MII_BUS_ID_SIZE, "SMI-%d",
78 - priv->slave_mii_bus->parent = priv->dev;
80 - ret = devm_of_mdiobus_register(priv->dev, priv->slave_mii_bus, mdio_np);
82 - dev_err(priv->dev, "unable to register MDIO bus %s\n",
83 - priv->slave_mii_bus->id);
88 - of_node_put(mdio_np);
93 static const struct realtek_interface_info realtek_smi_info = {
94 .reg_read = realtek_smi_read,
95 .reg_write = realtek_smi_write,
96 @@ -407,7 +352,7 @@ int realtek_smi_probe(struct platform_de
99 priv->write_reg_noack = realtek_smi_write_reg_noack;
100 - priv->setup_interface = realtek_smi_setup_mdio;
101 + priv->setup_interface = rtl83xx_setup_user_mdio;
102 priv->ds_ops = priv->variant->ds_ops_smi;
104 ret = rtl83xx_register_switch(priv);
105 --- a/drivers/net/dsa/realtek/rtl83xx.c
106 +++ b/drivers/net/dsa/realtek/rtl83xx.c
108 #include <linux/module.h>
109 #include <linux/regmap.h>
110 #include <linux/of_device.h> /* krnl 6.1 only */
111 +#include <linux/of_mdio.h>
115 @@ -44,6 +45,73 @@ void rtl83xx_unlock(void *ctx)
117 EXPORT_SYMBOL_NS_GPL(rtl83xx_unlock, REALTEK_DSA);
119 +static int rtl83xx_user_mdio_read(struct mii_bus *bus, int addr, int regnum)
121 + struct realtek_priv *priv = bus->priv;
123 + return priv->ops->phy_read(priv, addr, regnum);
126 +static int rtl83xx_user_mdio_write(struct mii_bus *bus, int addr, int regnum,
129 + struct realtek_priv *priv = bus->priv;
131 + return priv->ops->phy_write(priv, addr, regnum, val);
135 + * rtl83xx_setup_user_mdio() - register the user mii bus driver
136 + * @ds: DSA switch associated with this slave_mii_bus
138 + * Registers the MDIO bus for built-in Ethernet PHYs, and associates it with
139 + * the mandatory 'mdio' child OF node of the switch.
141 + * Context: Can sleep.
142 + * Return: 0 on success, negative value for failure.
144 +int rtl83xx_setup_user_mdio(struct dsa_switch *ds)
146 + struct realtek_priv *priv = ds->priv;
147 + struct device_node *mdio_np;
148 + struct mii_bus *bus;
151 + mdio_np = of_get_child_by_name(priv->dev->of_node, "mdio");
153 + dev_err(priv->dev, "no MDIO bus node\n");
157 + bus = devm_mdiobus_alloc(priv->dev);
164 + bus->name = "Realtek user MII";
165 + bus->read = rtl83xx_user_mdio_read;
166 + bus->write = rtl83xx_user_mdio_write;
167 + snprintf(bus->id, MII_BUS_ID_SIZE, "%s:slave_mii", dev_name(priv->dev));
168 + bus->parent = priv->dev;
170 + ret = devm_of_mdiobus_register(priv->dev, bus, mdio_np);
172 + dev_err(priv->dev, "unable to register MDIO bus %s\n",
177 + priv->slave_mii_bus = bus;
180 + of_node_put(mdio_np);
184 +EXPORT_SYMBOL_NS_GPL(rtl83xx_setup_user_mdio, REALTEK_DSA);
187 * rtl83xx_probe() - probe a Realtek switch
188 * @dev: the device being probed
189 --- a/drivers/net/dsa/realtek/rtl83xx.h
190 +++ b/drivers/net/dsa/realtek/rtl83xx.h
191 @@ -10,6 +10,7 @@ struct realtek_interface_info {
193 void rtl83xx_lock(void *ctx);
194 void rtl83xx_unlock(void *ctx);
195 +int rtl83xx_setup_user_mdio(struct dsa_switch *ds);
196 struct realtek_priv *
197 rtl83xx_probe(struct device *dev,
198 const struct realtek_interface_info *interface_info);