spi: ppc4xx: handle irq_of_parse_and_map() errors

Zero and negative number is not a valid IRQ for in-kernel code and the
irq_of_parse_and_map() function returns zero on error.  So this check for
valid IRQs should only accept values > 0.

Fixes: 44dab88e7c ("spi: add spi_ppc4xx driver")
Signed-off-by: Ma Ke <make24@iscas.ac.cn>
Link: https://patch.msgid.link/20240724084047.1506084-1-make24@iscas.ac.cn
Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
Ma Ke 2024-07-24 16:40:47 +08:00 committed by Mark Brown
parent 158678bea6
commit 0f245463b0
No known key found for this signature in database
GPG Key ID: 24D68B725D5487D0

View File

@ -413,6 +413,9 @@ static int spi_ppc4xx_of_probe(struct platform_device *op)
/* Request IRQ */ /* Request IRQ */
hw->irqnum = irq_of_parse_and_map(np, 0); hw->irqnum = irq_of_parse_and_map(np, 0);
if (hw->irqnum <= 0)
goto free_host;
ret = request_irq(hw->irqnum, spi_ppc4xx_int, ret = request_irq(hw->irqnum, spi_ppc4xx_int,
0, "spi_ppc4xx_of", (void *)hw); 0, "spi_ppc4xx_of", (void *)hw);
if (ret) { if (ret) {