Message ID | 1587850687-23675-1-git-send-email-stefan.wahren@i2se.com (mailing list archive) |
---|---|
State | Mainlined |
Commit | aef6f2e7cec184fac0ef50958b759e9605ed8128 |
Headers | show |
Series | i2c: brcmstb: Fix handling of optional interrupt | expand |
On 4/25/2020 2:38 PM, Stefan Wahren wrote: > From: Dave Stevenson <dave.stevenson@raspberrypi.com> > > If there is no interrupt defined then an error is logged due > to the use of platform_get_irq. The driver handles not having > the interrupt by falling back to polling, therefore make > the appropriate call when claiming it. > > Signed-off-by: Dave Stevenson <dave.stevenson@raspberrypi.com> > Signed-off-by: Stefan Wahren <stefan.wahren@i2se.com> Acked-by: Florian Fainelli <f.fainelli@gmail.com>
On Sat, Apr 25, 2020 at 11:38:07PM +0200, Stefan Wahren wrote: > From: Dave Stevenson <dave.stevenson@raspberrypi.com> > > If there is no interrupt defined then an error is logged due > to the use of platform_get_irq. The driver handles not having > the interrupt by falling back to polling, therefore make > the appropriate call when claiming it. > > Signed-off-by: Dave Stevenson <dave.stevenson@raspberrypi.com> > Signed-off-by: Stefan Wahren <stefan.wahren@i2se.com> Applied to for-next, thanks!
diff --git a/drivers/i2c/busses/i2c-brcmstb.c b/drivers/i2c/busses/i2c-brcmstb.c index 169a283..d4e0a0f 100644 --- a/drivers/i2c/busses/i2c-brcmstb.c +++ b/drivers/i2c/busses/i2c-brcmstb.c @@ -647,20 +647,22 @@ static int brcmstb_i2c_probe(struct platform_device *pdev) int_name = NULL; /* Get the interrupt number */ - dev->irq = platform_get_irq(pdev, 0); + dev->irq = platform_get_irq_optional(pdev, 0); /* disable the bsc interrupt line */ brcmstb_i2c_enable_disable_irq(dev, INT_DISABLE); /* register the ISR handler */ - rc = devm_request_irq(&pdev->dev, dev->irq, brcmstb_i2c_isr, - IRQF_SHARED, - int_name ? int_name : pdev->name, - dev); - - if (rc) { - dev_dbg(dev->device, "falling back to polling mode"); - dev->irq = -1; + if (dev->irq >= 0) { + rc = devm_request_irq(&pdev->dev, dev->irq, brcmstb_i2c_isr, + IRQF_SHARED, + int_name ? int_name : pdev->name, + dev); + + if (rc) { + dev_dbg(dev->device, "falling back to polling mode"); + dev->irq = -1; + } } if (of_property_read_u32(dev->device->of_node,