diff options
author | Miaoqian Lin <linmq006@gmail.com> | 2022-01-26 11:04:47 +0000 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2022-02-08 18:23:16 +0100 |
commit | 7ff2b0e024b10ea6a373192c31f6029c165d3ea5 (patch) | |
tree | abf47e8480da0625261add53a9fe14d99c4c51f9 | |
parent | 3395f878608779fc3e694e72bd2eec4a62637fa5 (diff) | |
download | linux-stable-7ff2b0e024b10ea6a373192c31f6029c165d3ea5.tar.gz linux-stable-7ff2b0e024b10ea6a373192c31f6029c165d3ea5.tar.bz2 linux-stable-7ff2b0e024b10ea6a373192c31f6029c165d3ea5.zip |
spi: meson-spicc: add IRQ check in meson_spicc_probe
commit e937440f7fc444a3e3f1fb75ea65292d6f433a44 upstream.
This check misses checking for platform_get_irq()'s call and may passes
the negative error codes to devm_request_irq(), which takes unsigned IRQ #,
causing it to fail with -EINVAL, overriding an original error code.
Stop calling devm_request_irq() with invalid IRQ #s.
Fixes: 454fa271bc4e ("spi: Add Meson SPICC driver")
Signed-off-by: Miaoqian Lin <linmq006@gmail.com>
Link: https://lore.kernel.org/r/20220126110447.24549-1-linmq006@gmail.com
Signed-off-by: Mark Brown <broonie@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r-- | drivers/spi/spi-meson-spicc.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/drivers/spi/spi-meson-spicc.c b/drivers/spi/spi-meson-spicc.c index 419756ebf2c0..24196fb0d78a 100644 --- a/drivers/spi/spi-meson-spicc.c +++ b/drivers/spi/spi-meson-spicc.c @@ -529,6 +529,11 @@ static int meson_spicc_probe(struct platform_device *pdev) writel_relaxed(0, spicc->base + SPICC_INTREG); irq = platform_get_irq(pdev, 0); + if (irq < 0) { + ret = irq; + goto out_master; + } + ret = devm_request_irq(&pdev->dev, irq, meson_spicc_irq, 0, NULL, spicc); if (ret) { |