public inbox for linux-mediatek@lists.infradead.org
 help / color / mirror / Atom feed
* [PATCH] PCI: mediatek-gen3: fix PCIe #PERST being de-asserted too early
@ 2023-10-06  7:45 Daniel Golle
  2023-10-10 16:04 ` Bjorn Helgaas
  0 siblings, 1 reply; 4+ messages in thread
From: Daniel Golle @ 2023-10-06  7:45 UTC (permalink / raw)
  To: linux-pci, linux-mediatek, linux-arm-kernel, linux-kernel,
	AngeloGioacchino Del Regno, Matthias Brugger, Bjorn Helgaas,
	Rob Herring, Krzysztof Wilczyński, Lorenzo Pieralisi,
	Jianjun Wang, Ryder Lee
  Cc: Christian Marangi, Frank Wunderlich, John Crispin

The driver for MediaTek gen3 PCIe hosts de-asserts all reset
signals at the same time using a single register write operation.
Delay the de-assertion of the #PERST signal by 100ms as required by
PCIe CEM clause 2.2, some PCIe devices fail to come up otherwise.

Signed-off-by: Daniel Golle <daniel@makrotopia.org>
---
 drivers/pci/controller/pcie-mediatek-gen3.c | 8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)

diff --git a/drivers/pci/controller/pcie-mediatek-gen3.c b/drivers/pci/controller/pcie-mediatek-gen3.c
index e0e27645fdf4..ba8cfce03aad 100644
--- a/drivers/pci/controller/pcie-mediatek-gen3.c
+++ b/drivers/pci/controller/pcie-mediatek-gen3.c
@@ -350,7 +350,13 @@ static int mtk_pcie_startup_port(struct mtk_gen3_pcie *pcie)
 	msleep(100);
 
 	/* De-assert reset signals */
-	val &= ~(PCIE_MAC_RSTB | PCIE_PHY_RSTB | PCIE_BRG_RSTB | PCIE_PE_RSTB);
+	val &= ~(PCIE_MAC_RSTB | PCIE_PHY_RSTB | PCIE_BRG_RSTB);
+	writel_relaxed(val, pcie->base + PCIE_RST_CTRL_REG);
+
+	msleep(100);
+
+	/* De-assert PERST# signals */
+	val &= ~(PCIE_PE_RSTB);
 	writel_relaxed(val, pcie->base + PCIE_RST_CTRL_REG);
 
 	/* Check if the link is up or not */
-- 
2.42.0



^ permalink raw reply related	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2023-10-13  8:41 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2023-10-06  7:45 [PATCH] PCI: mediatek-gen3: fix PCIe #PERST being de-asserted too early Daniel Golle
2023-10-10 16:04 ` Bjorn Helgaas
     [not found]   ` <1E611A63-AD66-4E61-90F9-F1DB41BD6466@fw-web.de>
2023-10-10 16:49     ` Christian Marangi
2023-10-13  8:31     ` Jianjun Wang (王建军)

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox