xref: /OK3568_Linux_fs/kernel/drivers/net/ethernet/stmicro/stmmac/stmmac_mdio.c (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*******************************************************************************
3   STMMAC Ethernet Driver -- MDIO bus implementation
4   Provides Bus interface for MII registers
5 
6   Copyright (C) 2007-2009  STMicroelectronics Ltd
7 
8 
9   Author: Carl Shaw <carl.shaw@st.com>
10   Maintainer: Giuseppe Cavallaro <peppe.cavallaro@st.com>
11 *******************************************************************************/
12 
13 #include <linux/gpio/consumer.h>
14 #include <linux/io.h>
15 #include <linux/iopoll.h>
16 #include <linux/mii.h>
17 #include <linux/of_mdio.h>
18 #include <linux/pm_runtime.h>
19 #include <linux/phy.h>
20 #include <linux/property.h>
21 #include <linux/slab.h>
22 
23 #include "dwxgmac2.h"
24 #include "stmmac.h"
25 
26 #define MII_BUSY 0x00000001
27 #define MII_WRITE 0x00000002
28 #define MII_DATA_MASK GENMASK(15, 0)
29 
30 /* GMAC4 defines */
31 #define MII_GMAC4_GOC_SHIFT		2
32 #define MII_GMAC4_REG_ADDR_SHIFT	16
33 #define MII_GMAC4_WRITE			(1 << MII_GMAC4_GOC_SHIFT)
34 #define MII_GMAC4_READ			(3 << MII_GMAC4_GOC_SHIFT)
35 #define MII_GMAC4_C45E			BIT(1)
36 
37 /* XGMAC defines */
38 #define MII_XGMAC_SADDR			BIT(18)
39 #define MII_XGMAC_CMD_SHIFT		16
40 #define MII_XGMAC_WRITE			(1 << MII_XGMAC_CMD_SHIFT)
41 #define MII_XGMAC_READ			(3 << MII_XGMAC_CMD_SHIFT)
42 #define MII_XGMAC_BUSY			BIT(22)
43 #define MII_XGMAC_MAX_C22ADDR		3
44 #define MII_XGMAC_C22P_MASK		GENMASK(MII_XGMAC_MAX_C22ADDR, 0)
45 #define MII_XGMAC_PA_SHIFT		16
46 #define MII_XGMAC_DA_SHIFT		21
47 
stmmac_xgmac2_c45_format(struct stmmac_priv * priv,int phyaddr,int phyreg,u32 * hw_addr)48 static int stmmac_xgmac2_c45_format(struct stmmac_priv *priv, int phyaddr,
49 				    int phyreg, u32 *hw_addr)
50 {
51 	u32 tmp;
52 
53 	/* Set port as Clause 45 */
54 	tmp = readl(priv->ioaddr + XGMAC_MDIO_C22P);
55 	tmp &= ~BIT(phyaddr);
56 	writel(tmp, priv->ioaddr + XGMAC_MDIO_C22P);
57 
58 	*hw_addr = (phyaddr << MII_XGMAC_PA_SHIFT) | (phyreg & 0xffff);
59 	*hw_addr |= (phyreg >> MII_DEVADDR_C45_SHIFT) << MII_XGMAC_DA_SHIFT;
60 	return 0;
61 }
62 
stmmac_xgmac2_c22_format(struct stmmac_priv * priv,int phyaddr,int phyreg,u32 * hw_addr)63 static int stmmac_xgmac2_c22_format(struct stmmac_priv *priv, int phyaddr,
64 				    int phyreg, u32 *hw_addr)
65 {
66 	u32 tmp;
67 
68 	/* HW does not support C22 addr >= 4 */
69 	if (phyaddr > MII_XGMAC_MAX_C22ADDR)
70 		return -ENODEV;
71 
72 	/* Set port as Clause 22 */
73 	tmp = readl(priv->ioaddr + XGMAC_MDIO_C22P);
74 	tmp &= ~MII_XGMAC_C22P_MASK;
75 	tmp |= BIT(phyaddr);
76 	writel(tmp, priv->ioaddr + XGMAC_MDIO_C22P);
77 
78 	*hw_addr = (phyaddr << MII_XGMAC_PA_SHIFT) | (phyreg & 0x1f);
79 	return 0;
80 }
81 
stmmac_xgmac2_mdio_read(struct mii_bus * bus,int phyaddr,int phyreg)82 static int stmmac_xgmac2_mdio_read(struct mii_bus *bus, int phyaddr, int phyreg)
83 {
84 	struct net_device *ndev = bus->priv;
85 	struct stmmac_priv *priv = netdev_priv(ndev);
86 	unsigned int mii_address = priv->hw->mii.addr;
87 	unsigned int mii_data = priv->hw->mii.data;
88 	u32 tmp, addr, value = MII_XGMAC_BUSY;
89 	int ret;
90 
91 	ret = pm_runtime_get_sync(priv->device);
92 	if (ret < 0) {
93 		pm_runtime_put_noidle(priv->device);
94 		return ret;
95 	}
96 
97 	/* Wait until any existing MII operation is complete */
98 	if (readl_poll_timeout(priv->ioaddr + mii_data, tmp,
99 			       !(tmp & MII_XGMAC_BUSY), 100, 10000)) {
100 		ret = -EBUSY;
101 		goto err_disable_clks;
102 	}
103 
104 	if (phyreg & MII_ADDR_C45) {
105 		phyreg &= ~MII_ADDR_C45;
106 
107 		ret = stmmac_xgmac2_c45_format(priv, phyaddr, phyreg, &addr);
108 		if (ret)
109 			goto err_disable_clks;
110 	} else {
111 		ret = stmmac_xgmac2_c22_format(priv, phyaddr, phyreg, &addr);
112 		if (ret)
113 			goto err_disable_clks;
114 
115 		value |= MII_XGMAC_SADDR;
116 	}
117 
118 	value |= (priv->clk_csr << priv->hw->mii.clk_csr_shift)
119 		& priv->hw->mii.clk_csr_mask;
120 	value |= MII_XGMAC_READ;
121 
122 	/* Wait until any existing MII operation is complete */
123 	if (readl_poll_timeout(priv->ioaddr + mii_data, tmp,
124 			       !(tmp & MII_XGMAC_BUSY), 100, 10000)) {
125 		ret = -EBUSY;
126 		goto err_disable_clks;
127 	}
128 
129 	/* Set the MII address register to read */
130 	writel(addr, priv->ioaddr + mii_address);
131 	writel(value, priv->ioaddr + mii_data);
132 
133 	/* Wait until any existing MII operation is complete */
134 	if (readl_poll_timeout(priv->ioaddr + mii_data, tmp,
135 			       !(tmp & MII_XGMAC_BUSY), 100, 10000)) {
136 		ret = -EBUSY;
137 		goto err_disable_clks;
138 	}
139 
140 	/* Read the data from the MII data register */
141 	ret = (int)readl(priv->ioaddr + mii_data) & GENMASK(15, 0);
142 
143 err_disable_clks:
144 	pm_runtime_put(priv->device);
145 
146 	return ret;
147 }
148 
stmmac_xgmac2_mdio_write(struct mii_bus * bus,int phyaddr,int phyreg,u16 phydata)149 static int stmmac_xgmac2_mdio_write(struct mii_bus *bus, int phyaddr,
150 				    int phyreg, u16 phydata)
151 {
152 	struct net_device *ndev = bus->priv;
153 	struct stmmac_priv *priv = netdev_priv(ndev);
154 	unsigned int mii_address = priv->hw->mii.addr;
155 	unsigned int mii_data = priv->hw->mii.data;
156 	u32 addr, tmp, value = MII_XGMAC_BUSY;
157 	int ret;
158 
159 	ret = pm_runtime_get_sync(priv->device);
160 	if (ret < 0) {
161 		pm_runtime_put_noidle(priv->device);
162 		return ret;
163 	}
164 
165 	/* Wait until any existing MII operation is complete */
166 	if (readl_poll_timeout(priv->ioaddr + mii_data, tmp,
167 			       !(tmp & MII_XGMAC_BUSY), 100, 10000)) {
168 		ret = -EBUSY;
169 		goto err_disable_clks;
170 	}
171 
172 	if (phyreg & MII_ADDR_C45) {
173 		phyreg &= ~MII_ADDR_C45;
174 
175 		ret = stmmac_xgmac2_c45_format(priv, phyaddr, phyreg, &addr);
176 		if (ret)
177 			goto err_disable_clks;
178 	} else {
179 		ret = stmmac_xgmac2_c22_format(priv, phyaddr, phyreg, &addr);
180 		if (ret)
181 			goto err_disable_clks;
182 
183 		value |= MII_XGMAC_SADDR;
184 	}
185 
186 	value |= (priv->clk_csr << priv->hw->mii.clk_csr_shift)
187 		& priv->hw->mii.clk_csr_mask;
188 	value |= phydata;
189 	value |= MII_XGMAC_WRITE;
190 
191 	/* Wait until any existing MII operation is complete */
192 	if (readl_poll_timeout(priv->ioaddr + mii_data, tmp,
193 			       !(tmp & MII_XGMAC_BUSY), 100, 10000)) {
194 		ret = -EBUSY;
195 		goto err_disable_clks;
196 	}
197 
198 	/* Set the MII address register to write */
199 	writel(addr, priv->ioaddr + mii_address);
200 	writel(value, priv->ioaddr + mii_data);
201 
202 	/* Wait until any existing MII operation is complete */
203 	ret = readl_poll_timeout(priv->ioaddr + mii_data, tmp,
204 				 !(tmp & MII_XGMAC_BUSY), 100, 10000);
205 
206 err_disable_clks:
207 	pm_runtime_put(priv->device);
208 
209 	return ret;
210 }
211 
212 /**
213  * stmmac_mdio_read
214  * @bus: points to the mii_bus structure
215  * @phyaddr: MII addr
216  * @phyreg: MII reg
217  * Description: it reads data from the MII register from within the phy device.
218  * For the 7111 GMAC, we must set the bit 0 in the MII address register while
219  * accessing the PHY registers.
220  * Fortunately, it seems this has no drawback for the 7109 MAC.
221  */
stmmac_mdio_read(struct mii_bus * bus,int phyaddr,int phyreg)222 static int stmmac_mdio_read(struct mii_bus *bus, int phyaddr, int phyreg)
223 {
224 	struct net_device *ndev = bus->priv;
225 	struct stmmac_priv *priv = netdev_priv(ndev);
226 	unsigned int mii_address = priv->hw->mii.addr;
227 	unsigned int mii_data = priv->hw->mii.data;
228 	u32 value = MII_BUSY;
229 	int data = 0;
230 	u32 v;
231 
232 	data = pm_runtime_get_sync(priv->device);
233 	if (data < 0) {
234 		pm_runtime_put_noidle(priv->device);
235 		return data;
236 	}
237 
238 	value |= (phyaddr << priv->hw->mii.addr_shift)
239 		& priv->hw->mii.addr_mask;
240 	value |= (phyreg << priv->hw->mii.reg_shift) & priv->hw->mii.reg_mask;
241 	value |= (priv->clk_csr << priv->hw->mii.clk_csr_shift)
242 		& priv->hw->mii.clk_csr_mask;
243 	if (priv->plat->has_gmac4) {
244 		value |= MII_GMAC4_READ;
245 		if (phyreg & MII_ADDR_C45) {
246 			value |= MII_GMAC4_C45E;
247 			value &= ~priv->hw->mii.reg_mask;
248 			value |= ((phyreg >> MII_DEVADDR_C45_SHIFT) <<
249 			       priv->hw->mii.reg_shift) &
250 			       priv->hw->mii.reg_mask;
251 
252 			data |= (phyreg & MII_REGADDR_C45_MASK) <<
253 				MII_GMAC4_REG_ADDR_SHIFT;
254 		}
255 	}
256 
257 	if (readl_poll_timeout(priv->ioaddr + mii_address, v, !(v & MII_BUSY),
258 			       100, 10000)) {
259 		data = -EBUSY;
260 		goto err_disable_clks;
261 	}
262 
263 	writel(data, priv->ioaddr + mii_data);
264 	writel(value, priv->ioaddr + mii_address);
265 
266 	if (readl_poll_timeout(priv->ioaddr + mii_address, v, !(v & MII_BUSY),
267 			       100, 10000)) {
268 		data = -EBUSY;
269 		goto err_disable_clks;
270 	}
271 
272 	/* Read the data from the MII data register */
273 	data = (int)readl(priv->ioaddr + mii_data) & MII_DATA_MASK;
274 
275 err_disable_clks:
276 	pm_runtime_put(priv->device);
277 
278 	return data;
279 }
280 
281 /**
282  * stmmac_mdio_write
283  * @bus: points to the mii_bus structure
284  * @phyaddr: MII addr
285  * @phyreg: MII reg
286  * @phydata: phy data
287  * Description: it writes the data into the MII register from within the device.
288  */
stmmac_mdio_write(struct mii_bus * bus,int phyaddr,int phyreg,u16 phydata)289 static int stmmac_mdio_write(struct mii_bus *bus, int phyaddr, int phyreg,
290 			     u16 phydata)
291 {
292 	struct net_device *ndev = bus->priv;
293 	struct stmmac_priv *priv = netdev_priv(ndev);
294 	unsigned int mii_address = priv->hw->mii.addr;
295 	unsigned int mii_data = priv->hw->mii.data;
296 	int ret, data = phydata;
297 	u32 value = MII_BUSY;
298 	u32 v;
299 
300 	ret = pm_runtime_get_sync(priv->device);
301 	if (ret < 0) {
302 		pm_runtime_put_noidle(priv->device);
303 		return ret;
304 	}
305 
306 	value |= (phyaddr << priv->hw->mii.addr_shift)
307 		& priv->hw->mii.addr_mask;
308 	value |= (phyreg << priv->hw->mii.reg_shift) & priv->hw->mii.reg_mask;
309 
310 	value |= (priv->clk_csr << priv->hw->mii.clk_csr_shift)
311 		& priv->hw->mii.clk_csr_mask;
312 	if (priv->plat->has_gmac4) {
313 		value |= MII_GMAC4_WRITE;
314 		if (phyreg & MII_ADDR_C45) {
315 			value |= MII_GMAC4_C45E;
316 			value &= ~priv->hw->mii.reg_mask;
317 			value |= ((phyreg >> MII_DEVADDR_C45_SHIFT) <<
318 			       priv->hw->mii.reg_shift) &
319 			       priv->hw->mii.reg_mask;
320 
321 			data |= (phyreg & MII_REGADDR_C45_MASK) <<
322 				MII_GMAC4_REG_ADDR_SHIFT;
323 		}
324 	} else {
325 		value |= MII_WRITE;
326 	}
327 
328 	/* Wait until any existing MII operation is complete */
329 	if (readl_poll_timeout(priv->ioaddr + mii_address, v, !(v & MII_BUSY),
330 			       100, 10000)) {
331 		ret = -EBUSY;
332 		goto err_disable_clks;
333 	}
334 
335 	/* Set the MII address register to write */
336 	writel(data, priv->ioaddr + mii_data);
337 	writel(value, priv->ioaddr + mii_address);
338 
339 	/* Wait until any existing MII operation is complete */
340 	ret = readl_poll_timeout(priv->ioaddr + mii_address, v, !(v & MII_BUSY),
341 				 100, 10000);
342 
343 err_disable_clks:
344 	pm_runtime_put(priv->device);
345 
346 	return ret;
347 }
348 
349 /**
350  * stmmac_mdio_reset
351  * @bus: points to the mii_bus structure
352  * Description: reset the MII bus
353  */
stmmac_mdio_reset(struct mii_bus * bus)354 int stmmac_mdio_reset(struct mii_bus *bus)
355 {
356 #if IS_ENABLED(CONFIG_STMMAC_PLATFORM)
357 	struct net_device *ndev = bus->priv;
358 	struct stmmac_priv *priv = netdev_priv(ndev);
359 	unsigned int mii_address = priv->hw->mii.addr;
360 
361 #ifdef CONFIG_OF
362 	if (priv->device->of_node) {
363 		struct gpio_desc *reset_gpio;
364 		u32 delays[3] = { 0, 0, 0 };
365 
366 		reset_gpio = devm_gpiod_get_optional(priv->device,
367 						     "snps,reset",
368 						     GPIOD_OUT_LOW);
369 		if (IS_ERR(reset_gpio))
370 			return PTR_ERR(reset_gpio);
371 
372 		device_property_read_u32_array(priv->device,
373 					       "snps,reset-delays-us",
374 					       delays, ARRAY_SIZE(delays));
375 
376 		if (delays[0])
377 			msleep(DIV_ROUND_UP(delays[0], 1000));
378 
379 		gpiod_set_value_cansleep(reset_gpio, 1);
380 		if (delays[1])
381 			msleep(DIV_ROUND_UP(delays[1], 1000));
382 
383 		gpiod_set_value_cansleep(reset_gpio, 0);
384 		if (delays[2])
385 			msleep(DIV_ROUND_UP(delays[2], 1000));
386 	}
387 #endif
388 
389 	/* This is a workaround for problems with the STE101P PHY.
390 	 * It doesn't complete its reset until at least one clock cycle
391 	 * on MDC, so perform a dummy mdio read. To be updated for GMAC4
392 	 * if needed.
393 	 */
394 	if (!priv->plat->has_gmac4)
395 		writel(0, priv->ioaddr + mii_address);
396 #endif
397 	return 0;
398 }
399 EXPORT_SYMBOL(stmmac_mdio_reset);
400 
401 /**
402  * stmmac_mdio_register
403  * @ndev: net device structure
404  * Description: it registers the MII bus
405  */
stmmac_mdio_register(struct net_device * ndev)406 int stmmac_mdio_register(struct net_device *ndev)
407 {
408 	int err = 0;
409 	struct mii_bus *new_bus;
410 	struct stmmac_priv *priv = netdev_priv(ndev);
411 	struct stmmac_mdio_bus_data *mdio_bus_data = priv->plat->mdio_bus_data;
412 	struct device_node *mdio_node = priv->plat->mdio_node;
413 	struct device *dev = ndev->dev.parent;
414 	int addr, found, max_addr;
415 
416 	if (!mdio_bus_data)
417 		return 0;
418 
419 	new_bus = mdiobus_alloc();
420 	if (!new_bus)
421 		return -ENOMEM;
422 
423 	if (mdio_bus_data->irqs)
424 		memcpy(new_bus->irq, mdio_bus_data->irqs, sizeof(new_bus->irq));
425 
426 	new_bus->name = "stmmac";
427 
428 	if (priv->plat->has_xgmac) {
429 		new_bus->read = &stmmac_xgmac2_mdio_read;
430 		new_bus->write = &stmmac_xgmac2_mdio_write;
431 
432 		/* Right now only C22 phys are supported */
433 		max_addr = MII_XGMAC_MAX_C22ADDR + 1;
434 
435 		/* Check if DT specified an unsupported phy addr */
436 		if (priv->plat->phy_addr > MII_XGMAC_MAX_C22ADDR)
437 			dev_err(dev, "Unsupported phy_addr (max=%d)\n",
438 					MII_XGMAC_MAX_C22ADDR);
439 	} else {
440 		new_bus->read = &stmmac_mdio_read;
441 		new_bus->write = &stmmac_mdio_write;
442 		max_addr = PHY_MAX_ADDR;
443 	}
444 
445 	if (mdio_bus_data->has_xpcs) {
446 		priv->hw->xpcs = mdio_xpcs_get_ops();
447 		if (!priv->hw->xpcs) {
448 			err = -ENODEV;
449 			goto bus_register_fail;
450 		}
451 	}
452 
453 	if (mdio_bus_data->needs_reset)
454 		new_bus->reset = &stmmac_mdio_reset;
455 
456 	snprintf(new_bus->id, MII_BUS_ID_SIZE, "%s-%x",
457 		 new_bus->name, priv->plat->bus_id);
458 	new_bus->priv = ndev;
459 	new_bus->phy_mask = mdio_bus_data->phy_mask;
460 	new_bus->parent = priv->device;
461 
462 	err = of_mdiobus_register(new_bus, mdio_node);
463 	if (err != 0) {
464 		dev_err(dev, "Cannot register the MDIO bus\n");
465 		goto bus_register_fail;
466 	}
467 
468 	/* Looks like we need a dummy read for XGMAC only and C45 PHYs */
469 	if (priv->plat->has_xgmac)
470 		stmmac_xgmac2_mdio_read(new_bus, 0, MII_ADDR_C45);
471 
472 	if (priv->plat->phy_node || mdio_node)
473 		goto bus_register_done;
474 
475 	found = 0;
476 	for (addr = 0; addr < max_addr; addr++) {
477 		struct phy_device *phydev = mdiobus_get_phy(new_bus, addr);
478 
479 		if (!phydev)
480 			continue;
481 
482 		/*
483 		 * If an IRQ was provided to be assigned after
484 		 * the bus probe, do it here.
485 		 */
486 		if (!mdio_bus_data->irqs &&
487 		    (mdio_bus_data->probed_phy_irq > 0)) {
488 			new_bus->irq[addr] = mdio_bus_data->probed_phy_irq;
489 			phydev->irq = mdio_bus_data->probed_phy_irq;
490 		}
491 
492 		/*
493 		 * If we're going to bind the MAC to this PHY bus,
494 		 * and no PHY number was provided to the MAC,
495 		 * use the one probed here.
496 		 */
497 		if (priv->plat->phy_addr == -1)
498 			priv->plat->phy_addr = addr;
499 
500 		phy_attached_info(phydev);
501 		found = 1;
502 	}
503 
504 	if (!found && !mdio_node) {
505 		dev_warn(dev, "No PHY found\n");
506 		err = -ENODEV;
507 		goto no_phy_found;
508 	}
509 
510 	/* Try to probe the XPCS by scanning all addresses. */
511 	if (priv->hw->xpcs) {
512 		struct mdio_xpcs_args *xpcs = &priv->hw->xpcs_args;
513 		int ret, mode = priv->plat->phy_interface;
514 		max_addr = PHY_MAX_ADDR;
515 
516 		xpcs->bus = new_bus;
517 
518 		found = 0;
519 		for (addr = 0; addr < max_addr; addr++) {
520 			xpcs->addr = addr;
521 
522 			ret = stmmac_xpcs_probe(priv, xpcs, mode);
523 			if (!ret) {
524 				found = 1;
525 				break;
526 			}
527 		}
528 
529 		if (!found && !mdio_node) {
530 			dev_warn(dev, "No XPCS found\n");
531 			err = -ENODEV;
532 			goto no_xpcs_found;
533 		}
534 	}
535 
536 bus_register_done:
537 	priv->mii = new_bus;
538 
539 	return 0;
540 
541 no_xpcs_found:
542 no_phy_found:
543 	mdiobus_unregister(new_bus);
544 bus_register_fail:
545 	mdiobus_free(new_bus);
546 	return err;
547 }
548 
549 /**
550  * stmmac_mdio_unregister
551  * @ndev: net device structure
552  * Description: it unregisters the MII bus
553  */
stmmac_mdio_unregister(struct net_device * ndev)554 int stmmac_mdio_unregister(struct net_device *ndev)
555 {
556 	struct stmmac_priv *priv = netdev_priv(ndev);
557 
558 	if (!priv->mii)
559 		return 0;
560 
561 	mdiobus_unregister(priv->mii);
562 	priv->mii->priv = NULL;
563 	mdiobus_free(priv->mii);
564 	priv->mii = NULL;
565 
566 	return 0;
567 }
568