]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
spi: ppc4xx: handle irq_of_parse_and_map() errors
authorMa Ke <make24@iscas.ac.cn>
Wed, 24 Jul 2024 08:40:47 +0000 (16:40 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 17 Oct 2024 13:07:43 +0000 (15:07 +0200)
[ Upstream commit 0f245463b01ea254ae90e1d0389e90b0e7d8dc75 ]

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: 44dab88e7cc9 ("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>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/spi/spi-ppc4xx.c

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