xref: /linux/drivers/net/ethernet/stmicro/stmmac/stmmac_mdio.c (revision f858cc9eed5b05cbe38d7ffd2787c21e3718eb7d)
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 
48 static void stmmac_xgmac2_c45_format(struct stmmac_priv *priv, int phyaddr,
49 				     int devad, 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 |= devad << MII_XGMAC_DA_SHIFT;
60 }
61 
62 static void stmmac_xgmac2_c22_format(struct stmmac_priv *priv, int phyaddr,
63 				     int phyreg, u32 *hw_addr)
64 {
65 	u32 tmp = 0;
66 
67 	if (priv->synopsys_id < DWXGMAC_CORE_2_20) {
68 		/* Until ver 2.20 XGMAC does not support C22 addr >= 4. Those
69 		 * bits above bit 3 of XGMAC_MDIO_C22P register are reserved.
70 		 */
71 		tmp = readl(priv->ioaddr + XGMAC_MDIO_C22P);
72 		tmp &= ~MII_XGMAC_C22P_MASK;
73 	}
74 	/* Set port as Clause 22 */
75 	tmp |= BIT(phyaddr);
76 	writel(tmp, priv->ioaddr + XGMAC_MDIO_C22P);
77 
78 	*hw_addr = (phyaddr << MII_XGMAC_PA_SHIFT) | (phyreg & 0x1f);
79 }
80 
81 static int stmmac_xgmac2_mdio_read(struct stmmac_priv *priv, u32 addr,
82 				   u32 value)
83 {
84 	unsigned int mii_address = priv->hw->mii.addr;
85 	unsigned int mii_data = priv->hw->mii.data;
86 	u32 tmp;
87 	int ret;
88 
89 	ret = pm_runtime_resume_and_get(priv->device);
90 	if (ret < 0)
91 		return ret;
92 
93 	/* Wait until any existing MII operation is complete */
94 	if (readl_poll_timeout(priv->ioaddr + mii_data, tmp,
95 			       !(tmp & MII_XGMAC_BUSY), 100, 10000)) {
96 		ret = -EBUSY;
97 		goto err_disable_clks;
98 	}
99 
100 	value |= (priv->clk_csr << priv->hw->mii.clk_csr_shift)
101 		& priv->hw->mii.clk_csr_mask;
102 	value |= MII_XGMAC_READ;
103 
104 	/* Wait until any existing MII operation is complete */
105 	if (readl_poll_timeout(priv->ioaddr + mii_data, tmp,
106 			       !(tmp & MII_XGMAC_BUSY), 100, 10000)) {
107 		ret = -EBUSY;
108 		goto err_disable_clks;
109 	}
110 
111 	/* Set the MII address register to read */
112 	writel(addr, priv->ioaddr + mii_address);
113 	writel(value, priv->ioaddr + mii_data);
114 
115 	/* Wait until any existing MII operation is complete */
116 	if (readl_poll_timeout(priv->ioaddr + mii_data, tmp,
117 			       !(tmp & MII_XGMAC_BUSY), 100, 10000)) {
118 		ret = -EBUSY;
119 		goto err_disable_clks;
120 	}
121 
122 	/* Read the data from the MII data register */
123 	ret = (int)readl(priv->ioaddr + mii_data) & GENMASK(15, 0);
124 
125 err_disable_clks:
126 	pm_runtime_put(priv->device);
127 
128 	return ret;
129 }
130 
131 static int stmmac_xgmac2_mdio_read_c22(struct mii_bus *bus, int phyaddr,
132 				       int phyreg)
133 {
134 	struct net_device *ndev = bus->priv;
135 	struct stmmac_priv *priv;
136 	u32 addr;
137 
138 	priv = netdev_priv(ndev);
139 
140 	/* Until ver 2.20 XGMAC does not support C22 addr >= 4 */
141 	if (priv->synopsys_id < DWXGMAC_CORE_2_20 &&
142 	    phyaddr > MII_XGMAC_MAX_C22ADDR)
143 		return -ENODEV;
144 
145 	stmmac_xgmac2_c22_format(priv, phyaddr, phyreg, &addr);
146 
147 	return stmmac_xgmac2_mdio_read(priv, addr, MII_XGMAC_BUSY);
148 }
149 
150 static int stmmac_xgmac2_mdio_read_c45(struct mii_bus *bus, int phyaddr,
151 				       int devad, int phyreg)
152 {
153 	struct net_device *ndev = bus->priv;
154 	struct stmmac_priv *priv;
155 	u32 addr;
156 
157 	priv = netdev_priv(ndev);
158 
159 	stmmac_xgmac2_c45_format(priv, phyaddr, devad, phyreg, &addr);
160 
161 	return stmmac_xgmac2_mdio_read(priv, addr, MII_XGMAC_BUSY);
162 }
163 
164 static int stmmac_xgmac2_mdio_write(struct stmmac_priv *priv, u32 addr,
165 				    u32 value, u16 phydata)
166 {
167 	unsigned int mii_address = priv->hw->mii.addr;
168 	unsigned int mii_data = priv->hw->mii.data;
169 	u32 tmp;
170 	int ret;
171 
172 	ret = pm_runtime_resume_and_get(priv->device);
173 	if (ret < 0)
174 		return ret;
175 
176 	/* Wait until any existing MII operation is complete */
177 	if (readl_poll_timeout(priv->ioaddr + mii_data, tmp,
178 			       !(tmp & MII_XGMAC_BUSY), 100, 10000)) {
179 		ret = -EBUSY;
180 		goto err_disable_clks;
181 	}
182 
183 	value |= (priv->clk_csr << priv->hw->mii.clk_csr_shift)
184 		& priv->hw->mii.clk_csr_mask;
185 	value |= phydata;
186 	value |= MII_XGMAC_WRITE;
187 
188 	/* Wait until any existing MII operation is complete */
189 	if (readl_poll_timeout(priv->ioaddr + mii_data, tmp,
190 			       !(tmp & MII_XGMAC_BUSY), 100, 10000)) {
191 		ret = -EBUSY;
192 		goto err_disable_clks;
193 	}
194 
195 	/* Set the MII address register to write */
196 	writel(addr, priv->ioaddr + mii_address);
197 	writel(value, priv->ioaddr + mii_data);
198 
199 	/* Wait until any existing MII operation is complete */
200 	ret = readl_poll_timeout(priv->ioaddr + mii_data, tmp,
201 				 !(tmp & MII_XGMAC_BUSY), 100, 10000);
202 
203 err_disable_clks:
204 	pm_runtime_put(priv->device);
205 
206 	return ret;
207 }
208 
209 static int stmmac_xgmac2_mdio_write_c22(struct mii_bus *bus, int phyaddr,
210 					int phyreg, u16 phydata)
211 {
212 	struct net_device *ndev = bus->priv;
213 	struct stmmac_priv *priv;
214 	u32 addr;
215 
216 	priv = netdev_priv(ndev);
217 
218 	/* Until ver 2.20 XGMAC does not support C22 addr >= 4 */
219 	if (priv->synopsys_id < DWXGMAC_CORE_2_20 &&
220 	    phyaddr > MII_XGMAC_MAX_C22ADDR)
221 		return -ENODEV;
222 
223 	stmmac_xgmac2_c22_format(priv, phyaddr, phyreg, &addr);
224 
225 	return stmmac_xgmac2_mdio_write(priv, addr,
226 					MII_XGMAC_BUSY | MII_XGMAC_SADDR, phydata);
227 }
228 
229 static int stmmac_xgmac2_mdio_write_c45(struct mii_bus *bus, int phyaddr,
230 					int devad, int phyreg, u16 phydata)
231 {
232 	struct net_device *ndev = bus->priv;
233 	struct stmmac_priv *priv;
234 	u32 addr;
235 
236 	priv = netdev_priv(ndev);
237 
238 	stmmac_xgmac2_c45_format(priv, phyaddr, devad, phyreg, &addr);
239 
240 	return stmmac_xgmac2_mdio_write(priv, addr, MII_XGMAC_BUSY,
241 					phydata);
242 }
243 
244 static int stmmac_mdio_read(struct stmmac_priv *priv, int data, u32 value)
245 {
246 	unsigned int mii_address = priv->hw->mii.addr;
247 	unsigned int mii_data = priv->hw->mii.data;
248 	u32 v;
249 
250 	if (readl_poll_timeout(priv->ioaddr + mii_address, v, !(v & MII_BUSY),
251 			       100, 10000))
252 		return -EBUSY;
253 
254 	writel(data, priv->ioaddr + mii_data);
255 	writel(value, priv->ioaddr + mii_address);
256 
257 	if (readl_poll_timeout(priv->ioaddr + mii_address, v, !(v & MII_BUSY),
258 			       100, 10000))
259 		return -EBUSY;
260 
261 	/* Read the data from the MII data register */
262 	return readl(priv->ioaddr + mii_data) & MII_DATA_MASK;
263 }
264 
265 /**
266  * stmmac_mdio_read_c22
267  * @bus: points to the mii_bus structure
268  * @phyaddr: MII addr
269  * @phyreg: MII reg
270  * Description: it reads data from the MII register from within the phy device.
271  * For the 7111 GMAC, we must set the bit 0 in the MII address register while
272  * accessing the PHY registers.
273  * Fortunately, it seems this has no drawback for the 7109 MAC.
274  */
275 static int stmmac_mdio_read_c22(struct mii_bus *bus, int phyaddr, int phyreg)
276 {
277 	struct net_device *ndev = bus->priv;
278 	struct stmmac_priv *priv = netdev_priv(ndev);
279 	u32 value = MII_BUSY;
280 	int data = 0;
281 
282 	data = pm_runtime_resume_and_get(priv->device);
283 	if (data < 0)
284 		return data;
285 
286 	value |= (phyaddr << priv->hw->mii.addr_shift)
287 		& priv->hw->mii.addr_mask;
288 	value |= (phyreg << priv->hw->mii.reg_shift) & priv->hw->mii.reg_mask;
289 	value |= (priv->clk_csr << priv->hw->mii.clk_csr_shift)
290 		& priv->hw->mii.clk_csr_mask;
291 	if (priv->plat->has_gmac4)
292 		value |= MII_GMAC4_READ;
293 
294 	data = stmmac_mdio_read(priv, data, value);
295 
296 	pm_runtime_put(priv->device);
297 
298 	return data;
299 }
300 
301 /**
302  * stmmac_mdio_read_c45
303  * @bus: points to the mii_bus structure
304  * @phyaddr: MII addr
305  * @devad: device address to read
306  * @phyreg: MII reg
307  * Description: it reads data from the MII register from within the phy device.
308  * For the 7111 GMAC, we must set the bit 0 in the MII address register while
309  * accessing the PHY registers.
310  * Fortunately, it seems this has no drawback for the 7109 MAC.
311  */
312 static int stmmac_mdio_read_c45(struct mii_bus *bus, int phyaddr, int devad,
313 				int phyreg)
314 {
315 	struct net_device *ndev = bus->priv;
316 	struct stmmac_priv *priv = netdev_priv(ndev);
317 	u32 value = MII_BUSY;
318 	int data = 0;
319 
320 	data = pm_runtime_get_sync(priv->device);
321 	if (data < 0) {
322 		pm_runtime_put_noidle(priv->device);
323 		return data;
324 	}
325 
326 	value |= (phyaddr << priv->hw->mii.addr_shift)
327 		& priv->hw->mii.addr_mask;
328 	value |= (phyreg << priv->hw->mii.reg_shift) & priv->hw->mii.reg_mask;
329 	value |= (priv->clk_csr << priv->hw->mii.clk_csr_shift)
330 		& priv->hw->mii.clk_csr_mask;
331 	value |= MII_GMAC4_READ;
332 	value |= MII_GMAC4_C45E;
333 	value &= ~priv->hw->mii.reg_mask;
334 	value |= (devad << priv->hw->mii.reg_shift) & priv->hw->mii.reg_mask;
335 
336 	data |= phyreg << MII_GMAC4_REG_ADDR_SHIFT;
337 
338 	data = stmmac_mdio_read(priv, data, value);
339 
340 	pm_runtime_put(priv->device);
341 
342 	return data;
343 }
344 
345 static int stmmac_mdio_write(struct stmmac_priv *priv, int data, u32 value)
346 {
347 	unsigned int mii_address = priv->hw->mii.addr;
348 	unsigned int mii_data = priv->hw->mii.data;
349 	u32 v;
350 
351 	/* Wait until any existing MII operation is complete */
352 	if (readl_poll_timeout(priv->ioaddr + mii_address, v, !(v & MII_BUSY),
353 			       100, 10000))
354 		return -EBUSY;
355 
356 	/* Set the MII address register to write */
357 	writel(data, priv->ioaddr + mii_data);
358 	writel(value, priv->ioaddr + mii_address);
359 
360 	/* Wait until any existing MII operation is complete */
361 	return readl_poll_timeout(priv->ioaddr + mii_address, v,
362 				  !(v & MII_BUSY), 100, 10000);
363 }
364 
365 /**
366  * stmmac_mdio_write_c22
367  * @bus: points to the mii_bus structure
368  * @phyaddr: MII addr
369  * @phyreg: MII reg
370  * @phydata: phy data
371  * Description: it writes the data into the MII register from within the device.
372  */
373 static int stmmac_mdio_write_c22(struct mii_bus *bus, int phyaddr, int phyreg,
374 				 u16 phydata)
375 {
376 	struct net_device *ndev = bus->priv;
377 	struct stmmac_priv *priv = netdev_priv(ndev);
378 	int ret, data = phydata;
379 	u32 value = MII_BUSY;
380 
381 	ret = pm_runtime_resume_and_get(priv->device);
382 	if (ret < 0)
383 		return ret;
384 
385 	value |= (phyaddr << priv->hw->mii.addr_shift)
386 		& priv->hw->mii.addr_mask;
387 	value |= (phyreg << priv->hw->mii.reg_shift) & priv->hw->mii.reg_mask;
388 
389 	value |= (priv->clk_csr << priv->hw->mii.clk_csr_shift)
390 		& priv->hw->mii.clk_csr_mask;
391 	if (priv->plat->has_gmac4)
392 		value |= MII_GMAC4_WRITE;
393 	else
394 		value |= MII_WRITE;
395 
396 	ret = stmmac_mdio_write(priv, data, value);
397 
398 	pm_runtime_put(priv->device);
399 
400 	return ret;
401 }
402 
403 /**
404  * stmmac_mdio_write_c45
405  * @bus: points to the mii_bus structure
406  * @phyaddr: MII addr
407  * @phyreg: MII reg
408  * @devad: device address to read
409  * @phydata: phy data
410  * Description: it writes the data into the MII register from within the device.
411  */
412 static int stmmac_mdio_write_c45(struct mii_bus *bus, int phyaddr,
413 				 int devad, int phyreg, u16 phydata)
414 {
415 	struct net_device *ndev = bus->priv;
416 	struct stmmac_priv *priv = netdev_priv(ndev);
417 	int ret, data = phydata;
418 	u32 value = MII_BUSY;
419 
420 	ret = pm_runtime_get_sync(priv->device);
421 	if (ret < 0) {
422 		pm_runtime_put_noidle(priv->device);
423 		return ret;
424 	}
425 
426 	value |= (phyaddr << priv->hw->mii.addr_shift)
427 		& priv->hw->mii.addr_mask;
428 	value |= (phyreg << priv->hw->mii.reg_shift) & priv->hw->mii.reg_mask;
429 
430 	value |= (priv->clk_csr << priv->hw->mii.clk_csr_shift)
431 		& priv->hw->mii.clk_csr_mask;
432 
433 	value |= MII_GMAC4_WRITE;
434 	value |= MII_GMAC4_C45E;
435 	value &= ~priv->hw->mii.reg_mask;
436 	value |= (devad << priv->hw->mii.reg_shift) & priv->hw->mii.reg_mask;
437 
438 	data |= phyreg << MII_GMAC4_REG_ADDR_SHIFT;
439 
440 	ret = stmmac_mdio_write(priv, data, value);
441 
442 	pm_runtime_put(priv->device);
443 
444 	return ret;
445 }
446 
447 /**
448  * stmmac_mdio_reset
449  * @bus: points to the mii_bus structure
450  * Description: reset the MII bus
451  */
452 int stmmac_mdio_reset(struct mii_bus *bus)
453 {
454 #if IS_ENABLED(CONFIG_STMMAC_PLATFORM)
455 	struct net_device *ndev = bus->priv;
456 	struct stmmac_priv *priv = netdev_priv(ndev);
457 	unsigned int mii_address = priv->hw->mii.addr;
458 
459 #ifdef CONFIG_OF
460 	if (priv->device->of_node) {
461 		struct gpio_desc *reset_gpio;
462 		u32 delays[3] = { 0, 0, 0 };
463 
464 		reset_gpio = devm_gpiod_get_optional(priv->device,
465 						     "snps,reset",
466 						     GPIOD_OUT_LOW);
467 		if (IS_ERR(reset_gpio))
468 			return PTR_ERR(reset_gpio);
469 
470 		device_property_read_u32_array(priv->device,
471 					       "snps,reset-delays-us",
472 					       delays, ARRAY_SIZE(delays));
473 
474 		if (delays[0])
475 			msleep(DIV_ROUND_UP(delays[0], 1000));
476 
477 		gpiod_set_value_cansleep(reset_gpio, 1);
478 		if (delays[1])
479 			msleep(DIV_ROUND_UP(delays[1], 1000));
480 
481 		gpiod_set_value_cansleep(reset_gpio, 0);
482 		if (delays[2])
483 			msleep(DIV_ROUND_UP(delays[2], 1000));
484 	}
485 #endif
486 
487 	/* This is a workaround for problems with the STE101P PHY.
488 	 * It doesn't complete its reset until at least one clock cycle
489 	 * on MDC, so perform a dummy mdio read. To be updated for GMAC4
490 	 * if needed.
491 	 */
492 	if (!priv->plat->has_gmac4)
493 		writel(0, priv->ioaddr + mii_address);
494 #endif
495 	return 0;
496 }
497 
498 int stmmac_pcs_setup(struct net_device *ndev)
499 {
500 	struct fwnode_handle *devnode, *pcsnode;
501 	struct dw_xpcs *xpcs = NULL;
502 	struct stmmac_priv *priv;
503 	int addr, ret;
504 
505 	priv = netdev_priv(ndev);
506 	devnode = priv->plat->port_node;
507 
508 	if (priv->plat->pcs_init) {
509 		ret = priv->plat->pcs_init(priv);
510 	} else if (fwnode_property_present(devnode, "pcs-handle")) {
511 		pcsnode = fwnode_find_reference(devnode, "pcs-handle", 0);
512 		xpcs = xpcs_create_fwnode(pcsnode);
513 		fwnode_handle_put(pcsnode);
514 		ret = PTR_ERR_OR_ZERO(xpcs);
515 	} else if (priv->plat->mdio_bus_data &&
516 		   priv->plat->mdio_bus_data->pcs_mask) {
517 		addr = ffs(priv->plat->mdio_bus_data->pcs_mask) - 1;
518 		xpcs = xpcs_create_mdiodev(priv->mii, addr);
519 		ret = PTR_ERR_OR_ZERO(xpcs);
520 	} else {
521 		return 0;
522 	}
523 
524 	if (ret)
525 		return dev_err_probe(priv->device, ret, "No xPCS found\n");
526 
527 	priv->hw->xpcs = xpcs;
528 
529 	return 0;
530 }
531 
532 void stmmac_pcs_clean(struct net_device *ndev)
533 {
534 	struct stmmac_priv *priv = netdev_priv(ndev);
535 
536 	if (priv->plat->pcs_exit)
537 		priv->plat->pcs_exit(priv);
538 
539 	if (!priv->hw->xpcs)
540 		return;
541 
542 	xpcs_destroy(priv->hw->xpcs);
543 	priv->hw->xpcs = NULL;
544 }
545 
546 /**
547  * stmmac_mdio_register
548  * @ndev: net device structure
549  * Description: it registers the MII bus
550  */
551 int stmmac_mdio_register(struct net_device *ndev)
552 {
553 	int err = 0;
554 	struct mii_bus *new_bus;
555 	struct stmmac_priv *priv = netdev_priv(ndev);
556 	struct stmmac_mdio_bus_data *mdio_bus_data = priv->plat->mdio_bus_data;
557 	struct device_node *mdio_node = priv->plat->mdio_node;
558 	struct device *dev = ndev->dev.parent;
559 	struct fwnode_handle *fixed_node;
560 	struct fwnode_handle *fwnode;
561 	int addr, found, max_addr;
562 
563 	if (!mdio_bus_data)
564 		return 0;
565 
566 	new_bus = mdiobus_alloc();
567 	if (!new_bus)
568 		return -ENOMEM;
569 
570 	if (mdio_bus_data->irqs)
571 		memcpy(new_bus->irq, mdio_bus_data->irqs, sizeof(new_bus->irq));
572 
573 	new_bus->name = "stmmac";
574 
575 	if (priv->plat->has_xgmac) {
576 		new_bus->read = &stmmac_xgmac2_mdio_read_c22;
577 		new_bus->write = &stmmac_xgmac2_mdio_write_c22;
578 		new_bus->read_c45 = &stmmac_xgmac2_mdio_read_c45;
579 		new_bus->write_c45 = &stmmac_xgmac2_mdio_write_c45;
580 
581 		if (priv->synopsys_id < DWXGMAC_CORE_2_20) {
582 			/* Right now only C22 phys are supported */
583 			max_addr = MII_XGMAC_MAX_C22ADDR + 1;
584 
585 			/* Check if DT specified an unsupported phy addr */
586 			if (priv->plat->phy_addr > MII_XGMAC_MAX_C22ADDR)
587 				dev_err(dev, "Unsupported phy_addr (max=%d)\n",
588 					MII_XGMAC_MAX_C22ADDR);
589 		} else {
590 			/* XGMAC version 2.20 onwards support 32 phy addr */
591 			max_addr = PHY_MAX_ADDR;
592 		}
593 	} else {
594 		new_bus->read = &stmmac_mdio_read_c22;
595 		new_bus->write = &stmmac_mdio_write_c22;
596 		if (priv->plat->has_gmac4) {
597 			new_bus->read_c45 = &stmmac_mdio_read_c45;
598 			new_bus->write_c45 = &stmmac_mdio_write_c45;
599 		}
600 
601 		max_addr = PHY_MAX_ADDR;
602 	}
603 
604 	if (mdio_bus_data->needs_reset)
605 		new_bus->reset = &stmmac_mdio_reset;
606 
607 	snprintf(new_bus->id, MII_BUS_ID_SIZE, "%s-%x",
608 		 new_bus->name, priv->plat->bus_id);
609 	new_bus->priv = ndev;
610 	new_bus->phy_mask = mdio_bus_data->phy_mask | mdio_bus_data->pcs_mask;
611 	new_bus->parent = priv->device;
612 
613 	err = of_mdiobus_register(new_bus, mdio_node);
614 	if (err == -ENODEV) {
615 		err = 0;
616 		dev_info(dev, "MDIO bus is disabled\n");
617 		goto bus_register_fail;
618 	} else if (err) {
619 		dev_err_probe(dev, err, "Cannot register the MDIO bus\n");
620 		goto bus_register_fail;
621 	}
622 
623 	/* Looks like we need a dummy read for XGMAC only and C45 PHYs */
624 	if (priv->plat->has_xgmac)
625 		stmmac_xgmac2_mdio_read_c45(new_bus, 0, 0, 0);
626 
627 	/* If fixed-link is set, skip PHY scanning */
628 	fwnode = priv->plat->port_node;
629 	if (!fwnode)
630 		fwnode = dev_fwnode(priv->device);
631 
632 	if (fwnode) {
633 		fixed_node = fwnode_get_named_child_node(fwnode, "fixed-link");
634 		if (fixed_node) {
635 			fwnode_handle_put(fixed_node);
636 			goto bus_register_done;
637 		}
638 	}
639 
640 	if (priv->plat->phy_node || mdio_node)
641 		goto bus_register_done;
642 
643 	found = 0;
644 	for (addr = 0; addr < max_addr; addr++) {
645 		struct phy_device *phydev = mdiobus_get_phy(new_bus, addr);
646 
647 		if (!phydev)
648 			continue;
649 
650 		/*
651 		 * If an IRQ was provided to be assigned after
652 		 * the bus probe, do it here.
653 		 */
654 		if (!mdio_bus_data->irqs &&
655 		    (mdio_bus_data->probed_phy_irq > 0)) {
656 			new_bus->irq[addr] = mdio_bus_data->probed_phy_irq;
657 			phydev->irq = mdio_bus_data->probed_phy_irq;
658 		}
659 
660 		/*
661 		 * If we're going to bind the MAC to this PHY bus,
662 		 * and no PHY number was provided to the MAC,
663 		 * use the one probed here.
664 		 */
665 		if (priv->plat->phy_addr == -1)
666 			priv->plat->phy_addr = addr;
667 
668 		phy_attached_info(phydev);
669 		found = 1;
670 	}
671 
672 	if (!found && !mdio_node) {
673 		dev_warn(dev, "No PHY found\n");
674 		err = -ENODEV;
675 		goto no_phy_found;
676 	}
677 
678 bus_register_done:
679 	priv->mii = new_bus;
680 
681 	return 0;
682 
683 no_phy_found:
684 	mdiobus_unregister(new_bus);
685 bus_register_fail:
686 	mdiobus_free(new_bus);
687 	return err;
688 }
689 
690 /**
691  * stmmac_mdio_unregister
692  * @ndev: net device structure
693  * Description: it unregisters the MII bus
694  */
695 int stmmac_mdio_unregister(struct net_device *ndev)
696 {
697 	struct stmmac_priv *priv = netdev_priv(ndev);
698 
699 	if (!priv->mii)
700 		return 0;
701 
702 	mdiobus_unregister(priv->mii);
703 	priv->mii->priv = NULL;
704 	mdiobus_free(priv->mii);
705 	priv->mii = NULL;
706 
707 	return 0;
708 }
709