Message ID | 1664440622-18556-5-git-send-email-hongxing.zhu@nxp.com (mailing list archive) |
---|---|
State | Superseded |
Headers | show |
Series | Add the iMX8MP PCIe support | expand |
Hi, On 29.09.22 09:37, Richard Zhu wrote: > Add i.MX8MP PCIe PHY support. > > Signed-off-by: Richard Zhu <hongxing.zhu@nxp.com> > Signed-off-by: Lucas Stach <l.stach@pengutronix.de> > Tested-by: Marek Vasut <marex@denx.de> > Tested-by: Richard Leitner <richard.leitner@skidata.com> > Tested-by: Alexander Stein <alexander.stein@ew.tq-group.com> > Reviewed-by: Lucas Stach <l.stach@pengutronix.de> > --- > drivers/phy/freescale/phy-fsl-imx8m-pcie.c | 23 ++++++++++++++++++++++ > 1 file changed, 23 insertions(+) > > diff --git a/drivers/phy/freescale/phy-fsl-imx8m-pcie.c b/drivers/phy/freescale/phy-fsl-imx8m-pcie.c > index 59b46a4ae069..be5e48864c5a 100644 > --- a/drivers/phy/freescale/phy-fsl-imx8m-pcie.c > +++ b/drivers/phy/freescale/phy-fsl-imx8m-pcie.c > @@ -48,6 +48,7 @@ > > enum imx8_pcie_phy_type { > IMX8MM, > + IMX8MP, > }; > > struct imx8_pcie_phy_drvdata { > @@ -60,6 +61,7 @@ struct imx8_pcie_phy { > struct clk *clk; > struct phy *phy; > struct regmap *iomuxc_gpr; > + struct reset_control *perst; > struct reset_control *reset; > u32 refclk_pad_mode; > u32 tx_deemph_gen1; > @@ -87,6 +89,9 @@ static int imx8_pcie_phy_init(struct phy *phy) > writel(imx8_phy->tx_deemph_gen2, > imx8_phy->base + PCIE_PHY_TRSV_REG6); > break; > + case IMX8MP: > + reset_control_assert(imx8_phy->perst); > + break; > } > > if (pad_mode == IMX8_PCIE_REFCLK_PAD_INPUT || > @@ -141,6 +146,9 @@ static int imx8_pcie_phy_init(struct phy *phy) > IMX8MM_GPR_PCIE_CMN_RST); > > switch (imx8_phy->drvdata->variant) { > + case IMX8MP: > + reset_control_deassert(imx8_phy->perst); > + fallthrough; > case IMX8MM: > reset_control_deassert(imx8_phy->reset); > usleep_range(200, 500); > @@ -181,8 +189,14 @@ static const struct imx8_pcie_phy_drvdata imx8mm_drvdata = { > .gpr = "fsl,imx8mm-iomuxc-gpr", > }; > > +static const struct imx8_pcie_phy_drvdata imx8mp_drvdata = { > + .variant = IMX8MP, > + .gpr = "fsl,imx8mp-iomuxc-gpr", > +}; > + > static const struct of_device_id imx8_pcie_phy_of_match[] = { > {.compatible = "fsl,imx8mm-pcie-phy", .data = &imx8mm_drvdata, }, > + {.compatible = "fsl,imx8mp-pcie-phy", .data = &imx8mp_drvdata, }, > { }, > }; > MODULE_DEVICE_TABLE(of, imx8_pcie_phy_of_match); > @@ -238,6 +252,15 @@ static int imx8_pcie_phy_probe(struct platform_device *pdev) > return PTR_ERR(imx8_phy->reset); > } > > + if (imx8_phy->drvdata->variant == IMX8MP) { > + imx8_phy->perst = > + devm_reset_control_get_exclusive(dev, "perst"); > + if (IS_ERR(imx8_phy->perst)) { > + dev_err(dev, "Failed to get PCIE PHY PERST control\n"); > + return PTR_ERR(imx8_phy->perst); Nitpick: dev_err_probe here would be useful if user forgets to enable PHY driver. Anyways: Reviewed-by: Ahmad Fatoum <a.fatoum@pengutronix.de> Cheers, Ahmad > + } > + } > + > res = platform_get_resource(pdev, IORESOURCE_MEM, 0); > imx8_phy->base = devm_ioremap_resource(dev, res); > if (IS_ERR(imx8_phy->base))
> -----Original Message----- > From: Ahmad Fatoum <a.fatoum@pengutronix.de> > Sent: 2022年9月30日 16:46 > To: Hongxing Zhu <hongxing.zhu@nxp.com>; vkoul@kernel.org; > p.zabel@pengutronix.de; l.stach@pengutronix.de; bhelgaas@google.com; > lorenzo.pieralisi@arm.com; robh@kernel.org; shawnguo@kernel.org; > alexander.stein@ew.tq-group.com; marex@denx.de; richard.leitner@linux.dev > Cc: devicetree@vger.kernel.org; linux-pci@vger.kernel.org; > linux-kernel@vger.kernel.org; dl-linux-imx <linux-imx@nxp.com>; > kernel@pengutronix.de; linux-phy@lists.infradead.org; > linux-arm-kernel@lists.infradead.org > Subject: Re: [PATCH v10 4/4] phy: freescale: imx8m-pcie: Add i.MX8MP PCIe > PHY support > > Hi, > > On 29.09.22 09:37, Richard Zhu wrote: > > Add i.MX8MP PCIe PHY support. > > > > Signed-off-by: Richard Zhu <hongxing.zhu@nxp.com> > > Signed-off-by: Lucas Stach <l.stach@pengutronix.de> > > Tested-by: Marek Vasut <marex@denx.de> > > Tested-by: Richard Leitner <richard.leitner@skidata.com> > > Tested-by: Alexander Stein <alexander.stein@ew.tq-group.com> > > Reviewed-by: Lucas Stach <l.stach@pengutronix.de> > > --- > > drivers/phy/freescale/phy-fsl-imx8m-pcie.c | 23 > > ++++++++++++++++++++++ > > 1 file changed, 23 insertions(+) > > > > diff --git a/drivers/phy/freescale/phy-fsl-imx8m-pcie.c > > b/drivers/phy/freescale/phy-fsl-imx8m-pcie.c > > index 59b46a4ae069..be5e48864c5a 100644 > > --- a/drivers/phy/freescale/phy-fsl-imx8m-pcie.c > > +++ b/drivers/phy/freescale/phy-fsl-imx8m-pcie.c > > @@ -48,6 +48,7 @@ > > > > enum imx8_pcie_phy_type { > > IMX8MM, > > + IMX8MP, > > }; > > > > struct imx8_pcie_phy_drvdata { > > @@ -60,6 +61,7 @@ struct imx8_pcie_phy { > > struct clk *clk; > > struct phy *phy; > > struct regmap *iomuxc_gpr; > > + struct reset_control *perst; > > struct reset_control *reset; > > u32 refclk_pad_mode; > > u32 tx_deemph_gen1; > > @@ -87,6 +89,9 @@ static int imx8_pcie_phy_init(struct phy *phy) > > writel(imx8_phy->tx_deemph_gen2, > > imx8_phy->base + PCIE_PHY_TRSV_REG6); > > break; > > + case IMX8MP: > > + reset_control_assert(imx8_phy->perst); > > + break; > > } > > > > if (pad_mode == IMX8_PCIE_REFCLK_PAD_INPUT || @@ -141,6 +146,9 > @@ > > static int imx8_pcie_phy_init(struct phy *phy) > > IMX8MM_GPR_PCIE_CMN_RST); > > > > switch (imx8_phy->drvdata->variant) { > > + case IMX8MP: > > + reset_control_deassert(imx8_phy->perst); > > + fallthrough; > > case IMX8MM: > > reset_control_deassert(imx8_phy->reset); > > usleep_range(200, 500); > > @@ -181,8 +189,14 @@ static const struct imx8_pcie_phy_drvdata > imx8mm_drvdata = { > > .gpr = "fsl,imx8mm-iomuxc-gpr", > > }; > > > > +static const struct imx8_pcie_phy_drvdata imx8mp_drvdata = { > > + .variant = IMX8MP, > > + .gpr = "fsl,imx8mp-iomuxc-gpr", > > +}; > > + > > static const struct of_device_id imx8_pcie_phy_of_match[] = { > > {.compatible = "fsl,imx8mm-pcie-phy", .data = &imx8mm_drvdata, }, > > + {.compatible = "fsl,imx8mp-pcie-phy", .data = &imx8mp_drvdata, }, > > { }, > > }; > > MODULE_DEVICE_TABLE(of, imx8_pcie_phy_of_match); @@ -238,6 > +252,15 @@ > > static int imx8_pcie_phy_probe(struct platform_device *pdev) > > return PTR_ERR(imx8_phy->reset); > > } > > > > + if (imx8_phy->drvdata->variant == IMX8MP) { > > + imx8_phy->perst = > > + devm_reset_control_get_exclusive(dev, "perst"); > > + if (IS_ERR(imx8_phy->perst)) { > > + dev_err(dev, "Failed to get PCIE PHY PERST control\n"); > > + return PTR_ERR(imx8_phy->perst); > > Nitpick: dev_err_probe here would be useful if user forgets to enable PHY > driver. Anyways: > > Reviewed-by: Ahmad Fatoum <a.fatoum@pengutronix.de> > Okay, got that. Thanks. Best Regards Richard Zhu > Cheers, > Ahmad > > > + } > > + } > > + > > res = platform_get_resource(pdev, IORESOURCE_MEM, 0); > > imx8_phy->base = devm_ioremap_resource(dev, res); > > if (IS_ERR(imx8_phy->base)) > > > -- > Pengutronix e.K. | > | > Steuerwalder Str. 21 | > https://eur01.safelinks.protection.outlook.com/?url=http%3A%2F%2Fwww.pe > ngutronix.de%2F&data=05%7C01%7Chongxing.zhu%40nxp.com%7Ca5b1 > 8eb3c555435f793508daa2c041cb%7C686ea1d3bc2b4c6fa92cd99c5c301635 > %7C0%7C0%7C638001243871200983%7CUnknown%7CTWFpbGZsb3d8eyJW > IjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3 > 000%7C%7C%7C&sdata=GYghtu2M2tRW0Y81l0Fr4qGxRI5NG0hkorjZ8tjC > Hbg%3D&reserved=0 | > 31137 Hildesheim, Germany | Phone: > +49-5121-206917-0 | > Amtsgericht Hildesheim, HRA 2686 | Fax: > +49-5121-206917-5555 |
diff --git a/drivers/phy/freescale/phy-fsl-imx8m-pcie.c b/drivers/phy/freescale/phy-fsl-imx8m-pcie.c index 59b46a4ae069..be5e48864c5a 100644 --- a/drivers/phy/freescale/phy-fsl-imx8m-pcie.c +++ b/drivers/phy/freescale/phy-fsl-imx8m-pcie.c @@ -48,6 +48,7 @@ enum imx8_pcie_phy_type { IMX8MM, + IMX8MP, }; struct imx8_pcie_phy_drvdata { @@ -60,6 +61,7 @@ struct imx8_pcie_phy { struct clk *clk; struct phy *phy; struct regmap *iomuxc_gpr; + struct reset_control *perst; struct reset_control *reset; u32 refclk_pad_mode; u32 tx_deemph_gen1; @@ -87,6 +89,9 @@ static int imx8_pcie_phy_init(struct phy *phy) writel(imx8_phy->tx_deemph_gen2, imx8_phy->base + PCIE_PHY_TRSV_REG6); break; + case IMX8MP: + reset_control_assert(imx8_phy->perst); + break; } if (pad_mode == IMX8_PCIE_REFCLK_PAD_INPUT || @@ -141,6 +146,9 @@ static int imx8_pcie_phy_init(struct phy *phy) IMX8MM_GPR_PCIE_CMN_RST); switch (imx8_phy->drvdata->variant) { + case IMX8MP: + reset_control_deassert(imx8_phy->perst); + fallthrough; case IMX8MM: reset_control_deassert(imx8_phy->reset); usleep_range(200, 500); @@ -181,8 +189,14 @@ static const struct imx8_pcie_phy_drvdata imx8mm_drvdata = { .gpr = "fsl,imx8mm-iomuxc-gpr", }; +static const struct imx8_pcie_phy_drvdata imx8mp_drvdata = { + .variant = IMX8MP, + .gpr = "fsl,imx8mp-iomuxc-gpr", +}; + static const struct of_device_id imx8_pcie_phy_of_match[] = { {.compatible = "fsl,imx8mm-pcie-phy", .data = &imx8mm_drvdata, }, + {.compatible = "fsl,imx8mp-pcie-phy", .data = &imx8mp_drvdata, }, { }, }; MODULE_DEVICE_TABLE(of, imx8_pcie_phy_of_match); @@ -238,6 +252,15 @@ static int imx8_pcie_phy_probe(struct platform_device *pdev) return PTR_ERR(imx8_phy->reset); } + if (imx8_phy->drvdata->variant == IMX8MP) { + imx8_phy->perst = + devm_reset_control_get_exclusive(dev, "perst"); + if (IS_ERR(imx8_phy->perst)) { + dev_err(dev, "Failed to get PCIE PHY PERST control\n"); + return PTR_ERR(imx8_phy->perst); + } + } + res = platform_get_resource(pdev, IORESOURCE_MEM, 0); imx8_phy->base = devm_ioremap_resource(dev, res); if (IS_ERR(imx8_phy->base))