Commit b9ac0f9d authored by Rob Herring's avatar Rob Herring Committed by Lorenzo Pieralisi

PCI: dwc: Move dw_pcie_setup_rc() to DWC common code

All RC complex drivers must call dw_pcie_setup_rc(). The ordering of the
call shouldn't be too important other than being after any RC resets.

There's a few calls of dw_pcie_setup_rc() left as drivers implementing
suspend/resume need it.

Link: https://lore.kernel.org/r/20201105211159.1814485-13-robh@kernel.orgTested-by: default avatarMarek Szyprowski <m.szyprowski@samsung.com>
Signed-off-by: default avatarRob Herring <robh@kernel.org>
Signed-off-by: default avatarLorenzo Pieralisi <lorenzo.pieralisi@arm.com>
Acked-by: default avatarJingoo Han <jingoohan1@gmail.com>
Cc: Kishon Vijay Abraham I <kishon@ti.com>
Cc: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
Cc: Bjorn Helgaas <bhelgaas@google.com>
Cc: Kukjin Kim <kgene@kernel.org>
Cc: Krzysztof Kozlowski <krzk@kernel.org>
Cc: Richard Zhu <hongxing.zhu@nxp.com>
Cc: Lucas Stach <l.stach@pengutronix.de>
Cc: Shawn Guo <shawnguo@kernel.org>
Cc: Sascha Hauer <s.hauer@pengutronix.de>
Cc: Pengutronix Kernel Team <kernel@pengutronix.de>
Cc: Fabio Estevam <festevam@gmail.com>
Cc: NXP Linux Team <linux-imx@nxp.com>
Cc: Murali Karicheri <m-karicheri2@ti.com>
Cc: Minghuan Lian <minghuan.Lian@nxp.com>
Cc: Mingkai Hu <mingkai.hu@nxp.com>
Cc: Roy Zang <roy.zang@nxp.com>
Cc: Yue Wang <yue.wang@Amlogic.com>
Cc: Kevin Hilman <khilman@baylibre.com>
Cc: Neil Armstrong <narmstrong@baylibre.com>
Cc: Jerome Brunet <jbrunet@baylibre.com>
Cc: Martin Blumenstingl <martin.blumenstingl@googlemail.com>
Cc: Thomas Petazzoni <thomas.petazzoni@bootlin.com>
Cc: Jesper Nilsson <jesper.nilsson@axis.com>
Cc: Gustavo Pimentel <gustavo.pimentel@synopsys.com>
Cc: Xiaowei Song <songxiaowei@hisilicon.com>
Cc: Binghui Wang <wangbinghui@hisilicon.com>
Cc: Andy Gross <agross@kernel.org>
Cc: Bjorn Andersson <bjorn.andersson@linaro.org>
Cc: Stanimir Varbanov <svarbanov@mm-sol.com>
Cc: Pratyush Anand <pratyush.anand@gmail.com>
Cc: Kunihiko Hayashi <hayashi.kunihiko@socionext.com>
Cc: Masahiro Yamada <yamada.masahiro@socionext.com>
Cc: linux-omap@vger.kernel.org
Cc: linux-samsung-soc@vger.kernel.org
Cc: linuxppc-dev@lists.ozlabs.org
Cc: linux-amlogic@lists.infradead.org
Cc: linux-arm-kernel@axis.com
Cc: linux-arm-msm@vger.kernel.org
parent 59fbab1a
...@@ -181,7 +181,6 @@ static int dra7xx_pcie_host_init(struct pcie_port *pp) ...@@ -181,7 +181,6 @@ static int dra7xx_pcie_host_init(struct pcie_port *pp)
struct dw_pcie *pci = to_dw_pcie_from_pp(pp); struct dw_pcie *pci = to_dw_pcie_from_pp(pp);
struct dra7xx_pcie *dra7xx = to_dra7xx_pcie(pci); struct dra7xx_pcie *dra7xx = to_dra7xx_pcie(pci);
dw_pcie_setup_rc(pp);
dra7xx_pcie_enable_interrupts(dra7xx); dra7xx_pcie_enable_interrupts(dra7xx);
return 0; return 0;
......
...@@ -372,7 +372,6 @@ static int exynos_pcie_host_init(struct pcie_port *pp) ...@@ -372,7 +372,6 @@ static int exynos_pcie_host_init(struct pcie_port *pp)
phy_init(ep->phy); phy_init(ep->phy);
exynos_pcie_deassert_core_reset(ep); exynos_pcie_deassert_core_reset(ep);
dw_pcie_setup_rc(pp);
exynos_pcie_assert_reset(ep); exynos_pcie_assert_reset(ep);
exynos_pcie_enable_interrupts(ep); exynos_pcie_enable_interrupts(ep);
......
...@@ -834,7 +834,6 @@ static int imx6_pcie_host_init(struct pcie_port *pp) ...@@ -834,7 +834,6 @@ static int imx6_pcie_host_init(struct pcie_port *pp)
imx6_pcie_init_phy(imx6_pcie); imx6_pcie_init_phy(imx6_pcie);
imx6_pcie_deassert_core_reset(imx6_pcie); imx6_pcie_deassert_core_reset(imx6_pcie);
imx6_setup_phy_mpll(imx6_pcie); imx6_setup_phy_mpll(imx6_pcie);
dw_pcie_setup_rc(pp);
return 0; return 0;
} }
......
...@@ -807,8 +807,6 @@ static int __init ks_pcie_host_init(struct pcie_port *pp) ...@@ -807,8 +807,6 @@ static int __init ks_pcie_host_init(struct pcie_port *pp)
if (ret) if (ret)
return ret; return ret;
dw_pcie_setup_rc(pp);
ks_pcie_stop_link(pci); ks_pcie_stop_link(pci);
ks_pcie_setup_rc_app_regs(ks_pcie); ks_pcie_setup_rc_app_regs(ks_pcie);
writew(PCI_IO_RANGE_TYPE_32 | (PCI_IO_RANGE_TYPE_32 << 8), writew(PCI_IO_RANGE_TYPE_32 | (PCI_IO_RANGE_TYPE_32 << 8),
......
...@@ -136,8 +136,6 @@ static int ls_pcie_host_init(struct pcie_port *pp) ...@@ -136,8 +136,6 @@ static int ls_pcie_host_init(struct pcie_port *pp)
ls_pcie_drop_msg_tlp(pcie); ls_pcie_drop_msg_tlp(pcie);
dw_pcie_setup_rc(pp);
return 0; return 0;
} }
......
...@@ -380,8 +380,6 @@ static int meson_pcie_host_init(struct pcie_port *pp) ...@@ -380,8 +380,6 @@ static int meson_pcie_host_init(struct pcie_port *pp)
meson_set_max_payload(mp, MAX_PAYLOAD_SIZE); meson_set_max_payload(mp, MAX_PAYLOAD_SIZE);
meson_set_max_rd_req_size(mp, MAX_READ_REQ_SIZE); meson_set_max_rd_req_size(mp, MAX_READ_REQ_SIZE);
dw_pcie_setup_rc(pp);
return 0; return 0;
} }
......
...@@ -171,8 +171,6 @@ static int armada8k_pcie_host_init(struct pcie_port *pp) ...@@ -171,8 +171,6 @@ static int armada8k_pcie_host_init(struct pcie_port *pp)
u32 reg; u32 reg;
struct dw_pcie *pci = to_dw_pcie_from_pp(pp); struct dw_pcie *pci = to_dw_pcie_from_pp(pp);
dw_pcie_setup_rc(pp);
if (!dw_pcie_link_up(pci)) { if (!dw_pcie_link_up(pci)) {
/* Disable LTSSM state machine to enable configuration */ /* Disable LTSSM state machine to enable configuration */
reg = dw_pcie_readl_dbi(pci, PCIE_GLOBAL_CONTROL_REG); reg = dw_pcie_readl_dbi(pci, PCIE_GLOBAL_CONTROL_REG);
......
...@@ -328,7 +328,6 @@ static int artpec6_pcie_host_init(struct pcie_port *pp) ...@@ -328,7 +328,6 @@ static int artpec6_pcie_host_init(struct pcie_port *pp)
artpec6_pcie_init_phy(artpec6_pcie); artpec6_pcie_init_phy(artpec6_pcie);
artpec6_pcie_deassert_core_reset(artpec6_pcie); artpec6_pcie_deassert_core_reset(artpec6_pcie);
artpec6_pcie_wait_for_phy(artpec6_pcie); artpec6_pcie_wait_for_phy(artpec6_pcie);
dw_pcie_setup_rc(pp);
return 0; return 0;
} }
......
...@@ -422,6 +422,7 @@ int dw_pcie_host_init(struct pcie_port *pp) ...@@ -422,6 +422,7 @@ int dw_pcie_host_init(struct pcie_port *pp)
goto err_free_msi; goto err_free_msi;
} }
dw_pcie_setup_rc(pp);
dw_pcie_msi_init(pp); dw_pcie_msi_init(pp);
if (!dw_pcie_link_up(pci) && pci->ops->start_link) { if (!dw_pcie_link_up(pci) && pci->ops->start_link) {
......
...@@ -33,15 +33,7 @@ struct dw_plat_pcie_of_data { ...@@ -33,15 +33,7 @@ struct dw_plat_pcie_of_data {
static const struct of_device_id dw_plat_pcie_of_match[]; static const struct of_device_id dw_plat_pcie_of_match[];
static int dw_plat_pcie_host_init(struct pcie_port *pp)
{
dw_pcie_setup_rc(pp);
return 0;
}
static const struct dw_pcie_host_ops dw_plat_pcie_host_ops = { static const struct dw_pcie_host_ops dw_plat_pcie_host_ops = {
.host_init = dw_plat_pcie_host_init,
}; };
static int dw_plat_pcie_establish_link(struct dw_pcie *pci) static int dw_plat_pcie_establish_link(struct dw_pcie *pci)
......
...@@ -196,9 +196,6 @@ static int histb_pcie_host_init(struct pcie_port *pp) ...@@ -196,9 +196,6 @@ static int histb_pcie_host_init(struct pcie_port *pp)
regval |= PCIE_WM_RC; regval |= PCIE_WM_RC;
histb_pcie_writel(hipcie, PCIE_SYS_CTRL0, regval); histb_pcie_writel(hipcie, PCIE_SYS_CTRL0, regval);
/* setup root complex */
dw_pcie_setup_rc(pp);
return 0; return 0;
} }
......
...@@ -405,8 +405,6 @@ static int kirin_pcie_host_init(struct pcie_port *pp) ...@@ -405,8 +405,6 @@ static int kirin_pcie_host_init(struct pcie_port *pp)
{ {
pp->bridge->ops = &kirin_pci_ops; pp->bridge->ops = &kirin_pci_ops;
dw_pcie_setup_rc(pp);
return 0; return 0;
} }
......
...@@ -1280,7 +1280,6 @@ static int qcom_pcie_host_init(struct pcie_port *pp) ...@@ -1280,7 +1280,6 @@ static int qcom_pcie_host_init(struct pcie_port *pp)
goto err_disable_phy; goto err_disable_phy;
} }
dw_pcie_setup_rc(pp);
qcom_ep_reset_deassert(pcie); qcom_ep_reset_deassert(pcie);
return 0; return 0;
......
...@@ -130,8 +130,6 @@ static int spear13xx_pcie_host_init(struct pcie_port *pp) ...@@ -130,8 +130,6 @@ static int spear13xx_pcie_host_init(struct pcie_port *pp)
spear13xx_pcie->app_base = pci->dbi_base + 0x2000; spear13xx_pcie->app_base = pci->dbi_base + 0x2000;
dw_pcie_setup_rc(pp);
/* /*
* this controller support only 128 bytes read size, however its * this controller support only 128 bytes read size, however its
* default value in capability register is 512 bytes. So force * default value in capability register is 512 bytes. So force
......
...@@ -314,8 +314,6 @@ static int uniphier_pcie_host_init(struct pcie_port *pp) ...@@ -314,8 +314,6 @@ static int uniphier_pcie_host_init(struct pcie_port *pp)
uniphier_pcie_irq_enable(priv); uniphier_pcie_irq_enable(priv);
dw_pcie_setup_rc(pp);
return 0; return 0;
} }
......
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