Hi Prabhakar, Thank you for the patch. On Thu, Dec 23, 2021 at 05:30:02PM +0000, Lad Prabhakar wrote: > platform_get_resource(pdev, IORESOURCE_IRQ, ..) relies on static > allocation of IRQ resources in DT core code, this causes an issue > when using hierarchical interrupt domains using "interrupts" property > in the node as this bypasses the hierarchical setup and messes up the > irq chaining. > > In preparation for removal of static setup of IRQ resource from DT core > code use platform_get_irq(). > > Signed-off-by: Lad Prabhakar <prabhakar.mahadev-lad.rj@xxxxxxxxxxxxxx> Will you get this merged with the whole series, or should I take it in my tree ? > --- > drivers/media/platform/vsp1/vsp1_drv.c | 13 +++++-------- > 1 file changed, 5 insertions(+), 8 deletions(-) > > diff --git a/drivers/media/platform/vsp1/vsp1_drv.c b/drivers/media/platform/vsp1/vsp1_drv.c > index c9044785b903..bbba91a65a0f 100644 > --- a/drivers/media/platform/vsp1/vsp1_drv.c > +++ b/drivers/media/platform/vsp1/vsp1_drv.c > @@ -794,7 +794,6 @@ static int vsp1_probe(struct platform_device *pdev) > { > struct vsp1_device *vsp1; > struct device_node *fcp_node; > - struct resource *irq; > unsigned int i; > int ret; > > @@ -813,14 +812,12 @@ static int vsp1_probe(struct platform_device *pdev) > if (IS_ERR(vsp1->mmio)) > return PTR_ERR(vsp1->mmio); > > - irq = platform_get_resource(pdev, IORESOURCE_IRQ, 0); > - if (!irq) { > - dev_err(&pdev->dev, "missing IRQ\n"); > - return -EINVAL; > - } > + ret = platform_get_irq(pdev, 0); > + if (ret < 0) > + return ret; I'd use an int irq local variable, but it doesn't matter much. Up to you. Reviewed-by: Laurent Pinchart <laurent.pinchart@xxxxxxxxxxxxxxxx> > > - ret = devm_request_irq(&pdev->dev, irq->start, vsp1_irq_handler, > - IRQF_SHARED, dev_name(&pdev->dev), vsp1); > + ret = devm_request_irq(&pdev->dev, ret, vsp1_irq_handler, > + IRQF_SHARED, dev_name(&pdev->dev), vsp1); > if (ret < 0) { > dev_err(&pdev->dev, "failed to request IRQ\n"); > return ret; -- Regards, Laurent Pinchart