Commit 59fbab1a authored by Rob Herring's avatar Rob Herring Committed by Lorenzo Pieralisi

PCI: dwc: Move dw_pcie_msi_init() into core

The host drivers which call dw_pcie_msi_init() are all the ones using
the built-in MSI controller, so let's move it into the common DWC code.

Link: https://lore.kernel.org/r/20201105211159.1814485-12-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: 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: 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: Stanimir Varbanov <svarbanov@mm-sol.com>
Cc: Andy Gross <agross@kernel.org>
Cc: Bjorn Andersson <bjorn.andersson@linaro.org>
Cc: Pratyush Anand <pratyush.anand@gmail.com>
Cc: Thierry Reding <thierry.reding@gmail.com>
Cc: Jonathan Hunter <jonathanh@nvidia.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: linux-amlogic@lists.infradead.org
Cc: linux-arm-kernel@axis.com
Cc: linux-arm-msm@vger.kernel.org
Cc: linux-tegra@vger.kernel.org
parent 886a9c13
...@@ -182,8 +182,6 @@ static int dra7xx_pcie_host_init(struct pcie_port *pp) ...@@ -182,8 +182,6 @@ static int dra7xx_pcie_host_init(struct pcie_port *pp)
struct dra7xx_pcie *dra7xx = to_dra7xx_pcie(pci); struct dra7xx_pcie *dra7xx = to_dra7xx_pcie(pci);
dw_pcie_setup_rc(pp); dw_pcie_setup_rc(pp);
dw_pcie_msi_init(pp);
dra7xx_pcie_enable_interrupts(dra7xx); dra7xx_pcie_enable_interrupts(dra7xx);
return 0; return 0;
......
...@@ -273,12 +273,8 @@ static irqreturn_t exynos_pcie_irq_handler(int irq, void *arg) ...@@ -273,12 +273,8 @@ static irqreturn_t exynos_pcie_irq_handler(int irq, void *arg)
static void exynos_pcie_msi_init(struct exynos_pcie *ep) static void exynos_pcie_msi_init(struct exynos_pcie *ep)
{ {
struct dw_pcie *pci = ep->pci;
struct pcie_port *pp = &pci->pp;
u32 val; u32 val;
dw_pcie_msi_init(pp);
/* enable MSI interrupt */ /* enable MSI interrupt */
val = exynos_pcie_readl(ep->mem_res->elbi_base, PCIE_IRQ_EN_LEVEL); val = exynos_pcie_readl(ep->mem_res->elbi_base, PCIE_IRQ_EN_LEVEL);
val |= IRQ_MSI_ENABLE; val |= IRQ_MSI_ENABLE;
......
...@@ -835,7 +835,6 @@ static int imx6_pcie_host_init(struct pcie_port *pp) ...@@ -835,7 +835,6 @@ static int imx6_pcie_host_init(struct pcie_port *pp)
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); dw_pcie_setup_rc(pp);
dw_pcie_msi_init(pp);
return 0; return 0;
} }
......
...@@ -381,7 +381,6 @@ static int meson_pcie_host_init(struct pcie_port *pp) ...@@ -381,7 +381,6 @@ static int meson_pcie_host_init(struct pcie_port *pp)
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); dw_pcie_setup_rc(pp);
dw_pcie_msi_init(pp);
return 0; return 0;
} }
......
...@@ -329,7 +329,6 @@ static int artpec6_pcie_host_init(struct pcie_port *pp) ...@@ -329,7 +329,6 @@ static int artpec6_pcie_host_init(struct pcie_port *pp)
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); dw_pcie_setup_rc(pp);
dw_pcie_msi_init(pp);
return 0; return 0;
} }
......
...@@ -256,7 +256,7 @@ int dw_pcie_allocate_domains(struct pcie_port *pp) ...@@ -256,7 +256,7 @@ int dw_pcie_allocate_domains(struct pcie_port *pp)
return 0; return 0;
} }
void dw_pcie_free_msi(struct pcie_port *pp) static void dw_pcie_free_msi(struct pcie_port *pp)
{ {
if (pp->msi_irq) { if (pp->msi_irq) {
irq_set_chained_handler(pp->msi_irq, NULL); irq_set_chained_handler(pp->msi_irq, NULL);
...@@ -275,19 +275,18 @@ void dw_pcie_free_msi(struct pcie_port *pp) ...@@ -275,19 +275,18 @@ void dw_pcie_free_msi(struct pcie_port *pp)
} }
} }
void dw_pcie_msi_init(struct pcie_port *pp) static void dw_pcie_msi_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);
u64 msi_target = (u64)pp->msi_data; u64 msi_target = (u64)pp->msi_data;
if (!IS_ENABLED(CONFIG_PCI_MSI)) if (!pci_msi_enabled() || !pp->has_msi_ctrl)
return; return;
/* Program the msi_data */ /* Program the msi_data */
dw_pcie_writel_dbi(pci, PCIE_MSI_ADDR_LO, lower_32_bits(msi_target)); dw_pcie_writel_dbi(pci, PCIE_MSI_ADDR_LO, lower_32_bits(msi_target));
dw_pcie_writel_dbi(pci, PCIE_MSI_ADDR_HI, upper_32_bits(msi_target)); dw_pcie_writel_dbi(pci, PCIE_MSI_ADDR_HI, upper_32_bits(msi_target));
} }
EXPORT_SYMBOL_GPL(dw_pcie_msi_init);
int dw_pcie_host_init(struct pcie_port *pp) int dw_pcie_host_init(struct pcie_port *pp)
{ {
...@@ -423,6 +422,8 @@ int dw_pcie_host_init(struct pcie_port *pp) ...@@ -423,6 +422,8 @@ int dw_pcie_host_init(struct pcie_port *pp)
goto err_free_msi; goto err_free_msi;
} }
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) {
ret = pci->ops->start_link(pci); ret = pci->ops->start_link(pci);
if (ret) if (ret)
......
...@@ -36,7 +36,6 @@ static const struct of_device_id dw_plat_pcie_of_match[]; ...@@ -36,7 +36,6 @@ static const struct of_device_id dw_plat_pcie_of_match[];
static int dw_plat_pcie_host_init(struct pcie_port *pp) static int dw_plat_pcie_host_init(struct pcie_port *pp)
{ {
dw_pcie_setup_rc(pp); dw_pcie_setup_rc(pp);
dw_pcie_msi_init(pp);
return 0; return 0;
} }
......
...@@ -364,8 +364,6 @@ static inline void dw_pcie_dbi_ro_wr_dis(struct dw_pcie *pci) ...@@ -364,8 +364,6 @@ static inline void dw_pcie_dbi_ro_wr_dis(struct dw_pcie *pci)
#ifdef CONFIG_PCIE_DW_HOST #ifdef CONFIG_PCIE_DW_HOST
irqreturn_t dw_handle_msi_irq(struct pcie_port *pp); irqreturn_t dw_handle_msi_irq(struct pcie_port *pp);
void dw_pcie_msi_init(struct pcie_port *pp);
void dw_pcie_free_msi(struct pcie_port *pp);
void dw_pcie_setup_rc(struct pcie_port *pp); void dw_pcie_setup_rc(struct pcie_port *pp);
int dw_pcie_host_init(struct pcie_port *pp); int dw_pcie_host_init(struct pcie_port *pp);
void dw_pcie_host_deinit(struct pcie_port *pp); void dw_pcie_host_deinit(struct pcie_port *pp);
...@@ -378,14 +376,6 @@ static inline irqreturn_t dw_handle_msi_irq(struct pcie_port *pp) ...@@ -378,14 +376,6 @@ static inline irqreturn_t dw_handle_msi_irq(struct pcie_port *pp)
return IRQ_NONE; return IRQ_NONE;
} }
static inline void dw_pcie_msi_init(struct pcie_port *pp)
{
}
static inline void dw_pcie_free_msi(struct pcie_port *pp)
{
}
static inline void dw_pcie_setup_rc(struct pcie_port *pp) static inline void dw_pcie_setup_rc(struct pcie_port *pp)
{ {
} }
......
...@@ -199,8 +199,6 @@ static int histb_pcie_host_init(struct pcie_port *pp) ...@@ -199,8 +199,6 @@ static int histb_pcie_host_init(struct pcie_port *pp)
/* setup root complex */ /* setup root complex */
dw_pcie_setup_rc(pp); dw_pcie_setup_rc(pp);
dw_pcie_msi_init(pp);
return 0; return 0;
} }
......
...@@ -406,7 +406,6 @@ static int kirin_pcie_host_init(struct pcie_port *pp) ...@@ -406,7 +406,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); dw_pcie_setup_rc(pp);
dw_pcie_msi_init(pp);
return 0; return 0;
} }
......
...@@ -1281,8 +1281,6 @@ static int qcom_pcie_host_init(struct pcie_port *pp) ...@@ -1281,8 +1281,6 @@ static int qcom_pcie_host_init(struct pcie_port *pp)
} }
dw_pcie_setup_rc(pp); dw_pcie_setup_rc(pp);
dw_pcie_msi_init(pp);
qcom_ep_reset_deassert(pcie); qcom_ep_reset_deassert(pcie);
return 0; return 0;
......
...@@ -102,16 +102,12 @@ static irqreturn_t spear13xx_pcie_irq_handler(int irq, void *arg) ...@@ -102,16 +102,12 @@ static irqreturn_t spear13xx_pcie_irq_handler(int irq, void *arg)
static void spear13xx_pcie_enable_interrupts(struct spear13xx_pcie *spear13xx_pcie) static void spear13xx_pcie_enable_interrupts(struct spear13xx_pcie *spear13xx_pcie)
{ {
struct dw_pcie *pci = spear13xx_pcie->pci;
struct pcie_port *pp = &pci->pp;
struct pcie_app_reg *app_reg = spear13xx_pcie->app_base; struct pcie_app_reg *app_reg = spear13xx_pcie->app_base;
/* Enable MSI interrupt */ /* Enable MSI interrupt */
if (IS_ENABLED(CONFIG_PCI_MSI)) { if (IS_ENABLED(CONFIG_PCI_MSI))
dw_pcie_msi_init(pp);
writel(readl(&app_reg->int_mask) | writel(readl(&app_reg->int_mask) |
MSI_CTRL_INT, &app_reg->int_mask); MSI_CTRL_INT, &app_reg->int_mask);
}
} }
static int spear13xx_pcie_link_up(struct dw_pcie *pci) static int spear13xx_pcie_link_up(struct dw_pcie *pci)
......
...@@ -765,8 +765,6 @@ static void tegra_pcie_enable_msi_interrupts(struct pcie_port *pp) ...@@ -765,8 +765,6 @@ static void tegra_pcie_enable_msi_interrupts(struct pcie_port *pp)
struct tegra_pcie_dw *pcie = to_tegra_pcie(pci); struct tegra_pcie_dw *pcie = to_tegra_pcie(pci);
u32 val; u32 val;
dw_pcie_msi_init(pp);
/* Enable MSI interrupt generation */ /* Enable MSI interrupt generation */
val = appl_readl(pcie, APPL_INTR_EN_L0_0); val = appl_readl(pcie, APPL_INTR_EN_L0_0);
val |= APPL_INTR_EN_L0_0_SYS_MSI_INTR_EN; val |= APPL_INTR_EN_L0_0_SYS_MSI_INTR_EN;
......
...@@ -315,7 +315,6 @@ static int uniphier_pcie_host_init(struct pcie_port *pp) ...@@ -315,7 +315,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); dw_pcie_setup_rc(pp);
dw_pcie_msi_init(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