Commit 2918ad14 authored by Lars-Peter Clausen's avatar Lars-Peter Clausen Committed by Jonathan Cameron

staging:iio:lpc32xx_adc: Fix IRQ check

The test in the lpc32xx_adc driver which checks whether the IRQ number returned
by platform_get_irq() has multiple problems. It accepts 0 even though this is an
invalid IRQ. It also rejects IRQ numbers that are larger or equal than NR_IRQS.
First of all drivers should never need to reference NR_IRQS and secondly with
CONFIG_SPARSE_IRQ NR_IRQS is not the upper limit, so the check might reject
valid IRQ numbers. This patch modifies the check to only test against less or
equal to 0.
Signed-off-by: default avatarLars-Peter Clausen <lars@metafoo.de>
Reported-by: default avatarkbuild test robot <fengguang.wu@intel.com>
Cc: Roland Stigge <stigge@antcom.de>
Signed-off-by: default avatarJonathan Cameron <jic23@kernel.org>
parent bf741c08
...@@ -160,7 +160,7 @@ static int lpc32xx_adc_probe(struct platform_device *pdev) ...@@ -160,7 +160,7 @@ static int lpc32xx_adc_probe(struct platform_device *pdev)
} }
irq = platform_get_irq(pdev, 0); irq = platform_get_irq(pdev, 0);
if ((irq < 0) || (irq >= NR_IRQS)) { if (irq <= 0) {
dev_err(&pdev->dev, "failed getting interrupt resource\n"); dev_err(&pdev->dev, "failed getting interrupt resource\n");
return -EINVAL; return -EINVAL;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment