On Wed, Sep 27, 2017 at 05:28:35PM +0530, Manikanta Maddireddy wrote: > UPHY programming is performed by BPMP, PHY enable calls are > not required for Tegra186 PCIe. Power partition ungate is > done by BPMP powergate driver. > > Signed-off-by: Manikanta Maddireddy <mmaddireddy@xxxxxxxxxx> > Reviewed-by: Mikko Perttunen <mperttunen@xxxxxxxxxx> > Tested-by: Mikko Perttunen <mperttunen@xxxxxxxxxx> > --- > V2: Add soc->program_uphy check for phy_exit call > drivers/pci/host/pci-tegra.c | 132 +++++++++++++++++++++++++++++++++++-------- > 1 file changed, 108 insertions(+), 24 deletions(-) > @@ -1012,10 +1016,12 @@ static int tegra_pcie_enable_controller(struct tegra_pcie *pcie) > afi_writel(pcie, value, AFI_FUSE); > } > > - err = tegra_pcie_phy_power_on(pcie); > - if (err < 0) { > - dev_err(dev, "failed to power on PHY(s): %d\n", err); > - return err; > + if (soc->program_uphy) { > + err = tegra_pcie_phy_power_on(pcie); > + if (err < 0) { > + dev_err(dev, "failed to power on PHY(s): %d\n", err); > + return err; > + } This looks good: it's obvious that the previously-supported devices continue to work the same way because you set ".program_uphy = true" for them. (It would be even more obvious if you changed the sense so that only the new device had to add this initializaer, but in general I prefer the positive logic as you have here, and I did verify that you added the initializer for all tegra_pcie_soc variants.) > @@ -1048,19 +1054,23 @@ static int tegra_pcie_enable_controller(struct tegra_pcie *pcie) > static void tegra_pcie_power_off(struct tegra_pcie *pcie) > { > struct device *dev = pcie->dev; > + const struct tegra_pcie_soc *soc = pcie->soc; > int err; > > /* TODO: disable and unprepare clocks? */ > > - err = tegra_pcie_phy_power_off(pcie); > - if (err < 0) > - dev_err(dev, "failed to power off PHY(s): %d\n", err); > + if (soc->program_uphy) { > + err = tegra_pcie_phy_power_off(pcie); > + if (err < 0) > + dev_err(dev, "failed to power off PHY(s): %d\n", err); > + } > > reset_control_assert(pcie->pcie_xrst); > reset_control_assert(pcie->afi_rst); > reset_control_assert(pcie->pex_rst); > > - tegra_powergate_power_off(TEGRA_POWERGATE_PCIE); > + if (!dev->pm_domain) > + tegra_powergate_power_off(TEGRA_POWERGATE_PCIE); But this one isn't obvious because nothing in your patch obviously affects dev->pm_domain, so I can't tell whether this is safe. It's worth a changelog comment to help justify this. Bjorn