Lines Matching refs:imx6_pcie
63 struct imx6_pcie { struct
144 static int pcie_phy_poll_ack(struct imx6_pcie *imx6_pcie, bool exp_val) in pcie_phy_poll_ack() argument
146 struct dw_pcie *pci = imx6_pcie->pci; in pcie_phy_poll_ack()
165 static int pcie_phy_wait_ack(struct imx6_pcie *imx6_pcie, int addr) in pcie_phy_wait_ack() argument
167 struct dw_pcie *pci = imx6_pcie->pci; in pcie_phy_wait_ack()
177 ret = pcie_phy_poll_ack(imx6_pcie, true); in pcie_phy_wait_ack()
184 return pcie_phy_poll_ack(imx6_pcie, false); in pcie_phy_wait_ack()
188 static int pcie_phy_read(struct imx6_pcie *imx6_pcie, int addr, u16 *data) in pcie_phy_read() argument
190 struct dw_pcie *pci = imx6_pcie->pci; in pcie_phy_read()
194 ret = pcie_phy_wait_ack(imx6_pcie, addr); in pcie_phy_read()
202 ret = pcie_phy_poll_ack(imx6_pcie, true); in pcie_phy_read()
211 return pcie_phy_poll_ack(imx6_pcie, false); in pcie_phy_read()
214 static int pcie_phy_write(struct imx6_pcie *imx6_pcie, int addr, u16 data) in pcie_phy_write() argument
216 struct dw_pcie *pci = imx6_pcie->pci; in pcie_phy_write()
222 ret = pcie_phy_wait_ack(imx6_pcie, addr); in pcie_phy_write()
233 ret = pcie_phy_poll_ack(imx6_pcie, true); in pcie_phy_write()
242 ret = pcie_phy_poll_ack(imx6_pcie, false); in pcie_phy_write()
251 ret = pcie_phy_poll_ack(imx6_pcie, true); in pcie_phy_write()
260 ret = pcie_phy_poll_ack(imx6_pcie, false); in pcie_phy_write()
269 static void imx6_pcie_reset_phy(struct imx6_pcie *imx6_pcie) in imx6_pcie_reset_phy() argument
273 if (!(imx6_pcie->drvdata->flags & IMX6_PCIE_FLAG_IMX6_PHY)) in imx6_pcie_reset_phy()
276 pcie_phy_read(imx6_pcie, PHY_RX_OVRD_IN_LO, &tmp); in imx6_pcie_reset_phy()
279 pcie_phy_write(imx6_pcie, PHY_RX_OVRD_IN_LO, tmp); in imx6_pcie_reset_phy()
283 pcie_phy_read(imx6_pcie, PHY_RX_OVRD_IN_LO, &tmp); in imx6_pcie_reset_phy()
286 pcie_phy_write(imx6_pcie, PHY_RX_OVRD_IN_LO, tmp); in imx6_pcie_reset_phy()
327 struct imx6_pcie *imx6_pcie = dev_get_drvdata(dev); in imx6_pcie_attach_pd() local
334 imx6_pcie->pd_pcie = dev_pm_domain_attach_by_name(dev, "pcie"); in imx6_pcie_attach_pd()
335 if (IS_ERR(imx6_pcie->pd_pcie)) in imx6_pcie_attach_pd()
336 return PTR_ERR(imx6_pcie->pd_pcie); in imx6_pcie_attach_pd()
338 if (!imx6_pcie->pd_pcie) in imx6_pcie_attach_pd()
340 link = device_link_add(dev, imx6_pcie->pd_pcie, in imx6_pcie_attach_pd()
349 imx6_pcie->pd_pcie_phy = dev_pm_domain_attach_by_name(dev, "pcie_phy"); in imx6_pcie_attach_pd()
350 if (IS_ERR(imx6_pcie->pd_pcie_phy)) in imx6_pcie_attach_pd()
351 return PTR_ERR(imx6_pcie->pd_pcie_phy); in imx6_pcie_attach_pd()
353 link = device_link_add(dev, imx6_pcie->pd_pcie_phy, in imx6_pcie_attach_pd()
365 static void imx6_pcie_assert_core_reset(struct imx6_pcie *imx6_pcie) in imx6_pcie_assert_core_reset() argument
367 struct device *dev = imx6_pcie->pci->dev; in imx6_pcie_assert_core_reset()
369 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_assert_core_reset()
372 reset_control_assert(imx6_pcie->pciephy_reset); in imx6_pcie_assert_core_reset()
373 reset_control_assert(imx6_pcie->apps_reset); in imx6_pcie_assert_core_reset()
376 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_assert_core_reset()
380 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR5, in imx6_pcie_assert_core_reset()
385 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1, in imx6_pcie_assert_core_reset()
390 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1, in imx6_pcie_assert_core_reset()
392 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1, in imx6_pcie_assert_core_reset()
397 if (imx6_pcie->vpcie && regulator_is_enabled(imx6_pcie->vpcie) > 0) { in imx6_pcie_assert_core_reset()
398 int ret = regulator_disable(imx6_pcie->vpcie); in imx6_pcie_assert_core_reset()
406 if (gpio_is_valid(imx6_pcie->reset_gpio)) in imx6_pcie_assert_core_reset()
407 gpio_set_value_cansleep(imx6_pcie->reset_gpio, in imx6_pcie_assert_core_reset()
408 imx6_pcie->gpio_active_high); in imx6_pcie_assert_core_reset()
411 static unsigned int imx6_pcie_grp_offset(const struct imx6_pcie *imx6_pcie) in imx6_pcie_grp_offset() argument
413 WARN_ON(imx6_pcie->drvdata->variant != IMX8MQ); in imx6_pcie_grp_offset()
414 return imx6_pcie->controller_id == 1 ? IOMUXC_GPR16 : IOMUXC_GPR14; in imx6_pcie_grp_offset()
417 static int imx6_pcie_enable_ref_clk(struct imx6_pcie *imx6_pcie) in imx6_pcie_enable_ref_clk() argument
419 struct dw_pcie *pci = imx6_pcie->pci; in imx6_pcie_enable_ref_clk()
424 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_enable_ref_clk()
426 ret = clk_prepare_enable(imx6_pcie->pcie_inbound_axi); in imx6_pcie_enable_ref_clk()
432 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_enable_ref_clk()
438 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1, in imx6_pcie_enable_ref_clk()
447 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1, in imx6_pcie_enable_ref_clk()
453 ret = clk_prepare_enable(imx6_pcie->pcie_aux); in imx6_pcie_enable_ref_clk()
459 offset = imx6_pcie_grp_offset(imx6_pcie); in imx6_pcie_enable_ref_clk()
464 regmap_update_bits(imx6_pcie->iomuxc_gpr, offset, in imx6_pcie_enable_ref_clk()
467 regmap_update_bits(imx6_pcie->iomuxc_gpr, offset, in imx6_pcie_enable_ref_clk()
476 static void imx7d_pcie_wait_for_phy_pll_lock(struct imx6_pcie *imx6_pcie) in imx7d_pcie_wait_for_phy_pll_lock() argument
479 struct device *dev = imx6_pcie->pci->dev; in imx7d_pcie_wait_for_phy_pll_lock()
481 if (regmap_read_poll_timeout(imx6_pcie->iomuxc_gpr, in imx7d_pcie_wait_for_phy_pll_lock()
489 static void imx6_pcie_deassert_core_reset(struct imx6_pcie *imx6_pcie) in imx6_pcie_deassert_core_reset() argument
491 struct dw_pcie *pci = imx6_pcie->pci; in imx6_pcie_deassert_core_reset()
495 if (imx6_pcie->vpcie && !regulator_is_enabled(imx6_pcie->vpcie)) { in imx6_pcie_deassert_core_reset()
496 ret = regulator_enable(imx6_pcie->vpcie); in imx6_pcie_deassert_core_reset()
504 ret = clk_prepare_enable(imx6_pcie->pcie_phy); in imx6_pcie_deassert_core_reset()
510 ret = clk_prepare_enable(imx6_pcie->pcie_bus); in imx6_pcie_deassert_core_reset()
516 ret = clk_prepare_enable(imx6_pcie->pcie); in imx6_pcie_deassert_core_reset()
522 ret = imx6_pcie_enable_ref_clk(imx6_pcie); in imx6_pcie_deassert_core_reset()
531 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_deassert_core_reset()
533 reset_control_deassert(imx6_pcie->pciephy_reset); in imx6_pcie_deassert_core_reset()
536 reset_control_deassert(imx6_pcie->pciephy_reset); in imx6_pcie_deassert_core_reset()
542 if (likely(imx6_pcie->phy_base)) { in imx6_pcie_deassert_core_reset()
545 imx6_pcie->phy_base + PCIE_PHY_CMN_REG4); in imx6_pcie_deassert_core_reset()
549 imx6_pcie->phy_base + PCIE_PHY_CMN_REG24); in imx6_pcie_deassert_core_reset()
552 imx6_pcie->phy_base + PCIE_PHY_CMN_REG26); in imx6_pcie_deassert_core_reset()
557 imx7d_pcie_wait_for_phy_pll_lock(imx6_pcie); in imx6_pcie_deassert_core_reset()
560 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR5, in imx6_pcie_deassert_core_reset()
564 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1, in imx6_pcie_deassert_core_reset()
574 if (gpio_is_valid(imx6_pcie->reset_gpio)) { in imx6_pcie_deassert_core_reset()
576 gpio_set_value_cansleep(imx6_pcie->reset_gpio, in imx6_pcie_deassert_core_reset()
577 !imx6_pcie->gpio_active_high); in imx6_pcie_deassert_core_reset()
585 clk_disable_unprepare(imx6_pcie->pcie); in imx6_pcie_deassert_core_reset()
587 clk_disable_unprepare(imx6_pcie->pcie_bus); in imx6_pcie_deassert_core_reset()
589 clk_disable_unprepare(imx6_pcie->pcie_phy); in imx6_pcie_deassert_core_reset()
591 if (imx6_pcie->vpcie && regulator_is_enabled(imx6_pcie->vpcie) > 0) { in imx6_pcie_deassert_core_reset()
592 ret = regulator_disable(imx6_pcie->vpcie); in imx6_pcie_deassert_core_reset()
599 static void imx6_pcie_configure_type(struct imx6_pcie *imx6_pcie) in imx6_pcie_configure_type() argument
603 if (imx6_pcie->drvdata->variant == IMX8MQ && in imx6_pcie_configure_type()
604 imx6_pcie->controller_id == 1) { in imx6_pcie_configure_type()
614 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, mask, val); in imx6_pcie_configure_type()
617 static void imx6_pcie_init_phy(struct imx6_pcie *imx6_pcie) in imx6_pcie_init_phy() argument
619 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_init_phy()
625 regmap_update_bits(imx6_pcie->iomuxc_gpr, in imx6_pcie_init_phy()
626 imx6_pcie_grp_offset(imx6_pcie), in imx6_pcie_init_phy()
631 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_init_phy()
635 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_init_phy()
640 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_init_phy()
644 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_init_phy()
647 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR8, in imx6_pcie_init_phy()
649 imx6_pcie->tx_deemph_gen1 << 0); in imx6_pcie_init_phy()
650 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR8, in imx6_pcie_init_phy()
652 imx6_pcie->tx_deemph_gen2_3p5db << 6); in imx6_pcie_init_phy()
653 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR8, in imx6_pcie_init_phy()
655 imx6_pcie->tx_deemph_gen2_6db << 12); in imx6_pcie_init_phy()
656 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR8, in imx6_pcie_init_phy()
658 imx6_pcie->tx_swing_full << 18); in imx6_pcie_init_phy()
659 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR8, in imx6_pcie_init_phy()
661 imx6_pcie->tx_swing_low << 25); in imx6_pcie_init_phy()
665 imx6_pcie_configure_type(imx6_pcie); in imx6_pcie_init_phy()
668 static int imx6_setup_phy_mpll(struct imx6_pcie *imx6_pcie) in imx6_setup_phy_mpll() argument
670 unsigned long phy_rate = clk_get_rate(imx6_pcie->pcie_phy); in imx6_setup_phy_mpll()
674 if (!(imx6_pcie->drvdata->flags & IMX6_PCIE_FLAG_IMX6_PHY)) in imx6_setup_phy_mpll()
693 dev_err(imx6_pcie->pci->dev, in imx6_setup_phy_mpll()
698 pcie_phy_read(imx6_pcie, PCIE_PHY_MPLL_OVRD_IN_LO, &val); in imx6_setup_phy_mpll()
703 pcie_phy_write(imx6_pcie, PCIE_PHY_MPLL_OVRD_IN_LO, val); in imx6_setup_phy_mpll()
705 pcie_phy_read(imx6_pcie, PCIE_PHY_ATEOVRD, &val); in imx6_setup_phy_mpll()
710 pcie_phy_write(imx6_pcie, PCIE_PHY_ATEOVRD, val); in imx6_setup_phy_mpll()
715 static int imx6_pcie_wait_for_speed_change(struct imx6_pcie *imx6_pcie) in imx6_pcie_wait_for_speed_change() argument
717 struct dw_pcie *pci = imx6_pcie->pci; in imx6_pcie_wait_for_speed_change()
736 struct imx6_pcie *imx6_pcie = dev_get_drvdata(dev); in imx6_pcie_ltssm_enable() local
738 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_ltssm_enable()
742 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_ltssm_enable()
748 reset_control_deassert(imx6_pcie->apps_reset); in imx6_pcie_ltssm_enable()
753 static int imx6_pcie_establish_link(struct imx6_pcie *imx6_pcie) in imx6_pcie_establish_link() argument
755 struct dw_pcie *pci = imx6_pcie->pci; in imx6_pcie_establish_link()
793 if (imx6_pcie->drvdata->flags & in imx6_pcie_establish_link()
804 ret = imx6_pcie_wait_for_speed_change(imx6_pcie); in imx6_pcie_establish_link()
829 imx6_pcie_reset_phy(imx6_pcie); in imx6_pcie_establish_link()
836 struct imx6_pcie *imx6_pcie = to_imx6_pcie(pci); in imx6_pcie_host_init() local
838 imx6_pcie_assert_core_reset(imx6_pcie); in imx6_pcie_host_init()
839 imx6_pcie_init_phy(imx6_pcie); in imx6_pcie_host_init()
840 imx6_pcie_deassert_core_reset(imx6_pcie); in imx6_pcie_host_init()
841 imx6_setup_phy_mpll(imx6_pcie); in imx6_pcie_host_init()
843 imx6_pcie_establish_link(imx6_pcie); in imx6_pcie_host_init()
853 static int imx6_add_pcie_port(struct imx6_pcie *imx6_pcie, in imx6_add_pcie_port() argument
856 struct dw_pcie *pci = imx6_pcie->pci; in imx6_add_pcie_port()
885 struct imx6_pcie *imx6_pcie = dev_get_drvdata(dev); in imx6_pcie_ltssm_disable() local
887 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_ltssm_disable()
890 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_ltssm_disable()
894 reset_control_assert(imx6_pcie->apps_reset); in imx6_pcie_ltssm_disable()
901 static void imx6_pcie_pm_turnoff(struct imx6_pcie *imx6_pcie) in imx6_pcie_pm_turnoff() argument
903 struct device *dev = imx6_pcie->pci->dev; in imx6_pcie_pm_turnoff()
906 if (imx6_pcie->turnoff_reset) { in imx6_pcie_pm_turnoff()
907 reset_control_assert(imx6_pcie->turnoff_reset); in imx6_pcie_pm_turnoff()
908 reset_control_deassert(imx6_pcie->turnoff_reset); in imx6_pcie_pm_turnoff()
913 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_pm_turnoff()
915 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_pm_turnoff()
918 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_pm_turnoff()
937 static void imx6_pcie_clk_disable(struct imx6_pcie *imx6_pcie) in imx6_pcie_clk_disable() argument
939 clk_disable_unprepare(imx6_pcie->pcie); in imx6_pcie_clk_disable()
940 clk_disable_unprepare(imx6_pcie->pcie_phy); in imx6_pcie_clk_disable()
941 clk_disable_unprepare(imx6_pcie->pcie_bus); in imx6_pcie_clk_disable()
943 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_clk_disable()
945 clk_disable_unprepare(imx6_pcie->pcie_inbound_axi); in imx6_pcie_clk_disable()
948 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_clk_disable()
953 clk_disable_unprepare(imx6_pcie->pcie_aux); in imx6_pcie_clk_disable()
962 struct imx6_pcie *imx6_pcie = dev_get_drvdata(dev); in imx6_pcie_suspend_noirq() local
964 if (!(imx6_pcie->drvdata->flags & IMX6_PCIE_FLAG_SUPPORTS_SUSPEND)) in imx6_pcie_suspend_noirq()
967 imx6_pcie_pm_turnoff(imx6_pcie); in imx6_pcie_suspend_noirq()
968 imx6_pcie_clk_disable(imx6_pcie); in imx6_pcie_suspend_noirq()
977 struct imx6_pcie *imx6_pcie = dev_get_drvdata(dev); in imx6_pcie_resume_noirq() local
978 struct pcie_port *pp = &imx6_pcie->pci->pp; in imx6_pcie_resume_noirq()
980 if (!(imx6_pcie->drvdata->flags & IMX6_PCIE_FLAG_SUPPORTS_SUSPEND)) in imx6_pcie_resume_noirq()
983 imx6_pcie_assert_core_reset(imx6_pcie); in imx6_pcie_resume_noirq()
984 imx6_pcie_init_phy(imx6_pcie); in imx6_pcie_resume_noirq()
985 imx6_pcie_deassert_core_reset(imx6_pcie); in imx6_pcie_resume_noirq()
988 ret = imx6_pcie_establish_link(imx6_pcie); in imx6_pcie_resume_noirq()
1005 struct imx6_pcie *imx6_pcie; in imx6_pcie_probe() local
1012 imx6_pcie = devm_kzalloc(dev, sizeof(*imx6_pcie), GFP_KERNEL); in imx6_pcie_probe()
1013 if (!imx6_pcie) in imx6_pcie_probe()
1023 imx6_pcie->pci = pci; in imx6_pcie_probe()
1024 imx6_pcie->drvdata = of_device_get_match_data(dev); in imx6_pcie_probe()
1036 imx6_pcie->phy_base = devm_ioremap_resource(dev, &res); in imx6_pcie_probe()
1037 if (IS_ERR(imx6_pcie->phy_base)) { in imx6_pcie_probe()
1039 return PTR_ERR(imx6_pcie->phy_base); in imx6_pcie_probe()
1049 imx6_pcie->reset_gpio = of_get_named_gpio(node, "reset-gpio", 0); in imx6_pcie_probe()
1050 imx6_pcie->gpio_active_high = of_property_read_bool(node, in imx6_pcie_probe()
1052 if (gpio_is_valid(imx6_pcie->reset_gpio)) { in imx6_pcie_probe()
1053 ret = devm_gpio_request_one(dev, imx6_pcie->reset_gpio, in imx6_pcie_probe()
1054 imx6_pcie->gpio_active_high ? in imx6_pcie_probe()
1062 } else if (imx6_pcie->reset_gpio == -EPROBE_DEFER) { in imx6_pcie_probe()
1063 return imx6_pcie->reset_gpio; in imx6_pcie_probe()
1067 imx6_pcie->pcie_phy = devm_clk_get(dev, "pcie_phy"); in imx6_pcie_probe()
1068 if (IS_ERR(imx6_pcie->pcie_phy)) in imx6_pcie_probe()
1069 return dev_err_probe(dev, PTR_ERR(imx6_pcie->pcie_phy), in imx6_pcie_probe()
1072 imx6_pcie->pcie_bus = devm_clk_get(dev, "pcie_bus"); in imx6_pcie_probe()
1073 if (IS_ERR(imx6_pcie->pcie_bus)) in imx6_pcie_probe()
1074 return dev_err_probe(dev, PTR_ERR(imx6_pcie->pcie_bus), in imx6_pcie_probe()
1077 imx6_pcie->pcie = devm_clk_get(dev, "pcie"); in imx6_pcie_probe()
1078 if (IS_ERR(imx6_pcie->pcie)) in imx6_pcie_probe()
1079 return dev_err_probe(dev, PTR_ERR(imx6_pcie->pcie), in imx6_pcie_probe()
1082 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_probe()
1084 imx6_pcie->pcie_inbound_axi = devm_clk_get(dev, in imx6_pcie_probe()
1086 if (IS_ERR(imx6_pcie->pcie_inbound_axi)) in imx6_pcie_probe()
1087 return dev_err_probe(dev, PTR_ERR(imx6_pcie->pcie_inbound_axi), in imx6_pcie_probe()
1091 imx6_pcie->pcie_aux = devm_clk_get(dev, "pcie_aux"); in imx6_pcie_probe()
1092 if (IS_ERR(imx6_pcie->pcie_aux)) in imx6_pcie_probe()
1093 return dev_err_probe(dev, PTR_ERR(imx6_pcie->pcie_aux), in imx6_pcie_probe()
1098 imx6_pcie->controller_id = 1; in imx6_pcie_probe()
1100 imx6_pcie->pciephy_reset = devm_reset_control_get_exclusive(dev, in imx6_pcie_probe()
1102 if (IS_ERR(imx6_pcie->pciephy_reset)) { in imx6_pcie_probe()
1104 return PTR_ERR(imx6_pcie->pciephy_reset); in imx6_pcie_probe()
1107 imx6_pcie->apps_reset = devm_reset_control_get_exclusive(dev, in imx6_pcie_probe()
1109 if (IS_ERR(imx6_pcie->apps_reset)) { in imx6_pcie_probe()
1111 return PTR_ERR(imx6_pcie->apps_reset); in imx6_pcie_probe()
1119 imx6_pcie->turnoff_reset = devm_reset_control_get_optional_exclusive(dev, "turnoff"); in imx6_pcie_probe()
1120 if (IS_ERR(imx6_pcie->turnoff_reset)) { in imx6_pcie_probe()
1122 return PTR_ERR(imx6_pcie->turnoff_reset); in imx6_pcie_probe()
1126 imx6_pcie->iomuxc_gpr = in imx6_pcie_probe()
1128 if (IS_ERR(imx6_pcie->iomuxc_gpr)) { in imx6_pcie_probe()
1130 return PTR_ERR(imx6_pcie->iomuxc_gpr); in imx6_pcie_probe()
1135 &imx6_pcie->tx_deemph_gen1)) in imx6_pcie_probe()
1136 imx6_pcie->tx_deemph_gen1 = 0; in imx6_pcie_probe()
1139 &imx6_pcie->tx_deemph_gen2_3p5db)) in imx6_pcie_probe()
1140 imx6_pcie->tx_deemph_gen2_3p5db = 0; in imx6_pcie_probe()
1143 &imx6_pcie->tx_deemph_gen2_6db)) in imx6_pcie_probe()
1144 imx6_pcie->tx_deemph_gen2_6db = 20; in imx6_pcie_probe()
1147 &imx6_pcie->tx_swing_full)) in imx6_pcie_probe()
1148 imx6_pcie->tx_swing_full = 127; in imx6_pcie_probe()
1151 &imx6_pcie->tx_swing_low)) in imx6_pcie_probe()
1152 imx6_pcie->tx_swing_low = 127; in imx6_pcie_probe()
1158 imx6_pcie->vpcie = devm_regulator_get_optional(&pdev->dev, "vpcie"); in imx6_pcie_probe()
1159 if (IS_ERR(imx6_pcie->vpcie)) { in imx6_pcie_probe()
1160 if (PTR_ERR(imx6_pcie->vpcie) != -ENODEV) in imx6_pcie_probe()
1161 return PTR_ERR(imx6_pcie->vpcie); in imx6_pcie_probe()
1162 imx6_pcie->vpcie = NULL; in imx6_pcie_probe()
1165 platform_set_drvdata(pdev, imx6_pcie); in imx6_pcie_probe()
1171 ret = imx6_add_pcie_port(imx6_pcie, pdev); in imx6_pcie_probe()
1187 struct imx6_pcie *imx6_pcie = platform_get_drvdata(pdev); in imx6_pcie_shutdown() local
1190 imx6_pcie_assert_core_reset(imx6_pcie); in imx6_pcie_shutdown()
1256 struct imx6_pcie *imx6_pcie = to_imx6_pcie(pci); in imx6_pcie_quirk() local
1262 if (imx6_pcie->drvdata->dbi_length) { in imx6_pcie_quirk()
1263 dev->cfg_size = imx6_pcie->drvdata->dbi_length; in imx6_pcie_quirk()