struct reset_control *afi_rst;
struct reset_control *pcie_xrst;
+ struct tegra_pmc *pmc;
+
bool legacy_phy;
struct phy *phy;
clk_disable_unprepare(pcie->afi_clk);
if (!dev->pm_domain)
- tegra_powergate_power_off(TEGRA_POWERGATE_PCIE);
+ tegra_pmc_powergate_power_off(pcie->pmc, TEGRA_POWERGATE_PCIE);
err = regulator_bulk_disable(pcie->num_supplies, pcie->supplies);
if (err < 0)
reset_control_assert(pcie->pex_rst);
if (!dev->pm_domain)
- tegra_powergate_power_off(TEGRA_POWERGATE_PCIE);
+ tegra_pmc_powergate_power_off(pcie->pmc, TEGRA_POWERGATE_PCIE);
/* enable regulators */
err = regulator_bulk_enable(pcie->num_supplies, pcie->supplies);
dev_err(dev, "failed to enable regulators: %d\n", err);
if (!dev->pm_domain) {
- err = tegra_powergate_power_on(TEGRA_POWERGATE_PCIE);
+ err = tegra_pmc_powergate_power_on(pcie->pmc,
+ TEGRA_POWERGATE_PCIE);
if (err) {
dev_err(dev, "failed to power ungate: %d\n", err);
goto regulator_disable;
}
- err = tegra_powergate_remove_clamping(TEGRA_POWERGATE_PCIE);
+ err = tegra_pmc_powergate_remove_clamping(pcie->pmc,
+ TEGRA_POWERGATE_PCIE);
if (err) {
dev_err(dev, "failed to remove clamp: %d\n", err);
goto powergate;
clk_disable_unprepare(pcie->afi_clk);
powergate:
if (!dev->pm_domain)
- tegra_powergate_power_off(TEGRA_POWERGATE_PCIE);
+ tegra_pmc_powergate_power_off(pcie->pmc, TEGRA_POWERGATE_PCIE);
regulator_disable:
regulator_bulk_disable(pcie->num_supplies, pcie->supplies);
return err;
}
+ pcie->pmc = devm_tegra_pmc_get(dev);
+ if (IS_ERR(pcie->pmc))
+ return dev_err_probe(dev, PTR_ERR(pcie->pmc),
+ "failed to get PMC\n");
+
if (soc->program_uphy) {
err = tegra_pcie_phys_get(pcie);
if (err < 0) {