mirror of
https://github.com/raspberrypi/linux.git
synced 2025-12-06 01:49:46 +00:00
rtc: max77686: Properly handle regmap_irq_get_virq() error code
commitfb166ba1d7upstream. The regmap_irq_get_virq() can return 0 or -EINVAL in error conditions but driver checked only for value of 0. This could lead to a cast of -EINVAL to an unsigned int used as a interrupt number for devm_request_threaded_irq(). Although this is not yet fatal (devm_request_threaded_irq() will just fail with -EINVAL) but might be a misleading when diagnosing errors. Signed-off-by: Krzysztof Kozlowski <k.kozlowski@samsung.com> Fixes:6f1c1e71d9("mfd: max77686: Convert to use regmap_irq") Reviewed-by: Javier Martinez Canillas <javier@osg.samsung.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@free-electrons.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
committed by
popcornmix
parent
76af090447
commit
2c13f5c9ef
@@ -465,7 +465,7 @@ static int max77686_rtc_probe(struct platform_device *pdev)
|
|||||||
|
|
||||||
info->virq = regmap_irq_get_virq(max77686->rtc_irq_data,
|
info->virq = regmap_irq_get_virq(max77686->rtc_irq_data,
|
||||||
MAX77686_RTCIRQ_RTCA1);
|
MAX77686_RTCIRQ_RTCA1);
|
||||||
if (!info->virq) {
|
if (info->virq <= 0) {
|
||||||
ret = -ENXIO;
|
ret = -ENXIO;
|
||||||
goto err_rtc;
|
goto err_rtc;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user