xref: /openbmc/linux/drivers/net/phy/at803x.c (revision e721eb06)
1 // SPDX-License-Identifier: GPL-2.0+
2 /*
3  * drivers/net/phy/at803x.c
4  *
5  * Driver for Qualcomm Atheros AR803x PHY
6  *
7  * Author: Matus Ujhelyi <ujhelyi.m@gmail.com>
8  */
9 
10 #include <linux/phy.h>
11 #include <linux/module.h>
12 #include <linux/string.h>
13 #include <linux/netdevice.h>
14 #include <linux/etherdevice.h>
15 #include <linux/ethtool_netlink.h>
16 #include <linux/of_gpio.h>
17 #include <linux/bitfield.h>
18 #include <linux/gpio/consumer.h>
19 #include <linux/regulator/of_regulator.h>
20 #include <linux/regulator/driver.h>
21 #include <linux/regulator/consumer.h>
22 #include <dt-bindings/net/qca-ar803x.h>
23 
24 #define AT803X_SPECIFIC_STATUS			0x11
25 #define AT803X_SS_SPEED_MASK			(3 << 14)
26 #define AT803X_SS_SPEED_1000			(2 << 14)
27 #define AT803X_SS_SPEED_100			(1 << 14)
28 #define AT803X_SS_SPEED_10			(0 << 14)
29 #define AT803X_SS_DUPLEX			BIT(13)
30 #define AT803X_SS_SPEED_DUPLEX_RESOLVED		BIT(11)
31 #define AT803X_SS_MDIX				BIT(6)
32 
33 #define AT803X_INTR_ENABLE			0x12
34 #define AT803X_INTR_ENABLE_AUTONEG_ERR		BIT(15)
35 #define AT803X_INTR_ENABLE_SPEED_CHANGED	BIT(14)
36 #define AT803X_INTR_ENABLE_DUPLEX_CHANGED	BIT(13)
37 #define AT803X_INTR_ENABLE_PAGE_RECEIVED	BIT(12)
38 #define AT803X_INTR_ENABLE_LINK_FAIL		BIT(11)
39 #define AT803X_INTR_ENABLE_LINK_SUCCESS		BIT(10)
40 #define AT803X_INTR_ENABLE_WIRESPEED_DOWNGRADE	BIT(5)
41 #define AT803X_INTR_ENABLE_POLARITY_CHANGED	BIT(1)
42 #define AT803X_INTR_ENABLE_WOL			BIT(0)
43 
44 #define AT803X_INTR_STATUS			0x13
45 
46 #define AT803X_SMART_SPEED			0x14
47 #define AT803X_SMART_SPEED_ENABLE		BIT(5)
48 #define AT803X_SMART_SPEED_RETRY_LIMIT_MASK	GENMASK(4, 2)
49 #define AT803X_SMART_SPEED_BYPASS_TIMER		BIT(1)
50 #define AT803X_CDT				0x16
51 #define AT803X_CDT_MDI_PAIR_MASK		GENMASK(9, 8)
52 #define AT803X_CDT_ENABLE_TEST			BIT(0)
53 #define AT803X_CDT_STATUS			0x1c
54 #define AT803X_CDT_STATUS_STAT_NORMAL		0
55 #define AT803X_CDT_STATUS_STAT_SHORT		1
56 #define AT803X_CDT_STATUS_STAT_OPEN		2
57 #define AT803X_CDT_STATUS_STAT_FAIL		3
58 #define AT803X_CDT_STATUS_STAT_MASK		GENMASK(9, 8)
59 #define AT803X_CDT_STATUS_DELTA_TIME_MASK	GENMASK(7, 0)
60 #define AT803X_LED_CONTROL			0x18
61 
62 #define AT803X_DEVICE_ADDR			0x03
63 #define AT803X_LOC_MAC_ADDR_0_15_OFFSET		0x804C
64 #define AT803X_LOC_MAC_ADDR_16_31_OFFSET	0x804B
65 #define AT803X_LOC_MAC_ADDR_32_47_OFFSET	0x804A
66 #define AT803X_REG_CHIP_CONFIG			0x1f
67 #define AT803X_BT_BX_REG_SEL			0x8000
68 
69 #define AT803X_DEBUG_ADDR			0x1D
70 #define AT803X_DEBUG_DATA			0x1E
71 
72 #define AT803X_MODE_CFG_MASK			0x0F
73 #define AT803X_MODE_CFG_SGMII			0x01
74 
75 #define AT803X_PSSR			0x11	/*PHY-Specific Status Register*/
76 #define AT803X_PSSR_MR_AN_COMPLETE	0x0200
77 
78 #define AT803X_DEBUG_REG_0			0x00
79 #define AT803X_DEBUG_RX_CLK_DLY_EN		BIT(15)
80 
81 #define AT803X_DEBUG_REG_5			0x05
82 #define AT803X_DEBUG_TX_CLK_DLY_EN		BIT(8)
83 
84 #define AT803X_DEBUG_REG_1F			0x1F
85 #define AT803X_DEBUG_PLL_ON			BIT(2)
86 #define AT803X_DEBUG_RGMII_1V8			BIT(3)
87 
88 /* AT803x supports either the XTAL input pad, an internal PLL or the
89  * DSP as clock reference for the clock output pad. The XTAL reference
90  * is only used for 25 MHz output, all other frequencies need the PLL.
91  * The DSP as a clock reference is used in synchronous ethernet
92  * applications.
93  *
94  * By default the PLL is only enabled if there is a link. Otherwise
95  * the PHY will go into low power state and disabled the PLL. You can
96  * set the PLL_ON bit (see debug register 0x1f) to keep the PLL always
97  * enabled.
98  */
99 #define AT803X_MMD7_CLK25M			0x8016
100 #define AT803X_CLK_OUT_MASK			GENMASK(4, 2)
101 #define AT803X_CLK_OUT_25MHZ_XTAL		0
102 #define AT803X_CLK_OUT_25MHZ_DSP		1
103 #define AT803X_CLK_OUT_50MHZ_PLL		2
104 #define AT803X_CLK_OUT_50MHZ_DSP		3
105 #define AT803X_CLK_OUT_62_5MHZ_PLL		4
106 #define AT803X_CLK_OUT_62_5MHZ_DSP		5
107 #define AT803X_CLK_OUT_125MHZ_PLL		6
108 #define AT803X_CLK_OUT_125MHZ_DSP		7
109 
110 /* The AR8035 has another mask which is compatible with the AR8031/AR8033 mask
111  * but doesn't support choosing between XTAL/PLL and DSP.
112  */
113 #define AT8035_CLK_OUT_MASK			GENMASK(4, 3)
114 
115 #define AT803X_CLK_OUT_STRENGTH_MASK		GENMASK(8, 7)
116 #define AT803X_CLK_OUT_STRENGTH_FULL		0
117 #define AT803X_CLK_OUT_STRENGTH_HALF		1
118 #define AT803X_CLK_OUT_STRENGTH_QUARTER		2
119 
120 #define AT803X_DEFAULT_DOWNSHIFT 5
121 #define AT803X_MIN_DOWNSHIFT 2
122 #define AT803X_MAX_DOWNSHIFT 9
123 
124 #define ATH9331_PHY_ID 0x004dd041
125 #define ATH8030_PHY_ID 0x004dd076
126 #define ATH8031_PHY_ID 0x004dd074
127 #define ATH8032_PHY_ID 0x004dd023
128 #define ATH8035_PHY_ID 0x004dd072
129 #define AT8030_PHY_ID_MASK			0xffffffef
130 
131 MODULE_DESCRIPTION("Qualcomm Atheros AR803x PHY driver");
132 MODULE_AUTHOR("Matus Ujhelyi");
133 MODULE_LICENSE("GPL");
134 
135 struct at803x_priv {
136 	int flags;
137 #define AT803X_KEEP_PLL_ENABLED	BIT(0)	/* don't turn off internal PLL */
138 	u16 clk_25m_reg;
139 	u16 clk_25m_mask;
140 	struct regulator_dev *vddio_rdev;
141 	struct regulator_dev *vddh_rdev;
142 	struct regulator *vddio;
143 };
144 
145 struct at803x_context {
146 	u16 bmcr;
147 	u16 advertise;
148 	u16 control1000;
149 	u16 int_enable;
150 	u16 smart_speed;
151 	u16 led_control;
152 };
153 
154 static int at803x_debug_reg_read(struct phy_device *phydev, u16 reg)
155 {
156 	int ret;
157 
158 	ret = phy_write(phydev, AT803X_DEBUG_ADDR, reg);
159 	if (ret < 0)
160 		return ret;
161 
162 	return phy_read(phydev, AT803X_DEBUG_DATA);
163 }
164 
165 static int at803x_debug_reg_mask(struct phy_device *phydev, u16 reg,
166 				 u16 clear, u16 set)
167 {
168 	u16 val;
169 	int ret;
170 
171 	ret = at803x_debug_reg_read(phydev, reg);
172 	if (ret < 0)
173 		return ret;
174 
175 	val = ret & 0xffff;
176 	val &= ~clear;
177 	val |= set;
178 
179 	return phy_write(phydev, AT803X_DEBUG_DATA, val);
180 }
181 
182 static int at803x_enable_rx_delay(struct phy_device *phydev)
183 {
184 	return at803x_debug_reg_mask(phydev, AT803X_DEBUG_REG_0, 0,
185 				     AT803X_DEBUG_RX_CLK_DLY_EN);
186 }
187 
188 static int at803x_enable_tx_delay(struct phy_device *phydev)
189 {
190 	return at803x_debug_reg_mask(phydev, AT803X_DEBUG_REG_5, 0,
191 				     AT803X_DEBUG_TX_CLK_DLY_EN);
192 }
193 
194 static int at803x_disable_rx_delay(struct phy_device *phydev)
195 {
196 	return at803x_debug_reg_mask(phydev, AT803X_DEBUG_REG_0,
197 				     AT803X_DEBUG_RX_CLK_DLY_EN, 0);
198 }
199 
200 static int at803x_disable_tx_delay(struct phy_device *phydev)
201 {
202 	return at803x_debug_reg_mask(phydev, AT803X_DEBUG_REG_5,
203 				     AT803X_DEBUG_TX_CLK_DLY_EN, 0);
204 }
205 
206 /* save relevant PHY registers to private copy */
207 static void at803x_context_save(struct phy_device *phydev,
208 				struct at803x_context *context)
209 {
210 	context->bmcr = phy_read(phydev, MII_BMCR);
211 	context->advertise = phy_read(phydev, MII_ADVERTISE);
212 	context->control1000 = phy_read(phydev, MII_CTRL1000);
213 	context->int_enable = phy_read(phydev, AT803X_INTR_ENABLE);
214 	context->smart_speed = phy_read(phydev, AT803X_SMART_SPEED);
215 	context->led_control = phy_read(phydev, AT803X_LED_CONTROL);
216 }
217 
218 /* restore relevant PHY registers from private copy */
219 static void at803x_context_restore(struct phy_device *phydev,
220 				   const struct at803x_context *context)
221 {
222 	phy_write(phydev, MII_BMCR, context->bmcr);
223 	phy_write(phydev, MII_ADVERTISE, context->advertise);
224 	phy_write(phydev, MII_CTRL1000, context->control1000);
225 	phy_write(phydev, AT803X_INTR_ENABLE, context->int_enable);
226 	phy_write(phydev, AT803X_SMART_SPEED, context->smart_speed);
227 	phy_write(phydev, AT803X_LED_CONTROL, context->led_control);
228 }
229 
230 static int at803x_set_wol(struct phy_device *phydev,
231 			  struct ethtool_wolinfo *wol)
232 {
233 	struct net_device *ndev = phydev->attached_dev;
234 	const u8 *mac;
235 	int ret;
236 	u32 value;
237 	unsigned int i, offsets[] = {
238 		AT803X_LOC_MAC_ADDR_32_47_OFFSET,
239 		AT803X_LOC_MAC_ADDR_16_31_OFFSET,
240 		AT803X_LOC_MAC_ADDR_0_15_OFFSET,
241 	};
242 
243 	if (!ndev)
244 		return -ENODEV;
245 
246 	if (wol->wolopts & WAKE_MAGIC) {
247 		mac = (const u8 *) ndev->dev_addr;
248 
249 		if (!is_valid_ether_addr(mac))
250 			return -EINVAL;
251 
252 		for (i = 0; i < 3; i++)
253 			phy_write_mmd(phydev, AT803X_DEVICE_ADDR, offsets[i],
254 				      mac[(i * 2) + 1] | (mac[(i * 2)] << 8));
255 
256 		value = phy_read(phydev, AT803X_INTR_ENABLE);
257 		value |= AT803X_INTR_ENABLE_WOL;
258 		ret = phy_write(phydev, AT803X_INTR_ENABLE, value);
259 		if (ret)
260 			return ret;
261 		value = phy_read(phydev, AT803X_INTR_STATUS);
262 	} else {
263 		value = phy_read(phydev, AT803X_INTR_ENABLE);
264 		value &= (~AT803X_INTR_ENABLE_WOL);
265 		ret = phy_write(phydev, AT803X_INTR_ENABLE, value);
266 		if (ret)
267 			return ret;
268 		value = phy_read(phydev, AT803X_INTR_STATUS);
269 	}
270 
271 	return ret;
272 }
273 
274 static void at803x_get_wol(struct phy_device *phydev,
275 			   struct ethtool_wolinfo *wol)
276 {
277 	u32 value;
278 
279 	wol->supported = WAKE_MAGIC;
280 	wol->wolopts = 0;
281 
282 	value = phy_read(phydev, AT803X_INTR_ENABLE);
283 	if (value & AT803X_INTR_ENABLE_WOL)
284 		wol->wolopts |= WAKE_MAGIC;
285 }
286 
287 static int at803x_suspend(struct phy_device *phydev)
288 {
289 	int value;
290 	int wol_enabled;
291 
292 	value = phy_read(phydev, AT803X_INTR_ENABLE);
293 	wol_enabled = value & AT803X_INTR_ENABLE_WOL;
294 
295 	if (wol_enabled)
296 		value = BMCR_ISOLATE;
297 	else
298 		value = BMCR_PDOWN;
299 
300 	phy_modify(phydev, MII_BMCR, 0, value);
301 
302 	return 0;
303 }
304 
305 static int at803x_resume(struct phy_device *phydev)
306 {
307 	return phy_modify(phydev, MII_BMCR, BMCR_PDOWN | BMCR_ISOLATE, 0);
308 }
309 
310 static int at803x_rgmii_reg_set_voltage_sel(struct regulator_dev *rdev,
311 					    unsigned int selector)
312 {
313 	struct phy_device *phydev = rdev_get_drvdata(rdev);
314 
315 	if (selector)
316 		return at803x_debug_reg_mask(phydev, AT803X_DEBUG_REG_1F,
317 					     0, AT803X_DEBUG_RGMII_1V8);
318 	else
319 		return at803x_debug_reg_mask(phydev, AT803X_DEBUG_REG_1F,
320 					     AT803X_DEBUG_RGMII_1V8, 0);
321 }
322 
323 static int at803x_rgmii_reg_get_voltage_sel(struct regulator_dev *rdev)
324 {
325 	struct phy_device *phydev = rdev_get_drvdata(rdev);
326 	int val;
327 
328 	val = at803x_debug_reg_read(phydev, AT803X_DEBUG_REG_1F);
329 	if (val < 0)
330 		return val;
331 
332 	return (val & AT803X_DEBUG_RGMII_1V8) ? 1 : 0;
333 }
334 
335 static struct regulator_ops vddio_regulator_ops = {
336 	.list_voltage = regulator_list_voltage_table,
337 	.set_voltage_sel = at803x_rgmii_reg_set_voltage_sel,
338 	.get_voltage_sel = at803x_rgmii_reg_get_voltage_sel,
339 };
340 
341 static const unsigned int vddio_voltage_table[] = {
342 	1500000,
343 	1800000,
344 };
345 
346 static const struct regulator_desc vddio_desc = {
347 	.name = "vddio",
348 	.of_match = of_match_ptr("vddio-regulator"),
349 	.n_voltages = ARRAY_SIZE(vddio_voltage_table),
350 	.volt_table = vddio_voltage_table,
351 	.ops = &vddio_regulator_ops,
352 	.type = REGULATOR_VOLTAGE,
353 	.owner = THIS_MODULE,
354 };
355 
356 static struct regulator_ops vddh_regulator_ops = {
357 };
358 
359 static const struct regulator_desc vddh_desc = {
360 	.name = "vddh",
361 	.of_match = of_match_ptr("vddh-regulator"),
362 	.n_voltages = 1,
363 	.fixed_uV = 2500000,
364 	.ops = &vddh_regulator_ops,
365 	.type = REGULATOR_VOLTAGE,
366 	.owner = THIS_MODULE,
367 };
368 
369 static int at8031_register_regulators(struct phy_device *phydev)
370 {
371 	struct at803x_priv *priv = phydev->priv;
372 	struct device *dev = &phydev->mdio.dev;
373 	struct regulator_config config = { };
374 
375 	config.dev = dev;
376 	config.driver_data = phydev;
377 
378 	priv->vddio_rdev = devm_regulator_register(dev, &vddio_desc, &config);
379 	if (IS_ERR(priv->vddio_rdev)) {
380 		phydev_err(phydev, "failed to register VDDIO regulator\n");
381 		return PTR_ERR(priv->vddio_rdev);
382 	}
383 
384 	priv->vddh_rdev = devm_regulator_register(dev, &vddh_desc, &config);
385 	if (IS_ERR(priv->vddh_rdev)) {
386 		phydev_err(phydev, "failed to register VDDH regulator\n");
387 		return PTR_ERR(priv->vddh_rdev);
388 	}
389 
390 	return 0;
391 }
392 
393 static bool at803x_match_phy_id(struct phy_device *phydev, u32 phy_id)
394 {
395 	return (phydev->phy_id & phydev->drv->phy_id_mask)
396 		== (phy_id & phydev->drv->phy_id_mask);
397 }
398 
399 static int at803x_parse_dt(struct phy_device *phydev)
400 {
401 	struct device_node *node = phydev->mdio.dev.of_node;
402 	struct at803x_priv *priv = phydev->priv;
403 	unsigned int sel, mask;
404 	u32 freq, strength;
405 	int ret;
406 
407 	if (!IS_ENABLED(CONFIG_OF_MDIO))
408 		return 0;
409 
410 	ret = of_property_read_u32(node, "qca,clk-out-frequency", &freq);
411 	if (!ret) {
412 		mask = AT803X_CLK_OUT_MASK;
413 		switch (freq) {
414 		case 25000000:
415 			sel = AT803X_CLK_OUT_25MHZ_XTAL;
416 			break;
417 		case 50000000:
418 			sel = AT803X_CLK_OUT_50MHZ_PLL;
419 			break;
420 		case 62500000:
421 			sel = AT803X_CLK_OUT_62_5MHZ_PLL;
422 			break;
423 		case 125000000:
424 			sel = AT803X_CLK_OUT_125MHZ_PLL;
425 			break;
426 		default:
427 			phydev_err(phydev, "invalid qca,clk-out-frequency\n");
428 			return -EINVAL;
429 		}
430 
431 		priv->clk_25m_reg |= FIELD_PREP(mask, sel);
432 		priv->clk_25m_mask |= mask;
433 
434 		/* Fixup for the AR8030/AR8035. This chip has another mask and
435 		 * doesn't support the DSP reference. Eg. the lowest bit of the
436 		 * mask. The upper two bits select the same frequencies. Mask
437 		 * the lowest bit here.
438 		 *
439 		 * Warning:
440 		 *   There was no datasheet for the AR8030 available so this is
441 		 *   just a guess. But the AR8035 is listed as pin compatible
442 		 *   to the AR8030 so there might be a good chance it works on
443 		 *   the AR8030 too.
444 		 */
445 		if (at803x_match_phy_id(phydev, ATH8030_PHY_ID) ||
446 		    at803x_match_phy_id(phydev, ATH8035_PHY_ID)) {
447 			priv->clk_25m_reg &= AT8035_CLK_OUT_MASK;
448 			priv->clk_25m_mask &= AT8035_CLK_OUT_MASK;
449 		}
450 	}
451 
452 	ret = of_property_read_u32(node, "qca,clk-out-strength", &strength);
453 	if (!ret) {
454 		priv->clk_25m_mask |= AT803X_CLK_OUT_STRENGTH_MASK;
455 		switch (strength) {
456 		case AR803X_STRENGTH_FULL:
457 			priv->clk_25m_reg |= AT803X_CLK_OUT_STRENGTH_FULL;
458 			break;
459 		case AR803X_STRENGTH_HALF:
460 			priv->clk_25m_reg |= AT803X_CLK_OUT_STRENGTH_HALF;
461 			break;
462 		case AR803X_STRENGTH_QUARTER:
463 			priv->clk_25m_reg |= AT803X_CLK_OUT_STRENGTH_QUARTER;
464 			break;
465 		default:
466 			phydev_err(phydev, "invalid qca,clk-out-strength\n");
467 			return -EINVAL;
468 		}
469 	}
470 
471 	/* Only supported on AR8031/AR8033, the AR8030/AR8035 use strapping
472 	 * options.
473 	 */
474 	if (at803x_match_phy_id(phydev, ATH8031_PHY_ID)) {
475 		if (of_property_read_bool(node, "qca,keep-pll-enabled"))
476 			priv->flags |= AT803X_KEEP_PLL_ENABLED;
477 
478 		ret = at8031_register_regulators(phydev);
479 		if (ret < 0)
480 			return ret;
481 
482 		priv->vddio = devm_regulator_get_optional(&phydev->mdio.dev,
483 							  "vddio");
484 		if (IS_ERR(priv->vddio)) {
485 			phydev_err(phydev, "failed to get VDDIO regulator\n");
486 			return PTR_ERR(priv->vddio);
487 		}
488 
489 		ret = regulator_enable(priv->vddio);
490 		if (ret < 0)
491 			return ret;
492 	}
493 
494 	return 0;
495 }
496 
497 static int at803x_probe(struct phy_device *phydev)
498 {
499 	struct device *dev = &phydev->mdio.dev;
500 	struct at803x_priv *priv;
501 
502 	priv = devm_kzalloc(dev, sizeof(*priv), GFP_KERNEL);
503 	if (!priv)
504 		return -ENOMEM;
505 
506 	phydev->priv = priv;
507 
508 	return at803x_parse_dt(phydev);
509 }
510 
511 static void at803x_remove(struct phy_device *phydev)
512 {
513 	struct at803x_priv *priv = phydev->priv;
514 
515 	if (priv->vddio)
516 		regulator_disable(priv->vddio);
517 }
518 
519 static int at803x_clk_out_config(struct phy_device *phydev)
520 {
521 	struct at803x_priv *priv = phydev->priv;
522 	int val;
523 
524 	if (!priv->clk_25m_mask)
525 		return 0;
526 
527 	val = phy_read_mmd(phydev, MDIO_MMD_AN, AT803X_MMD7_CLK25M);
528 	if (val < 0)
529 		return val;
530 
531 	val &= ~priv->clk_25m_mask;
532 	val |= priv->clk_25m_reg;
533 
534 	return phy_write_mmd(phydev, MDIO_MMD_AN, AT803X_MMD7_CLK25M, val);
535 }
536 
537 static int at8031_pll_config(struct phy_device *phydev)
538 {
539 	struct at803x_priv *priv = phydev->priv;
540 
541 	/* The default after hardware reset is PLL OFF. After a soft reset, the
542 	 * values are retained.
543 	 */
544 	if (priv->flags & AT803X_KEEP_PLL_ENABLED)
545 		return at803x_debug_reg_mask(phydev, AT803X_DEBUG_REG_1F,
546 					     0, AT803X_DEBUG_PLL_ON);
547 	else
548 		return at803x_debug_reg_mask(phydev, AT803X_DEBUG_REG_1F,
549 					     AT803X_DEBUG_PLL_ON, 0);
550 }
551 
552 static int at803x_config_init(struct phy_device *phydev)
553 {
554 	int ret;
555 
556 	/* The RX and TX delay default is:
557 	 *   after HW reset: RX delay enabled and TX delay disabled
558 	 *   after SW reset: RX delay enabled, while TX delay retains the
559 	 *   value before reset.
560 	 */
561 	if (phydev->interface == PHY_INTERFACE_MODE_RGMII_ID ||
562 	    phydev->interface == PHY_INTERFACE_MODE_RGMII_RXID)
563 		ret = at803x_enable_rx_delay(phydev);
564 	else
565 		ret = at803x_disable_rx_delay(phydev);
566 	if (ret < 0)
567 		return ret;
568 
569 	if (phydev->interface == PHY_INTERFACE_MODE_RGMII_ID ||
570 	    phydev->interface == PHY_INTERFACE_MODE_RGMII_TXID)
571 		ret = at803x_enable_tx_delay(phydev);
572 	else
573 		ret = at803x_disable_tx_delay(phydev);
574 	if (ret < 0)
575 		return ret;
576 
577 	ret = at803x_clk_out_config(phydev);
578 	if (ret < 0)
579 		return ret;
580 
581 	if (at803x_match_phy_id(phydev, ATH8031_PHY_ID)) {
582 		ret = at8031_pll_config(phydev);
583 		if (ret < 0)
584 			return ret;
585 	}
586 
587 	return 0;
588 }
589 
590 static int at803x_ack_interrupt(struct phy_device *phydev)
591 {
592 	int err;
593 
594 	err = phy_read(phydev, AT803X_INTR_STATUS);
595 
596 	return (err < 0) ? err : 0;
597 }
598 
599 static int at803x_config_intr(struct phy_device *phydev)
600 {
601 	int err;
602 	int value;
603 
604 	value = phy_read(phydev, AT803X_INTR_ENABLE);
605 
606 	if (phydev->interrupts == PHY_INTERRUPT_ENABLED) {
607 		value |= AT803X_INTR_ENABLE_AUTONEG_ERR;
608 		value |= AT803X_INTR_ENABLE_SPEED_CHANGED;
609 		value |= AT803X_INTR_ENABLE_DUPLEX_CHANGED;
610 		value |= AT803X_INTR_ENABLE_LINK_FAIL;
611 		value |= AT803X_INTR_ENABLE_LINK_SUCCESS;
612 
613 		err = phy_write(phydev, AT803X_INTR_ENABLE, value);
614 	}
615 	else
616 		err = phy_write(phydev, AT803X_INTR_ENABLE, 0);
617 
618 	return err;
619 }
620 
621 static void at803x_link_change_notify(struct phy_device *phydev)
622 {
623 	/*
624 	 * Conduct a hardware reset for AT8030 every time a link loss is
625 	 * signalled. This is necessary to circumvent a hardware bug that
626 	 * occurs when the cable is unplugged while TX packets are pending
627 	 * in the FIFO. In such cases, the FIFO enters an error mode it
628 	 * cannot recover from by software.
629 	 */
630 	if (phydev->state == PHY_NOLINK && phydev->mdio.reset_gpio) {
631 		struct at803x_context context;
632 
633 		at803x_context_save(phydev, &context);
634 
635 		phy_device_reset(phydev, 1);
636 		msleep(1);
637 		phy_device_reset(phydev, 0);
638 		msleep(1);
639 
640 		at803x_context_restore(phydev, &context);
641 
642 		phydev_dbg(phydev, "%s(): phy was reset\n", __func__);
643 	}
644 }
645 
646 static int at803x_aneg_done(struct phy_device *phydev)
647 {
648 	int ccr;
649 
650 	int aneg_done = genphy_aneg_done(phydev);
651 	if (aneg_done != BMSR_ANEGCOMPLETE)
652 		return aneg_done;
653 
654 	/*
655 	 * in SGMII mode, if copper side autoneg is successful,
656 	 * also check SGMII side autoneg result
657 	 */
658 	ccr = phy_read(phydev, AT803X_REG_CHIP_CONFIG);
659 	if ((ccr & AT803X_MODE_CFG_MASK) != AT803X_MODE_CFG_SGMII)
660 		return aneg_done;
661 
662 	/* switch to SGMII/fiber page */
663 	phy_write(phydev, AT803X_REG_CHIP_CONFIG, ccr & ~AT803X_BT_BX_REG_SEL);
664 
665 	/* check if the SGMII link is OK. */
666 	if (!(phy_read(phydev, AT803X_PSSR) & AT803X_PSSR_MR_AN_COMPLETE)) {
667 		phydev_warn(phydev, "803x_aneg_done: SGMII link is not ok\n");
668 		aneg_done = 0;
669 	}
670 	/* switch back to copper page */
671 	phy_write(phydev, AT803X_REG_CHIP_CONFIG, ccr | AT803X_BT_BX_REG_SEL);
672 
673 	return aneg_done;
674 }
675 
676 static int at803x_read_status(struct phy_device *phydev)
677 {
678 	int ss, err, old_link = phydev->link;
679 
680 	/* Update the link, but return if there was an error */
681 	err = genphy_update_link(phydev);
682 	if (err)
683 		return err;
684 
685 	/* why bother the PHY if nothing can have changed */
686 	if (phydev->autoneg == AUTONEG_ENABLE && old_link && phydev->link)
687 		return 0;
688 
689 	phydev->speed = SPEED_UNKNOWN;
690 	phydev->duplex = DUPLEX_UNKNOWN;
691 	phydev->pause = 0;
692 	phydev->asym_pause = 0;
693 
694 	err = genphy_read_lpa(phydev);
695 	if (err < 0)
696 		return err;
697 
698 	/* Read the AT8035 PHY-Specific Status register, which indicates the
699 	 * speed and duplex that the PHY is actually using, irrespective of
700 	 * whether we are in autoneg mode or not.
701 	 */
702 	ss = phy_read(phydev, AT803X_SPECIFIC_STATUS);
703 	if (ss < 0)
704 		return ss;
705 
706 	if (ss & AT803X_SS_SPEED_DUPLEX_RESOLVED) {
707 		switch (ss & AT803X_SS_SPEED_MASK) {
708 		case AT803X_SS_SPEED_10:
709 			phydev->speed = SPEED_10;
710 			break;
711 		case AT803X_SS_SPEED_100:
712 			phydev->speed = SPEED_100;
713 			break;
714 		case AT803X_SS_SPEED_1000:
715 			phydev->speed = SPEED_1000;
716 			break;
717 		}
718 		if (ss & AT803X_SS_DUPLEX)
719 			phydev->duplex = DUPLEX_FULL;
720 		else
721 			phydev->duplex = DUPLEX_HALF;
722 		if (ss & AT803X_SS_MDIX)
723 			phydev->mdix = ETH_TP_MDI_X;
724 		else
725 			phydev->mdix = ETH_TP_MDI;
726 	}
727 
728 	if (phydev->autoneg == AUTONEG_ENABLE && phydev->autoneg_complete)
729 		phy_resolve_aneg_pause(phydev);
730 
731 	return 0;
732 }
733 
734 static int at803x_get_downshift(struct phy_device *phydev, u8 *d)
735 {
736 	int val;
737 
738 	val = phy_read(phydev, AT803X_SMART_SPEED);
739 	if (val < 0)
740 		return val;
741 
742 	if (val & AT803X_SMART_SPEED_ENABLE)
743 		*d = FIELD_GET(AT803X_SMART_SPEED_RETRY_LIMIT_MASK, val) + 2;
744 	else
745 		*d = DOWNSHIFT_DEV_DISABLE;
746 
747 	return 0;
748 }
749 
750 static int at803x_set_downshift(struct phy_device *phydev, u8 cnt)
751 {
752 	u16 mask, set;
753 	int ret;
754 
755 	switch (cnt) {
756 	case DOWNSHIFT_DEV_DEFAULT_COUNT:
757 		cnt = AT803X_DEFAULT_DOWNSHIFT;
758 		fallthrough;
759 	case AT803X_MIN_DOWNSHIFT ... AT803X_MAX_DOWNSHIFT:
760 		set = AT803X_SMART_SPEED_ENABLE |
761 		      AT803X_SMART_SPEED_BYPASS_TIMER |
762 		      FIELD_PREP(AT803X_SMART_SPEED_RETRY_LIMIT_MASK, cnt - 2);
763 		mask = AT803X_SMART_SPEED_RETRY_LIMIT_MASK;
764 		break;
765 	case DOWNSHIFT_DEV_DISABLE:
766 		set = 0;
767 		mask = AT803X_SMART_SPEED_ENABLE |
768 		       AT803X_SMART_SPEED_BYPASS_TIMER;
769 		break;
770 	default:
771 		return -EINVAL;
772 	}
773 
774 	ret = phy_modify_changed(phydev, AT803X_SMART_SPEED, mask, set);
775 
776 	/* After changing the smart speed settings, we need to perform a
777 	 * software reset, use phy_init_hw() to make sure we set the
778 	 * reapply any values which might got lost during software reset.
779 	 */
780 	if (ret == 1)
781 		ret = phy_init_hw(phydev);
782 
783 	return ret;
784 }
785 
786 static int at803x_get_tunable(struct phy_device *phydev,
787 			      struct ethtool_tunable *tuna, void *data)
788 {
789 	switch (tuna->id) {
790 	case ETHTOOL_PHY_DOWNSHIFT:
791 		return at803x_get_downshift(phydev, data);
792 	default:
793 		return -EOPNOTSUPP;
794 	}
795 }
796 
797 static int at803x_set_tunable(struct phy_device *phydev,
798 			      struct ethtool_tunable *tuna, const void *data)
799 {
800 	switch (tuna->id) {
801 	case ETHTOOL_PHY_DOWNSHIFT:
802 		return at803x_set_downshift(phydev, *(const u8 *)data);
803 	default:
804 		return -EOPNOTSUPP;
805 	}
806 }
807 
808 static int at803x_cable_test_result_trans(u16 status)
809 {
810 	switch (FIELD_GET(AT803X_CDT_STATUS_STAT_MASK, status)) {
811 	case AT803X_CDT_STATUS_STAT_NORMAL:
812 		return ETHTOOL_A_CABLE_RESULT_CODE_OK;
813 	case AT803X_CDT_STATUS_STAT_SHORT:
814 		return ETHTOOL_A_CABLE_RESULT_CODE_SAME_SHORT;
815 	case AT803X_CDT_STATUS_STAT_OPEN:
816 		return ETHTOOL_A_CABLE_RESULT_CODE_OPEN;
817 	case AT803X_CDT_STATUS_STAT_FAIL:
818 	default:
819 		return ETHTOOL_A_CABLE_RESULT_CODE_UNSPEC;
820 	}
821 }
822 
823 static bool at803x_cdt_test_failed(u16 status)
824 {
825 	return FIELD_GET(AT803X_CDT_STATUS_STAT_MASK, status) ==
826 		AT803X_CDT_STATUS_STAT_FAIL;
827 }
828 
829 static bool at803x_cdt_fault_length_valid(u16 status)
830 {
831 	switch (FIELD_GET(AT803X_CDT_STATUS_STAT_MASK, status)) {
832 	case AT803X_CDT_STATUS_STAT_OPEN:
833 	case AT803X_CDT_STATUS_STAT_SHORT:
834 		return true;
835 	}
836 	return false;
837 }
838 
839 static int at803x_cdt_fault_length(u16 status)
840 {
841 	int dt;
842 
843 	/* According to the datasheet the distance to the fault is
844 	 * DELTA_TIME * 0.824 meters.
845 	 *
846 	 * The author suspect the correct formula is:
847 	 *
848 	 *   fault_distance = DELTA_TIME * (c * VF) / 125MHz / 2
849 	 *
850 	 * where c is the speed of light, VF is the velocity factor of
851 	 * the twisted pair cable, 125MHz the counter frequency and
852 	 * we need to divide by 2 because the hardware will measure the
853 	 * round trip time to the fault and back to the PHY.
854 	 *
855 	 * With a VF of 0.69 we get the factor 0.824 mentioned in the
856 	 * datasheet.
857 	 */
858 	dt = FIELD_GET(AT803X_CDT_STATUS_DELTA_TIME_MASK, status);
859 
860 	return (dt * 824) / 10;
861 }
862 
863 static int at803x_cdt_start(struct phy_device *phydev, int pair)
864 {
865 	u16 cdt;
866 
867 	cdt = FIELD_PREP(AT803X_CDT_MDI_PAIR_MASK, pair) |
868 	      AT803X_CDT_ENABLE_TEST;
869 
870 	return phy_write(phydev, AT803X_CDT, cdt);
871 }
872 
873 static int at803x_cdt_wait_for_completion(struct phy_device *phydev)
874 {
875 	int val, ret;
876 
877 	/* One test run takes about 25ms */
878 	ret = phy_read_poll_timeout(phydev, AT803X_CDT, val,
879 				    !(val & AT803X_CDT_ENABLE_TEST),
880 				    30000, 100000, true);
881 
882 	return ret < 0 ? ret : 0;
883 }
884 
885 static int at803x_cable_test_one_pair(struct phy_device *phydev, int pair)
886 {
887 	static const int ethtool_pair[] = {
888 		ETHTOOL_A_CABLE_PAIR_A,
889 		ETHTOOL_A_CABLE_PAIR_B,
890 		ETHTOOL_A_CABLE_PAIR_C,
891 		ETHTOOL_A_CABLE_PAIR_D,
892 	};
893 	int ret, val;
894 
895 	ret = at803x_cdt_start(phydev, pair);
896 	if (ret)
897 		return ret;
898 
899 	ret = at803x_cdt_wait_for_completion(phydev);
900 	if (ret)
901 		return ret;
902 
903 	val = phy_read(phydev, AT803X_CDT_STATUS);
904 	if (val < 0)
905 		return val;
906 
907 	if (at803x_cdt_test_failed(val))
908 		return 0;
909 
910 	ethnl_cable_test_result(phydev, ethtool_pair[pair],
911 				at803x_cable_test_result_trans(val));
912 
913 	if (at803x_cdt_fault_length_valid(val))
914 		ethnl_cable_test_fault_length(phydev, ethtool_pair[pair],
915 					      at803x_cdt_fault_length(val));
916 
917 	return 1;
918 }
919 
920 static int at803x_cable_test_get_status(struct phy_device *phydev,
921 					bool *finished)
922 {
923 	unsigned long pair_mask;
924 	int retries = 20;
925 	int pair, ret;
926 
927 	if (phydev->phy_id == ATH9331_PHY_ID ||
928 	    phydev->phy_id == ATH8032_PHY_ID)
929 		pair_mask = 0x3;
930 	else
931 		pair_mask = 0xf;
932 
933 	*finished = false;
934 
935 	/* According to the datasheet the CDT can be performed when
936 	 * there is no link partner or when the link partner is
937 	 * auto-negotiating. Starting the test will restart the AN
938 	 * automatically. It seems that doing this repeatedly we will
939 	 * get a slot where our link partner won't disturb our
940 	 * measurement.
941 	 */
942 	while (pair_mask && retries--) {
943 		for_each_set_bit(pair, &pair_mask, 4) {
944 			ret = at803x_cable_test_one_pair(phydev, pair);
945 			if (ret < 0)
946 				return ret;
947 			if (ret)
948 				clear_bit(pair, &pair_mask);
949 		}
950 		if (pair_mask)
951 			msleep(250);
952 	}
953 
954 	*finished = true;
955 
956 	return 0;
957 }
958 
959 static int at803x_cable_test_start(struct phy_device *phydev)
960 {
961 	/* Enable auto-negotiation, but advertise no capabilities, no link
962 	 * will be established. A restart of the auto-negotiation is not
963 	 * required, because the cable test will automatically break the link.
964 	 */
965 	phy_write(phydev, MII_BMCR, BMCR_ANENABLE);
966 	phy_write(phydev, MII_ADVERTISE, ADVERTISE_CSMA);
967 	if (phydev->phy_id != ATH9331_PHY_ID &&
968 	    phydev->phy_id != ATH8032_PHY_ID)
969 		phy_write(phydev, MII_CTRL1000, 0);
970 
971 	/* we do all the (time consuming) work later */
972 	return 0;
973 }
974 
975 static struct phy_driver at803x_driver[] = {
976 {
977 	/* Qualcomm Atheros AR8035 */
978 	PHY_ID_MATCH_EXACT(ATH8035_PHY_ID),
979 	.name			= "Qualcomm Atheros AR8035",
980 	.flags			= PHY_POLL_CABLE_TEST,
981 	.probe			= at803x_probe,
982 	.remove			= at803x_remove,
983 	.config_init		= at803x_config_init,
984 	.soft_reset		= genphy_soft_reset,
985 	.set_wol		= at803x_set_wol,
986 	.get_wol		= at803x_get_wol,
987 	.suspend		= at803x_suspend,
988 	.resume			= at803x_resume,
989 	/* PHY_GBIT_FEATURES */
990 	.read_status		= at803x_read_status,
991 	.ack_interrupt		= at803x_ack_interrupt,
992 	.config_intr		= at803x_config_intr,
993 	.get_tunable		= at803x_get_tunable,
994 	.set_tunable		= at803x_set_tunable,
995 	.cable_test_start	= at803x_cable_test_start,
996 	.cable_test_get_status	= at803x_cable_test_get_status,
997 }, {
998 	/* Qualcomm Atheros AR8030 */
999 	.phy_id			= ATH8030_PHY_ID,
1000 	.name			= "Qualcomm Atheros AR8030",
1001 	.phy_id_mask		= AT8030_PHY_ID_MASK,
1002 	.probe			= at803x_probe,
1003 	.remove			= at803x_remove,
1004 	.config_init		= at803x_config_init,
1005 	.link_change_notify	= at803x_link_change_notify,
1006 	.set_wol		= at803x_set_wol,
1007 	.get_wol		= at803x_get_wol,
1008 	.suspend		= at803x_suspend,
1009 	.resume			= at803x_resume,
1010 	/* PHY_BASIC_FEATURES */
1011 	.ack_interrupt		= at803x_ack_interrupt,
1012 	.config_intr		= at803x_config_intr,
1013 }, {
1014 	/* Qualcomm Atheros AR8031/AR8033 */
1015 	PHY_ID_MATCH_EXACT(ATH8031_PHY_ID),
1016 	.name			= "Qualcomm Atheros AR8031/AR8033",
1017 	.flags			= PHY_POLL_CABLE_TEST,
1018 	.probe			= at803x_probe,
1019 	.remove			= at803x_remove,
1020 	.config_init		= at803x_config_init,
1021 	.soft_reset		= genphy_soft_reset,
1022 	.set_wol		= at803x_set_wol,
1023 	.get_wol		= at803x_get_wol,
1024 	.suspend		= at803x_suspend,
1025 	.resume			= at803x_resume,
1026 	/* PHY_GBIT_FEATURES */
1027 	.read_status		= at803x_read_status,
1028 	.aneg_done		= at803x_aneg_done,
1029 	.ack_interrupt		= &at803x_ack_interrupt,
1030 	.config_intr		= &at803x_config_intr,
1031 	.get_tunable		= at803x_get_tunable,
1032 	.set_tunable		= at803x_set_tunable,
1033 	.cable_test_start	= at803x_cable_test_start,
1034 	.cable_test_get_status	= at803x_cable_test_get_status,
1035 }, {
1036 	/* Qualcomm Atheros AR8032 */
1037 	PHY_ID_MATCH_EXACT(ATH8032_PHY_ID),
1038 	.name			= "Qualcomm Atheros AR8032",
1039 	.probe			= at803x_probe,
1040 	.remove			= at803x_remove,
1041 	.flags			= PHY_POLL_CABLE_TEST,
1042 	.config_init		= at803x_config_init,
1043 	.link_change_notify	= at803x_link_change_notify,
1044 	.set_wol		= at803x_set_wol,
1045 	.get_wol		= at803x_get_wol,
1046 	.suspend		= at803x_suspend,
1047 	.resume			= at803x_resume,
1048 	/* PHY_BASIC_FEATURES */
1049 	.ack_interrupt		= at803x_ack_interrupt,
1050 	.config_intr		= at803x_config_intr,
1051 	.cable_test_start	= at803x_cable_test_start,
1052 	.cable_test_get_status	= at803x_cable_test_get_status,
1053 }, {
1054 	/* ATHEROS AR9331 */
1055 	PHY_ID_MATCH_EXACT(ATH9331_PHY_ID),
1056 	.name			= "Qualcomm Atheros AR9331 built-in PHY",
1057 	.suspend		= at803x_suspend,
1058 	.resume			= at803x_resume,
1059 	.flags			= PHY_POLL_CABLE_TEST,
1060 	/* PHY_BASIC_FEATURES */
1061 	.ack_interrupt		= &at803x_ack_interrupt,
1062 	.config_intr		= &at803x_config_intr,
1063 	.cable_test_start	= at803x_cable_test_start,
1064 	.cable_test_get_status	= at803x_cable_test_get_status,
1065 } };
1066 
1067 module_phy_driver(at803x_driver);
1068 
1069 static struct mdio_device_id __maybe_unused atheros_tbl[] = {
1070 	{ ATH8030_PHY_ID, AT8030_PHY_ID_MASK },
1071 	{ PHY_ID_MATCH_EXACT(ATH8031_PHY_ID) },
1072 	{ PHY_ID_MATCH_EXACT(ATH8032_PHY_ID) },
1073 	{ PHY_ID_MATCH_EXACT(ATH8035_PHY_ID) },
1074 	{ PHY_ID_MATCH_EXACT(ATH9331_PHY_ID) },
1075 	{ }
1076 };
1077 
1078 MODULE_DEVICE_TABLE(mdio, atheros_tbl);
1079