]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
PCI: imx6: Fix establish link failure in EP mode for i.MX8MM and i.MX8MP
authorRichard Zhu <hongxing.zhu@nxp.com>
Mon, 29 Jul 2024 20:18:08 +0000 (16:18 -0400)
committerKrzysztof Wilczyński <kwilczynski@kernel.org>
Mon, 9 Sep 2024 14:08:12 +0000 (14:08 +0000)
Add IMX6_PCIE_FLAG_HAS_APP_RESET flag to IMX8MM_EP and IMX8MP_EP drvdata.

This flag was overlooked during code restructuring. It is crucial to
release the app-reset from the System Reset Controller before initiating
LTSSM to rectify the issue.

Fixes: 0c9651c21f2a ("PCI: imx6: Simplify reset handling by using *_FLAG_HAS_*_RESET")
Link: https://lore.kernel.org/linux-pci/20240729-pci2_upstream-v8-1-b68ee5ef2b4d@nxp.com
Signed-off-by: Richard Zhu <hongxing.zhu@nxp.com>
Signed-off-by: Frank Li <Frank.Li@nxp.com>
[kwilczynski: commit log]
Signed-off-by: Krzysztof Wilczyński <kwilczynski@kernel.org>
Reviewed-by: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
Cc: <stable@vger.kernel.org> # 6.9+
drivers/pci/controller/dwc/pci-imx6.c

index 964d67756eb2be9847576d9a28fa087bf3457330..42fd17fbadfa59315bb2ea81d987d0000fa0c9d4 100644 (file)
@@ -1562,7 +1562,8 @@ static const struct imx6_pcie_drvdata drvdata[] = {
        },
        [IMX8MM_EP] = {
                .variant = IMX8MM_EP,
-               .flags = IMX6_PCIE_FLAG_HAS_PHYDRV,
+               .flags = IMX6_PCIE_FLAG_HAS_APP_RESET |
+                        IMX6_PCIE_FLAG_HAS_PHYDRV,
                .mode = DW_PCIE_EP_TYPE,
                .gpr = "fsl,imx8mm-iomuxc-gpr",
                .clk_names = imx8mm_clks,
@@ -1573,7 +1574,8 @@ static const struct imx6_pcie_drvdata drvdata[] = {
        },
        [IMX8MP_EP] = {
                .variant = IMX8MP_EP,
-               .flags = IMX6_PCIE_FLAG_HAS_PHYDRV,
+               .flags = IMX6_PCIE_FLAG_HAS_APP_RESET |
+                        IMX6_PCIE_FLAG_HAS_PHYDRV,
                .mode = DW_PCIE_EP_TYPE,
                .gpr = "fsl,imx8mp-iomuxc-gpr",
                .clk_names = imx8mm_clks,