[PATCH v6 08/11] PCI: dwc: Invoke post_init in dw_pcie_resume_noirq()
Hongxing Zhu
hongxing.zhu at nxp.com
Thu Jan 8 18:10:07 PST 2026
> -----Original Message-----
> From: Bjorn Helgaas <helgaas at kernel.org>
> Sent: 2026年1月9日 5:50
> To: Hongxing Zhu <hongxing.zhu at nxp.com>
> Cc: Frank Li <frank.li at nxp.com>; l.stach at pengutronix.de;
> lpieralisi at kernel.org; kwilczynski at kernel.org; mani at kernel.org;
> robh at kernel.org; krzk+dt at kernel.org; conor+dt at kernel.org;
> bhelgaas at google.com; shawnguo at kernel.org; s.hauer at pengutronix.de;
> kernel at pengutronix.de; festevam at gmail.com; linux-pci at vger.kernel.org;
> linux-arm-kernel at lists.infradead.org; devicetree at vger.kernel.org;
> imx at lists.linux.dev; linux-kernel at vger.kernel.org
> Subject: Re: [PATCH v6 08/11] PCI: dwc: Invoke post_init in
> dw_pcie_resume_noirq()
>
> On Wed, Oct 15, 2025 at 11:04:25AM +0800, Richard Zhu wrote:
> > If the ops has post_init callback, invoke it in dw_pcie_resume_noirq().
>
> I'm trying to write the merge commit log for this branch, and I don't quite
> understand this.
>
> The effect is to apply the GEN3_ZRXDC_NONCOMPL workaround for the
> ERR051586 erratum, and Mani added the hint that this enables REFCLK
> during resume. But it seems weird that we apply a REFCLK workaround
> after the link is already up.
>
> During probe, .post_init() is run after pci_host_probe(), so we apply the
> workaround after enumerating all the devices, which means REFCLK must
> already be valid and the link is already up.
>
> Is "enabling REFCLK" actually what imx_pcie_host_post_init() does?
The codes are used to clean up the CLKREQ# override active low configurations
after link is up and the CLKREQ# is drove to low by remote endpoint device at
this point(support-clkreq is TRUE).
It paves the way to support the CLKREQ# toggling mandatory required by L1SS.
>
> Could the workaround be done in imx_pcie_host_init() before the link is
> brought up? If it could, it looks like we wouldn't need
> imx_pcie_host_post_init() at all.
>
Two actions are done in imx_pcie_post_init().
One is to apply the workaround of ERR051586 by commit 744a1c20ce93 ("PCI:
imx6: Add workaround for errata ERR051586"). It should be applied after link
is up.
The other one is to clean up the CLKREQ# override active low configurations
previous set in imx_pcie_host_init().
Hope this can resolve your confusions.
Best Regards
Richard Zhu
> For now, I put this in the merge commit log:
>
> - Apply i.MX95 ERR051586 erratum workaround for REFCLK issue during
> resume (Richard Zhu)
>
> > ---
> > drivers/pci/controller/dwc/pcie-designware-host.c | 3 +++
> > 1 file changed, 3 insertions(+)
> >
> > diff --git a/drivers/pci/controller/dwc/pcie-designware-host.c
> > b/drivers/pci/controller/dwc/pcie-designware-host.c
> > index 20c9333bcb1c4..2b59e7d2e6179 100644
> > --- a/drivers/pci/controller/dwc/pcie-designware-host.c
> > +++ b/drivers/pci/controller/dwc/pcie-designware-host.c
> > @@ -1199,6 +1199,9 @@ int dw_pcie_resume_noirq(struct dw_pcie *pci)
> > if (ret)
> > return ret;
> >
> > + if (pci->pp.ops->post_init)
> > + pci->pp.ops->post_init(&pci->pp);
> > +
> > return ret;
> > }
> > EXPORT_SYMBOL_GPL(dw_pcie_resume_noirq);
> > --
> > 2.37.1
> >
More information about the linux-arm-kernel
mailing list