Commit b8f0d671 authored by Vidya Sagar's avatar Vidya Sagar Committed by Lorenzo Pieralisi

PCI: tegra: Continue unconfig sequence even if parts fail

Currently the driver checks for error value of different APIs during the
uninitialization sequence. It just returns from there if there is any error
observed for one of those calls. Comparatively it is better to continue the
uninitialization sequence irrespective of whether some of them are
returning error. That way, it is more closer to complete uninitialization.

Link: https://lore.kernel.org/r/20201203133451.17716-4-vidyas@nvidia.comTested-by: default avatarThierry Reding <treding@nvidia.com>
Signed-off-by: default avatarVidya Sagar <vidyas@nvidia.com>
Signed-off-by: default avatarLorenzo Pieralisi <lorenzo.pieralisi@arm.com>
Acked-by: default avatarThierry Reding <treding@nvidia.com>
parent 01254b6d
...@@ -1415,43 +1415,32 @@ static int tegra_pcie_config_controller(struct tegra_pcie_dw *pcie, ...@@ -1415,43 +1415,32 @@ static int tegra_pcie_config_controller(struct tegra_pcie_dw *pcie,
return ret; return ret;
} }
static int __deinit_controller(struct tegra_pcie_dw *pcie) static void tegra_pcie_unconfig_controller(struct tegra_pcie_dw *pcie)
{ {
int ret; int ret;
ret = reset_control_assert(pcie->core_rst); ret = reset_control_assert(pcie->core_rst);
if (ret) { if (ret)
dev_err(pcie->dev, "Failed to assert \"core\" reset: %d\n", dev_err(pcie->dev, "Failed to assert \"core\" reset: %d\n", ret);
ret);
return ret;
}
tegra_pcie_disable_phy(pcie); tegra_pcie_disable_phy(pcie);
ret = reset_control_assert(pcie->core_apb_rst); ret = reset_control_assert(pcie->core_apb_rst);
if (ret) { if (ret)
dev_err(pcie->dev, "Failed to assert APB reset: %d\n", ret); dev_err(pcie->dev, "Failed to assert APB reset: %d\n", ret);
return ret;
}
clk_disable_unprepare(pcie->core_clk); clk_disable_unprepare(pcie->core_clk);
ret = regulator_disable(pcie->pex_ctl_supply); ret = regulator_disable(pcie->pex_ctl_supply);
if (ret) { if (ret)
dev_err(pcie->dev, "Failed to disable regulator: %d\n", ret); dev_err(pcie->dev, "Failed to disable regulator: %d\n", ret);
return ret;
}
tegra_pcie_disable_slot_regulators(pcie); tegra_pcie_disable_slot_regulators(pcie);
ret = tegra_pcie_bpmp_set_ctrl_state(pcie, false); ret = tegra_pcie_bpmp_set_ctrl_state(pcie, false);
if (ret) { if (ret)
dev_err(pcie->dev, "Failed to disable controller %d: %d\n", dev_err(pcie->dev, "Failed to disable controller %d: %d\n",
pcie->cid, ret); pcie->cid, ret);
return ret;
}
return ret;
} }
static int tegra_pcie_init_controller(struct tegra_pcie_dw *pcie) static int tegra_pcie_init_controller(struct tegra_pcie_dw *pcie)
...@@ -1475,7 +1464,8 @@ static int tegra_pcie_init_controller(struct tegra_pcie_dw *pcie) ...@@ -1475,7 +1464,8 @@ static int tegra_pcie_init_controller(struct tegra_pcie_dw *pcie)
return 0; return 0;
fail_host_init: fail_host_init:
return __deinit_controller(pcie); tegra_pcie_unconfig_controller(pcie);
return ret;
} }
static int tegra_pcie_try_link_l2(struct tegra_pcie_dw *pcie) static int tegra_pcie_try_link_l2(struct tegra_pcie_dw *pcie)
...@@ -1544,13 +1534,12 @@ static void tegra_pcie_dw_pme_turnoff(struct tegra_pcie_dw *pcie) ...@@ -1544,13 +1534,12 @@ static void tegra_pcie_dw_pme_turnoff(struct tegra_pcie_dw *pcie)
appl_writel(pcie, data, APPL_PINMUX); appl_writel(pcie, data, APPL_PINMUX);
} }
static int tegra_pcie_deinit_controller(struct tegra_pcie_dw *pcie) static void tegra_pcie_deinit_controller(struct tegra_pcie_dw *pcie)
{ {
tegra_pcie_downstream_dev_to_D0(pcie); tegra_pcie_downstream_dev_to_D0(pcie);
dw_pcie_host_deinit(&pcie->pci.pp); dw_pcie_host_deinit(&pcie->pci.pp);
tegra_pcie_dw_pme_turnoff(pcie); tegra_pcie_dw_pme_turnoff(pcie);
tegra_pcie_unconfig_controller(pcie);
return __deinit_controller(pcie);
} }
static int tegra_pcie_config_rp(struct tegra_pcie_dw *pcie) static int tegra_pcie_config_rp(struct tegra_pcie_dw *pcie)
...@@ -2197,8 +2186,9 @@ static int tegra_pcie_dw_suspend_noirq(struct device *dev) ...@@ -2197,8 +2186,9 @@ static int tegra_pcie_dw_suspend_noirq(struct device *dev)
PORT_LOGIC_MSI_CTRL_INT_0_EN); PORT_LOGIC_MSI_CTRL_INT_0_EN);
tegra_pcie_downstream_dev_to_D0(pcie); tegra_pcie_downstream_dev_to_D0(pcie);
tegra_pcie_dw_pme_turnoff(pcie); tegra_pcie_dw_pme_turnoff(pcie);
tegra_pcie_unconfig_controller(pcie);
return __deinit_controller(pcie); return 0;
} }
static int tegra_pcie_dw_resume_noirq(struct device *dev) static int tegra_pcie_dw_resume_noirq(struct device *dev)
...@@ -2226,7 +2216,8 @@ static int tegra_pcie_dw_resume_noirq(struct device *dev) ...@@ -2226,7 +2216,8 @@ static int tegra_pcie_dw_resume_noirq(struct device *dev)
return 0; return 0;
fail_host_init: fail_host_init:
return __deinit_controller(pcie); tegra_pcie_unconfig_controller(pcie);
return ret;
} }
static int tegra_pcie_dw_resume_early(struct device *dev) static int tegra_pcie_dw_resume_early(struct device *dev)
...@@ -2264,7 +2255,7 @@ static void tegra_pcie_dw_shutdown(struct platform_device *pdev) ...@@ -2264,7 +2255,7 @@ static void tegra_pcie_dw_shutdown(struct platform_device *pdev)
disable_irq(pcie->pci.pp.msi_irq); disable_irq(pcie->pci.pp.msi_irq);
tegra_pcie_dw_pme_turnoff(pcie); tegra_pcie_dw_pme_turnoff(pcie);
__deinit_controller(pcie); tegra_pcie_unconfig_controller(pcie);
} }
static const struct tegra_pcie_dw_of_data tegra_pcie_dw_rc_of_data = { static const struct tegra_pcie_dw_of_data tegra_pcie_dw_rc_of_data = {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment