[EXT] Re: [PATCH 1/2] perf: imx9_ddr_perf: resolve resource map conflict

Xu Yang xu.yang_2 at nxp.com
Thu Sep 14 19:46:41 PDT 2023


Hi Krzysztof,

> On 14/09/2023 12:20, Xu Yang wrote:
> > Usually, the ddr pmu node will be a subnode of DDR controller, then using
> > devm_platform_ioremap_resource will report conflict with DDR controller
> > resource. So update the driver to use devm_ioremap to avoid such
> > resource check.
> >
> 
> Why would you like to map same region twice? The resource check is for
> purpose there...
> 

Because the ddr pmu region is a subset of ddr controller region. When
edac driver is enabled, it will map the whole region firstly. I will check
if this can be changed.

> > Signed-off-by: Ye Li <ye.li at nxp.com>
> > Signed-off-by: Xu Yang <xu.yang_2 at nxp.com>
> > ---
> >  drivers/perf/fsl_imx9_ddr_perf.c | 9 ++++++++-
> >  1 file changed, 8 insertions(+), 1 deletion(-)
> >
> > diff --git a/drivers/perf/fsl_imx9_ddr_perf.c b/drivers/perf/fsl_imx9_ddr_perf.c
> > index 5cf770a1bc31..885024665968 100644
> > --- a/drivers/perf/fsl_imx9_ddr_perf.c
> > +++ b/drivers/perf/fsl_imx9_ddr_perf.c
> > @@ -602,8 +602,15 @@ static int ddr_perf_probe(struct platform_device *pdev)
> >       void __iomem *base;
> >       int ret, irq;
> >       char *name;
> > +     struct resource *r;
> >
> > -     base = devm_platform_ioremap_resource(pdev, 0);
> > +     r = platform_get_resource(pdev, IORESOURCE_MEM, 0);
> > +     if (!r) {
> > +             dev_err(&pdev->dev, "platform_get_resource() failed\n");
> > +             return -ENOMEM;
> > +     }
> > +
> > +     base = devm_ioremap(&pdev->dev, r->start, resource_size(r));
> 
> You need to document this, otherwise someone will revert your commit soon.
> 
> 
> Best regards,
> Krzysztof

Thanks,
Xu Yang


More information about the linux-arm-kernel mailing list