Lines Matching +full:imx8mm +full:- +full:power
1 // SPDX-License-Identifier: GPL-2.0
17 #include <linux/mfd/syscon/imx6q-iomuxc-gpr.h>
18 #include <linux/mfd/syscon/imx7-iomuxc-gpr.h>
36 #include "pcie-designware.h"
45 #define to_imx6_pcie(x) dev_get_drvdata((x)->dev)
53 IMX8MM, enumerator
97 /* power domain for pcie */
99 /* power domain for pcie phy */
109 /* PCIe Port Logic registers (memory-mapped) */
122 /* PHY registers (not memory-mapped) */
159 WARN_ON(imx6_pcie->drvdata->variant != IMX8MQ && in imx6_pcie_grp_offset()
160 imx6_pcie->drvdata->variant != IMX8MQ_EP && in imx6_pcie_grp_offset()
161 imx6_pcie->drvdata->variant != IMX8MM && in imx6_pcie_grp_offset()
162 imx6_pcie->drvdata->variant != IMX8MM_EP && in imx6_pcie_grp_offset()
163 imx6_pcie->drvdata->variant != IMX8MP && in imx6_pcie_grp_offset()
164 imx6_pcie->drvdata->variant != IMX8MP_EP); in imx6_pcie_grp_offset()
165 return imx6_pcie->controller_id == 1 ? IOMUXC_GPR16 : IOMUXC_GPR14; in imx6_pcie_grp_offset()
172 if (imx6_pcie->drvdata->mode == DW_PCIE_EP_TYPE) in imx6_pcie_configure_type()
177 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_configure_type()
180 if (imx6_pcie->controller_id == 1) { in imx6_pcie_configure_type()
195 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, mask, val); in imx6_pcie_configure_type()
200 struct dw_pcie *pci = imx6_pcie->pci; in pcie_phy_poll_ack()
216 return -ETIMEDOUT; in pcie_phy_poll_ack()
221 struct dw_pcie *pci = imx6_pcie->pci; in pcie_phy_wait_ack()
241 /* Read from the 16-bit PCIe PHY control registers (not memory-mapped) */
244 struct dw_pcie *pci = imx6_pcie->pci; in pcie_phy_read()
270 struct dw_pcie *pci = imx6_pcie->pci; in pcie_phy_write()
295 /* wait for ack de-assertion */ in pcie_phy_write()
313 /* wait for ack de-assertion */ in pcie_phy_write()
325 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_init_phy()
326 case IMX8MM: in imx6_pcie_init_phy()
341 regmap_update_bits(imx6_pcie->iomuxc_gpr, in imx6_pcie_init_phy()
350 if (imx6_pcie->vph && in imx6_pcie_init_phy()
351 regulator_get_voltage(imx6_pcie->vph) > 3000000) in imx6_pcie_init_phy()
352 regmap_update_bits(imx6_pcie->iomuxc_gpr, in imx6_pcie_init_phy()
358 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_init_phy()
362 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_init_phy()
367 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_init_phy()
371 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_init_phy()
374 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR8, in imx6_pcie_init_phy()
376 imx6_pcie->tx_deemph_gen1 << 0); in imx6_pcie_init_phy()
377 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR8, in imx6_pcie_init_phy()
379 imx6_pcie->tx_deemph_gen2_3p5db << 6); in imx6_pcie_init_phy()
380 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR8, in imx6_pcie_init_phy()
382 imx6_pcie->tx_deemph_gen2_6db << 12); in imx6_pcie_init_phy()
383 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR8, in imx6_pcie_init_phy()
385 imx6_pcie->tx_swing_full << 18); in imx6_pcie_init_phy()
386 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR8, in imx6_pcie_init_phy()
388 imx6_pcie->tx_swing_low << 25); in imx6_pcie_init_phy()
398 struct device *dev = imx6_pcie->pci->dev; in imx7d_pcie_wait_for_phy_pll_lock()
400 if (regmap_read_poll_timeout(imx6_pcie->iomuxc_gpr, in imx7d_pcie_wait_for_phy_pll_lock()
415 if (!(imx6_pcie->drvdata->flags & IMX6_PCIE_FLAG_IMX6_PHY)) in imx6_setup_phy_mpll()
418 for (i = 0; i < imx6_pcie->drvdata->clks_cnt; i++) in imx6_setup_phy_mpll()
419 if (strncmp(imx6_pcie->clks[i].id, "pcie_phy", 8) == 0) in imx6_setup_phy_mpll()
420 phy_rate = clk_get_rate(imx6_pcie->clks[i].clk); in imx6_setup_phy_mpll()
438 dev_err(imx6_pcie->pci->dev, in imx6_setup_phy_mpll()
440 return -EINVAL; in imx6_setup_phy_mpll()
464 if (!(imx6_pcie->drvdata->flags & IMX6_PCIE_FLAG_IMX6_PHY)) in imx6_pcie_reset_phy()
491 * make it look like it read all-ones. in imx6q_pcie_abort_handler()
499 val = -1; in imx6q_pcie_abort_handler()
501 regs->uregs[reg] = val; in imx6q_pcie_abort_handler()
502 regs->ARM_pc += 4; in imx6q_pcie_abort_handler()
507 regs->uregs[reg] = -1; in imx6q_pcie_abort_handler()
508 regs->ARM_pc += 4; in imx6q_pcie_abort_handler()
521 /* Do nothing when in a single power domain */ in imx6_pcie_attach_pd()
522 if (dev->pm_domain) in imx6_pcie_attach_pd()
525 imx6_pcie->pd_pcie = dev_pm_domain_attach_by_name(dev, "pcie"); in imx6_pcie_attach_pd()
526 if (IS_ERR(imx6_pcie->pd_pcie)) in imx6_pcie_attach_pd()
527 return PTR_ERR(imx6_pcie->pd_pcie); in imx6_pcie_attach_pd()
528 /* Do nothing when power domain missing */ in imx6_pcie_attach_pd()
529 if (!imx6_pcie->pd_pcie) in imx6_pcie_attach_pd()
531 link = device_link_add(dev, imx6_pcie->pd_pcie, in imx6_pcie_attach_pd()
537 return -EINVAL; in imx6_pcie_attach_pd()
540 imx6_pcie->pd_pcie_phy = dev_pm_domain_attach_by_name(dev, "pcie_phy"); in imx6_pcie_attach_pd()
541 if (IS_ERR(imx6_pcie->pd_pcie_phy)) in imx6_pcie_attach_pd()
542 return PTR_ERR(imx6_pcie->pd_pcie_phy); in imx6_pcie_attach_pd()
544 link = device_link_add(dev, imx6_pcie->pd_pcie_phy, in imx6_pcie_attach_pd()
550 return -EINVAL; in imx6_pcie_attach_pd()
561 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_enable_ref_clk()
563 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_enable_ref_clk()
568 /* power up core phy and enable ref clock */ in imx6_pcie_enable_ref_clk()
569 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1, in imx6_pcie_enable_ref_clk()
578 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1, in imx6_pcie_enable_ref_clk()
583 case IMX8MM: in imx6_pcie_enable_ref_clk()
594 regmap_update_bits(imx6_pcie->iomuxc_gpr, offset, in imx6_pcie_enable_ref_clk()
597 regmap_update_bits(imx6_pcie->iomuxc_gpr, offset, in imx6_pcie_enable_ref_clk()
608 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_disable_ref_clk()
611 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1, in imx6_pcie_disable_ref_clk()
613 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1, in imx6_pcie_disable_ref_clk()
618 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_disable_ref_clk()
629 struct dw_pcie *pci = imx6_pcie->pci; in imx6_pcie_clk_enable()
630 struct device *dev = pci->dev; in imx6_pcie_clk_enable()
633 ret = clk_bulk_prepare_enable(imx6_pcie->drvdata->clks_cnt, imx6_pcie->clks); in imx6_pcie_clk_enable()
648 clk_bulk_disable_unprepare(imx6_pcie->drvdata->clks_cnt, imx6_pcie->clks); in imx6_pcie_clk_enable()
656 clk_bulk_disable_unprepare(imx6_pcie->drvdata->clks_cnt, imx6_pcie->clks); in imx6_pcie_clk_disable()
661 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_assert_core_reset()
665 reset_control_assert(imx6_pcie->pciephy_reset); in imx6_pcie_assert_core_reset()
667 case IMX8MM: in imx6_pcie_assert_core_reset()
671 reset_control_assert(imx6_pcie->apps_reset); in imx6_pcie_assert_core_reset()
674 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_assert_core_reset()
678 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR5, in imx6_pcie_assert_core_reset()
683 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1, in imx6_pcie_assert_core_reset()
688 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1, in imx6_pcie_assert_core_reset()
690 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1, in imx6_pcie_assert_core_reset()
696 if (gpio_is_valid(imx6_pcie->reset_gpio)) in imx6_pcie_assert_core_reset()
697 gpio_set_value_cansleep(imx6_pcie->reset_gpio, in imx6_pcie_assert_core_reset()
698 imx6_pcie->gpio_active_high); in imx6_pcie_assert_core_reset()
703 struct dw_pcie *pci = imx6_pcie->pci; in imx6_pcie_deassert_core_reset()
704 struct device *dev = pci->dev; in imx6_pcie_deassert_core_reset()
706 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_deassert_core_reset()
709 reset_control_deassert(imx6_pcie->pciephy_reset); in imx6_pcie_deassert_core_reset()
712 reset_control_deassert(imx6_pcie->pciephy_reset); in imx6_pcie_deassert_core_reset()
714 /* Workaround for ERR010728, failure of PCI-e PLL VCO to in imx6_pcie_deassert_core_reset()
715 * oscillate, especially when cold. This turns off "Duty-cycle in imx6_pcie_deassert_core_reset()
718 if (likely(imx6_pcie->phy_base)) { in imx6_pcie_deassert_core_reset()
719 /* De-assert DCC_FB_EN */ in imx6_pcie_deassert_core_reset()
721 imx6_pcie->phy_base + PCIE_PHY_CMN_REG4); in imx6_pcie_deassert_core_reset()
725 imx6_pcie->phy_base + PCIE_PHY_CMN_REG24); in imx6_pcie_deassert_core_reset()
728 imx6_pcie->phy_base + PCIE_PHY_CMN_REG26); in imx6_pcie_deassert_core_reset()
730 dev_warn(dev, "Unable to apply ERR010728 workaround. DT missing fsl,imx7d-pcie-phy phandle ?\n"); in imx6_pcie_deassert_core_reset()
736 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR5, in imx6_pcie_deassert_core_reset()
740 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1, in imx6_pcie_deassert_core_reset()
746 case IMX8MM: in imx6_pcie_deassert_core_reset()
754 if (gpio_is_valid(imx6_pcie->reset_gpio)) { in imx6_pcie_deassert_core_reset()
756 gpio_set_value_cansleep(imx6_pcie->reset_gpio, in imx6_pcie_deassert_core_reset()
757 !imx6_pcie->gpio_active_high); in imx6_pcie_deassert_core_reset()
767 struct dw_pcie *pci = imx6_pcie->pci; in imx6_pcie_wait_for_speed_change()
768 struct device *dev = pci->dev; in imx6_pcie_wait_for_speed_change()
781 return -ETIMEDOUT; in imx6_pcie_wait_for_speed_change()
788 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_ltssm_enable()
792 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_ltssm_enable()
799 case IMX8MM: in imx6_pcie_ltssm_enable()
803 reset_control_deassert(imx6_pcie->apps_reset); in imx6_pcie_ltssm_enable()
812 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_ltssm_disable()
816 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_ltssm_disable()
822 case IMX8MM: in imx6_pcie_ltssm_disable()
826 reset_control_assert(imx6_pcie->apps_reset); in imx6_pcie_ltssm_disable()
834 struct device *dev = pci->dev; in imx6_pcie_start_link()
858 if (pci->link_gen > 1) { in imx6_pcie_start_link()
863 tmp |= pci->link_gen; in imx6_pcie_start_link()
875 if (imx6_pcie->drvdata->flags & in imx6_pcie_start_link()
880 * occurs and we go Gen1 -> yep, Gen1. The difference in imx6_pcie_start_link()
901 imx6_pcie->link_is_up = true; in imx6_pcie_start_link()
907 imx6_pcie->link_is_up = false; in imx6_pcie_start_link()
917 struct device *dev = pci->dev; in imx6_pcie_stop_link()
926 struct device *dev = pci->dev; in imx6_pcie_host_init()
930 if (imx6_pcie->vpcie) { in imx6_pcie_host_init()
931 ret = regulator_enable(imx6_pcie->vpcie); in imx6_pcie_host_init()
948 if (imx6_pcie->phy) { in imx6_pcie_host_init()
949 ret = phy_init(imx6_pcie->phy); in imx6_pcie_host_init()
951 dev_err(dev, "pcie PHY power up failed\n"); in imx6_pcie_host_init()
956 if (imx6_pcie->phy) { in imx6_pcie_host_init()
957 ret = phy_power_on(imx6_pcie->phy); in imx6_pcie_host_init()
975 phy_power_off(imx6_pcie->phy); in imx6_pcie_host_init()
977 phy_exit(imx6_pcie->phy); in imx6_pcie_host_init()
981 if (imx6_pcie->vpcie) in imx6_pcie_host_init()
982 regulator_disable(imx6_pcie->vpcie); in imx6_pcie_host_init()
991 if (imx6_pcie->phy) { in imx6_pcie_host_exit()
992 if (phy_power_off(imx6_pcie->phy)) in imx6_pcie_host_exit()
993 dev_err(pci->dev, "unable to power off PHY\n"); in imx6_pcie_host_exit()
994 phy_exit(imx6_pcie->phy); in imx6_pcie_host_exit()
998 if (imx6_pcie->vpcie) in imx6_pcie_host_exit()
999 regulator_disable(imx6_pcie->vpcie); in imx6_pcie_host_exit()
1035 dev_err(pci->dev, "UNKNOWN IRQ type\n"); in imx6_pcie_ep_raise_irq()
1036 return -EINVAL; in imx6_pcie_ep_raise_irq()
1069 struct dw_pcie *pci = imx6_pcie->pci; in imx6_add_pcie_ep()
1070 struct dw_pcie_rp *pp = &pci->pp; in imx6_add_pcie_ep()
1071 struct device *dev = pci->dev; in imx6_add_pcie_ep()
1074 ep = &pci->ep; in imx6_add_pcie_ep()
1075 ep->ops = &pcie_ep_ops; in imx6_add_pcie_ep()
1077 switch (imx6_pcie->drvdata->variant) { in imx6_add_pcie_ep()
1087 pci->dbi_base2 = pci->dbi_base + pcie_dbi2_offset; in imx6_add_pcie_ep()
1090 return -EINVAL; in imx6_add_pcie_ep()
1092 ep->phys_base = res->start; in imx6_add_pcie_ep()
1093 ep->addr_size = resource_size(res); in imx6_add_pcie_ep()
1094 ep->page_size = SZ_64K; in imx6_add_pcie_ep()
1109 struct device *dev = imx6_pcie->pci->dev; in imx6_pcie_pm_turnoff()
1112 if (imx6_pcie->turnoff_reset) { in imx6_pcie_pm_turnoff()
1113 reset_control_assert(imx6_pcie->turnoff_reset); in imx6_pcie_pm_turnoff()
1114 reset_control_deassert(imx6_pcie->turnoff_reset); in imx6_pcie_pm_turnoff()
1119 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_pm_turnoff()
1122 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_pm_turnoff()
1125 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_pm_turnoff()
1137 * The standard recommends a 1-10ms timeout after which to in imx6_pcie_pm_turnoff()
1148 struct dw_pcie *pci = imx6_pcie->pci; in imx6_pcie_msi_save_restore()
1154 imx6_pcie->msi_ctrl = val; in imx6_pcie_msi_save_restore()
1157 val = imx6_pcie->msi_ctrl; in imx6_pcie_msi_save_restore()
1167 struct dw_pcie_rp *pp = &imx6_pcie->pci->pp; in imx6_pcie_suspend_noirq()
1169 if (!(imx6_pcie->drvdata->flags & IMX6_PCIE_FLAG_SUPPORTS_SUSPEND)) in imx6_pcie_suspend_noirq()
1174 imx6_pcie_stop_link(imx6_pcie->pci); in imx6_pcie_suspend_noirq()
1184 struct dw_pcie_rp *pp = &imx6_pcie->pci->pp; in imx6_pcie_resume_noirq()
1186 if (!(imx6_pcie->drvdata->flags & IMX6_PCIE_FLAG_SUPPORTS_SUSPEND)) in imx6_pcie_resume_noirq()
1195 if (imx6_pcie->link_is_up) in imx6_pcie_resume_noirq()
1196 imx6_pcie_start_link(imx6_pcie->pci); in imx6_pcie_resume_noirq()
1208 struct device *dev = &pdev->dev; in imx6_pcie_probe()
1213 struct device_node *node = dev->of_node; in imx6_pcie_probe()
1220 return -ENOMEM; in imx6_pcie_probe()
1224 return -ENOMEM; in imx6_pcie_probe()
1226 pci->dev = dev; in imx6_pcie_probe()
1227 pci->ops = &dw_pcie_ops; in imx6_pcie_probe()
1228 pci->pp.ops = &imx6_pcie_host_ops; in imx6_pcie_probe()
1230 imx6_pcie->pci = pci; in imx6_pcie_probe()
1231 imx6_pcie->drvdata = of_device_get_match_data(dev); in imx6_pcie_probe()
1234 np = of_parse_phandle(node, "fsl,imx7d-pcie-phy", 0); in imx6_pcie_probe()
1243 imx6_pcie->phy_base = devm_ioremap_resource(dev, &res); in imx6_pcie_probe()
1244 if (IS_ERR(imx6_pcie->phy_base)) in imx6_pcie_probe()
1245 return PTR_ERR(imx6_pcie->phy_base); in imx6_pcie_probe()
1248 pci->dbi_base = devm_platform_get_and_ioremap_resource(pdev, 0, &dbi_base); in imx6_pcie_probe()
1249 if (IS_ERR(pci->dbi_base)) in imx6_pcie_probe()
1250 return PTR_ERR(pci->dbi_base); in imx6_pcie_probe()
1253 imx6_pcie->reset_gpio = of_get_named_gpio(node, "reset-gpio", 0); in imx6_pcie_probe()
1254 imx6_pcie->gpio_active_high = of_property_read_bool(node, in imx6_pcie_probe()
1255 "reset-gpio-active-high"); in imx6_pcie_probe()
1256 if (gpio_is_valid(imx6_pcie->reset_gpio)) { in imx6_pcie_probe()
1257 ret = devm_gpio_request_one(dev, imx6_pcie->reset_gpio, in imx6_pcie_probe()
1258 imx6_pcie->gpio_active_high ? in imx6_pcie_probe()
1266 } else if (imx6_pcie->reset_gpio == -EPROBE_DEFER) { in imx6_pcie_probe()
1267 return imx6_pcie->reset_gpio; in imx6_pcie_probe()
1270 if (imx6_pcie->drvdata->clks_cnt >= IMX6_PCIE_MAX_CLKS) in imx6_pcie_probe()
1271 return dev_err_probe(dev, -ENOMEM, "clks_cnt is too big\n"); in imx6_pcie_probe()
1273 for (i = 0; i < imx6_pcie->drvdata->clks_cnt; i++) in imx6_pcie_probe()
1274 imx6_pcie->clks[i].id = imx6_pcie->drvdata->clk_names[i]; in imx6_pcie_probe()
1277 ret = devm_clk_bulk_get(dev, imx6_pcie->drvdata->clks_cnt, imx6_pcie->clks); in imx6_pcie_probe()
1281 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_probe()
1284 if (dbi_base->start == IMX8MQ_PCIE2_BASE_ADDR) in imx6_pcie_probe()
1285 imx6_pcie->controller_id = 1; in imx6_pcie_probe()
1287 imx6_pcie->pciephy_reset = devm_reset_control_get_exclusive(dev, in imx6_pcie_probe()
1289 if (IS_ERR(imx6_pcie->pciephy_reset)) { in imx6_pcie_probe()
1291 return PTR_ERR(imx6_pcie->pciephy_reset); in imx6_pcie_probe()
1294 imx6_pcie->apps_reset = devm_reset_control_get_exclusive(dev, in imx6_pcie_probe()
1296 if (IS_ERR(imx6_pcie->apps_reset)) { in imx6_pcie_probe()
1298 return PTR_ERR(imx6_pcie->apps_reset); in imx6_pcie_probe()
1301 case IMX8MM: in imx6_pcie_probe()
1305 imx6_pcie->apps_reset = devm_reset_control_get_exclusive(dev, in imx6_pcie_probe()
1307 if (IS_ERR(imx6_pcie->apps_reset)) in imx6_pcie_probe()
1308 return dev_err_probe(dev, PTR_ERR(imx6_pcie->apps_reset), in imx6_pcie_probe()
1311 imx6_pcie->phy = devm_phy_get(dev, "pcie-phy"); in imx6_pcie_probe()
1312 if (IS_ERR(imx6_pcie->phy)) in imx6_pcie_probe()
1313 return dev_err_probe(dev, PTR_ERR(imx6_pcie->phy), in imx6_pcie_probe()
1322 imx6_pcie->turnoff_reset = devm_reset_control_get_optional_exclusive(dev, "turnoff"); in imx6_pcie_probe()
1323 if (IS_ERR(imx6_pcie->turnoff_reset)) { in imx6_pcie_probe()
1325 return PTR_ERR(imx6_pcie->turnoff_reset); in imx6_pcie_probe()
1329 imx6_pcie->iomuxc_gpr = in imx6_pcie_probe()
1330 syscon_regmap_lookup_by_compatible(imx6_pcie->drvdata->gpr); in imx6_pcie_probe()
1331 if (IS_ERR(imx6_pcie->iomuxc_gpr)) { in imx6_pcie_probe()
1333 return PTR_ERR(imx6_pcie->iomuxc_gpr); in imx6_pcie_probe()
1337 if (of_property_read_u32(node, "fsl,tx-deemph-gen1", in imx6_pcie_probe()
1338 &imx6_pcie->tx_deemph_gen1)) in imx6_pcie_probe()
1339 imx6_pcie->tx_deemph_gen1 = 0; in imx6_pcie_probe()
1341 if (of_property_read_u32(node, "fsl,tx-deemph-gen2-3p5db", in imx6_pcie_probe()
1342 &imx6_pcie->tx_deemph_gen2_3p5db)) in imx6_pcie_probe()
1343 imx6_pcie->tx_deemph_gen2_3p5db = 0; in imx6_pcie_probe()
1345 if (of_property_read_u32(node, "fsl,tx-deemph-gen2-6db", in imx6_pcie_probe()
1346 &imx6_pcie->tx_deemph_gen2_6db)) in imx6_pcie_probe()
1347 imx6_pcie->tx_deemph_gen2_6db = 20; in imx6_pcie_probe()
1349 if (of_property_read_u32(node, "fsl,tx-swing-full", in imx6_pcie_probe()
1350 &imx6_pcie->tx_swing_full)) in imx6_pcie_probe()
1351 imx6_pcie->tx_swing_full = 127; in imx6_pcie_probe()
1353 if (of_property_read_u32(node, "fsl,tx-swing-low", in imx6_pcie_probe()
1354 &imx6_pcie->tx_swing_low)) in imx6_pcie_probe()
1355 imx6_pcie->tx_swing_low = 127; in imx6_pcie_probe()
1358 pci->link_gen = 1; in imx6_pcie_probe()
1359 of_property_read_u32(node, "fsl,max-link-speed", &pci->link_gen); in imx6_pcie_probe()
1361 imx6_pcie->vpcie = devm_regulator_get_optional(&pdev->dev, "vpcie"); in imx6_pcie_probe()
1362 if (IS_ERR(imx6_pcie->vpcie)) { in imx6_pcie_probe()
1363 if (PTR_ERR(imx6_pcie->vpcie) != -ENODEV) in imx6_pcie_probe()
1364 return PTR_ERR(imx6_pcie->vpcie); in imx6_pcie_probe()
1365 imx6_pcie->vpcie = NULL; in imx6_pcie_probe()
1368 imx6_pcie->vph = devm_regulator_get_optional(&pdev->dev, "vph"); in imx6_pcie_probe()
1369 if (IS_ERR(imx6_pcie->vph)) { in imx6_pcie_probe()
1370 if (PTR_ERR(imx6_pcie->vph) != -ENODEV) in imx6_pcie_probe()
1371 return PTR_ERR(imx6_pcie->vph); in imx6_pcie_probe()
1372 imx6_pcie->vph = NULL; in imx6_pcie_probe()
1381 if (imx6_pcie->drvdata->mode == DW_PCIE_EP_TYPE) { in imx6_pcie_probe()
1386 ret = dw_pcie_host_init(&pci->pp); in imx6_pcie_probe()
1421 .gpr = "fsl,imx6q-iomuxc-gpr",
1430 .gpr = "fsl,imx6q-iomuxc-gpr",
1440 .gpr = "fsl,imx6q-iomuxc-gpr",
1447 .gpr = "fsl,imx7d-iomuxc-gpr",
1453 .gpr = "fsl,imx8mq-iomuxc-gpr",
1457 [IMX8MM] = {
1458 .variant = IMX8MM,
1460 .gpr = "fsl,imx8mm-iomuxc-gpr",
1467 .gpr = "fsl,imx8mp-iomuxc-gpr",
1474 .gpr = "fsl,imx8mq-iomuxc-gpr",
1481 .gpr = "fsl,imx8mm-iomuxc-gpr",
1488 .gpr = "fsl,imx8mp-iomuxc-gpr",
1495 { .compatible = "fsl,imx6q-pcie", .data = &drvdata[IMX6Q], },
1496 { .compatible = "fsl,imx6sx-pcie", .data = &drvdata[IMX6SX], },
1497 { .compatible = "fsl,imx6qp-pcie", .data = &drvdata[IMX6QP], },
1498 { .compatible = "fsl,imx7d-pcie", .data = &drvdata[IMX7D], },
1499 { .compatible = "fsl,imx8mq-pcie", .data = &drvdata[IMX8MQ], },
1500 { .compatible = "fsl,imx8mm-pcie", .data = &drvdata[IMX8MM], },
1501 { .compatible = "fsl,imx8mp-pcie", .data = &drvdata[IMX8MP], },
1502 { .compatible = "fsl,imx8mq-pcie-ep", .data = &drvdata[IMX8MQ_EP], },
1503 { .compatible = "fsl,imx8mm-pcie-ep", .data = &drvdata[IMX8MM_EP], },
1504 { .compatible = "fsl,imx8mp-pcie-ep", .data = &drvdata[IMX8MP_EP], },
1510 .name = "imx6q-pcie",
1522 struct pci_bus *bus = dev->bus; in imx6_pcie_quirk()
1523 struct dw_pcie_rp *pp = bus->sysdata; in imx6_pcie_quirk()
1526 if (!bus->dev.parent || !bus->dev.parent->parent) in imx6_pcie_quirk()
1530 if (bus->dev.parent->parent->driver != &imx6_pcie_driver.driver) in imx6_pcie_quirk()
1541 if (imx6_pcie->drvdata->dbi_length) { in imx6_pcie_quirk()
1542 dev->cfg_size = imx6_pcie->drvdata->dbi_length; in imx6_pcie_quirk()
1543 dev_info(&dev->dev, "Limiting cfg_size to %d\n", in imx6_pcie_quirk()
1544 dev->cfg_size); in imx6_pcie_quirk()
1558 return -ENODEV; in imx6_pcie_init()
1564 * by kernel and since imx6q_pcie_abort_handler() is a no-op, in imx6_pcie_init()
1569 "external abort on non-linefetch"); in imx6_pcie_init()