Lines Matching +full:lynx +full:- +full:28 +full:g

1 // SPDX-License-Identifier: GPL-2.0+
2 /* Copyright (c) 2021-2022 NXP. */
24 #define LYNX_28G_LNa_PCC_OFFSET(lane) (4 * (LYNX_28G_NUM_LANE - (lane->id) - 1))
40 #define LYNX_28G_PLLnCR1_FRATE_SEL(cr1) (((cr1) & GENMASK(28, 24)))
64 #define LYNX_28G_LNaTGCR0_USE_PLLS BIT(28)
65 #define LYNX_28G_LNaTGCR0_USE_PLL_MSK BIT(28)
83 #define LYNX_28G_LNaRGCR0_USE_PLLS BIT(28)
84 #define LYNX_28G_LNaRGCR0_USE_PLL_MSK BIT(28)
143 void __iomem *reg = priv->base + off; in lynx_28g_rmw()
153 lynx_28g_rmw((lane)->priv, LYNX_28G_##reg(lane->id), \
156 ioread32((lane)->priv->base + LYNX_28G_##reg((lane)->id))
158 ioread32((pll)->priv->base + LYNX_28G_##reg((pll)->id))
165 if (LYNX_28G_PLLnRSTCTL_DIS(priv->pll[i].rstctl)) in lynx_28g_supports_interface()
168 if (test_bit(intf, priv->pll[i].supported)) in lynx_28g_supports_interface()
182 pll = &priv->pll[i]; in lynx_28g_pll_get()
184 if (LYNX_28G_PLLnRSTCTL_DIS(pll->rstctl)) in lynx_28g_pll_get()
187 if (test_bit(intf, pll->supported)) in lynx_28g_pll_get()
198 switch (LYNX_28G_PLLnCR1_FRATE_SEL(pll->cr1)) { in lynx_28g_lane_set_nrate()
230 if (pll->id == 0) { in lynx_28g_lane_set_pll()
242 struct lynx_28g_priv *priv = lane->priv; in lynx_28g_cleanup_lane()
245 switch (lane->interface) { in lynx_28g_cleanup_lane()
265 struct lynx_28g_priv *priv = lane->priv; in lynx_28g_lane_set_sgmii()
290 iowrite32(0x00808006, priv->base + LYNX_28G_LNaTECR0(lane->id)); in lynx_28g_lane_set_sgmii()
291 iowrite32(0x04310000, priv->base + LYNX_28G_LNaRGCR1(lane->id)); in lynx_28g_lane_set_sgmii()
292 iowrite32(0x9f800000, priv->base + LYNX_28G_LNaRECR0(lane->id)); in lynx_28g_lane_set_sgmii()
293 iowrite32(0x001f0000, priv->base + LYNX_28G_LNaRECR1(lane->id)); in lynx_28g_lane_set_sgmii()
294 iowrite32(0x00000000, priv->base + LYNX_28G_LNaRECR2(lane->id)); in lynx_28g_lane_set_sgmii()
295 iowrite32(0x00000000, priv->base + LYNX_28G_LNaRSCCR0(lane->id)); in lynx_28g_lane_set_sgmii()
301 struct lynx_28g_priv *priv = lane->priv; in lynx_28g_lane_set_10gbaser()
326 iowrite32(0x10808307, priv->base + LYNX_28G_LNaTECR0(lane->id)); in lynx_28g_lane_set_10gbaser()
327 iowrite32(0x10000000, priv->base + LYNX_28G_LNaRGCR1(lane->id)); in lynx_28g_lane_set_10gbaser()
328 iowrite32(0x00000000, priv->base + LYNX_28G_LNaRECR0(lane->id)); in lynx_28g_lane_set_10gbaser()
329 iowrite32(0x001f0000, priv->base + LYNX_28G_LNaRECR1(lane->id)); in lynx_28g_lane_set_10gbaser()
330 iowrite32(0x81000020, priv->base + LYNX_28G_LNaRECR2(lane->id)); in lynx_28g_lane_set_10gbaser()
331 iowrite32(0x00002000, priv->base + LYNX_28G_LNaRSCCR0(lane->id)); in lynx_28g_lane_set_10gbaser()
339 if (!lane->powered_up) in lynx_28g_power_off()
353 lane->powered_up = false; in lynx_28g_power_off()
363 if (lane->powered_up) in lynx_28g_power_on()
377 lane->powered_up = true; in lynx_28g_power_on()
385 struct lynx_28g_priv *priv = lane->priv; in lynx_28g_set_mode()
386 int powered_up = lane->powered_up; in lynx_28g_set_mode()
390 return -EOPNOTSUPP; in lynx_28g_set_mode()
392 if (lane->interface == PHY_INTERFACE_MODE_NA) in lynx_28g_set_mode()
393 return -EOPNOTSUPP; in lynx_28g_set_mode()
396 return -EOPNOTSUPP; in lynx_28g_set_mode()
404 spin_lock(&priv->pcc_lock); in lynx_28g_set_mode()
415 err = -EOPNOTSUPP; in lynx_28g_set_mode()
419 lane->interface = submode; in lynx_28g_set_mode()
422 spin_unlock(&priv->pcc_lock); in lynx_28g_set_mode()
435 struct lynx_28g_priv *priv = lane->priv; in lynx_28g_validate()
438 return -EOPNOTSUPP; in lynx_28g_validate()
441 return -EOPNOTSUPP; in lynx_28g_validate()
451 lane->init = true; in lynx_28g_init()
454 * by this driver will get powered down at init time aka at dpaa2-eth in lynx_28g_init()
457 lane->powered_up = true; in lynx_28g_init()
478 pll = &priv->pll[i]; in lynx_28g_pll_read_configuration()
479 pll->priv = priv; in lynx_28g_pll_read_configuration()
480 pll->id = i; in lynx_28g_pll_read_configuration()
482 pll->rstctl = lynx_28g_pll_read(pll, PLLnRSTCTL); in lynx_28g_pll_read_configuration()
483 pll->cr0 = lynx_28g_pll_read(pll, PLLnCR0); in lynx_28g_pll_read_configuration()
484 pll->cr1 = lynx_28g_pll_read(pll, PLLnCR1); in lynx_28g_pll_read_configuration()
486 if (LYNX_28G_PLLnRSTCTL_DIS(pll->rstctl)) in lynx_28g_pll_read_configuration()
489 switch (LYNX_28G_PLLnCR1_FRATE_SEL(pll->cr1)) { in lynx_28g_pll_read_configuration()
493 __set_bit(PHY_INTERFACE_MODE_1000BASEX, pll->supported); in lynx_28g_pll_read_configuration()
494 __set_bit(PHY_INTERFACE_MODE_SGMII, pll->supported); in lynx_28g_pll_read_configuration()
498 __set_bit(PHY_INTERFACE_MODE_10GBASER, pll->supported); in lynx_28g_pll_read_configuration()
517 lane = &priv->lane[i]; in lynx_28g_cdr_lock_check()
519 mutex_lock(&lane->phy->mutex); in lynx_28g_cdr_lock_check()
521 if (!lane->init || !lane->powered_up) { in lynx_28g_cdr_lock_check()
522 mutex_unlock(&lane->phy->mutex); in lynx_28g_cdr_lock_check()
534 mutex_unlock(&lane->phy->mutex); in lynx_28g_cdr_lock_check()
536 queue_delayed_work(system_power_efficient_wq, &priv->cdr_check, in lynx_28g_cdr_lock_check()
548 lane->interface = PHY_INTERFACE_MODE_SGMII; in lynx_28g_lane_read_configuration()
551 lane->interface = PHY_INTERFACE_MODE_10GBASER; in lynx_28g_lane_read_configuration()
554 lane->interface = PHY_INTERFACE_MODE_NA; in lynx_28g_lane_read_configuration()
562 int idx = args->args[0]; in lynx_28g_xlate()
565 return ERR_PTR(-EINVAL); in lynx_28g_xlate()
567 return priv->lane[idx].phy; in lynx_28g_xlate()
572 struct device *dev = &pdev->dev; in lynx_28g_probe()
577 priv = devm_kzalloc(&pdev->dev, sizeof(*priv), GFP_KERNEL); in lynx_28g_probe()
579 return -ENOMEM; in lynx_28g_probe()
580 priv->dev = &pdev->dev; in lynx_28g_probe()
582 priv->base = devm_platform_ioremap_resource(pdev, 0); in lynx_28g_probe()
583 if (IS_ERR(priv->base)) in lynx_28g_probe()
584 return PTR_ERR(priv->base); in lynx_28g_probe()
589 struct lynx_28g_lane *lane = &priv->lane[i]; in lynx_28g_probe()
594 phy = devm_phy_create(&pdev->dev, NULL, &lynx_28g_ops); in lynx_28g_probe()
598 lane->priv = priv; in lynx_28g_probe()
599 lane->phy = phy; in lynx_28g_probe()
600 lane->id = i; in lynx_28g_probe()
607 spin_lock_init(&priv->pcc_lock); in lynx_28g_probe()
608 INIT_DELAYED_WORK(&priv->cdr_check, lynx_28g_cdr_lock_check); in lynx_28g_probe()
610 queue_delayed_work(system_power_efficient_wq, &priv->cdr_check, in lynx_28g_probe()
613 dev_set_drvdata(&pdev->dev, priv); in lynx_28g_probe()
614 provider = devm_of_phy_provider_register(&pdev->dev, lynx_28g_xlate); in lynx_28g_probe()
621 struct device *dev = &pdev->dev; in lynx_28g_remove()
624 cancel_delayed_work_sync(&priv->cdr_check); in lynx_28g_remove()
628 { .compatible = "fsl,lynx-28g" },
637 .name = "lynx-28g",
644 MODULE_DESCRIPTION("Lynx 28G SerDes PHY driver for Layerscape SoCs");