Linux kernel mirror (for testing)
git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel
os
linux
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/bitfield.h>
17#include <linux/regulator/of_regulator.h>
18#include <linux/regulator/driver.h>
19#include <linux/regulator/consumer.h>
20#include <linux/of.h>
21#include <linux/phylink.h>
22#include <linux/sfp.h>
23#include <dt-bindings/net/qca-ar803x.h>
24
25#include "qcom.h"
26
27#define AT803X_LED_CONTROL 0x18
28
29#define AT803X_PHY_MMD3_WOL_CTRL 0x8012
30#define AT803X_WOL_EN BIT(5)
31
32#define AT803X_REG_CHIP_CONFIG 0x1f
33#define AT803X_BT_BX_REG_SEL 0x8000
34
35#define AT803X_MODE_CFG_MASK 0x0F
36#define AT803X_MODE_CFG_BASET_RGMII 0x00
37#define AT803X_MODE_CFG_BASET_SGMII 0x01
38#define AT803X_MODE_CFG_BX1000_RGMII_50OHM 0x02
39#define AT803X_MODE_CFG_BX1000_RGMII_75OHM 0x03
40#define AT803X_MODE_CFG_BX1000_CONV_50OHM 0x04
41#define AT803X_MODE_CFG_BX1000_CONV_75OHM 0x05
42#define AT803X_MODE_CFG_FX100_RGMII_50OHM 0x06
43#define AT803X_MODE_CFG_FX100_CONV_50OHM 0x07
44#define AT803X_MODE_CFG_RGMII_AUTO_MDET 0x0B
45#define AT803X_MODE_CFG_FX100_RGMII_75OHM 0x0E
46#define AT803X_MODE_CFG_FX100_CONV_75OHM 0x0F
47
48#define AT803X_PSSR 0x11 /*PHY-Specific Status Register*/
49#define AT803X_PSSR_MR_AN_COMPLETE 0x0200
50
51#define AT803X_DEBUG_REG_1F 0x1F
52#define AT803X_DEBUG_PLL_ON BIT(2)
53#define AT803X_DEBUG_RGMII_1V8 BIT(3)
54
55/* AT803x supports either the XTAL input pad, an internal PLL or the
56 * DSP as clock reference for the clock output pad. The XTAL reference
57 * is only used for 25 MHz output, all other frequencies need the PLL.
58 * The DSP as a clock reference is used in synchronous ethernet
59 * applications.
60 *
61 * By default the PLL is only enabled if there is a link. Otherwise
62 * the PHY will go into low power state and disabled the PLL. You can
63 * set the PLL_ON bit (see debug register 0x1f) to keep the PLL always
64 * enabled.
65 */
66#define AT803X_MMD7_CLK25M 0x8016
67#define AT803X_CLK_OUT_MASK GENMASK(4, 2)
68#define AT803X_CLK_OUT_25MHZ_XTAL 0
69#define AT803X_CLK_OUT_25MHZ_DSP 1
70#define AT803X_CLK_OUT_50MHZ_PLL 2
71#define AT803X_CLK_OUT_50MHZ_DSP 3
72#define AT803X_CLK_OUT_62_5MHZ_PLL 4
73#define AT803X_CLK_OUT_62_5MHZ_DSP 5
74#define AT803X_CLK_OUT_125MHZ_PLL 6
75#define AT803X_CLK_OUT_125MHZ_DSP 7
76
77/* The AR8035 has another mask which is compatible with the AR8031/AR8033 mask
78 * but doesn't support choosing between XTAL/PLL and DSP.
79 */
80#define AT8035_CLK_OUT_MASK GENMASK(4, 3)
81
82#define AT803X_CLK_OUT_STRENGTH_MASK GENMASK(8, 7)
83#define AT803X_CLK_OUT_STRENGTH_FULL 0
84#define AT803X_CLK_OUT_STRENGTH_HALF 1
85#define AT803X_CLK_OUT_STRENGTH_QUARTER 2
86
87#define AT803X_MMD3_SMARTEEE_CTL1 0x805b
88#define AT803X_MMD3_SMARTEEE_CTL2 0x805c
89#define AT803X_MMD3_SMARTEEE_CTL3 0x805d
90#define AT803X_MMD3_SMARTEEE_CTL3_LPI_EN BIT(8)
91
92#define ATH9331_PHY_ID 0x004dd041
93#define ATH8030_PHY_ID 0x004dd076
94#define ATH8031_PHY_ID 0x004dd074
95#define ATH8032_PHY_ID 0x004dd023
96#define ATH8035_PHY_ID 0x004dd072
97#define AT8030_PHY_ID_MASK 0xffffffef
98
99#define QCA9561_PHY_ID 0x004dd042
100
101#define AT803X_PAGE_FIBER 0
102#define AT803X_PAGE_COPPER 1
103
104/* don't turn off internal PLL */
105#define AT803X_KEEP_PLL_ENABLED BIT(0)
106#define AT803X_DISABLE_SMARTEEE BIT(1)
107
108/* disable hibernation mode */
109#define AT803X_DISABLE_HIBERNATION_MODE BIT(2)
110
111MODULE_DESCRIPTION("Qualcomm Atheros AR803x PHY driver");
112MODULE_AUTHOR("Matus Ujhelyi");
113MODULE_LICENSE("GPL");
114
115struct at803x_priv {
116 int flags;
117 u16 clk_25m_reg;
118 u16 clk_25m_mask;
119 u8 smarteee_lpi_tw_1g;
120 u8 smarteee_lpi_tw_100m;
121 bool is_fiber;
122 bool is_1000basex;
123 struct regulator_dev *vddio_rdev;
124 struct regulator_dev *vddh_rdev;
125};
126
127struct at803x_context {
128 u16 bmcr;
129 u16 advertise;
130 u16 control1000;
131 u16 int_enable;
132 u16 smart_speed;
133 u16 led_control;
134};
135
136static int at803x_write_page(struct phy_device *phydev, int page)
137{
138 int mask;
139 int set;
140
141 if (page == AT803X_PAGE_COPPER) {
142 set = AT803X_BT_BX_REG_SEL;
143 mask = 0;
144 } else {
145 set = 0;
146 mask = AT803X_BT_BX_REG_SEL;
147 }
148
149 return __phy_modify(phydev, AT803X_REG_CHIP_CONFIG, mask, set);
150}
151
152static int at803x_read_page(struct phy_device *phydev)
153{
154 int ccr = __phy_read(phydev, AT803X_REG_CHIP_CONFIG);
155
156 if (ccr < 0)
157 return ccr;
158
159 if (ccr & AT803X_BT_BX_REG_SEL)
160 return AT803X_PAGE_COPPER;
161
162 return AT803X_PAGE_FIBER;
163}
164
165static int at803x_enable_rx_delay(struct phy_device *phydev)
166{
167 return at803x_debug_reg_mask(phydev, AT803X_DEBUG_ANALOG_TEST_CTRL, 0,
168 AT803X_DEBUG_RX_CLK_DLY_EN);
169}
170
171static int at803x_enable_tx_delay(struct phy_device *phydev)
172{
173 return at803x_debug_reg_mask(phydev, AT803X_DEBUG_SYSTEM_CTRL_MODE, 0,
174 AT803X_DEBUG_TX_CLK_DLY_EN);
175}
176
177static int at803x_disable_rx_delay(struct phy_device *phydev)
178{
179 return at803x_debug_reg_mask(phydev, AT803X_DEBUG_ANALOG_TEST_CTRL,
180 AT803X_DEBUG_RX_CLK_DLY_EN, 0);
181}
182
183static int at803x_disable_tx_delay(struct phy_device *phydev)
184{
185 return at803x_debug_reg_mask(phydev, AT803X_DEBUG_SYSTEM_CTRL_MODE,
186 AT803X_DEBUG_TX_CLK_DLY_EN, 0);
187}
188
189/* save relevant PHY registers to private copy */
190static void at803x_context_save(struct phy_device *phydev,
191 struct at803x_context *context)
192{
193 context->bmcr = phy_read(phydev, MII_BMCR);
194 context->advertise = phy_read(phydev, MII_ADVERTISE);
195 context->control1000 = phy_read(phydev, MII_CTRL1000);
196 context->int_enable = phy_read(phydev, AT803X_INTR_ENABLE);
197 context->smart_speed = phy_read(phydev, AT803X_SMART_SPEED);
198 context->led_control = phy_read(phydev, AT803X_LED_CONTROL);
199}
200
201/* restore relevant PHY registers from private copy */
202static void at803x_context_restore(struct phy_device *phydev,
203 const struct at803x_context *context)
204{
205 phy_write(phydev, MII_BMCR, context->bmcr);
206 phy_write(phydev, MII_ADVERTISE, context->advertise);
207 phy_write(phydev, MII_CTRL1000, context->control1000);
208 phy_write(phydev, AT803X_INTR_ENABLE, context->int_enable);
209 phy_write(phydev, AT803X_SMART_SPEED, context->smart_speed);
210 phy_write(phydev, AT803X_LED_CONTROL, context->led_control);
211}
212
213static int at803x_suspend(struct phy_device *phydev)
214{
215 int value;
216 int wol_enabled;
217
218 value = phy_read(phydev, AT803X_INTR_ENABLE);
219 wol_enabled = value & AT803X_INTR_ENABLE_WOL;
220
221 if (wol_enabled)
222 value = BMCR_ISOLATE;
223 else
224 value = BMCR_PDOWN;
225
226 phy_modify(phydev, MII_BMCR, 0, value);
227
228 return 0;
229}
230
231static int at803x_resume(struct phy_device *phydev)
232{
233 return phy_modify(phydev, MII_BMCR, BMCR_PDOWN | BMCR_ISOLATE, 0);
234}
235
236static int at803x_parse_dt(struct phy_device *phydev)
237{
238 struct device_node *node = phydev->mdio.dev.of_node;
239 struct at803x_priv *priv = phydev->priv;
240 u32 freq, strength, tw;
241 unsigned int sel;
242 int ret;
243
244 if (!IS_ENABLED(CONFIG_OF_MDIO))
245 return 0;
246
247 if (of_property_read_bool(node, "qca,disable-smarteee"))
248 priv->flags |= AT803X_DISABLE_SMARTEEE;
249
250 if (of_property_read_bool(node, "qca,disable-hibernation-mode"))
251 priv->flags |= AT803X_DISABLE_HIBERNATION_MODE;
252
253 if (!of_property_read_u32(node, "qca,smarteee-tw-us-1g", &tw)) {
254 if (!tw || tw > 255) {
255 phydev_err(phydev, "invalid qca,smarteee-tw-us-1g\n");
256 return -EINVAL;
257 }
258 priv->smarteee_lpi_tw_1g = tw;
259 }
260
261 if (!of_property_read_u32(node, "qca,smarteee-tw-us-100m", &tw)) {
262 if (!tw || tw > 255) {
263 phydev_err(phydev, "invalid qca,smarteee-tw-us-100m\n");
264 return -EINVAL;
265 }
266 priv->smarteee_lpi_tw_100m = tw;
267 }
268
269 ret = of_property_read_u32(node, "qca,clk-out-frequency", &freq);
270 if (!ret) {
271 switch (freq) {
272 case 25000000:
273 sel = AT803X_CLK_OUT_25MHZ_XTAL;
274 break;
275 case 50000000:
276 sel = AT803X_CLK_OUT_50MHZ_PLL;
277 break;
278 case 62500000:
279 sel = AT803X_CLK_OUT_62_5MHZ_PLL;
280 break;
281 case 125000000:
282 sel = AT803X_CLK_OUT_125MHZ_PLL;
283 break;
284 default:
285 phydev_err(phydev, "invalid qca,clk-out-frequency\n");
286 return -EINVAL;
287 }
288
289 priv->clk_25m_reg |= FIELD_PREP(AT803X_CLK_OUT_MASK, sel);
290 priv->clk_25m_mask |= AT803X_CLK_OUT_MASK;
291 }
292
293 ret = of_property_read_u32(node, "qca,clk-out-strength", &strength);
294 if (!ret) {
295 priv->clk_25m_mask |= AT803X_CLK_OUT_STRENGTH_MASK;
296 switch (strength) {
297 case AR803X_STRENGTH_FULL:
298 priv->clk_25m_reg |= AT803X_CLK_OUT_STRENGTH_FULL;
299 break;
300 case AR803X_STRENGTH_HALF:
301 priv->clk_25m_reg |= AT803X_CLK_OUT_STRENGTH_HALF;
302 break;
303 case AR803X_STRENGTH_QUARTER:
304 priv->clk_25m_reg |= AT803X_CLK_OUT_STRENGTH_QUARTER;
305 break;
306 default:
307 phydev_err(phydev, "invalid qca,clk-out-strength\n");
308 return -EINVAL;
309 }
310 }
311
312 return 0;
313}
314
315static int at803x_probe(struct phy_device *phydev)
316{
317 struct device *dev = &phydev->mdio.dev;
318 struct at803x_priv *priv;
319 int ret;
320
321 priv = devm_kzalloc(dev, sizeof(*priv), GFP_KERNEL);
322 if (!priv)
323 return -ENOMEM;
324
325 phydev->priv = priv;
326
327 ret = at803x_parse_dt(phydev);
328 if (ret)
329 return ret;
330
331 return 0;
332}
333
334static int at803x_get_features(struct phy_device *phydev)
335{
336 struct at803x_priv *priv = phydev->priv;
337 int err;
338
339 err = genphy_read_abilities(phydev);
340 if (err)
341 return err;
342
343 if (phydev->drv->phy_id != ATH8031_PHY_ID)
344 return 0;
345
346 /* AR8031/AR8033 have different status registers
347 * for copper and fiber operation. However, the
348 * extended status register is the same for both
349 * operation modes.
350 *
351 * As a result of that, ESTATUS_1000_XFULL is set
352 * to 1 even when operating in copper TP mode.
353 *
354 * Remove this mode from the supported link modes
355 * when not operating in 1000BaseX mode.
356 */
357 if (!priv->is_1000basex)
358 linkmode_clear_bit(ETHTOOL_LINK_MODE_1000baseX_Full_BIT,
359 phydev->supported);
360
361 return 0;
362}
363
364static int at803x_smarteee_config(struct phy_device *phydev)
365{
366 struct at803x_priv *priv = phydev->priv;
367 u16 mask = 0, val = 0;
368 int ret;
369
370 if (priv->flags & AT803X_DISABLE_SMARTEEE)
371 return phy_modify_mmd(phydev, MDIO_MMD_PCS,
372 AT803X_MMD3_SMARTEEE_CTL3,
373 AT803X_MMD3_SMARTEEE_CTL3_LPI_EN, 0);
374
375 if (priv->smarteee_lpi_tw_1g) {
376 mask |= 0xff00;
377 val |= priv->smarteee_lpi_tw_1g << 8;
378 }
379 if (priv->smarteee_lpi_tw_100m) {
380 mask |= 0x00ff;
381 val |= priv->smarteee_lpi_tw_100m;
382 }
383 if (!mask)
384 return 0;
385
386 ret = phy_modify_mmd(phydev, MDIO_MMD_PCS, AT803X_MMD3_SMARTEEE_CTL1,
387 mask, val);
388 if (ret)
389 return ret;
390
391 return phy_modify_mmd(phydev, MDIO_MMD_PCS, AT803X_MMD3_SMARTEEE_CTL3,
392 AT803X_MMD3_SMARTEEE_CTL3_LPI_EN,
393 AT803X_MMD3_SMARTEEE_CTL3_LPI_EN);
394}
395
396static int at803x_clk_out_config(struct phy_device *phydev)
397{
398 struct at803x_priv *priv = phydev->priv;
399
400 if (!priv->clk_25m_mask)
401 return 0;
402
403 return phy_modify_mmd(phydev, MDIO_MMD_AN, AT803X_MMD7_CLK25M,
404 priv->clk_25m_mask, priv->clk_25m_reg);
405}
406
407static int at8031_pll_config(struct phy_device *phydev)
408{
409 struct at803x_priv *priv = phydev->priv;
410
411 /* The default after hardware reset is PLL OFF. After a soft reset, the
412 * values are retained.
413 */
414 if (priv->flags & AT803X_KEEP_PLL_ENABLED)
415 return at803x_debug_reg_mask(phydev, AT803X_DEBUG_REG_1F,
416 0, AT803X_DEBUG_PLL_ON);
417 else
418 return at803x_debug_reg_mask(phydev, AT803X_DEBUG_REG_1F,
419 AT803X_DEBUG_PLL_ON, 0);
420}
421
422static int at803x_hibernation_mode_config(struct phy_device *phydev)
423{
424 struct at803x_priv *priv = phydev->priv;
425
426 /* The default after hardware reset is hibernation mode enabled. After
427 * software reset, the value is retained.
428 */
429 if (!(priv->flags & AT803X_DISABLE_HIBERNATION_MODE))
430 return 0;
431
432 return at803x_debug_reg_mask(phydev, AT803X_DEBUG_REG_HIB_CTRL,
433 AT803X_DEBUG_HIB_CTRL_PS_HIB_EN, 0);
434}
435
436static int at803x_config_init(struct phy_device *phydev)
437{
438 int ret;
439
440 /* The RX and TX delay default is:
441 * after HW reset: RX delay enabled and TX delay disabled
442 * after SW reset: RX delay enabled, while TX delay retains the
443 * value before reset.
444 */
445 if (phydev->interface == PHY_INTERFACE_MODE_RGMII_ID ||
446 phydev->interface == PHY_INTERFACE_MODE_RGMII_RXID)
447 ret = at803x_enable_rx_delay(phydev);
448 else
449 ret = at803x_disable_rx_delay(phydev);
450 if (ret < 0)
451 return ret;
452
453 if (phydev->interface == PHY_INTERFACE_MODE_RGMII_ID ||
454 phydev->interface == PHY_INTERFACE_MODE_RGMII_TXID)
455 ret = at803x_enable_tx_delay(phydev);
456 else
457 ret = at803x_disable_tx_delay(phydev);
458 if (ret < 0)
459 return ret;
460
461 ret = at803x_smarteee_config(phydev);
462 if (ret < 0)
463 return ret;
464
465 ret = at803x_clk_out_config(phydev);
466 if (ret < 0)
467 return ret;
468
469 ret = at803x_hibernation_mode_config(phydev);
470 if (ret < 0)
471 return ret;
472
473 /* Ar803x extended next page bit is enabled by default. Cisco
474 * multigig switches read this bit and attempt to negotiate 10Gbps
475 * rates even if the next page bit is disabled. This is incorrect
476 * behaviour but we still need to accommodate it. XNP is only needed
477 * for 10Gbps support, so disable XNP.
478 */
479 return phy_modify(phydev, MII_ADVERTISE, MDIO_AN_CTRL1_XNP, 0);
480}
481
482static void at803x_link_change_notify(struct phy_device *phydev)
483{
484 /*
485 * Conduct a hardware reset for AT8030 every time a link loss is
486 * signalled. This is necessary to circumvent a hardware bug that
487 * occurs when the cable is unplugged while TX packets are pending
488 * in the FIFO. In such cases, the FIFO enters an error mode it
489 * cannot recover from by software.
490 */
491 if (phydev->state == PHY_NOLINK && phydev->mdio.reset_gpio) {
492 struct at803x_context context;
493
494 at803x_context_save(phydev, &context);
495
496 phy_device_reset(phydev, 1);
497 usleep_range(1000, 2000);
498 phy_device_reset(phydev, 0);
499 usleep_range(1000, 2000);
500
501 at803x_context_restore(phydev, &context);
502
503 phydev_dbg(phydev, "%s(): phy was reset\n", __func__);
504 }
505}
506
507static int at803x_config_aneg(struct phy_device *phydev)
508{
509 struct at803x_priv *priv = phydev->priv;
510 int ret;
511
512 ret = at803x_prepare_config_aneg(phydev);
513 if (ret)
514 return ret;
515
516 if (priv->is_1000basex)
517 return genphy_c37_config_aneg(phydev);
518
519 return genphy_config_aneg(phydev);
520}
521
522static int at803x_cable_test_result_trans(u16 status)
523{
524 switch (FIELD_GET(AT803X_CDT_STATUS_STAT_MASK, status)) {
525 case AT803X_CDT_STATUS_STAT_NORMAL:
526 return ETHTOOL_A_CABLE_RESULT_CODE_OK;
527 case AT803X_CDT_STATUS_STAT_SHORT:
528 return ETHTOOL_A_CABLE_RESULT_CODE_SAME_SHORT;
529 case AT803X_CDT_STATUS_STAT_OPEN:
530 return ETHTOOL_A_CABLE_RESULT_CODE_OPEN;
531 case AT803X_CDT_STATUS_STAT_FAIL:
532 default:
533 return ETHTOOL_A_CABLE_RESULT_CODE_UNSPEC;
534 }
535}
536
537static bool at803x_cdt_test_failed(u16 status)
538{
539 return FIELD_GET(AT803X_CDT_STATUS_STAT_MASK, status) ==
540 AT803X_CDT_STATUS_STAT_FAIL;
541}
542
543static bool at803x_cdt_fault_length_valid(u16 status)
544{
545 switch (FIELD_GET(AT803X_CDT_STATUS_STAT_MASK, status)) {
546 case AT803X_CDT_STATUS_STAT_OPEN:
547 case AT803X_CDT_STATUS_STAT_SHORT:
548 return true;
549 }
550 return false;
551}
552
553static int at803x_cable_test_one_pair(struct phy_device *phydev, int pair)
554{
555 static const int ethtool_pair[] = {
556 ETHTOOL_A_CABLE_PAIR_A,
557 ETHTOOL_A_CABLE_PAIR_B,
558 ETHTOOL_A_CABLE_PAIR_C,
559 ETHTOOL_A_CABLE_PAIR_D,
560 };
561 int ret, val;
562
563 val = FIELD_PREP(AT803X_CDT_MDI_PAIR_MASK, pair) |
564 AT803X_CDT_ENABLE_TEST;
565 ret = at803x_cdt_start(phydev, val);
566 if (ret)
567 return ret;
568
569 ret = at803x_cdt_wait_for_completion(phydev, AT803X_CDT_ENABLE_TEST);
570 if (ret)
571 return ret;
572
573 val = phy_read(phydev, AT803X_CDT_STATUS);
574 if (val < 0)
575 return val;
576
577 if (at803x_cdt_test_failed(val))
578 return 0;
579
580 ethnl_cable_test_result(phydev, ethtool_pair[pair],
581 at803x_cable_test_result_trans(val));
582
583 if (at803x_cdt_fault_length_valid(val)) {
584 val = FIELD_GET(AT803X_CDT_STATUS_DELTA_TIME_MASK, val);
585 ethnl_cable_test_fault_length(phydev, ethtool_pair[pair],
586 at803x_cdt_fault_length(val));
587 }
588
589 return 1;
590}
591
592static int at803x_cable_test_get_status(struct phy_device *phydev,
593 bool *finished, unsigned long pair_mask)
594{
595 int retries = 20;
596 int pair, ret;
597
598 *finished = false;
599
600 /* According to the datasheet the CDT can be performed when
601 * there is no link partner or when the link partner is
602 * auto-negotiating. Starting the test will restart the AN
603 * automatically. It seems that doing this repeatedly we will
604 * get a slot where our link partner won't disturb our
605 * measurement.
606 */
607 while (pair_mask && retries--) {
608 for_each_set_bit(pair, &pair_mask, 4) {
609 ret = at803x_cable_test_one_pair(phydev, pair);
610 if (ret < 0)
611 return ret;
612 if (ret)
613 clear_bit(pair, &pair_mask);
614 }
615 if (pair_mask)
616 msleep(250);
617 }
618
619 *finished = true;
620
621 return 0;
622}
623
624static void at803x_cable_test_autoneg(struct phy_device *phydev)
625{
626 /* Enable auto-negotiation, but advertise no capabilities, no link
627 * will be established. A restart of the auto-negotiation is not
628 * required, because the cable test will automatically break the link.
629 */
630 phy_write(phydev, MII_BMCR, BMCR_ANENABLE);
631 phy_write(phydev, MII_ADVERTISE, ADVERTISE_CSMA);
632}
633
634static int at803x_cable_test_start(struct phy_device *phydev)
635{
636 at803x_cable_test_autoneg(phydev);
637 /* we do all the (time consuming) work later */
638 return 0;
639}
640
641static int at8031_rgmii_reg_set_voltage_sel(struct regulator_dev *rdev,
642 unsigned int selector)
643{
644 struct phy_device *phydev = rdev_get_drvdata(rdev);
645
646 if (selector)
647 return at803x_debug_reg_mask(phydev, AT803X_DEBUG_REG_1F,
648 0, AT803X_DEBUG_RGMII_1V8);
649 else
650 return at803x_debug_reg_mask(phydev, AT803X_DEBUG_REG_1F,
651 AT803X_DEBUG_RGMII_1V8, 0);
652}
653
654static int at8031_rgmii_reg_get_voltage_sel(struct regulator_dev *rdev)
655{
656 struct phy_device *phydev = rdev_get_drvdata(rdev);
657 int val;
658
659 val = at803x_debug_reg_read(phydev, AT803X_DEBUG_REG_1F);
660 if (val < 0)
661 return val;
662
663 return (val & AT803X_DEBUG_RGMII_1V8) ? 1 : 0;
664}
665
666static const struct regulator_ops vddio_regulator_ops = {
667 .list_voltage = regulator_list_voltage_table,
668 .set_voltage_sel = at8031_rgmii_reg_set_voltage_sel,
669 .get_voltage_sel = at8031_rgmii_reg_get_voltage_sel,
670};
671
672static const unsigned int vddio_voltage_table[] = {
673 1500000,
674 1800000,
675};
676
677static const struct regulator_desc vddio_desc = {
678 .name = "vddio",
679 .of_match = of_match_ptr("vddio-regulator"),
680 .n_voltages = ARRAY_SIZE(vddio_voltage_table),
681 .volt_table = vddio_voltage_table,
682 .ops = &vddio_regulator_ops,
683 .type = REGULATOR_VOLTAGE,
684 .owner = THIS_MODULE,
685};
686
687static const struct regulator_ops vddh_regulator_ops = {
688};
689
690static const struct regulator_desc vddh_desc = {
691 .name = "vddh",
692 .of_match = of_match_ptr("vddh-regulator"),
693 .n_voltages = 1,
694 .fixed_uV = 2500000,
695 .ops = &vddh_regulator_ops,
696 .type = REGULATOR_VOLTAGE,
697 .owner = THIS_MODULE,
698};
699
700static int at8031_register_regulators(struct phy_device *phydev)
701{
702 struct at803x_priv *priv = phydev->priv;
703 struct device *dev = &phydev->mdio.dev;
704 struct regulator_config config = { };
705
706 config.dev = dev;
707 config.driver_data = phydev;
708
709 priv->vddio_rdev = devm_regulator_register(dev, &vddio_desc, &config);
710 if (IS_ERR(priv->vddio_rdev)) {
711 phydev_err(phydev, "failed to register VDDIO regulator\n");
712 return PTR_ERR(priv->vddio_rdev);
713 }
714
715 priv->vddh_rdev = devm_regulator_register(dev, &vddh_desc, &config);
716 if (IS_ERR(priv->vddh_rdev)) {
717 phydev_err(phydev, "failed to register VDDH regulator\n");
718 return PTR_ERR(priv->vddh_rdev);
719 }
720
721 return 0;
722}
723
724static int at8031_sfp_insert(void *upstream, const struct sfp_eeprom_id *id)
725{
726 struct phy_device *phydev = upstream;
727 __ETHTOOL_DECLARE_LINK_MODE_MASK(phy_support);
728 __ETHTOOL_DECLARE_LINK_MODE_MASK(sfp_support);
729 DECLARE_PHY_INTERFACE_MASK(interfaces);
730 phy_interface_t iface;
731
732 linkmode_zero(phy_support);
733 phylink_set(phy_support, 1000baseX_Full);
734 phylink_set(phy_support, 1000baseT_Full);
735 phylink_set(phy_support, Autoneg);
736 phylink_set(phy_support, Pause);
737 phylink_set(phy_support, Asym_Pause);
738
739 linkmode_zero(sfp_support);
740 sfp_parse_support(phydev->sfp_bus, id, sfp_support, interfaces);
741 /* Some modules support 10G modes as well as others we support.
742 * Mask out non-supported modes so the correct interface is picked.
743 */
744 linkmode_and(sfp_support, phy_support, sfp_support);
745
746 if (linkmode_empty(sfp_support)) {
747 dev_err(&phydev->mdio.dev, "incompatible SFP module inserted\n");
748 return -EINVAL;
749 }
750
751 iface = sfp_select_interface(phydev->sfp_bus, sfp_support);
752
753 /* Only 1000Base-X is supported by AR8031/8033 as the downstream SerDes
754 * interface for use with SFP modules.
755 * However, some copper modules detected as having a preferred SGMII
756 * interface do default to and function in 1000Base-X mode, so just
757 * print a warning and allow such modules, as they may have some chance
758 * of working.
759 */
760 if (iface == PHY_INTERFACE_MODE_SGMII)
761 dev_warn(&phydev->mdio.dev, "module may not function if 1000Base-X not supported\n");
762 else if (iface != PHY_INTERFACE_MODE_1000BASEX)
763 return -EINVAL;
764
765 return 0;
766}
767
768static const struct sfp_upstream_ops at8031_sfp_ops = {
769 .attach = phy_sfp_attach,
770 .detach = phy_sfp_detach,
771 .module_insert = at8031_sfp_insert,
772};
773
774static int at8031_parse_dt(struct phy_device *phydev)
775{
776 struct device_node *node = phydev->mdio.dev.of_node;
777 struct at803x_priv *priv = phydev->priv;
778 int ret;
779
780 if (of_property_read_bool(node, "qca,keep-pll-enabled"))
781 priv->flags |= AT803X_KEEP_PLL_ENABLED;
782
783 ret = at8031_register_regulators(phydev);
784 if (ret < 0)
785 return ret;
786
787 ret = devm_regulator_get_enable_optional(&phydev->mdio.dev,
788 "vddio");
789 if (ret) {
790 phydev_err(phydev, "failed to get VDDIO regulator\n");
791 return ret;
792 }
793
794 /* Only AR8031/8033 support 1000Base-X for SFP modules */
795 return phy_sfp_probe(phydev, &at8031_sfp_ops);
796}
797
798static int at8031_probe(struct phy_device *phydev)
799{
800 struct at803x_priv *priv = phydev->priv;
801 int mode_cfg;
802 int ccr;
803 int ret;
804
805 ret = at803x_probe(phydev);
806 if (ret)
807 return ret;
808
809 /* Only supported on AR8031/AR8033, the AR8030/AR8035 use strapping
810 * options.
811 */
812 ret = at8031_parse_dt(phydev);
813 if (ret)
814 return ret;
815
816 ccr = phy_read(phydev, AT803X_REG_CHIP_CONFIG);
817 if (ccr < 0)
818 return ccr;
819 mode_cfg = ccr & AT803X_MODE_CFG_MASK;
820
821 switch (mode_cfg) {
822 case AT803X_MODE_CFG_BX1000_RGMII_50OHM:
823 case AT803X_MODE_CFG_BX1000_RGMII_75OHM:
824 priv->is_1000basex = true;
825 fallthrough;
826 case AT803X_MODE_CFG_FX100_RGMII_50OHM:
827 case AT803X_MODE_CFG_FX100_RGMII_75OHM:
828 priv->is_fiber = true;
829 break;
830 }
831
832 /* Disable WoL in 1588 register which is enabled
833 * by default
834 */
835 return phy_modify_mmd(phydev, MDIO_MMD_PCS,
836 AT803X_PHY_MMD3_WOL_CTRL,
837 AT803X_WOL_EN, 0);
838}
839
840static int at8031_config_init(struct phy_device *phydev)
841{
842 struct at803x_priv *priv = phydev->priv;
843 int ret;
844
845 /* Some bootloaders leave the fiber page selected.
846 * Switch to the appropriate page (fiber or copper), as otherwise we
847 * read the PHY capabilities from the wrong page.
848 */
849 phy_lock_mdio_bus(phydev);
850 ret = at803x_write_page(phydev,
851 priv->is_fiber ? AT803X_PAGE_FIBER :
852 AT803X_PAGE_COPPER);
853 phy_unlock_mdio_bus(phydev);
854 if (ret)
855 return ret;
856
857 ret = at8031_pll_config(phydev);
858 if (ret < 0)
859 return ret;
860
861 return at803x_config_init(phydev);
862}
863
864static int at8031_set_wol(struct phy_device *phydev,
865 struct ethtool_wolinfo *wol)
866{
867 int ret;
868
869 /* First setup MAC address and enable WOL interrupt */
870 ret = at803x_set_wol(phydev, wol);
871 if (ret)
872 return ret;
873
874 if (wol->wolopts & WAKE_MAGIC)
875 /* Enable WOL function for 1588 */
876 ret = phy_modify_mmd(phydev, MDIO_MMD_PCS,
877 AT803X_PHY_MMD3_WOL_CTRL,
878 0, AT803X_WOL_EN);
879 else
880 /* Disable WoL function for 1588 */
881 ret = phy_modify_mmd(phydev, MDIO_MMD_PCS,
882 AT803X_PHY_MMD3_WOL_CTRL,
883 AT803X_WOL_EN, 0);
884
885 return ret;
886}
887
888static int at8031_config_intr(struct phy_device *phydev)
889{
890 struct at803x_priv *priv = phydev->priv;
891 int err, value = 0;
892
893 if (phydev->interrupts == PHY_INTERRUPT_ENABLED &&
894 priv->is_fiber) {
895 /* Clear any pending interrupts */
896 err = at803x_ack_interrupt(phydev);
897 if (err)
898 return err;
899
900 value |= AT803X_INTR_ENABLE_LINK_FAIL_BX;
901 value |= AT803X_INTR_ENABLE_LINK_SUCCESS_BX;
902
903 err = phy_set_bits(phydev, AT803X_INTR_ENABLE, value);
904 if (err)
905 return err;
906 }
907
908 return at803x_config_intr(phydev);
909}
910
911/* AR8031 and AR8033 share the same read status logic */
912static int at8031_read_status(struct phy_device *phydev)
913{
914 struct at803x_priv *priv = phydev->priv;
915 bool changed;
916
917 if (priv->is_1000basex)
918 return genphy_c37_read_status(phydev, &changed);
919
920 return at803x_read_status(phydev);
921}
922
923/* AR8031 and AR8035 share the same cable test get status reg */
924static int at8031_cable_test_get_status(struct phy_device *phydev,
925 bool *finished)
926{
927 return at803x_cable_test_get_status(phydev, finished, 0xf);
928}
929
930/* AR8031 and AR8035 share the same cable test start logic */
931static int at8031_cable_test_start(struct phy_device *phydev)
932{
933 at803x_cable_test_autoneg(phydev);
934 phy_write(phydev, MII_CTRL1000, 0);
935 /* we do all the (time consuming) work later */
936 return 0;
937}
938
939/* AR8032, AR9331 and QCA9561 share the same cable test get status reg */
940static int at8032_cable_test_get_status(struct phy_device *phydev,
941 bool *finished)
942{
943 return at803x_cable_test_get_status(phydev, finished, 0x3);
944}
945
946static int at8035_parse_dt(struct phy_device *phydev)
947{
948 struct at803x_priv *priv = phydev->priv;
949
950 /* Mask is set by the generic at803x_parse_dt
951 * if property is set. Assume property is set
952 * with the mask not zero.
953 */
954 if (priv->clk_25m_mask) {
955 /* Fixup for the AR8030/AR8035. This chip has another mask and
956 * doesn't support the DSP reference. Eg. the lowest bit of the
957 * mask. The upper two bits select the same frequencies. Mask
958 * the lowest bit here.
959 *
960 * Warning:
961 * There was no datasheet for the AR8030 available so this is
962 * just a guess. But the AR8035 is listed as pin compatible
963 * to the AR8030 so there might be a good chance it works on
964 * the AR8030 too.
965 */
966 priv->clk_25m_reg &= AT8035_CLK_OUT_MASK;
967 priv->clk_25m_mask &= AT8035_CLK_OUT_MASK;
968 }
969
970 return 0;
971}
972
973/* AR8030 and AR8035 shared the same special mask for clk_25m */
974static int at8035_probe(struct phy_device *phydev)
975{
976 int ret;
977
978 ret = at803x_probe(phydev);
979 if (ret)
980 return ret;
981
982 return at8035_parse_dt(phydev);
983}
984
985static struct phy_driver at803x_driver[] = {
986{
987 /* Qualcomm Atheros AR8035 */
988 PHY_ID_MATCH_EXACT(ATH8035_PHY_ID),
989 .name = "Qualcomm Atheros AR8035",
990 .flags = PHY_POLL_CABLE_TEST,
991 .probe = at8035_probe,
992 .config_aneg = at803x_config_aneg,
993 .config_init = at803x_config_init,
994 .soft_reset = genphy_soft_reset,
995 .set_wol = at803x_set_wol,
996 .get_wol = at803x_get_wol,
997 .suspend = at803x_suspend,
998 .resume = at803x_resume,
999 /* PHY_GBIT_FEATURES */
1000 .read_status = at803x_read_status,
1001 .config_intr = at803x_config_intr,
1002 .handle_interrupt = at803x_handle_interrupt,
1003 .get_tunable = at803x_get_tunable,
1004 .set_tunable = at803x_set_tunable,
1005 .cable_test_start = at8031_cable_test_start,
1006 .cable_test_get_status = at8031_cable_test_get_status,
1007}, {
1008 /* Qualcomm Atheros AR8030 */
1009 .phy_id = ATH8030_PHY_ID,
1010 .name = "Qualcomm Atheros AR8030",
1011 .phy_id_mask = AT8030_PHY_ID_MASK,
1012 .probe = at8035_probe,
1013 .config_init = at803x_config_init,
1014 .link_change_notify = at803x_link_change_notify,
1015 .set_wol = at803x_set_wol,
1016 .get_wol = at803x_get_wol,
1017 .suspend = at803x_suspend,
1018 .resume = at803x_resume,
1019 /* PHY_BASIC_FEATURES */
1020 .config_intr = at803x_config_intr,
1021 .handle_interrupt = at803x_handle_interrupt,
1022}, {
1023 /* Qualcomm Atheros AR8031/AR8033 */
1024 PHY_ID_MATCH_EXACT(ATH8031_PHY_ID),
1025 .name = "Qualcomm Atheros AR8031/AR8033",
1026 .flags = PHY_POLL_CABLE_TEST,
1027 .probe = at8031_probe,
1028 .config_init = at8031_config_init,
1029 .config_aneg = at803x_config_aneg,
1030 .soft_reset = genphy_soft_reset,
1031 .set_wol = at8031_set_wol,
1032 .get_wol = at803x_get_wol,
1033 .suspend = at803x_suspend,
1034 .resume = at803x_resume,
1035 .read_page = at803x_read_page,
1036 .write_page = at803x_write_page,
1037 .get_features = at803x_get_features,
1038 .read_status = at8031_read_status,
1039 .config_intr = at8031_config_intr,
1040 .handle_interrupt = at803x_handle_interrupt,
1041 .get_tunable = at803x_get_tunable,
1042 .set_tunable = at803x_set_tunable,
1043 .cable_test_start = at8031_cable_test_start,
1044 .cable_test_get_status = at8031_cable_test_get_status,
1045}, {
1046 /* Qualcomm Atheros AR8032 */
1047 PHY_ID_MATCH_EXACT(ATH8032_PHY_ID),
1048 .name = "Qualcomm Atheros AR8032",
1049 .probe = at803x_probe,
1050 .flags = PHY_POLL_CABLE_TEST,
1051 .config_init = at803x_config_init,
1052 .link_change_notify = at803x_link_change_notify,
1053 .suspend = at803x_suspend,
1054 .resume = at803x_resume,
1055 /* PHY_BASIC_FEATURES */
1056 .config_intr = at803x_config_intr,
1057 .handle_interrupt = at803x_handle_interrupt,
1058 .cable_test_start = at803x_cable_test_start,
1059 .cable_test_get_status = at8032_cable_test_get_status,
1060}, {
1061 /* ATHEROS AR9331 */
1062 PHY_ID_MATCH_EXACT(ATH9331_PHY_ID),
1063 .name = "Qualcomm Atheros AR9331 built-in PHY",
1064 .probe = at803x_probe,
1065 .suspend = at803x_suspend,
1066 .resume = at803x_resume,
1067 .flags = PHY_POLL_CABLE_TEST,
1068 /* PHY_BASIC_FEATURES */
1069 .config_intr = at803x_config_intr,
1070 .handle_interrupt = at803x_handle_interrupt,
1071 .cable_test_start = at803x_cable_test_start,
1072 .cable_test_get_status = at8032_cable_test_get_status,
1073 .read_status = at803x_read_status,
1074 .soft_reset = genphy_soft_reset,
1075 .config_aneg = at803x_config_aneg,
1076}, {
1077 /* Qualcomm Atheros QCA9561 */
1078 PHY_ID_MATCH_EXACT(QCA9561_PHY_ID),
1079 .name = "Qualcomm Atheros QCA9561 built-in PHY",
1080 .probe = at803x_probe,
1081 .suspend = at803x_suspend,
1082 .resume = at803x_resume,
1083 .flags = PHY_POLL_CABLE_TEST,
1084 /* PHY_BASIC_FEATURES */
1085 .config_intr = at803x_config_intr,
1086 .handle_interrupt = at803x_handle_interrupt,
1087 .cable_test_start = at803x_cable_test_start,
1088 .cable_test_get_status = at8032_cable_test_get_status,
1089 .read_status = at803x_read_status,
1090 .soft_reset = genphy_soft_reset,
1091 .config_aneg = at803x_config_aneg,
1092}, };
1093
1094module_phy_driver(at803x_driver);
1095
1096static struct mdio_device_id __maybe_unused atheros_tbl[] = {
1097 { ATH8030_PHY_ID, AT8030_PHY_ID_MASK },
1098 { PHY_ID_MATCH_EXACT(ATH8031_PHY_ID) },
1099 { PHY_ID_MATCH_EXACT(ATH8032_PHY_ID) },
1100 { PHY_ID_MATCH_EXACT(ATH8035_PHY_ID) },
1101 { PHY_ID_MATCH_EXACT(ATH9331_PHY_ID) },
1102 { PHY_ID_MATCH_EXACT(QCA9561_PHY_ID) },
1103 { }
1104};
1105
1106MODULE_DEVICE_TABLE(mdio, atheros_tbl);