The check to see if platform_get_irq failed is performed on the
unsigned value of pctrl->irq[i] and the check is never true because
an unsigned cannot be less than zero. Fix this by assinging the
signed int ret to the return of platform_get_irq and checking ret
instead.
Detected by CoverityScan, CID#
1470247 ("Unsigned comparison against 0")
Fixes: 6c5d0736e9c0 ("pinctrl: actions: Add interrupt support for OWL S900 SoC")
Signed-off-by: Colin Ian King <colin.king@canonical.com>
Acked-by: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
}
for (i = 0; i < pctrl->num_irq ; i++) {
- pctrl->irq[i] = platform_get_irq(pdev, i);
- if (pctrl->irq[i] < 0) {
- ret = pctrl->irq[i];
+ ret = platform_get_irq(pdev, i);
+ if (ret < 0)
goto err_exit;
- }
+ pctrl->irq[i] = ret;
}
ret = owl_gpio_init(pctrl);