• Home
  • Raw
  • Download

Lines Matching refs:imx6_pcie

64 struct imx6_pcie {  struct
146 static int pcie_phy_poll_ack(struct imx6_pcie *imx6_pcie, bool exp_val) in pcie_phy_poll_ack() argument
148 struct dw_pcie *pci = imx6_pcie->pci; in pcie_phy_poll_ack()
167 static int pcie_phy_wait_ack(struct imx6_pcie *imx6_pcie, int addr) in pcie_phy_wait_ack() argument
169 struct dw_pcie *pci = imx6_pcie->pci; in pcie_phy_wait_ack()
179 ret = pcie_phy_poll_ack(imx6_pcie, true); in pcie_phy_wait_ack()
186 return pcie_phy_poll_ack(imx6_pcie, false); in pcie_phy_wait_ack()
190 static int pcie_phy_read(struct imx6_pcie *imx6_pcie, int addr, u16 *data) in pcie_phy_read() argument
192 struct dw_pcie *pci = imx6_pcie->pci; in pcie_phy_read()
196 ret = pcie_phy_wait_ack(imx6_pcie, addr); in pcie_phy_read()
204 ret = pcie_phy_poll_ack(imx6_pcie, true); in pcie_phy_read()
213 return pcie_phy_poll_ack(imx6_pcie, false); in pcie_phy_read()
216 static int pcie_phy_write(struct imx6_pcie *imx6_pcie, int addr, u16 data) in pcie_phy_write() argument
218 struct dw_pcie *pci = imx6_pcie->pci; in pcie_phy_write()
224 ret = pcie_phy_wait_ack(imx6_pcie, addr); in pcie_phy_write()
235 ret = pcie_phy_poll_ack(imx6_pcie, true); in pcie_phy_write()
244 ret = pcie_phy_poll_ack(imx6_pcie, false); in pcie_phy_write()
253 ret = pcie_phy_poll_ack(imx6_pcie, true); in pcie_phy_write()
262 ret = pcie_phy_poll_ack(imx6_pcie, false); in pcie_phy_write()
271 static void imx6_pcie_reset_phy(struct imx6_pcie *imx6_pcie) in imx6_pcie_reset_phy() argument
275 if (!(imx6_pcie->drvdata->flags & IMX6_PCIE_FLAG_IMX6_PHY)) in imx6_pcie_reset_phy()
278 pcie_phy_read(imx6_pcie, PHY_RX_OVRD_IN_LO, &tmp); in imx6_pcie_reset_phy()
281 pcie_phy_write(imx6_pcie, PHY_RX_OVRD_IN_LO, tmp); in imx6_pcie_reset_phy()
285 pcie_phy_read(imx6_pcie, PHY_RX_OVRD_IN_LO, &tmp); in imx6_pcie_reset_phy()
288 pcie_phy_write(imx6_pcie, PHY_RX_OVRD_IN_LO, tmp); in imx6_pcie_reset_phy()
329 struct imx6_pcie *imx6_pcie = dev_get_drvdata(dev); in imx6_pcie_attach_pd() local
336 imx6_pcie->pd_pcie = dev_pm_domain_attach_by_name(dev, "pcie"); in imx6_pcie_attach_pd()
337 if (IS_ERR(imx6_pcie->pd_pcie)) in imx6_pcie_attach_pd()
338 return PTR_ERR(imx6_pcie->pd_pcie); in imx6_pcie_attach_pd()
340 if (!imx6_pcie->pd_pcie) in imx6_pcie_attach_pd()
342 link = device_link_add(dev, imx6_pcie->pd_pcie, in imx6_pcie_attach_pd()
351 imx6_pcie->pd_pcie_phy = dev_pm_domain_attach_by_name(dev, "pcie_phy"); in imx6_pcie_attach_pd()
352 if (IS_ERR(imx6_pcie->pd_pcie_phy)) in imx6_pcie_attach_pd()
353 return PTR_ERR(imx6_pcie->pd_pcie_phy); in imx6_pcie_attach_pd()
355 link = device_link_add(dev, imx6_pcie->pd_pcie_phy, in imx6_pcie_attach_pd()
367 static void imx6_pcie_assert_core_reset(struct imx6_pcie *imx6_pcie) in imx6_pcie_assert_core_reset() argument
369 struct device *dev = imx6_pcie->pci->dev; in imx6_pcie_assert_core_reset()
371 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_assert_core_reset()
374 reset_control_assert(imx6_pcie->pciephy_reset); in imx6_pcie_assert_core_reset()
375 reset_control_assert(imx6_pcie->apps_reset); in imx6_pcie_assert_core_reset()
378 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_assert_core_reset()
382 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR5, in imx6_pcie_assert_core_reset()
387 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()
394 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1, in imx6_pcie_assert_core_reset()
399 if (imx6_pcie->vpcie && regulator_is_enabled(imx6_pcie->vpcie) > 0) { in imx6_pcie_assert_core_reset()
400 int ret = regulator_disable(imx6_pcie->vpcie); in imx6_pcie_assert_core_reset()
408 if (gpio_is_valid(imx6_pcie->reset_gpio)) in imx6_pcie_assert_core_reset()
409 gpio_set_value_cansleep(imx6_pcie->reset_gpio, in imx6_pcie_assert_core_reset()
410 imx6_pcie->gpio_active_high); in imx6_pcie_assert_core_reset()
413 static unsigned int imx6_pcie_grp_offset(const struct imx6_pcie *imx6_pcie) in imx6_pcie_grp_offset() argument
415 WARN_ON(imx6_pcie->drvdata->variant != IMX8MQ); in imx6_pcie_grp_offset()
416 return imx6_pcie->controller_id == 1 ? IOMUXC_GPR16 : IOMUXC_GPR14; in imx6_pcie_grp_offset()
419 static int imx6_pcie_enable_ref_clk(struct imx6_pcie *imx6_pcie) in imx6_pcie_enable_ref_clk() argument
421 struct dw_pcie *pci = imx6_pcie->pci; in imx6_pcie_enable_ref_clk()
426 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_enable_ref_clk()
428 ret = clk_prepare_enable(imx6_pcie->pcie_inbound_axi); in imx6_pcie_enable_ref_clk()
434 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_enable_ref_clk()
440 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1, in imx6_pcie_enable_ref_clk()
449 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1, in imx6_pcie_enable_ref_clk()
455 ret = clk_prepare_enable(imx6_pcie->pcie_aux); in imx6_pcie_enable_ref_clk()
461 offset = imx6_pcie_grp_offset(imx6_pcie); in imx6_pcie_enable_ref_clk()
466 regmap_update_bits(imx6_pcie->iomuxc_gpr, offset, in imx6_pcie_enable_ref_clk()
469 regmap_update_bits(imx6_pcie->iomuxc_gpr, offset, in imx6_pcie_enable_ref_clk()
478 static void imx7d_pcie_wait_for_phy_pll_lock(struct imx6_pcie *imx6_pcie) in imx7d_pcie_wait_for_phy_pll_lock() argument
481 struct device *dev = imx6_pcie->pci->dev; in imx7d_pcie_wait_for_phy_pll_lock()
483 if (regmap_read_poll_timeout(imx6_pcie->iomuxc_gpr, in imx7d_pcie_wait_for_phy_pll_lock()
491 static void imx6_pcie_deassert_core_reset(struct imx6_pcie *imx6_pcie) in imx6_pcie_deassert_core_reset() argument
493 struct dw_pcie *pci = imx6_pcie->pci; in imx6_pcie_deassert_core_reset()
497 if (imx6_pcie->vpcie && !regulator_is_enabled(imx6_pcie->vpcie)) { in imx6_pcie_deassert_core_reset()
498 ret = regulator_enable(imx6_pcie->vpcie); in imx6_pcie_deassert_core_reset()
506 ret = clk_prepare_enable(imx6_pcie->pcie_phy); in imx6_pcie_deassert_core_reset()
512 ret = clk_prepare_enable(imx6_pcie->pcie_bus); in imx6_pcie_deassert_core_reset()
518 ret = clk_prepare_enable(imx6_pcie->pcie); in imx6_pcie_deassert_core_reset()
524 ret = imx6_pcie_enable_ref_clk(imx6_pcie); in imx6_pcie_deassert_core_reset()
533 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_deassert_core_reset()
535 reset_control_deassert(imx6_pcie->pciephy_reset); in imx6_pcie_deassert_core_reset()
538 reset_control_deassert(imx6_pcie->pciephy_reset); in imx6_pcie_deassert_core_reset()
544 if (likely(imx6_pcie->phy_base)) { in imx6_pcie_deassert_core_reset()
547 imx6_pcie->phy_base + PCIE_PHY_CMN_REG4); in imx6_pcie_deassert_core_reset()
551 imx6_pcie->phy_base + PCIE_PHY_CMN_REG24); in imx6_pcie_deassert_core_reset()
554 imx6_pcie->phy_base + PCIE_PHY_CMN_REG26); in imx6_pcie_deassert_core_reset()
559 imx7d_pcie_wait_for_phy_pll_lock(imx6_pcie); in imx6_pcie_deassert_core_reset()
562 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR5, in imx6_pcie_deassert_core_reset()
566 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1, in imx6_pcie_deassert_core_reset()
576 if (gpio_is_valid(imx6_pcie->reset_gpio)) { in imx6_pcie_deassert_core_reset()
578 gpio_set_value_cansleep(imx6_pcie->reset_gpio, in imx6_pcie_deassert_core_reset()
579 !imx6_pcie->gpio_active_high); in imx6_pcie_deassert_core_reset()
587 clk_disable_unprepare(imx6_pcie->pcie); in imx6_pcie_deassert_core_reset()
589 clk_disable_unprepare(imx6_pcie->pcie_bus); in imx6_pcie_deassert_core_reset()
591 clk_disable_unprepare(imx6_pcie->pcie_phy); in imx6_pcie_deassert_core_reset()
593 if (imx6_pcie->vpcie && regulator_is_enabled(imx6_pcie->vpcie) > 0) { in imx6_pcie_deassert_core_reset()
594 ret = regulator_disable(imx6_pcie->vpcie); in imx6_pcie_deassert_core_reset()
601 static void imx6_pcie_configure_type(struct imx6_pcie *imx6_pcie) in imx6_pcie_configure_type() argument
605 if (imx6_pcie->drvdata->variant == IMX8MQ && in imx6_pcie_configure_type()
606 imx6_pcie->controller_id == 1) { in imx6_pcie_configure_type()
616 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, mask, val); in imx6_pcie_configure_type()
619 static void imx6_pcie_init_phy(struct imx6_pcie *imx6_pcie) in imx6_pcie_init_phy() argument
621 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_init_phy()
627 regmap_update_bits(imx6_pcie->iomuxc_gpr, in imx6_pcie_init_phy()
628 imx6_pcie_grp_offset(imx6_pcie), in imx6_pcie_init_phy()
636 if (imx6_pcie->vph && in imx6_pcie_init_phy()
637 regulator_get_voltage(imx6_pcie->vph) > 3000000) in imx6_pcie_init_phy()
638 regmap_update_bits(imx6_pcie->iomuxc_gpr, in imx6_pcie_init_phy()
639 imx6_pcie_grp_offset(imx6_pcie), in imx6_pcie_init_phy()
644 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_init_phy()
648 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_init_phy()
653 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_init_phy()
657 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_init_phy()
660 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR8, in imx6_pcie_init_phy()
662 imx6_pcie->tx_deemph_gen1 << 0); in imx6_pcie_init_phy()
663 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR8, in imx6_pcie_init_phy()
665 imx6_pcie->tx_deemph_gen2_3p5db << 6); in imx6_pcie_init_phy()
666 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR8, in imx6_pcie_init_phy()
668 imx6_pcie->tx_deemph_gen2_6db << 12); in imx6_pcie_init_phy()
669 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR8, in imx6_pcie_init_phy()
671 imx6_pcie->tx_swing_full << 18); in imx6_pcie_init_phy()
672 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR8, in imx6_pcie_init_phy()
674 imx6_pcie->tx_swing_low << 25); in imx6_pcie_init_phy()
678 imx6_pcie_configure_type(imx6_pcie); in imx6_pcie_init_phy()
681 static int imx6_setup_phy_mpll(struct imx6_pcie *imx6_pcie) in imx6_setup_phy_mpll() argument
683 unsigned long phy_rate = clk_get_rate(imx6_pcie->pcie_phy); in imx6_setup_phy_mpll()
687 if (!(imx6_pcie->drvdata->flags & IMX6_PCIE_FLAG_IMX6_PHY)) in imx6_setup_phy_mpll()
706 dev_err(imx6_pcie->pci->dev, in imx6_setup_phy_mpll()
711 pcie_phy_read(imx6_pcie, PCIE_PHY_MPLL_OVRD_IN_LO, &val); in imx6_setup_phy_mpll()
716 pcie_phy_write(imx6_pcie, PCIE_PHY_MPLL_OVRD_IN_LO, val); in imx6_setup_phy_mpll()
718 pcie_phy_read(imx6_pcie, PCIE_PHY_ATEOVRD, &val); in imx6_setup_phy_mpll()
723 pcie_phy_write(imx6_pcie, PCIE_PHY_ATEOVRD, val); in imx6_setup_phy_mpll()
728 static int imx6_pcie_wait_for_speed_change(struct imx6_pcie *imx6_pcie) in imx6_pcie_wait_for_speed_change() argument
730 struct dw_pcie *pci = imx6_pcie->pci; in imx6_pcie_wait_for_speed_change()
749 struct imx6_pcie *imx6_pcie = dev_get_drvdata(dev); in imx6_pcie_ltssm_enable() local
751 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_ltssm_enable()
755 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_ltssm_enable()
761 reset_control_deassert(imx6_pcie->apps_reset); in imx6_pcie_ltssm_enable()
768 struct imx6_pcie *imx6_pcie = to_imx6_pcie(pci); in imx6_pcie_start_link() local
804 if (imx6_pcie->drvdata->flags & in imx6_pcie_start_link()
815 ret = imx6_pcie_wait_for_speed_change(imx6_pcie); in imx6_pcie_start_link()
836 imx6_pcie_reset_phy(imx6_pcie); in imx6_pcie_start_link()
843 struct imx6_pcie *imx6_pcie = to_imx6_pcie(pci); in imx6_pcie_host_init() local
845 imx6_pcie_assert_core_reset(imx6_pcie); in imx6_pcie_host_init()
846 imx6_pcie_init_phy(imx6_pcie); in imx6_pcie_host_init()
847 imx6_pcie_deassert_core_reset(imx6_pcie); in imx6_pcie_host_init()
848 imx6_setup_phy_mpll(imx6_pcie); in imx6_pcie_host_init()
864 struct imx6_pcie *imx6_pcie = dev_get_drvdata(dev); in imx6_pcie_ltssm_disable() local
866 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_ltssm_disable()
869 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_ltssm_disable()
873 reset_control_assert(imx6_pcie->apps_reset); in imx6_pcie_ltssm_disable()
880 static void imx6_pcie_pm_turnoff(struct imx6_pcie *imx6_pcie) in imx6_pcie_pm_turnoff() argument
882 struct device *dev = imx6_pcie->pci->dev; in imx6_pcie_pm_turnoff()
885 if (imx6_pcie->turnoff_reset) { in imx6_pcie_pm_turnoff()
886 reset_control_assert(imx6_pcie->turnoff_reset); in imx6_pcie_pm_turnoff()
887 reset_control_deassert(imx6_pcie->turnoff_reset); in imx6_pcie_pm_turnoff()
892 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_pm_turnoff()
894 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_pm_turnoff()
897 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_pm_turnoff()
916 static void imx6_pcie_clk_disable(struct imx6_pcie *imx6_pcie) in imx6_pcie_clk_disable() argument
918 clk_disable_unprepare(imx6_pcie->pcie); in imx6_pcie_clk_disable()
919 clk_disable_unprepare(imx6_pcie->pcie_phy); in imx6_pcie_clk_disable()
920 clk_disable_unprepare(imx6_pcie->pcie_bus); in imx6_pcie_clk_disable()
922 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_clk_disable()
924 clk_disable_unprepare(imx6_pcie->pcie_inbound_axi); in imx6_pcie_clk_disable()
927 regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12, in imx6_pcie_clk_disable()
932 clk_disable_unprepare(imx6_pcie->pcie_aux); in imx6_pcie_clk_disable()
941 struct imx6_pcie *imx6_pcie = dev_get_drvdata(dev); in imx6_pcie_suspend_noirq() local
943 if (!(imx6_pcie->drvdata->flags & IMX6_PCIE_FLAG_SUPPORTS_SUSPEND)) in imx6_pcie_suspend_noirq()
946 imx6_pcie_pm_turnoff(imx6_pcie); in imx6_pcie_suspend_noirq()
947 imx6_pcie_clk_disable(imx6_pcie); in imx6_pcie_suspend_noirq()
956 struct imx6_pcie *imx6_pcie = dev_get_drvdata(dev); in imx6_pcie_resume_noirq() local
957 struct pcie_port *pp = &imx6_pcie->pci->pp; in imx6_pcie_resume_noirq()
959 if (!(imx6_pcie->drvdata->flags & IMX6_PCIE_FLAG_SUPPORTS_SUSPEND)) in imx6_pcie_resume_noirq()
962 imx6_pcie_assert_core_reset(imx6_pcie); in imx6_pcie_resume_noirq()
963 imx6_pcie_init_phy(imx6_pcie); in imx6_pcie_resume_noirq()
964 imx6_pcie_deassert_core_reset(imx6_pcie); in imx6_pcie_resume_noirq()
967 ret = imx6_pcie_start_link(imx6_pcie->pci); in imx6_pcie_resume_noirq()
984 struct imx6_pcie *imx6_pcie; in imx6_pcie_probe() local
991 imx6_pcie = devm_kzalloc(dev, sizeof(*imx6_pcie), GFP_KERNEL); in imx6_pcie_probe()
992 if (!imx6_pcie) in imx6_pcie_probe()
1003 imx6_pcie->pci = pci; in imx6_pcie_probe()
1004 imx6_pcie->drvdata = of_device_get_match_data(dev); in imx6_pcie_probe()
1016 imx6_pcie->phy_base = devm_ioremap_resource(dev, &res); in imx6_pcie_probe()
1017 if (IS_ERR(imx6_pcie->phy_base)) in imx6_pcie_probe()
1018 return PTR_ERR(imx6_pcie->phy_base); in imx6_pcie_probe()
1027 imx6_pcie->reset_gpio = of_get_named_gpio(node, "reset-gpio", 0); in imx6_pcie_probe()
1028 imx6_pcie->gpio_active_high = of_property_read_bool(node, in imx6_pcie_probe()
1030 if (gpio_is_valid(imx6_pcie->reset_gpio)) { in imx6_pcie_probe()
1031 ret = devm_gpio_request_one(dev, imx6_pcie->reset_gpio, in imx6_pcie_probe()
1032 imx6_pcie->gpio_active_high ? in imx6_pcie_probe()
1040 } else if (imx6_pcie->reset_gpio == -EPROBE_DEFER) { in imx6_pcie_probe()
1041 return imx6_pcie->reset_gpio; in imx6_pcie_probe()
1045 imx6_pcie->pcie_phy = devm_clk_get(dev, "pcie_phy"); in imx6_pcie_probe()
1046 if (IS_ERR(imx6_pcie->pcie_phy)) in imx6_pcie_probe()
1047 return dev_err_probe(dev, PTR_ERR(imx6_pcie->pcie_phy), in imx6_pcie_probe()
1050 imx6_pcie->pcie_bus = devm_clk_get(dev, "pcie_bus"); in imx6_pcie_probe()
1051 if (IS_ERR(imx6_pcie->pcie_bus)) in imx6_pcie_probe()
1052 return dev_err_probe(dev, PTR_ERR(imx6_pcie->pcie_bus), in imx6_pcie_probe()
1055 imx6_pcie->pcie = devm_clk_get(dev, "pcie"); in imx6_pcie_probe()
1056 if (IS_ERR(imx6_pcie->pcie)) in imx6_pcie_probe()
1057 return dev_err_probe(dev, PTR_ERR(imx6_pcie->pcie), in imx6_pcie_probe()
1060 switch (imx6_pcie->drvdata->variant) { in imx6_pcie_probe()
1062 imx6_pcie->pcie_inbound_axi = devm_clk_get(dev, in imx6_pcie_probe()
1064 if (IS_ERR(imx6_pcie->pcie_inbound_axi)) in imx6_pcie_probe()
1065 return dev_err_probe(dev, PTR_ERR(imx6_pcie->pcie_inbound_axi), in imx6_pcie_probe()
1069 imx6_pcie->pcie_aux = devm_clk_get(dev, "pcie_aux"); in imx6_pcie_probe()
1070 if (IS_ERR(imx6_pcie->pcie_aux)) in imx6_pcie_probe()
1071 return dev_err_probe(dev, PTR_ERR(imx6_pcie->pcie_aux), in imx6_pcie_probe()
1076 imx6_pcie->controller_id = 1; in imx6_pcie_probe()
1078 imx6_pcie->pciephy_reset = devm_reset_control_get_exclusive(dev, in imx6_pcie_probe()
1080 if (IS_ERR(imx6_pcie->pciephy_reset)) { in imx6_pcie_probe()
1082 return PTR_ERR(imx6_pcie->pciephy_reset); in imx6_pcie_probe()
1085 imx6_pcie->apps_reset = devm_reset_control_get_exclusive(dev, in imx6_pcie_probe()
1087 if (IS_ERR(imx6_pcie->apps_reset)) { in imx6_pcie_probe()
1089 return PTR_ERR(imx6_pcie->apps_reset); in imx6_pcie_probe()
1097 imx6_pcie->turnoff_reset = devm_reset_control_get_optional_exclusive(dev, "turnoff"); in imx6_pcie_probe()
1098 if (IS_ERR(imx6_pcie->turnoff_reset)) { in imx6_pcie_probe()
1100 return PTR_ERR(imx6_pcie->turnoff_reset); in imx6_pcie_probe()
1104 imx6_pcie->iomuxc_gpr = in imx6_pcie_probe()
1106 if (IS_ERR(imx6_pcie->iomuxc_gpr)) { in imx6_pcie_probe()
1108 return PTR_ERR(imx6_pcie->iomuxc_gpr); in imx6_pcie_probe()
1113 &imx6_pcie->tx_deemph_gen1)) in imx6_pcie_probe()
1114 imx6_pcie->tx_deemph_gen1 = 0; in imx6_pcie_probe()
1117 &imx6_pcie->tx_deemph_gen2_3p5db)) in imx6_pcie_probe()
1118 imx6_pcie->tx_deemph_gen2_3p5db = 0; in imx6_pcie_probe()
1121 &imx6_pcie->tx_deemph_gen2_6db)) in imx6_pcie_probe()
1122 imx6_pcie->tx_deemph_gen2_6db = 20; in imx6_pcie_probe()
1125 &imx6_pcie->tx_swing_full)) in imx6_pcie_probe()
1126 imx6_pcie->tx_swing_full = 127; in imx6_pcie_probe()
1129 &imx6_pcie->tx_swing_low)) in imx6_pcie_probe()
1130 imx6_pcie->tx_swing_low = 127; in imx6_pcie_probe()
1136 imx6_pcie->vpcie = devm_regulator_get_optional(&pdev->dev, "vpcie"); in imx6_pcie_probe()
1137 if (IS_ERR(imx6_pcie->vpcie)) { in imx6_pcie_probe()
1138 if (PTR_ERR(imx6_pcie->vpcie) != -ENODEV) in imx6_pcie_probe()
1139 return PTR_ERR(imx6_pcie->vpcie); in imx6_pcie_probe()
1140 imx6_pcie->vpcie = NULL; in imx6_pcie_probe()
1143 imx6_pcie->vph = devm_regulator_get_optional(&pdev->dev, "vph"); in imx6_pcie_probe()
1144 if (IS_ERR(imx6_pcie->vph)) { in imx6_pcie_probe()
1145 if (PTR_ERR(imx6_pcie->vph) != -ENODEV) in imx6_pcie_probe()
1146 return PTR_ERR(imx6_pcie->vph); in imx6_pcie_probe()
1147 imx6_pcie->vph = NULL; in imx6_pcie_probe()
1150 platform_set_drvdata(pdev, imx6_pcie); in imx6_pcie_probe()
1172 struct imx6_pcie *imx6_pcie = platform_get_drvdata(pdev); in imx6_pcie_shutdown() local
1175 imx6_pcie_assert_core_reset(imx6_pcie); in imx6_pcie_shutdown()
1242 struct imx6_pcie *imx6_pcie = to_imx6_pcie(pci); in imx6_pcie_quirk() local
1248 if (imx6_pcie->drvdata->dbi_length) { in imx6_pcie_quirk()
1249 dev->cfg_size = imx6_pcie->drvdata->dbi_length; in imx6_pcie_quirk()