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 111 MODULE_DESCRIPTION("Qualcomm Atheros AR803x PHY driver"); 112 MODULE_AUTHOR("Matus Ujhelyi"); 113 MODULE_LICENSE("GPL"); 114 115 struct 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 127 struct 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 136 static 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 152 static 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 165 static 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 171 static 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 177 static 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 183 static 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 */ 190 static 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 */ 202 static 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 213 static 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 231 static int at803x_resume(struct phy_device *phydev) 232 { 233 return phy_modify(phydev, MII_BMCR, BMCR_PDOWN | BMCR_ISOLATE, 0); 234 } 235 236 static 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 315 static 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 334 static 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 364 static 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 396 static 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 407 static 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 422 static 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 436 static 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 482 static 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 507 static 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 522 static 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 537 static 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 543 static 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 553 static 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 592 static 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 624 static 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 634 static 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 641 static 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 654 static 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 666 static 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 672 static const unsigned int vddio_voltage_table[] = { 673 1500000, 674 1800000, 675 }; 676 677 static 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 687 static const struct regulator_ops vddh_regulator_ops = { 688 }; 689 690 static 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 700 static 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 724 static 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 768 static 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 774 static 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 798 static 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 840 static 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 864 static 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 888 static 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 */ 912 static 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 */ 924 static 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 */ 931 static 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 */ 940 static 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 946 static 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 */ 974 static 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 985 static 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 1094 module_phy_driver(at803x_driver); 1095 1096 static 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 1106 MODULE_DEVICE_TABLE(mdio, atheros_tbl); 1107