xref: /openbmc/linux/drivers/net/phy/marvell.c (revision 4ed91d48259d9ddd378424d008f2e6559f7e78f8)
1 /*
2  * drivers/net/phy/marvell.c
3  *
4  * Driver for Marvell PHYs
5  *
6  * Author: Andy Fleming
7  *
8  * Copyright (c) 2004 Freescale Semiconductor, Inc.
9  *
10  * Copyright (c) 2013 Michael Stapelberg <michael@stapelberg.de>
11  *
12  * This program is free software; you can redistribute  it and/or modify it
13  * under  the terms of  the GNU General  Public License as published by the
14  * Free Software Foundation;  either version 2 of the  License, or (at your
15  * option) any later version.
16  *
17  */
18 #include <linux/kernel.h>
19 #include <linux/string.h>
20 #include <linux/ctype.h>
21 #include <linux/errno.h>
22 #include <linux/unistd.h>
23 #include <linux/hwmon.h>
24 #include <linux/interrupt.h>
25 #include <linux/init.h>
26 #include <linux/delay.h>
27 #include <linux/netdevice.h>
28 #include <linux/etherdevice.h>
29 #include <linux/skbuff.h>
30 #include <linux/spinlock.h>
31 #include <linux/mm.h>
32 #include <linux/module.h>
33 #include <linux/mii.h>
34 #include <linux/ethtool.h>
35 #include <linux/phy.h>
36 #include <linux/marvell_phy.h>
37 #include <linux/of.h>
38 
39 #include <linux/io.h>
40 #include <asm/irq.h>
41 #include <linux/uaccess.h>
42 
43 #define MII_MARVELL_PHY_PAGE		22
44 
45 #define MII_M1011_IEVENT		0x13
46 #define MII_M1011_IEVENT_CLEAR		0x0000
47 
48 #define MII_M1011_IMASK			0x12
49 #define MII_M1011_IMASK_INIT		0x6400
50 #define MII_M1011_IMASK_CLEAR		0x0000
51 
52 #define MII_M1011_PHY_SCR		0x10
53 #define MII_M1011_PHY_SCR_MDI		0x0000
54 #define MII_M1011_PHY_SCR_MDI_X		0x0020
55 #define MII_M1011_PHY_SCR_AUTO_CROSS	0x0060
56 
57 #define MII_M1145_PHY_EXT_ADDR_PAGE	0x16
58 #define MII_M1145_PHY_EXT_SR		0x1b
59 #define MII_M1145_PHY_EXT_CR		0x14
60 #define MII_M1145_RGMII_RX_DELAY	0x0080
61 #define MII_M1145_RGMII_TX_DELAY	0x0002
62 #define MII_M1145_HWCFG_MODE_SGMII_NO_CLK	0x4
63 #define MII_M1145_HWCFG_MODE_MASK		0xf
64 #define MII_M1145_HWCFG_FIBER_COPPER_AUTO	0x8000
65 
66 #define MII_M1145_HWCFG_MODE_SGMII_NO_CLK	0x4
67 #define MII_M1145_HWCFG_MODE_MASK		0xf
68 #define MII_M1145_HWCFG_FIBER_COPPER_AUTO	0x8000
69 
70 #define MII_M1111_PHY_LED_CONTROL	0x18
71 #define MII_M1111_PHY_LED_DIRECT	0x4100
72 #define MII_M1111_PHY_LED_COMBINE	0x411c
73 #define MII_M1111_PHY_EXT_CR		0x14
74 #define MII_M1111_RX_DELAY		0x80
75 #define MII_M1111_TX_DELAY		0x2
76 #define MII_M1111_PHY_EXT_SR		0x1b
77 
78 #define MII_M1111_HWCFG_MODE_MASK		0xf
79 #define MII_M1111_HWCFG_MODE_COPPER_RGMII	0xb
80 #define MII_M1111_HWCFG_MODE_FIBER_RGMII	0x3
81 #define MII_M1111_HWCFG_MODE_SGMII_NO_CLK	0x4
82 #define MII_M1111_HWCFG_MODE_COPPER_RTBI	0x9
83 #define MII_M1111_HWCFG_FIBER_COPPER_AUTO	0x8000
84 #define MII_M1111_HWCFG_FIBER_COPPER_RES	0x2000
85 
86 #define MII_M1111_COPPER		0
87 #define MII_M1111_FIBER			1
88 
89 #define MII_88E1121_PHY_MSCR_PAGE	2
90 #define MII_88E1121_PHY_MSCR_REG	21
91 #define MII_88E1121_PHY_MSCR_RX_DELAY	BIT(5)
92 #define MII_88E1121_PHY_MSCR_TX_DELAY	BIT(4)
93 #define MII_88E1121_PHY_MSCR_DELAY_MASK	(~(0x3 << 4))
94 
95 #define MII_88E1121_MISC_TEST				0x1a
96 #define MII_88E1510_MISC_TEST_TEMP_THRESHOLD_MASK	0x1f00
97 #define MII_88E1510_MISC_TEST_TEMP_THRESHOLD_SHIFT	8
98 #define MII_88E1510_MISC_TEST_TEMP_IRQ_EN		BIT(7)
99 #define MII_88E1510_MISC_TEST_TEMP_IRQ			BIT(6)
100 #define MII_88E1121_MISC_TEST_TEMP_SENSOR_EN		BIT(5)
101 #define MII_88E1121_MISC_TEST_TEMP_MASK			0x1f
102 
103 #define MII_88E1510_TEMP_SENSOR		0x1b
104 #define MII_88E1510_TEMP_SENSOR_MASK	0xff
105 
106 #define MII_88E1318S_PHY_MSCR1_REG	16
107 #define MII_88E1318S_PHY_MSCR1_PAD_ODD	BIT(6)
108 
109 /* Copper Specific Interrupt Enable Register */
110 #define MII_88E1318S_PHY_CSIER                              0x12
111 /* WOL Event Interrupt Enable */
112 #define MII_88E1318S_PHY_CSIER_WOL_EIE                      BIT(7)
113 
114 /* LED Timer Control Register */
115 #define MII_88E1318S_PHY_LED_PAGE                           0x03
116 #define MII_88E1318S_PHY_LED_TCR                            0x12
117 #define MII_88E1318S_PHY_LED_TCR_FORCE_INT                  BIT(15)
118 #define MII_88E1318S_PHY_LED_TCR_INTn_ENABLE                BIT(7)
119 #define MII_88E1318S_PHY_LED_TCR_INT_ACTIVE_LOW             BIT(11)
120 
121 /* Magic Packet MAC address registers */
122 #define MII_88E1318S_PHY_MAGIC_PACKET_WORD2                 0x17
123 #define MII_88E1318S_PHY_MAGIC_PACKET_WORD1                 0x18
124 #define MII_88E1318S_PHY_MAGIC_PACKET_WORD0                 0x19
125 
126 #define MII_88E1318S_PHY_WOL_PAGE                           0x11
127 #define MII_88E1318S_PHY_WOL_CTRL                           0x10
128 #define MII_88E1318S_PHY_WOL_CTRL_CLEAR_WOL_STATUS          BIT(12)
129 #define MII_88E1318S_PHY_WOL_CTRL_MAGIC_PACKET_MATCH_ENABLE BIT(14)
130 
131 #define MII_88E1121_PHY_LED_CTRL	16
132 #define MII_88E1121_PHY_LED_PAGE	3
133 #define MII_88E1121_PHY_LED_DEF		0x0030
134 
135 #define MII_M1011_PHY_STATUS		0x11
136 #define MII_M1011_PHY_STATUS_1000	0x8000
137 #define MII_M1011_PHY_STATUS_100	0x4000
138 #define MII_M1011_PHY_STATUS_SPD_MASK	0xc000
139 #define MII_M1011_PHY_STATUS_FULLDUPLEX	0x2000
140 #define MII_M1011_PHY_STATUS_RESOLVED	0x0800
141 #define MII_M1011_PHY_STATUS_LINK	0x0400
142 
143 #define MII_M1116R_CONTROL_REG_MAC	21
144 
145 #define MII_88E3016_PHY_SPEC_CTRL	0x10
146 #define MII_88E3016_DISABLE_SCRAMBLER	0x0200
147 #define MII_88E3016_AUTO_MDIX_CROSSOVER	0x0030
148 
149 #define MII_88E1510_GEN_CTRL_REG_1		0x14
150 #define MII_88E1510_GEN_CTRL_REG_1_MODE_MASK	0x7
151 #define MII_88E1510_GEN_CTRL_REG_1_MODE_SGMII	0x1	/* SGMII to copper */
152 #define MII_88E1510_GEN_CTRL_REG_1_RESET	0x8000	/* Soft reset */
153 
154 #define LPA_FIBER_1000HALF	0x40
155 #define LPA_FIBER_1000FULL	0x20
156 
157 #define LPA_PAUSE_FIBER	0x180
158 #define LPA_PAUSE_ASYM_FIBER	0x100
159 
160 #define ADVERTISE_FIBER_1000HALF	0x40
161 #define ADVERTISE_FIBER_1000FULL	0x20
162 
163 #define ADVERTISE_PAUSE_FIBER		0x180
164 #define ADVERTISE_PAUSE_ASYM_FIBER	0x100
165 
166 #define REGISTER_LINK_STATUS	0x400
167 #define NB_FIBER_STATS	1
168 
169 MODULE_DESCRIPTION("Marvell PHY driver");
170 MODULE_AUTHOR("Andy Fleming");
171 MODULE_LICENSE("GPL");
172 
173 struct marvell_hw_stat {
174 	const char *string;
175 	u8 page;
176 	u8 reg;
177 	u8 bits;
178 };
179 
180 static struct marvell_hw_stat marvell_hw_stats[] = {
181 	{ "phy_receive_errors_copper", 0, 21, 16},
182 	{ "phy_idle_errors", 0, 10, 8 },
183 	{ "phy_receive_errors_fiber", 1, 21, 16},
184 };
185 
186 struct marvell_priv {
187 	u64 stats[ARRAY_SIZE(marvell_hw_stats)];
188 	char *hwmon_name;
189 	struct device *hwmon_dev;
190 };
191 
192 static int marvell_ack_interrupt(struct phy_device *phydev)
193 {
194 	int err;
195 
196 	/* Clear the interrupts by reading the reg */
197 	err = phy_read(phydev, MII_M1011_IEVENT);
198 
199 	if (err < 0)
200 		return err;
201 
202 	return 0;
203 }
204 
205 static int marvell_config_intr(struct phy_device *phydev)
206 {
207 	int err;
208 
209 	if (phydev->interrupts == PHY_INTERRUPT_ENABLED)
210 		err = phy_write(phydev, MII_M1011_IMASK, MII_M1011_IMASK_INIT);
211 	else
212 		err = phy_write(phydev, MII_M1011_IMASK, MII_M1011_IMASK_CLEAR);
213 
214 	return err;
215 }
216 
217 static int marvell_set_polarity(struct phy_device *phydev, int polarity)
218 {
219 	int reg;
220 	int err;
221 	int val;
222 
223 	/* get the current settings */
224 	reg = phy_read(phydev, MII_M1011_PHY_SCR);
225 	if (reg < 0)
226 		return reg;
227 
228 	val = reg;
229 	val &= ~MII_M1011_PHY_SCR_AUTO_CROSS;
230 	switch (polarity) {
231 	case ETH_TP_MDI:
232 		val |= MII_M1011_PHY_SCR_MDI;
233 		break;
234 	case ETH_TP_MDI_X:
235 		val |= MII_M1011_PHY_SCR_MDI_X;
236 		break;
237 	case ETH_TP_MDI_AUTO:
238 	case ETH_TP_MDI_INVALID:
239 	default:
240 		val |= MII_M1011_PHY_SCR_AUTO_CROSS;
241 		break;
242 	}
243 
244 	if (val != reg) {
245 		/* Set the new polarity value in the register */
246 		err = phy_write(phydev, MII_M1011_PHY_SCR, val);
247 		if (err)
248 			return err;
249 	}
250 
251 	return 0;
252 }
253 
254 static int marvell_config_aneg(struct phy_device *phydev)
255 {
256 	int err;
257 
258 	/* The Marvell PHY has an errata which requires
259 	 * that certain registers get written in order
260 	 * to restart autonegotiation */
261 	err = phy_write(phydev, MII_BMCR, BMCR_RESET);
262 
263 	if (err < 0)
264 		return err;
265 
266 	err = phy_write(phydev, 0x1d, 0x1f);
267 	if (err < 0)
268 		return err;
269 
270 	err = phy_write(phydev, 0x1e, 0x200c);
271 	if (err < 0)
272 		return err;
273 
274 	err = phy_write(phydev, 0x1d, 0x5);
275 	if (err < 0)
276 		return err;
277 
278 	err = phy_write(phydev, 0x1e, 0);
279 	if (err < 0)
280 		return err;
281 
282 	err = phy_write(phydev, 0x1e, 0x100);
283 	if (err < 0)
284 		return err;
285 
286 	err = marvell_set_polarity(phydev, phydev->mdix_ctrl);
287 	if (err < 0)
288 		return err;
289 
290 	err = phy_write(phydev, MII_M1111_PHY_LED_CONTROL,
291 			MII_M1111_PHY_LED_DIRECT);
292 	if (err < 0)
293 		return err;
294 
295 	err = genphy_config_aneg(phydev);
296 	if (err < 0)
297 		return err;
298 
299 	if (phydev->autoneg != AUTONEG_ENABLE) {
300 		int bmcr;
301 
302 		/*
303 		 * A write to speed/duplex bits (that is performed by
304 		 * genphy_config_aneg() call above) must be followed by
305 		 * a software reset. Otherwise, the write has no effect.
306 		 */
307 		bmcr = phy_read(phydev, MII_BMCR);
308 		if (bmcr < 0)
309 			return bmcr;
310 
311 		err = phy_write(phydev, MII_BMCR, bmcr | BMCR_RESET);
312 		if (err < 0)
313 			return err;
314 	}
315 
316 	return 0;
317 }
318 
319 static int m88e1111_config_aneg(struct phy_device *phydev)
320 {
321 	int err;
322 
323 	/* The Marvell PHY has an errata which requires
324 	 * that certain registers get written in order
325 	 * to restart autonegotiation
326 	 */
327 	err = phy_write(phydev, MII_BMCR, BMCR_RESET);
328 
329 	err = marvell_set_polarity(phydev, phydev->mdix_ctrl);
330 	if (err < 0)
331 		return err;
332 
333 	err = phy_write(phydev, MII_M1111_PHY_LED_CONTROL,
334 			MII_M1111_PHY_LED_DIRECT);
335 	if (err < 0)
336 		return err;
337 
338 	err = genphy_config_aneg(phydev);
339 	if (err < 0)
340 		return err;
341 
342 	if (phydev->autoneg != AUTONEG_ENABLE) {
343 		int bmcr;
344 
345 		/* A write to speed/duplex bits (that is performed by
346 		 * genphy_config_aneg() call above) must be followed by
347 		 * a software reset. Otherwise, the write has no effect.
348 		 */
349 		bmcr = phy_read(phydev, MII_BMCR);
350 		if (bmcr < 0)
351 			return bmcr;
352 
353 		err = phy_write(phydev, MII_BMCR, bmcr | BMCR_RESET);
354 		if (err < 0)
355 			return err;
356 	}
357 
358 	return 0;
359 }
360 
361 #ifdef CONFIG_OF_MDIO
362 /*
363  * Set and/or override some configuration registers based on the
364  * marvell,reg-init property stored in the of_node for the phydev.
365  *
366  * marvell,reg-init = <reg-page reg mask value>,...;
367  *
368  * There may be one or more sets of <reg-page reg mask value>:
369  *
370  * reg-page: which register bank to use.
371  * reg: the register.
372  * mask: if non-zero, ANDed with existing register value.
373  * value: ORed with the masked value and written to the regiser.
374  *
375  */
376 static int marvell_of_reg_init(struct phy_device *phydev)
377 {
378 	const __be32 *paddr;
379 	int len, i, saved_page, current_page, ret;
380 
381 	if (!phydev->mdio.dev.of_node)
382 		return 0;
383 
384 	paddr = of_get_property(phydev->mdio.dev.of_node,
385 				"marvell,reg-init", &len);
386 	if (!paddr || len < (4 * sizeof(*paddr)))
387 		return 0;
388 
389 	saved_page = phy_read(phydev, MII_MARVELL_PHY_PAGE);
390 	if (saved_page < 0)
391 		return saved_page;
392 	current_page = saved_page;
393 
394 	ret = 0;
395 	len /= sizeof(*paddr);
396 	for (i = 0; i < len - 3; i += 4) {
397 		u16 reg_page = be32_to_cpup(paddr + i);
398 		u16 reg = be32_to_cpup(paddr + i + 1);
399 		u16 mask = be32_to_cpup(paddr + i + 2);
400 		u16 val_bits = be32_to_cpup(paddr + i + 3);
401 		int val;
402 
403 		if (reg_page != current_page) {
404 			current_page = reg_page;
405 			ret = phy_write(phydev, MII_MARVELL_PHY_PAGE, reg_page);
406 			if (ret < 0)
407 				goto err;
408 		}
409 
410 		val = 0;
411 		if (mask) {
412 			val = phy_read(phydev, reg);
413 			if (val < 0) {
414 				ret = val;
415 				goto err;
416 			}
417 			val &= mask;
418 		}
419 		val |= val_bits;
420 
421 		ret = phy_write(phydev, reg, val);
422 		if (ret < 0)
423 			goto err;
424 
425 	}
426 err:
427 	if (current_page != saved_page) {
428 		i = phy_write(phydev, MII_MARVELL_PHY_PAGE, saved_page);
429 		if (ret == 0)
430 			ret = i;
431 	}
432 	return ret;
433 }
434 #else
435 static int marvell_of_reg_init(struct phy_device *phydev)
436 {
437 	return 0;
438 }
439 #endif /* CONFIG_OF_MDIO */
440 
441 static int m88e1121_config_aneg(struct phy_device *phydev)
442 {
443 	int err, oldpage, mscr;
444 
445 	oldpage = phy_read(phydev, MII_MARVELL_PHY_PAGE);
446 
447 	err = phy_write(phydev, MII_MARVELL_PHY_PAGE,
448 			MII_88E1121_PHY_MSCR_PAGE);
449 	if (err < 0)
450 		return err;
451 
452 	if (phy_interface_is_rgmii(phydev)) {
453 
454 		mscr = phy_read(phydev, MII_88E1121_PHY_MSCR_REG) &
455 			MII_88E1121_PHY_MSCR_DELAY_MASK;
456 
457 		if (phydev->interface == PHY_INTERFACE_MODE_RGMII_ID)
458 			mscr |= (MII_88E1121_PHY_MSCR_RX_DELAY |
459 				 MII_88E1121_PHY_MSCR_TX_DELAY);
460 		else if (phydev->interface == PHY_INTERFACE_MODE_RGMII_RXID)
461 			mscr |= MII_88E1121_PHY_MSCR_RX_DELAY;
462 		else if (phydev->interface == PHY_INTERFACE_MODE_RGMII_TXID)
463 			mscr |= MII_88E1121_PHY_MSCR_TX_DELAY;
464 
465 		err = phy_write(phydev, MII_88E1121_PHY_MSCR_REG, mscr);
466 		if (err < 0)
467 			return err;
468 	}
469 
470 	phy_write(phydev, MII_MARVELL_PHY_PAGE, oldpage);
471 
472 	err = phy_write(phydev, MII_BMCR, BMCR_RESET);
473 	if (err < 0)
474 		return err;
475 
476 	err = phy_write(phydev, MII_M1011_PHY_SCR,
477 			MII_M1011_PHY_SCR_AUTO_CROSS);
478 	if (err < 0)
479 		return err;
480 
481 	return genphy_config_aneg(phydev);
482 }
483 
484 static int m88e1318_config_aneg(struct phy_device *phydev)
485 {
486 	int err, oldpage, mscr;
487 
488 	oldpage = phy_read(phydev, MII_MARVELL_PHY_PAGE);
489 
490 	err = phy_write(phydev, MII_MARVELL_PHY_PAGE,
491 			MII_88E1121_PHY_MSCR_PAGE);
492 	if (err < 0)
493 		return err;
494 
495 	mscr = phy_read(phydev, MII_88E1318S_PHY_MSCR1_REG);
496 	mscr |= MII_88E1318S_PHY_MSCR1_PAD_ODD;
497 
498 	err = phy_write(phydev, MII_88E1318S_PHY_MSCR1_REG, mscr);
499 	if (err < 0)
500 		return err;
501 
502 	err = phy_write(phydev, MII_MARVELL_PHY_PAGE, oldpage);
503 	if (err < 0)
504 		return err;
505 
506 	return m88e1121_config_aneg(phydev);
507 }
508 
509 /**
510  * ethtool_adv_to_fiber_adv_t
511  * @ethadv: the ethtool advertisement settings
512  *
513  * A small helper function that translates ethtool advertisement
514  * settings to phy autonegotiation advertisements for the
515  * MII_ADV register for fiber link.
516  */
517 static inline u32 ethtool_adv_to_fiber_adv_t(u32 ethadv)
518 {
519 	u32 result = 0;
520 
521 	if (ethadv & ADVERTISED_1000baseT_Half)
522 		result |= ADVERTISE_FIBER_1000HALF;
523 	if (ethadv & ADVERTISED_1000baseT_Full)
524 		result |= ADVERTISE_FIBER_1000FULL;
525 
526 	if ((ethadv & ADVERTISE_PAUSE_ASYM) && (ethadv & ADVERTISE_PAUSE_CAP))
527 		result |= LPA_PAUSE_ASYM_FIBER;
528 	else if (ethadv & ADVERTISE_PAUSE_CAP)
529 		result |= (ADVERTISE_PAUSE_FIBER
530 			   & (~ADVERTISE_PAUSE_ASYM_FIBER));
531 
532 	return result;
533 }
534 
535 /**
536  * marvell_config_aneg_fiber - restart auto-negotiation or write BMCR
537  * @phydev: target phy_device struct
538  *
539  * Description: If auto-negotiation is enabled, we configure the
540  *   advertising, and then restart auto-negotiation.  If it is not
541  *   enabled, then we write the BMCR. Adapted for fiber link in
542  *   some Marvell's devices.
543  */
544 static int marvell_config_aneg_fiber(struct phy_device *phydev)
545 {
546 	int changed = 0;
547 	int err;
548 	int adv, oldadv;
549 	u32 advertise;
550 
551 	if (phydev->autoneg != AUTONEG_ENABLE)
552 		return genphy_setup_forced(phydev);
553 
554 	/* Only allow advertising what this PHY supports */
555 	phydev->advertising &= phydev->supported;
556 	advertise = phydev->advertising;
557 
558 	/* Setup fiber advertisement */
559 	adv = phy_read(phydev, MII_ADVERTISE);
560 	if (adv < 0)
561 		return adv;
562 
563 	oldadv = adv;
564 	adv &= ~(ADVERTISE_FIBER_1000HALF | ADVERTISE_FIBER_1000FULL
565 		| LPA_PAUSE_FIBER);
566 	adv |= ethtool_adv_to_fiber_adv_t(advertise);
567 
568 	if (adv != oldadv) {
569 		err = phy_write(phydev, MII_ADVERTISE, adv);
570 		if (err < 0)
571 			return err;
572 
573 		changed = 1;
574 	}
575 
576 	if (changed == 0) {
577 		/* Advertisement hasn't changed, but maybe aneg was never on to
578 		 * begin with?  Or maybe phy was isolated?
579 		 */
580 		int ctl = phy_read(phydev, MII_BMCR);
581 
582 		if (ctl < 0)
583 			return ctl;
584 
585 		if (!(ctl & BMCR_ANENABLE) || (ctl & BMCR_ISOLATE))
586 			changed = 1; /* do restart aneg */
587 	}
588 
589 	/* Only restart aneg if we are advertising something different
590 	 * than we were before.
591 	 */
592 	if (changed > 0)
593 		changed = genphy_restart_aneg(phydev);
594 
595 	return changed;
596 }
597 
598 static int m88e1510_config_aneg(struct phy_device *phydev)
599 {
600 	int err;
601 
602 	err = phy_write(phydev, MII_MARVELL_PHY_PAGE, MII_M1111_COPPER);
603 	if (err < 0)
604 		goto error;
605 
606 	/* Configure the copper link first */
607 	err = m88e1318_config_aneg(phydev);
608 	if (err < 0)
609 		goto error;
610 
611 	/* Then the fiber link */
612 	err = phy_write(phydev, MII_MARVELL_PHY_PAGE, MII_M1111_FIBER);
613 	if (err < 0)
614 		goto error;
615 
616 	err = marvell_config_aneg_fiber(phydev);
617 	if (err < 0)
618 		goto error;
619 
620 	return phy_write(phydev, MII_MARVELL_PHY_PAGE, MII_M1111_COPPER);
621 
622 error:
623 	phy_write(phydev, MII_MARVELL_PHY_PAGE, MII_M1111_COPPER);
624 	return err;
625 }
626 
627 static int marvell_config_init(struct phy_device *phydev)
628 {
629 	/* Set registers from marvell,reg-init DT property */
630 	return marvell_of_reg_init(phydev);
631 }
632 
633 static int m88e1116r_config_init(struct phy_device *phydev)
634 {
635 	int temp;
636 	int err;
637 
638 	temp = phy_read(phydev, MII_BMCR);
639 	temp |= BMCR_RESET;
640 	err = phy_write(phydev, MII_BMCR, temp);
641 	if (err < 0)
642 		return err;
643 
644 	mdelay(500);
645 
646 	err = phy_write(phydev, MII_MARVELL_PHY_PAGE, 0);
647 	if (err < 0)
648 		return err;
649 
650 	temp = phy_read(phydev, MII_M1011_PHY_SCR);
651 	temp |= (7 << 12);	/* max number of gigabit attempts */
652 	temp |= (1 << 11);	/* enable downshift */
653 	temp |= MII_M1011_PHY_SCR_AUTO_CROSS;
654 	err = phy_write(phydev, MII_M1011_PHY_SCR, temp);
655 	if (err < 0)
656 		return err;
657 
658 	err = phy_write(phydev, MII_MARVELL_PHY_PAGE, 2);
659 	if (err < 0)
660 		return err;
661 	temp = phy_read(phydev, MII_M1116R_CONTROL_REG_MAC);
662 	temp |= (1 << 5);
663 	temp |= (1 << 4);
664 	err = phy_write(phydev, MII_M1116R_CONTROL_REG_MAC, temp);
665 	if (err < 0)
666 		return err;
667 	err = phy_write(phydev, MII_MARVELL_PHY_PAGE, 0);
668 	if (err < 0)
669 		return err;
670 
671 	temp = phy_read(phydev, MII_BMCR);
672 	temp |= BMCR_RESET;
673 	err = phy_write(phydev, MII_BMCR, temp);
674 	if (err < 0)
675 		return err;
676 
677 	mdelay(500);
678 
679 	return marvell_config_init(phydev);
680 }
681 
682 static int m88e3016_config_init(struct phy_device *phydev)
683 {
684 	int reg;
685 
686 	/* Enable Scrambler and Auto-Crossover */
687 	reg = phy_read(phydev, MII_88E3016_PHY_SPEC_CTRL);
688 	if (reg < 0)
689 		return reg;
690 
691 	reg &= ~MII_88E3016_DISABLE_SCRAMBLER;
692 	reg |= MII_88E3016_AUTO_MDIX_CROSSOVER;
693 
694 	reg = phy_write(phydev, MII_88E3016_PHY_SPEC_CTRL, reg);
695 	if (reg < 0)
696 		return reg;
697 
698 	return marvell_config_init(phydev);
699 }
700 
701 static int m88e1111_config_init(struct phy_device *phydev)
702 {
703 	int err;
704 	int temp;
705 
706 	if (phy_interface_is_rgmii(phydev)) {
707 
708 		temp = phy_read(phydev, MII_M1111_PHY_EXT_CR);
709 		if (temp < 0)
710 			return temp;
711 
712 		if (phydev->interface == PHY_INTERFACE_MODE_RGMII_ID) {
713 			temp |= (MII_M1111_RX_DELAY | MII_M1111_TX_DELAY);
714 		} else if (phydev->interface == PHY_INTERFACE_MODE_RGMII_RXID) {
715 			temp &= ~MII_M1111_TX_DELAY;
716 			temp |= MII_M1111_RX_DELAY;
717 		} else if (phydev->interface == PHY_INTERFACE_MODE_RGMII_TXID) {
718 			temp &= ~MII_M1111_RX_DELAY;
719 			temp |= MII_M1111_TX_DELAY;
720 		}
721 
722 		err = phy_write(phydev, MII_M1111_PHY_EXT_CR, temp);
723 		if (err < 0)
724 			return err;
725 
726 		temp = phy_read(phydev, MII_M1111_PHY_EXT_SR);
727 		if (temp < 0)
728 			return temp;
729 
730 		temp &= ~(MII_M1111_HWCFG_MODE_MASK);
731 
732 		if (temp & MII_M1111_HWCFG_FIBER_COPPER_RES)
733 			temp |= MII_M1111_HWCFG_MODE_FIBER_RGMII;
734 		else
735 			temp |= MII_M1111_HWCFG_MODE_COPPER_RGMII;
736 
737 		err = phy_write(phydev, MII_M1111_PHY_EXT_SR, temp);
738 		if (err < 0)
739 			return err;
740 	}
741 
742 	if (phydev->interface == PHY_INTERFACE_MODE_SGMII) {
743 		temp = phy_read(phydev, MII_M1111_PHY_EXT_SR);
744 		if (temp < 0)
745 			return temp;
746 
747 		temp &= ~(MII_M1111_HWCFG_MODE_MASK);
748 		temp |= MII_M1111_HWCFG_MODE_SGMII_NO_CLK;
749 		temp |= MII_M1111_HWCFG_FIBER_COPPER_AUTO;
750 
751 		err = phy_write(phydev, MII_M1111_PHY_EXT_SR, temp);
752 		if (err < 0)
753 			return err;
754 
755 		/* make sure copper is selected */
756 		err = phy_read(phydev, MII_M1145_PHY_EXT_ADDR_PAGE);
757 		if (err < 0)
758 			return err;
759 
760 		err = phy_write(phydev, MII_M1145_PHY_EXT_ADDR_PAGE,
761 				err & (~0xff));
762 		if (err < 0)
763 			return err;
764 	}
765 
766 	if (phydev->interface == PHY_INTERFACE_MODE_RTBI) {
767 		temp = phy_read(phydev, MII_M1111_PHY_EXT_CR);
768 		if (temp < 0)
769 			return temp;
770 		temp |= (MII_M1111_RX_DELAY | MII_M1111_TX_DELAY);
771 		err = phy_write(phydev, MII_M1111_PHY_EXT_CR, temp);
772 		if (err < 0)
773 			return err;
774 
775 		temp = phy_read(phydev, MII_M1111_PHY_EXT_SR);
776 		if (temp < 0)
777 			return temp;
778 		temp &= ~(MII_M1111_HWCFG_MODE_MASK | MII_M1111_HWCFG_FIBER_COPPER_RES);
779 		temp |= 0x7 | MII_M1111_HWCFG_FIBER_COPPER_AUTO;
780 		err = phy_write(phydev, MII_M1111_PHY_EXT_SR, temp);
781 		if (err < 0)
782 			return err;
783 
784 		/* soft reset */
785 		err = phy_write(phydev, MII_BMCR, BMCR_RESET);
786 		if (err < 0)
787 			return err;
788 		do
789 			temp = phy_read(phydev, MII_BMCR);
790 		while (temp & BMCR_RESET);
791 
792 		temp = phy_read(phydev, MII_M1111_PHY_EXT_SR);
793 		if (temp < 0)
794 			return temp;
795 		temp &= ~(MII_M1111_HWCFG_MODE_MASK | MII_M1111_HWCFG_FIBER_COPPER_RES);
796 		temp |= MII_M1111_HWCFG_MODE_COPPER_RTBI | MII_M1111_HWCFG_FIBER_COPPER_AUTO;
797 		err = phy_write(phydev, MII_M1111_PHY_EXT_SR, temp);
798 		if (err < 0)
799 			return err;
800 	}
801 
802 	err = marvell_of_reg_init(phydev);
803 	if (err < 0)
804 		return err;
805 
806 	return phy_write(phydev, MII_BMCR, BMCR_RESET);
807 }
808 
809 static int m88e1121_config_init(struct phy_device *phydev)
810 {
811 	int err, oldpage;
812 
813 	oldpage = phy_read(phydev, MII_MARVELL_PHY_PAGE);
814 
815 	err = phy_write(phydev, MII_MARVELL_PHY_PAGE, MII_88E1121_PHY_LED_PAGE);
816 	if (err < 0)
817 		return err;
818 
819 	/* Default PHY LED config: LED[0] .. Link, LED[1] .. Activity */
820 	err = phy_write(phydev, MII_88E1121_PHY_LED_CTRL,
821 			MII_88E1121_PHY_LED_DEF);
822 	if (err < 0)
823 		return err;
824 
825 	phy_write(phydev, MII_MARVELL_PHY_PAGE, oldpage);
826 
827 	/* Set marvell,reg-init configuration from device tree */
828 	return marvell_config_init(phydev);
829 }
830 
831 static int m88e1510_config_init(struct phy_device *phydev)
832 {
833 	int err;
834 	int temp;
835 
836 	/* SGMII-to-Copper mode initialization */
837 	if (phydev->interface == PHY_INTERFACE_MODE_SGMII) {
838 		/* Select page 18 */
839 		err = phy_write(phydev, MII_MARVELL_PHY_PAGE, 18);
840 		if (err < 0)
841 			return err;
842 
843 		/* In reg 20, write MODE[2:0] = 0x1 (SGMII to Copper) */
844 		temp = phy_read(phydev, MII_88E1510_GEN_CTRL_REG_1);
845 		temp &= ~MII_88E1510_GEN_CTRL_REG_1_MODE_MASK;
846 		temp |= MII_88E1510_GEN_CTRL_REG_1_MODE_SGMII;
847 		err = phy_write(phydev, MII_88E1510_GEN_CTRL_REG_1, temp);
848 		if (err < 0)
849 			return err;
850 
851 		/* PHY reset is necessary after changing MODE[2:0] */
852 		temp |= MII_88E1510_GEN_CTRL_REG_1_RESET;
853 		err = phy_write(phydev, MII_88E1510_GEN_CTRL_REG_1, temp);
854 		if (err < 0)
855 			return err;
856 
857 		/* Reset page selection */
858 		err = phy_write(phydev, MII_MARVELL_PHY_PAGE, 0);
859 		if (err < 0)
860 			return err;
861 	}
862 
863 	return m88e1121_config_init(phydev);
864 }
865 
866 static int m88e1118_config_aneg(struct phy_device *phydev)
867 {
868 	int err;
869 
870 	err = phy_write(phydev, MII_BMCR, BMCR_RESET);
871 	if (err < 0)
872 		return err;
873 
874 	err = phy_write(phydev, MII_M1011_PHY_SCR,
875 			MII_M1011_PHY_SCR_AUTO_CROSS);
876 	if (err < 0)
877 		return err;
878 
879 	err = genphy_config_aneg(phydev);
880 	return 0;
881 }
882 
883 static int m88e1118_config_init(struct phy_device *phydev)
884 {
885 	int err;
886 
887 	/* Change address */
888 	err = phy_write(phydev, MII_MARVELL_PHY_PAGE, 0x0002);
889 	if (err < 0)
890 		return err;
891 
892 	/* Enable 1000 Mbit */
893 	err = phy_write(phydev, 0x15, 0x1070);
894 	if (err < 0)
895 		return err;
896 
897 	/* Change address */
898 	err = phy_write(phydev, MII_MARVELL_PHY_PAGE, 0x0003);
899 	if (err < 0)
900 		return err;
901 
902 	/* Adjust LED Control */
903 	if (phydev->dev_flags & MARVELL_PHY_M1118_DNS323_LEDS)
904 		err = phy_write(phydev, 0x10, 0x1100);
905 	else
906 		err = phy_write(phydev, 0x10, 0x021e);
907 	if (err < 0)
908 		return err;
909 
910 	err = marvell_of_reg_init(phydev);
911 	if (err < 0)
912 		return err;
913 
914 	/* Reset address */
915 	err = phy_write(phydev, MII_MARVELL_PHY_PAGE, 0x0);
916 	if (err < 0)
917 		return err;
918 
919 	return phy_write(phydev, MII_BMCR, BMCR_RESET);
920 }
921 
922 static int m88e1149_config_init(struct phy_device *phydev)
923 {
924 	int err;
925 
926 	/* Change address */
927 	err = phy_write(phydev, MII_MARVELL_PHY_PAGE, 0x0002);
928 	if (err < 0)
929 		return err;
930 
931 	/* Enable 1000 Mbit */
932 	err = phy_write(phydev, 0x15, 0x1048);
933 	if (err < 0)
934 		return err;
935 
936 	err = marvell_of_reg_init(phydev);
937 	if (err < 0)
938 		return err;
939 
940 	/* Reset address */
941 	err = phy_write(phydev, MII_MARVELL_PHY_PAGE, 0x0);
942 	if (err < 0)
943 		return err;
944 
945 	return phy_write(phydev, MII_BMCR, BMCR_RESET);
946 }
947 
948 static int m88e1145_config_init(struct phy_device *phydev)
949 {
950 	int err;
951 	int temp;
952 
953 	/* Take care of errata E0 & E1 */
954 	err = phy_write(phydev, 0x1d, 0x001b);
955 	if (err < 0)
956 		return err;
957 
958 	err = phy_write(phydev, 0x1e, 0x418f);
959 	if (err < 0)
960 		return err;
961 
962 	err = phy_write(phydev, 0x1d, 0x0016);
963 	if (err < 0)
964 		return err;
965 
966 	err = phy_write(phydev, 0x1e, 0xa2da);
967 	if (err < 0)
968 		return err;
969 
970 	if (phydev->interface == PHY_INTERFACE_MODE_RGMII_ID) {
971 		int temp = phy_read(phydev, MII_M1145_PHY_EXT_CR);
972 		if (temp < 0)
973 			return temp;
974 
975 		temp |= (MII_M1145_RGMII_RX_DELAY | MII_M1145_RGMII_TX_DELAY);
976 
977 		err = phy_write(phydev, MII_M1145_PHY_EXT_CR, temp);
978 		if (err < 0)
979 			return err;
980 
981 		if (phydev->dev_flags & MARVELL_PHY_M1145_FLAGS_RESISTANCE) {
982 			err = phy_write(phydev, 0x1d, 0x0012);
983 			if (err < 0)
984 				return err;
985 
986 			temp = phy_read(phydev, 0x1e);
987 			if (temp < 0)
988 				return temp;
989 
990 			temp &= 0xf03f;
991 			temp |= 2 << 9;	/* 36 ohm */
992 			temp |= 2 << 6;	/* 39 ohm */
993 
994 			err = phy_write(phydev, 0x1e, temp);
995 			if (err < 0)
996 				return err;
997 
998 			err = phy_write(phydev, 0x1d, 0x3);
999 			if (err < 0)
1000 				return err;
1001 
1002 			err = phy_write(phydev, 0x1e, 0x8000);
1003 			if (err < 0)
1004 				return err;
1005 		}
1006 	}
1007 
1008 	if (phydev->interface == PHY_INTERFACE_MODE_SGMII) {
1009 		temp = phy_read(phydev, MII_M1145_PHY_EXT_SR);
1010 		if (temp < 0)
1011 			return temp;
1012 
1013 		temp &= ~MII_M1145_HWCFG_MODE_MASK;
1014 		temp |= MII_M1145_HWCFG_MODE_SGMII_NO_CLK;
1015 		temp |= MII_M1145_HWCFG_FIBER_COPPER_AUTO;
1016 
1017 		err = phy_write(phydev, MII_M1145_PHY_EXT_SR, temp);
1018 		if (err < 0)
1019 			return err;
1020 	}
1021 
1022 	err = marvell_of_reg_init(phydev);
1023 	if (err < 0)
1024 		return err;
1025 
1026 	return 0;
1027 }
1028 
1029 /**
1030  * fiber_lpa_to_ethtool_lpa_t
1031  * @lpa: value of the MII_LPA register for fiber link
1032  *
1033  * A small helper function that translates MII_LPA
1034  * bits to ethtool LP advertisement settings.
1035  */
1036 static u32 fiber_lpa_to_ethtool_lpa_t(u32 lpa)
1037 {
1038 	u32 result = 0;
1039 
1040 	if (lpa & LPA_FIBER_1000HALF)
1041 		result |= ADVERTISED_1000baseT_Half;
1042 	if (lpa & LPA_FIBER_1000FULL)
1043 		result |= ADVERTISED_1000baseT_Full;
1044 
1045 	return result;
1046 }
1047 
1048 /**
1049  * marvell_update_link - update link status in real time in @phydev
1050  * @phydev: target phy_device struct
1051  *
1052  * Description: Update the value in phydev->link to reflect the
1053  *   current link value.
1054  */
1055 static int marvell_update_link(struct phy_device *phydev, int fiber)
1056 {
1057 	int status;
1058 
1059 	/* Use the generic register for copper link, or specific
1060 	 * register for fiber case */
1061 	if (fiber) {
1062 		status = phy_read(phydev, MII_M1011_PHY_STATUS);
1063 		if (status < 0)
1064 			return status;
1065 
1066 		if ((status & REGISTER_LINK_STATUS) == 0)
1067 			phydev->link = 0;
1068 		else
1069 			phydev->link = 1;
1070 	} else {
1071 		return genphy_update_link(phydev);
1072 	}
1073 
1074 	return 0;
1075 }
1076 
1077 /* marvell_read_status_page
1078  *
1079  * Description:
1080  *   Check the link, then figure out the current state
1081  *   by comparing what we advertise with what the link partner
1082  *   advertises.  Start by checking the gigabit possibilities,
1083  *   then move on to 10/100.
1084  */
1085 static int marvell_read_status_page(struct phy_device *phydev, int page)
1086 {
1087 	int adv;
1088 	int err;
1089 	int lpa;
1090 	int lpagb;
1091 	int status = 0;
1092 	int fiber;
1093 
1094 	/* Detect and update the link, but return if there
1095 	 * was an error */
1096 	if (page == MII_M1111_FIBER)
1097 		fiber = 1;
1098 	else
1099 		fiber = 0;
1100 
1101 	err = marvell_update_link(phydev, fiber);
1102 	if (err)
1103 		return err;
1104 
1105 	if (AUTONEG_ENABLE == phydev->autoneg) {
1106 		status = phy_read(phydev, MII_M1011_PHY_STATUS);
1107 		if (status < 0)
1108 			return status;
1109 
1110 		lpa = phy_read(phydev, MII_LPA);
1111 		if (lpa < 0)
1112 			return lpa;
1113 
1114 		lpagb = phy_read(phydev, MII_STAT1000);
1115 		if (lpagb < 0)
1116 			return lpagb;
1117 
1118 		adv = phy_read(phydev, MII_ADVERTISE);
1119 		if (adv < 0)
1120 			return adv;
1121 
1122 		lpa &= adv;
1123 
1124 		if (status & MII_M1011_PHY_STATUS_FULLDUPLEX)
1125 			phydev->duplex = DUPLEX_FULL;
1126 		else
1127 			phydev->duplex = DUPLEX_HALF;
1128 
1129 		status = status & MII_M1011_PHY_STATUS_SPD_MASK;
1130 		phydev->pause = phydev->asym_pause = 0;
1131 
1132 		switch (status) {
1133 		case MII_M1011_PHY_STATUS_1000:
1134 			phydev->speed = SPEED_1000;
1135 			break;
1136 
1137 		case MII_M1011_PHY_STATUS_100:
1138 			phydev->speed = SPEED_100;
1139 			break;
1140 
1141 		default:
1142 			phydev->speed = SPEED_10;
1143 			break;
1144 		}
1145 
1146 		if (!fiber) {
1147 			phydev->lp_advertising = mii_stat1000_to_ethtool_lpa_t(lpagb) |
1148 					 mii_lpa_to_ethtool_lpa_t(lpa);
1149 
1150 			if (phydev->duplex == DUPLEX_FULL) {
1151 				phydev->pause = lpa & LPA_PAUSE_CAP ? 1 : 0;
1152 				phydev->asym_pause = lpa & LPA_PAUSE_ASYM ? 1 : 0;
1153 			}
1154 		} else {
1155 			/* The fiber link is only 1000M capable */
1156 			phydev->lp_advertising = fiber_lpa_to_ethtool_lpa_t(lpa);
1157 
1158 			if (phydev->duplex == DUPLEX_FULL) {
1159 				if (!(lpa & LPA_PAUSE_FIBER)) {
1160 					phydev->pause = 0;
1161 					phydev->asym_pause = 0;
1162 				} else if ((lpa & LPA_PAUSE_ASYM_FIBER)) {
1163 					phydev->pause = 1;
1164 					phydev->asym_pause = 1;
1165 				} else {
1166 					phydev->pause = 1;
1167 					phydev->asym_pause = 0;
1168 				}
1169 			}
1170 		}
1171 	} else {
1172 		int bmcr = phy_read(phydev, MII_BMCR);
1173 
1174 		if (bmcr < 0)
1175 			return bmcr;
1176 
1177 		if (bmcr & BMCR_FULLDPLX)
1178 			phydev->duplex = DUPLEX_FULL;
1179 		else
1180 			phydev->duplex = DUPLEX_HALF;
1181 
1182 		if (bmcr & BMCR_SPEED1000)
1183 			phydev->speed = SPEED_1000;
1184 		else if (bmcr & BMCR_SPEED100)
1185 			phydev->speed = SPEED_100;
1186 		else
1187 			phydev->speed = SPEED_10;
1188 
1189 		phydev->pause = phydev->asym_pause = 0;
1190 		phydev->lp_advertising = 0;
1191 	}
1192 
1193 	return 0;
1194 }
1195 
1196 /* marvell_read_status
1197  *
1198  * Some Marvell's phys have two modes: fiber and copper.
1199  * Both need status checked.
1200  * Description:
1201  *   First, check the fiber link and status.
1202  *   If the fiber link is down, check the copper link and status which
1203  *   will be the default value if both link are down.
1204  */
1205 static int marvell_read_status(struct phy_device *phydev)
1206 {
1207 	int err;
1208 
1209 	/* Check the fiber mode first */
1210 	if (phydev->supported & SUPPORTED_FIBRE &&
1211 	    phydev->interface != PHY_INTERFACE_MODE_SGMII) {
1212 		err = phy_write(phydev, MII_MARVELL_PHY_PAGE, MII_M1111_FIBER);
1213 		if (err < 0)
1214 			goto error;
1215 
1216 		err = marvell_read_status_page(phydev, MII_M1111_FIBER);
1217 		if (err < 0)
1218 			goto error;
1219 
1220 		/* If the fiber link is up, it is the selected and used link.
1221 		 * In this case, we need to stay in the fiber page.
1222 		 * Please to be careful about that, avoid to restore Copper page
1223 		 * in other functions which could break the behaviour
1224 		 * for some fiber phy like 88E1512.
1225 		 * */
1226 		if (phydev->link)
1227 			return 0;
1228 
1229 		/* If fiber link is down, check and save copper mode state */
1230 		err = phy_write(phydev, MII_MARVELL_PHY_PAGE, MII_M1111_COPPER);
1231 		if (err < 0)
1232 			goto error;
1233 	}
1234 
1235 	return marvell_read_status_page(phydev, MII_M1111_COPPER);
1236 
1237 error:
1238 	phy_write(phydev, MII_MARVELL_PHY_PAGE, MII_M1111_COPPER);
1239 	return err;
1240 }
1241 
1242 /* marvell_suspend
1243  *
1244  * Some Marvell's phys have two modes: fiber and copper.
1245  * Both need to be suspended
1246  */
1247 static int marvell_suspend(struct phy_device *phydev)
1248 {
1249 	int err;
1250 
1251 	/* Suspend the fiber mode first */
1252 	if (!(phydev->supported & SUPPORTED_FIBRE)) {
1253 		err = phy_write(phydev, MII_MARVELL_PHY_PAGE, MII_M1111_FIBER);
1254 		if (err < 0)
1255 			goto error;
1256 
1257 		/* With the page set, use the generic suspend */
1258 		err = genphy_suspend(phydev);
1259 		if (err < 0)
1260 			goto error;
1261 
1262 		/* Then, the copper link */
1263 		err = phy_write(phydev, MII_MARVELL_PHY_PAGE, MII_M1111_COPPER);
1264 		if (err < 0)
1265 			goto error;
1266 	}
1267 
1268 	/* With the page set, use the generic suspend */
1269 	return genphy_suspend(phydev);
1270 
1271 error:
1272 	phy_write(phydev, MII_MARVELL_PHY_PAGE, MII_M1111_COPPER);
1273 	return err;
1274 }
1275 
1276 /* marvell_resume
1277  *
1278  * Some Marvell's phys have two modes: fiber and copper.
1279  * Both need to be resumed
1280  */
1281 static int marvell_resume(struct phy_device *phydev)
1282 {
1283 	int err;
1284 
1285 	/* Resume the fiber mode first */
1286 	if (!(phydev->supported & SUPPORTED_FIBRE)) {
1287 		err = phy_write(phydev, MII_MARVELL_PHY_PAGE, MII_M1111_FIBER);
1288 		if (err < 0)
1289 			goto error;
1290 
1291 		/* With the page set, use the generic resume */
1292 		err = genphy_resume(phydev);
1293 		if (err < 0)
1294 			goto error;
1295 
1296 		/* Then, the copper link */
1297 		err = phy_write(phydev, MII_MARVELL_PHY_PAGE, MII_M1111_COPPER);
1298 		if (err < 0)
1299 			goto error;
1300 	}
1301 
1302 	/* With the page set, use the generic resume */
1303 	return genphy_resume(phydev);
1304 
1305 error:
1306 	phy_write(phydev, MII_MARVELL_PHY_PAGE, MII_M1111_COPPER);
1307 	return err;
1308 }
1309 
1310 static int marvell_aneg_done(struct phy_device *phydev)
1311 {
1312 	int retval = phy_read(phydev, MII_M1011_PHY_STATUS);
1313 	return (retval < 0) ? retval : (retval & MII_M1011_PHY_STATUS_RESOLVED);
1314 }
1315 
1316 static int m88e1121_did_interrupt(struct phy_device *phydev)
1317 {
1318 	int imask;
1319 
1320 	imask = phy_read(phydev, MII_M1011_IEVENT);
1321 
1322 	if (imask & MII_M1011_IMASK_INIT)
1323 		return 1;
1324 
1325 	return 0;
1326 }
1327 
1328 static void m88e1318_get_wol(struct phy_device *phydev, struct ethtool_wolinfo *wol)
1329 {
1330 	wol->supported = WAKE_MAGIC;
1331 	wol->wolopts = 0;
1332 
1333 	if (phy_write(phydev, MII_MARVELL_PHY_PAGE,
1334 		      MII_88E1318S_PHY_WOL_PAGE) < 0)
1335 		return;
1336 
1337 	if (phy_read(phydev, MII_88E1318S_PHY_WOL_CTRL) &
1338 	    MII_88E1318S_PHY_WOL_CTRL_MAGIC_PACKET_MATCH_ENABLE)
1339 		wol->wolopts |= WAKE_MAGIC;
1340 
1341 	if (phy_write(phydev, MII_MARVELL_PHY_PAGE, 0x00) < 0)
1342 		return;
1343 }
1344 
1345 static int m88e1318_set_wol(struct phy_device *phydev, struct ethtool_wolinfo *wol)
1346 {
1347 	int err, oldpage, temp;
1348 
1349 	oldpage = phy_read(phydev, MII_MARVELL_PHY_PAGE);
1350 
1351 	if (wol->wolopts & WAKE_MAGIC) {
1352 		/* Explicitly switch to page 0x00, just to be sure */
1353 		err = phy_write(phydev, MII_MARVELL_PHY_PAGE, 0x00);
1354 		if (err < 0)
1355 			return err;
1356 
1357 		/* Enable the WOL interrupt */
1358 		temp = phy_read(phydev, MII_88E1318S_PHY_CSIER);
1359 		temp |= MII_88E1318S_PHY_CSIER_WOL_EIE;
1360 		err = phy_write(phydev, MII_88E1318S_PHY_CSIER, temp);
1361 		if (err < 0)
1362 			return err;
1363 
1364 		err = phy_write(phydev, MII_MARVELL_PHY_PAGE,
1365 				MII_88E1318S_PHY_LED_PAGE);
1366 		if (err < 0)
1367 			return err;
1368 
1369 		/* Setup LED[2] as interrupt pin (active low) */
1370 		temp = phy_read(phydev, MII_88E1318S_PHY_LED_TCR);
1371 		temp &= ~MII_88E1318S_PHY_LED_TCR_FORCE_INT;
1372 		temp |= MII_88E1318S_PHY_LED_TCR_INTn_ENABLE;
1373 		temp |= MII_88E1318S_PHY_LED_TCR_INT_ACTIVE_LOW;
1374 		err = phy_write(phydev, MII_88E1318S_PHY_LED_TCR, temp);
1375 		if (err < 0)
1376 			return err;
1377 
1378 		err = phy_write(phydev, MII_MARVELL_PHY_PAGE,
1379 				MII_88E1318S_PHY_WOL_PAGE);
1380 		if (err < 0)
1381 			return err;
1382 
1383 		/* Store the device address for the magic packet */
1384 		err = phy_write(phydev, MII_88E1318S_PHY_MAGIC_PACKET_WORD2,
1385 				((phydev->attached_dev->dev_addr[5] << 8) |
1386 				 phydev->attached_dev->dev_addr[4]));
1387 		if (err < 0)
1388 			return err;
1389 		err = phy_write(phydev, MII_88E1318S_PHY_MAGIC_PACKET_WORD1,
1390 				((phydev->attached_dev->dev_addr[3] << 8) |
1391 				 phydev->attached_dev->dev_addr[2]));
1392 		if (err < 0)
1393 			return err;
1394 		err = phy_write(phydev, MII_88E1318S_PHY_MAGIC_PACKET_WORD0,
1395 				((phydev->attached_dev->dev_addr[1] << 8) |
1396 				 phydev->attached_dev->dev_addr[0]));
1397 		if (err < 0)
1398 			return err;
1399 
1400 		/* Clear WOL status and enable magic packet matching */
1401 		temp = phy_read(phydev, MII_88E1318S_PHY_WOL_CTRL);
1402 		temp |= MII_88E1318S_PHY_WOL_CTRL_CLEAR_WOL_STATUS;
1403 		temp |= MII_88E1318S_PHY_WOL_CTRL_MAGIC_PACKET_MATCH_ENABLE;
1404 		err = phy_write(phydev, MII_88E1318S_PHY_WOL_CTRL, temp);
1405 		if (err < 0)
1406 			return err;
1407 	} else {
1408 		err = phy_write(phydev, MII_MARVELL_PHY_PAGE,
1409 				MII_88E1318S_PHY_WOL_PAGE);
1410 		if (err < 0)
1411 			return err;
1412 
1413 		/* Clear WOL status and disable magic packet matching */
1414 		temp = phy_read(phydev, MII_88E1318S_PHY_WOL_CTRL);
1415 		temp |= MII_88E1318S_PHY_WOL_CTRL_CLEAR_WOL_STATUS;
1416 		temp &= ~MII_88E1318S_PHY_WOL_CTRL_MAGIC_PACKET_MATCH_ENABLE;
1417 		err = phy_write(phydev, MII_88E1318S_PHY_WOL_CTRL, temp);
1418 		if (err < 0)
1419 			return err;
1420 	}
1421 
1422 	err = phy_write(phydev, MII_MARVELL_PHY_PAGE, oldpage);
1423 	if (err < 0)
1424 		return err;
1425 
1426 	return 0;
1427 }
1428 
1429 static int marvell_get_sset_count(struct phy_device *phydev)
1430 {
1431 	if (phydev->supported & SUPPORTED_FIBRE)
1432 		return ARRAY_SIZE(marvell_hw_stats);
1433 	else
1434 		return ARRAY_SIZE(marvell_hw_stats) - NB_FIBER_STATS;
1435 }
1436 
1437 static void marvell_get_strings(struct phy_device *phydev, u8 *data)
1438 {
1439 	int i;
1440 
1441 	for (i = 0; i < ARRAY_SIZE(marvell_hw_stats); i++) {
1442 		memcpy(data + i * ETH_GSTRING_LEN,
1443 		       marvell_hw_stats[i].string, ETH_GSTRING_LEN);
1444 	}
1445 }
1446 
1447 #ifndef UINT64_MAX
1448 #define UINT64_MAX              (u64)(~((u64)0))
1449 #endif
1450 static u64 marvell_get_stat(struct phy_device *phydev, int i)
1451 {
1452 	struct marvell_hw_stat stat = marvell_hw_stats[i];
1453 	struct marvell_priv *priv = phydev->priv;
1454 	int err, oldpage, val;
1455 	u64 ret;
1456 
1457 	oldpage = phy_read(phydev, MII_MARVELL_PHY_PAGE);
1458 	err = phy_write(phydev, MII_MARVELL_PHY_PAGE,
1459 			stat.page);
1460 	if (err < 0)
1461 		return UINT64_MAX;
1462 
1463 	val = phy_read(phydev, stat.reg);
1464 	if (val < 0) {
1465 		ret = UINT64_MAX;
1466 	} else {
1467 		val = val & ((1 << stat.bits) - 1);
1468 		priv->stats[i] += val;
1469 		ret = priv->stats[i];
1470 	}
1471 
1472 	phy_write(phydev, MII_MARVELL_PHY_PAGE, oldpage);
1473 
1474 	return ret;
1475 }
1476 
1477 static void marvell_get_stats(struct phy_device *phydev,
1478 			      struct ethtool_stats *stats, u64 *data)
1479 {
1480 	int i;
1481 
1482 	for (i = 0; i < ARRAY_SIZE(marvell_hw_stats); i++)
1483 		data[i] = marvell_get_stat(phydev, i);
1484 }
1485 
1486 #ifdef CONFIG_HWMON
1487 static int m88e1121_get_temp(struct phy_device *phydev, long *temp)
1488 {
1489 	int ret;
1490 	int val;
1491 
1492 	*temp = 0;
1493 
1494 	mutex_lock(&phydev->lock);
1495 
1496 	ret = phy_write(phydev, MII_M1145_PHY_EXT_ADDR_PAGE, 0x6);
1497 	if (ret < 0)
1498 		goto error;
1499 
1500 	/* Enable temperature sensor */
1501 	ret = phy_read(phydev, MII_88E1121_MISC_TEST);
1502 	if (ret < 0)
1503 		goto error;
1504 
1505 	ret = phy_write(phydev, MII_88E1121_MISC_TEST,
1506 			ret | MII_88E1121_MISC_TEST_TEMP_SENSOR_EN);
1507 	if (ret < 0)
1508 		goto error;
1509 
1510 	/* Wait for temperature to stabilize */
1511 	usleep_range(10000, 12000);
1512 
1513 	val = phy_read(phydev, MII_88E1121_MISC_TEST);
1514 	if (val < 0) {
1515 		ret = val;
1516 		goto error;
1517 	}
1518 
1519 	/* Disable temperature sensor */
1520 	ret = phy_write(phydev, MII_88E1121_MISC_TEST,
1521 			ret & ~MII_88E1121_MISC_TEST_TEMP_SENSOR_EN);
1522 	if (ret < 0)
1523 		goto error;
1524 
1525 	*temp = ((val & MII_88E1121_MISC_TEST_TEMP_MASK) - 5) * 5000;
1526 
1527 error:
1528 	phy_write(phydev, MII_M1145_PHY_EXT_ADDR_PAGE, 0x0);
1529 	mutex_unlock(&phydev->lock);
1530 
1531 	return ret;
1532 }
1533 
1534 static int m88e1121_hwmon_read(struct device *dev,
1535 			       enum hwmon_sensor_types type,
1536 			       u32 attr, int channel, long *temp)
1537 {
1538 	struct phy_device *phydev = dev_get_drvdata(dev);
1539 	int err;
1540 
1541 	switch (attr) {
1542 	case hwmon_temp_input:
1543 		err = m88e1121_get_temp(phydev, temp);
1544 		break;
1545 	default:
1546 		return -EOPNOTSUPP;
1547 	}
1548 
1549 	return err;
1550 }
1551 
1552 static umode_t m88e1121_hwmon_is_visible(const void *data,
1553 					 enum hwmon_sensor_types type,
1554 					 u32 attr, int channel)
1555 {
1556 	if (type != hwmon_temp)
1557 		return 0;
1558 
1559 	switch (attr) {
1560 	case hwmon_temp_input:
1561 		return 0444;
1562 	default:
1563 		return 0;
1564 	}
1565 }
1566 
1567 static u32 m88e1121_hwmon_chip_config[] = {
1568 	HWMON_C_REGISTER_TZ,
1569 	0
1570 };
1571 
1572 static const struct hwmon_channel_info m88e1121_hwmon_chip = {
1573 	.type = hwmon_chip,
1574 	.config = m88e1121_hwmon_chip_config,
1575 };
1576 
1577 static u32 m88e1121_hwmon_temp_config[] = {
1578 	HWMON_T_INPUT,
1579 	0
1580 };
1581 
1582 static const struct hwmon_channel_info m88e1121_hwmon_temp = {
1583 	.type = hwmon_temp,
1584 	.config = m88e1121_hwmon_temp_config,
1585 };
1586 
1587 static const struct hwmon_channel_info *m88e1121_hwmon_info[] = {
1588 	&m88e1121_hwmon_chip,
1589 	&m88e1121_hwmon_temp,
1590 	NULL
1591 };
1592 
1593 static const struct hwmon_ops m88e1121_hwmon_hwmon_ops = {
1594 	.is_visible = m88e1121_hwmon_is_visible,
1595 	.read = m88e1121_hwmon_read,
1596 };
1597 
1598 static const struct hwmon_chip_info m88e1121_hwmon_chip_info = {
1599 	.ops = &m88e1121_hwmon_hwmon_ops,
1600 	.info = m88e1121_hwmon_info,
1601 };
1602 
1603 static int m88e1510_get_temp(struct phy_device *phydev, long *temp)
1604 {
1605 	int ret;
1606 
1607 	*temp = 0;
1608 
1609 	mutex_lock(&phydev->lock);
1610 
1611 	ret = phy_write(phydev, MII_M1145_PHY_EXT_ADDR_PAGE, 0x6);
1612 	if (ret < 0)
1613 		goto error;
1614 
1615 	ret = phy_read(phydev, MII_88E1510_TEMP_SENSOR);
1616 	if (ret < 0)
1617 		goto error;
1618 
1619 	*temp = ((ret & MII_88E1510_TEMP_SENSOR_MASK) - 25) * 1000;
1620 
1621 error:
1622 	phy_write(phydev, MII_M1145_PHY_EXT_ADDR_PAGE, 0x0);
1623 	mutex_unlock(&phydev->lock);
1624 
1625 	return ret;
1626 }
1627 
1628 int m88e1510_get_temp_critical(struct phy_device *phydev, long *temp)
1629 {
1630 	int ret;
1631 
1632 	*temp = 0;
1633 
1634 	mutex_lock(&phydev->lock);
1635 
1636 	ret = phy_write(phydev, MII_M1145_PHY_EXT_ADDR_PAGE, 0x6);
1637 	if (ret < 0)
1638 		goto error;
1639 
1640 	ret = phy_read(phydev, MII_88E1121_MISC_TEST);
1641 	if (ret < 0)
1642 		goto error;
1643 
1644 	*temp = (((ret & MII_88E1510_MISC_TEST_TEMP_THRESHOLD_MASK) >>
1645 		  MII_88E1510_MISC_TEST_TEMP_THRESHOLD_SHIFT) * 5) - 25;
1646 	/* convert to mC */
1647 	*temp *= 1000;
1648 
1649 error:
1650 	phy_write(phydev, MII_M1145_PHY_EXT_ADDR_PAGE, 0x0);
1651 	mutex_unlock(&phydev->lock);
1652 
1653 	return ret;
1654 }
1655 
1656 int m88e1510_set_temp_critical(struct phy_device *phydev, long temp)
1657 {
1658 	int ret;
1659 
1660 	mutex_lock(&phydev->lock);
1661 
1662 	ret = phy_write(phydev, MII_M1145_PHY_EXT_ADDR_PAGE, 0x6);
1663 	if (ret < 0)
1664 		goto error;
1665 
1666 	ret = phy_read(phydev, MII_88E1121_MISC_TEST);
1667 	if (ret < 0)
1668 		goto error;
1669 
1670 	temp = temp / 1000;
1671 	temp = clamp_val(DIV_ROUND_CLOSEST(temp, 5) + 5, 0, 0x1f);
1672 	ret = phy_write(phydev, MII_88E1121_MISC_TEST,
1673 			(ret & ~MII_88E1510_MISC_TEST_TEMP_THRESHOLD_MASK) |
1674 			(temp << MII_88E1510_MISC_TEST_TEMP_THRESHOLD_SHIFT));
1675 
1676 error:
1677 	phy_write(phydev, MII_M1145_PHY_EXT_ADDR_PAGE, 0x0);
1678 	mutex_unlock(&phydev->lock);
1679 
1680 	return ret;
1681 }
1682 
1683 int m88e1510_get_temp_alarm(struct phy_device *phydev, long *alarm)
1684 {
1685 	int ret;
1686 
1687 	*alarm = false;
1688 
1689 	mutex_lock(&phydev->lock);
1690 
1691 	ret = phy_write(phydev, MII_M1145_PHY_EXT_ADDR_PAGE, 0x6);
1692 	if (ret < 0)
1693 		goto error;
1694 
1695 	ret = phy_read(phydev, MII_88E1121_MISC_TEST);
1696 	if (ret < 0)
1697 		goto error;
1698 	*alarm = !!(ret & MII_88E1510_MISC_TEST_TEMP_IRQ);
1699 
1700 error:
1701 	phy_write(phydev, MII_M1145_PHY_EXT_ADDR_PAGE, 0x0);
1702 	mutex_unlock(&phydev->lock);
1703 
1704 	return ret;
1705 }
1706 
1707 static int m88e1510_hwmon_read(struct device *dev,
1708 			       enum hwmon_sensor_types type,
1709 			       u32 attr, int channel, long *temp)
1710 {
1711 	struct phy_device *phydev = dev_get_drvdata(dev);
1712 	int err;
1713 
1714 	switch (attr) {
1715 	case hwmon_temp_input:
1716 		err = m88e1510_get_temp(phydev, temp);
1717 		break;
1718 	case hwmon_temp_crit:
1719 		err = m88e1510_get_temp_critical(phydev, temp);
1720 		break;
1721 	case hwmon_temp_max_alarm:
1722 		err = m88e1510_get_temp_alarm(phydev, temp);
1723 		break;
1724 	default:
1725 		return -EOPNOTSUPP;
1726 	}
1727 
1728 	return err;
1729 }
1730 
1731 static int m88e1510_hwmon_write(struct device *dev,
1732 				enum hwmon_sensor_types type,
1733 				u32 attr, int channel, long temp)
1734 {
1735 	struct phy_device *phydev = dev_get_drvdata(dev);
1736 	int err;
1737 
1738 	switch (attr) {
1739 	case hwmon_temp_crit:
1740 		err = m88e1510_set_temp_critical(phydev, temp);
1741 		break;
1742 	default:
1743 		return -EOPNOTSUPP;
1744 	}
1745 	return err;
1746 }
1747 
1748 static umode_t m88e1510_hwmon_is_visible(const void *data,
1749 					 enum hwmon_sensor_types type,
1750 					 u32 attr, int channel)
1751 {
1752 	if (type != hwmon_temp)
1753 		return 0;
1754 
1755 	switch (attr) {
1756 	case hwmon_temp_input:
1757 	case hwmon_temp_max_alarm:
1758 		return 0444;
1759 	case hwmon_temp_crit:
1760 		return 0644;
1761 	default:
1762 		return 0;
1763 	}
1764 }
1765 
1766 static u32 m88e1510_hwmon_temp_config[] = {
1767 	HWMON_T_INPUT | HWMON_T_CRIT | HWMON_T_MAX_ALARM,
1768 	0
1769 };
1770 
1771 static const struct hwmon_channel_info m88e1510_hwmon_temp = {
1772 	.type = hwmon_temp,
1773 	.config = m88e1510_hwmon_temp_config,
1774 };
1775 
1776 static const struct hwmon_channel_info *m88e1510_hwmon_info[] = {
1777 	&m88e1121_hwmon_chip,
1778 	&m88e1510_hwmon_temp,
1779 	NULL
1780 };
1781 
1782 static const struct hwmon_ops m88e1510_hwmon_hwmon_ops = {
1783 	.is_visible = m88e1510_hwmon_is_visible,
1784 	.read = m88e1510_hwmon_read,
1785 	.write = m88e1510_hwmon_write,
1786 };
1787 
1788 static const struct hwmon_chip_info m88e1510_hwmon_chip_info = {
1789 	.ops = &m88e1510_hwmon_hwmon_ops,
1790 	.info = m88e1510_hwmon_info,
1791 };
1792 
1793 static int marvell_hwmon_name(struct phy_device *phydev)
1794 {
1795 	struct marvell_priv *priv = phydev->priv;
1796 	struct device *dev = &phydev->mdio.dev;
1797 	const char *devname = dev_name(dev);
1798 	size_t len = strlen(devname);
1799 	int i, j;
1800 
1801 	priv->hwmon_name = devm_kzalloc(dev, len, GFP_KERNEL);
1802 	if (!priv->hwmon_name)
1803 		return -ENOMEM;
1804 
1805 	for (i = j = 0; i < len && devname[i]; i++) {
1806 		if (isalnum(devname[i]))
1807 			priv->hwmon_name[j++] = devname[i];
1808 	}
1809 
1810 	return 0;
1811 }
1812 
1813 static int marvell_hwmon_probe(struct phy_device *phydev,
1814 			       const struct hwmon_chip_info *chip)
1815 {
1816 	struct marvell_priv *priv = phydev->priv;
1817 	struct device *dev = &phydev->mdio.dev;
1818 	int err;
1819 
1820 	err = marvell_hwmon_name(phydev);
1821 	if (err)
1822 		return err;
1823 
1824 	priv->hwmon_dev = devm_hwmon_device_register_with_info(
1825 		dev, priv->hwmon_name, phydev, chip, NULL);
1826 
1827 	return PTR_ERR_OR_ZERO(priv->hwmon_dev);
1828 }
1829 
1830 static int m88e1121_hwmon_probe(struct phy_device *phydev)
1831 {
1832 	return marvell_hwmon_probe(phydev, &m88e1121_hwmon_chip_info);
1833 }
1834 
1835 static int m88e1510_hwmon_probe(struct phy_device *phydev)
1836 {
1837 	return marvell_hwmon_probe(phydev, &m88e1510_hwmon_chip_info);
1838 }
1839 #else
1840 static int m88e1121_hwmon_probe(struct phy_device *phydev)
1841 {
1842 	return 0;
1843 }
1844 
1845 static int m88e1510_hwmon_probe(struct phy_device *phydev)
1846 {
1847 	return 0;
1848 }
1849 #endif
1850 
1851 static int marvell_probe(struct phy_device *phydev)
1852 {
1853 	struct marvell_priv *priv;
1854 
1855 	priv = devm_kzalloc(&phydev->mdio.dev, sizeof(*priv), GFP_KERNEL);
1856 	if (!priv)
1857 		return -ENOMEM;
1858 
1859 	phydev->priv = priv;
1860 
1861 	return 0;
1862 }
1863 
1864 static int m88e1121_probe(struct phy_device *phydev)
1865 {
1866 	int err;
1867 
1868 	err = marvell_probe(phydev);
1869 	if (err)
1870 		return err;
1871 
1872 	return m88e1121_hwmon_probe(phydev);
1873 }
1874 
1875 static int m88e1510_probe(struct phy_device *phydev)
1876 {
1877 	int err;
1878 
1879 	err = marvell_probe(phydev);
1880 	if (err)
1881 		return err;
1882 
1883 	return m88e1510_hwmon_probe(phydev);
1884 }
1885 
1886 static void marvell_remove(struct phy_device *phydev)
1887 {
1888 #ifdef CONFIG_HWMON
1889 
1890 	struct marvell_priv *priv = phydev->priv;
1891 
1892 	if (priv && priv->hwmon_dev)
1893 		hwmon_device_unregister(priv->hwmon_dev);
1894 #endif
1895 }
1896 
1897 static struct phy_driver marvell_drivers[] = {
1898 	{
1899 		.phy_id = MARVELL_PHY_ID_88E1101,
1900 		.phy_id_mask = MARVELL_PHY_ID_MASK,
1901 		.name = "Marvell 88E1101",
1902 		.features = PHY_GBIT_FEATURES,
1903 		.flags = PHY_HAS_INTERRUPT,
1904 		.probe = marvell_probe,
1905 		.config_init = &marvell_config_init,
1906 		.config_aneg = &marvell_config_aneg,
1907 		.read_status = &genphy_read_status,
1908 		.ack_interrupt = &marvell_ack_interrupt,
1909 		.config_intr = &marvell_config_intr,
1910 		.resume = &genphy_resume,
1911 		.suspend = &genphy_suspend,
1912 		.get_sset_count = marvell_get_sset_count,
1913 		.get_strings = marvell_get_strings,
1914 		.get_stats = marvell_get_stats,
1915 	},
1916 	{
1917 		.phy_id = MARVELL_PHY_ID_88E1112,
1918 		.phy_id_mask = MARVELL_PHY_ID_MASK,
1919 		.name = "Marvell 88E1112",
1920 		.features = PHY_GBIT_FEATURES,
1921 		.flags = PHY_HAS_INTERRUPT,
1922 		.probe = marvell_probe,
1923 		.config_init = &m88e1111_config_init,
1924 		.config_aneg = &marvell_config_aneg,
1925 		.read_status = &genphy_read_status,
1926 		.ack_interrupt = &marvell_ack_interrupt,
1927 		.config_intr = &marvell_config_intr,
1928 		.resume = &genphy_resume,
1929 		.suspend = &genphy_suspend,
1930 		.get_sset_count = marvell_get_sset_count,
1931 		.get_strings = marvell_get_strings,
1932 		.get_stats = marvell_get_stats,
1933 	},
1934 	{
1935 		.phy_id = MARVELL_PHY_ID_88E1111,
1936 		.phy_id_mask = MARVELL_PHY_ID_MASK,
1937 		.name = "Marvell 88E1111",
1938 		.features = PHY_GBIT_FEATURES,
1939 		.flags = PHY_HAS_INTERRUPT,
1940 		.probe = marvell_probe,
1941 		.config_init = &m88e1111_config_init,
1942 		.config_aneg = &m88e1111_config_aneg,
1943 		.read_status = &marvell_read_status,
1944 		.ack_interrupt = &marvell_ack_interrupt,
1945 		.config_intr = &marvell_config_intr,
1946 		.resume = &genphy_resume,
1947 		.suspend = &genphy_suspend,
1948 		.get_sset_count = marvell_get_sset_count,
1949 		.get_strings = marvell_get_strings,
1950 		.get_stats = marvell_get_stats,
1951 	},
1952 	{
1953 		.phy_id = MARVELL_PHY_ID_88E1118,
1954 		.phy_id_mask = MARVELL_PHY_ID_MASK,
1955 		.name = "Marvell 88E1118",
1956 		.features = PHY_GBIT_FEATURES,
1957 		.flags = PHY_HAS_INTERRUPT,
1958 		.probe = marvell_probe,
1959 		.config_init = &m88e1118_config_init,
1960 		.config_aneg = &m88e1118_config_aneg,
1961 		.read_status = &genphy_read_status,
1962 		.ack_interrupt = &marvell_ack_interrupt,
1963 		.config_intr = &marvell_config_intr,
1964 		.resume = &genphy_resume,
1965 		.suspend = &genphy_suspend,
1966 		.get_sset_count = marvell_get_sset_count,
1967 		.get_strings = marvell_get_strings,
1968 		.get_stats = marvell_get_stats,
1969 	},
1970 	{
1971 		.phy_id = MARVELL_PHY_ID_88E1121R,
1972 		.phy_id_mask = MARVELL_PHY_ID_MASK,
1973 		.name = "Marvell 88E1121R",
1974 		.features = PHY_GBIT_FEATURES,
1975 		.flags = PHY_HAS_INTERRUPT,
1976 		.probe = &m88e1121_probe,
1977 		.remove = &marvell_remove,
1978 		.config_init = &m88e1121_config_init,
1979 		.config_aneg = &m88e1121_config_aneg,
1980 		.read_status = &marvell_read_status,
1981 		.ack_interrupt = &marvell_ack_interrupt,
1982 		.config_intr = &marvell_config_intr,
1983 		.did_interrupt = &m88e1121_did_interrupt,
1984 		.resume = &genphy_resume,
1985 		.suspend = &genphy_suspend,
1986 		.get_sset_count = marvell_get_sset_count,
1987 		.get_strings = marvell_get_strings,
1988 		.get_stats = marvell_get_stats,
1989 	},
1990 	{
1991 		.phy_id = MARVELL_PHY_ID_88E1318S,
1992 		.phy_id_mask = MARVELL_PHY_ID_MASK,
1993 		.name = "Marvell 88E1318S",
1994 		.features = PHY_GBIT_FEATURES,
1995 		.flags = PHY_HAS_INTERRUPT,
1996 		.probe = marvell_probe,
1997 		.config_init = &m88e1121_config_init,
1998 		.config_aneg = &m88e1318_config_aneg,
1999 		.read_status = &marvell_read_status,
2000 		.ack_interrupt = &marvell_ack_interrupt,
2001 		.config_intr = &marvell_config_intr,
2002 		.did_interrupt = &m88e1121_did_interrupt,
2003 		.get_wol = &m88e1318_get_wol,
2004 		.set_wol = &m88e1318_set_wol,
2005 		.resume = &genphy_resume,
2006 		.suspend = &genphy_suspend,
2007 		.get_sset_count = marvell_get_sset_count,
2008 		.get_strings = marvell_get_strings,
2009 		.get_stats = marvell_get_stats,
2010 	},
2011 	{
2012 		.phy_id = MARVELL_PHY_ID_88E1145,
2013 		.phy_id_mask = MARVELL_PHY_ID_MASK,
2014 		.name = "Marvell 88E1145",
2015 		.features = PHY_GBIT_FEATURES,
2016 		.flags = PHY_HAS_INTERRUPT,
2017 		.probe = marvell_probe,
2018 		.config_init = &m88e1145_config_init,
2019 		.config_aneg = &marvell_config_aneg,
2020 		.read_status = &genphy_read_status,
2021 		.ack_interrupt = &marvell_ack_interrupt,
2022 		.config_intr = &marvell_config_intr,
2023 		.resume = &genphy_resume,
2024 		.suspend = &genphy_suspend,
2025 		.get_sset_count = marvell_get_sset_count,
2026 		.get_strings = marvell_get_strings,
2027 		.get_stats = marvell_get_stats,
2028 	},
2029 	{
2030 		.phy_id = MARVELL_PHY_ID_88E1149R,
2031 		.phy_id_mask = MARVELL_PHY_ID_MASK,
2032 		.name = "Marvell 88E1149R",
2033 		.features = PHY_GBIT_FEATURES,
2034 		.flags = PHY_HAS_INTERRUPT,
2035 		.probe = marvell_probe,
2036 		.config_init = &m88e1149_config_init,
2037 		.config_aneg = &m88e1118_config_aneg,
2038 		.read_status = &genphy_read_status,
2039 		.ack_interrupt = &marvell_ack_interrupt,
2040 		.config_intr = &marvell_config_intr,
2041 		.resume = &genphy_resume,
2042 		.suspend = &genphy_suspend,
2043 		.get_sset_count = marvell_get_sset_count,
2044 		.get_strings = marvell_get_strings,
2045 		.get_stats = marvell_get_stats,
2046 	},
2047 	{
2048 		.phy_id = MARVELL_PHY_ID_88E1240,
2049 		.phy_id_mask = MARVELL_PHY_ID_MASK,
2050 		.name = "Marvell 88E1240",
2051 		.features = PHY_GBIT_FEATURES,
2052 		.flags = PHY_HAS_INTERRUPT,
2053 		.probe = marvell_probe,
2054 		.config_init = &m88e1111_config_init,
2055 		.config_aneg = &marvell_config_aneg,
2056 		.read_status = &genphy_read_status,
2057 		.ack_interrupt = &marvell_ack_interrupt,
2058 		.config_intr = &marvell_config_intr,
2059 		.resume = &genphy_resume,
2060 		.suspend = &genphy_suspend,
2061 		.get_sset_count = marvell_get_sset_count,
2062 		.get_strings = marvell_get_strings,
2063 		.get_stats = marvell_get_stats,
2064 	},
2065 	{
2066 		.phy_id = MARVELL_PHY_ID_88E1116R,
2067 		.phy_id_mask = MARVELL_PHY_ID_MASK,
2068 		.name = "Marvell 88E1116R",
2069 		.features = PHY_GBIT_FEATURES,
2070 		.flags = PHY_HAS_INTERRUPT,
2071 		.probe = marvell_probe,
2072 		.config_init = &m88e1116r_config_init,
2073 		.config_aneg = &genphy_config_aneg,
2074 		.read_status = &genphy_read_status,
2075 		.ack_interrupt = &marvell_ack_interrupt,
2076 		.config_intr = &marvell_config_intr,
2077 		.resume = &genphy_resume,
2078 		.suspend = &genphy_suspend,
2079 		.get_sset_count = marvell_get_sset_count,
2080 		.get_strings = marvell_get_strings,
2081 		.get_stats = marvell_get_stats,
2082 	},
2083 	{
2084 		.phy_id = MARVELL_PHY_ID_88E1510,
2085 		.phy_id_mask = MARVELL_PHY_ID_MASK,
2086 		.name = "Marvell 88E1510",
2087 		.features = PHY_GBIT_FEATURES | SUPPORTED_FIBRE,
2088 		.flags = PHY_HAS_INTERRUPT,
2089 		.probe = &m88e1510_probe,
2090 		.remove = &marvell_remove,
2091 		.config_init = &m88e1510_config_init,
2092 		.config_aneg = &m88e1510_config_aneg,
2093 		.read_status = &marvell_read_status,
2094 		.ack_interrupt = &marvell_ack_interrupt,
2095 		.config_intr = &marvell_config_intr,
2096 		.did_interrupt = &m88e1121_did_interrupt,
2097 		.get_wol = &m88e1318_get_wol,
2098 		.set_wol = &m88e1318_set_wol,
2099 		.resume = &marvell_resume,
2100 		.suspend = &marvell_suspend,
2101 		.get_sset_count = marvell_get_sset_count,
2102 		.get_strings = marvell_get_strings,
2103 		.get_stats = marvell_get_stats,
2104 	},
2105 	{
2106 		.phy_id = MARVELL_PHY_ID_88E1540,
2107 		.phy_id_mask = MARVELL_PHY_ID_MASK,
2108 		.name = "Marvell 88E1540",
2109 		.features = PHY_GBIT_FEATURES,
2110 		.flags = PHY_HAS_INTERRUPT,
2111 		.probe = m88e1510_probe,
2112 		.remove = &marvell_remove,
2113 		.config_init = &marvell_config_init,
2114 		.config_aneg = &m88e1510_config_aneg,
2115 		.read_status = &marvell_read_status,
2116 		.ack_interrupt = &marvell_ack_interrupt,
2117 		.config_intr = &marvell_config_intr,
2118 		.did_interrupt = &m88e1121_did_interrupt,
2119 		.resume = &genphy_resume,
2120 		.suspend = &genphy_suspend,
2121 		.get_sset_count = marvell_get_sset_count,
2122 		.get_strings = marvell_get_strings,
2123 		.get_stats = marvell_get_stats,
2124 	},
2125 	{
2126 		.phy_id = MARVELL_PHY_ID_88E1545,
2127 		.phy_id_mask = MARVELL_PHY_ID_MASK,
2128 		.name = "Marvell 88E1545",
2129 		.probe = m88e1510_probe,
2130 		.remove = &marvell_remove,
2131 		.features = PHY_GBIT_FEATURES,
2132 		.flags = PHY_HAS_INTERRUPT,
2133 		.config_init = &marvell_config_init,
2134 		.config_aneg = &m88e1510_config_aneg,
2135 		.read_status = &marvell_read_status,
2136 		.ack_interrupt = &marvell_ack_interrupt,
2137 		.config_intr = &marvell_config_intr,
2138 		.did_interrupt = &m88e1121_did_interrupt,
2139 		.resume = &genphy_resume,
2140 		.suspend = &genphy_suspend,
2141 		.get_sset_count = marvell_get_sset_count,
2142 		.get_strings = marvell_get_strings,
2143 		.get_stats = marvell_get_stats,
2144 	},
2145 	{
2146 		.phy_id = MARVELL_PHY_ID_88E3016,
2147 		.phy_id_mask = MARVELL_PHY_ID_MASK,
2148 		.name = "Marvell 88E3016",
2149 		.features = PHY_BASIC_FEATURES,
2150 		.flags = PHY_HAS_INTERRUPT,
2151 		.probe = marvell_probe,
2152 		.config_aneg = &genphy_config_aneg,
2153 		.config_init = &m88e3016_config_init,
2154 		.aneg_done = &marvell_aneg_done,
2155 		.read_status = &marvell_read_status,
2156 		.ack_interrupt = &marvell_ack_interrupt,
2157 		.config_intr = &marvell_config_intr,
2158 		.did_interrupt = &m88e1121_did_interrupt,
2159 		.resume = &genphy_resume,
2160 		.suspend = &genphy_suspend,
2161 		.get_sset_count = marvell_get_sset_count,
2162 		.get_strings = marvell_get_strings,
2163 		.get_stats = marvell_get_stats,
2164 	},
2165 	{
2166 		.phy_id = MARVELL_PHY_ID_88E6390,
2167 		.phy_id_mask = MARVELL_PHY_ID_MASK,
2168 		.name = "Marvell 88E6390",
2169 		.features = PHY_GBIT_FEATURES,
2170 		.flags = PHY_HAS_INTERRUPT,
2171 		.probe = m88e1510_probe,
2172 		.config_init = &marvell_config_init,
2173 		.config_aneg = &m88e1510_config_aneg,
2174 		.read_status = &marvell_read_status,
2175 		.ack_interrupt = &marvell_ack_interrupt,
2176 		.config_intr = &marvell_config_intr,
2177 		.did_interrupt = &m88e1121_did_interrupt,
2178 		.resume = &genphy_resume,
2179 		.suspend = &genphy_suspend,
2180 		.get_sset_count = marvell_get_sset_count,
2181 		.get_strings = marvell_get_strings,
2182 		.get_stats = marvell_get_stats,
2183 	},
2184 };
2185 
2186 module_phy_driver(marvell_drivers);
2187 
2188 static struct mdio_device_id __maybe_unused marvell_tbl[] = {
2189 	{ MARVELL_PHY_ID_88E1101, MARVELL_PHY_ID_MASK },
2190 	{ MARVELL_PHY_ID_88E1112, MARVELL_PHY_ID_MASK },
2191 	{ MARVELL_PHY_ID_88E1111, MARVELL_PHY_ID_MASK },
2192 	{ MARVELL_PHY_ID_88E1118, MARVELL_PHY_ID_MASK },
2193 	{ MARVELL_PHY_ID_88E1121R, MARVELL_PHY_ID_MASK },
2194 	{ MARVELL_PHY_ID_88E1145, MARVELL_PHY_ID_MASK },
2195 	{ MARVELL_PHY_ID_88E1149R, MARVELL_PHY_ID_MASK },
2196 	{ MARVELL_PHY_ID_88E1240, MARVELL_PHY_ID_MASK },
2197 	{ MARVELL_PHY_ID_88E1318S, MARVELL_PHY_ID_MASK },
2198 	{ MARVELL_PHY_ID_88E1116R, MARVELL_PHY_ID_MASK },
2199 	{ MARVELL_PHY_ID_88E1510, MARVELL_PHY_ID_MASK },
2200 	{ MARVELL_PHY_ID_88E1540, MARVELL_PHY_ID_MASK },
2201 	{ MARVELL_PHY_ID_88E1545, MARVELL_PHY_ID_MASK },
2202 	{ MARVELL_PHY_ID_88E3016, MARVELL_PHY_ID_MASK },
2203 	{ MARVELL_PHY_ID_88E6390, MARVELL_PHY_ID_MASK },
2204 	{ }
2205 };
2206 
2207 MODULE_DEVICE_TABLE(mdio, marvell_tbl);
2208