Commit 09573b1c authored by Jinjie Ruan's avatar Jinjie Ruan Committed by Stefan Schmidt

net: ieee802154: mcr20a: Use IRQF_NO_AUTOEN flag in request_irq()

disable_irq() after request_irq() still has a time gap in which
interrupts can come. request_irq() with IRQF_NO_AUTOEN flag will
disable IRQ auto-enable when request IRQ.

Fixes: 8c6ad9cc ("ieee802154: Add NXP MCR20A IEEE 802.15.4 transceiver driver")
Reviewed-by: default avatarMiquel Raynal <miquel.raynal@bootlin.com>
Signed-off-by: default avatarJinjie Ruan <ruanjinjie@huawei.com>
Link: https://lore.kernel.org/20240911094234.1922418-1-ruanjinjie@huawei.comSigned-off-by: default avatarStefan Schmidt <stefan@datenfreihafen.org>
parent bff1709b
...@@ -1302,16 +1302,13 @@ mcr20a_probe(struct spi_device *spi) ...@@ -1302,16 +1302,13 @@ mcr20a_probe(struct spi_device *spi)
irq_type = IRQF_TRIGGER_FALLING; irq_type = IRQF_TRIGGER_FALLING;
ret = devm_request_irq(&spi->dev, spi->irq, mcr20a_irq_isr, ret = devm_request_irq(&spi->dev, spi->irq, mcr20a_irq_isr,
irq_type, dev_name(&spi->dev), lp); irq_type | IRQF_NO_AUTOEN, dev_name(&spi->dev), lp);
if (ret) { if (ret) {
dev_err(&spi->dev, "could not request_irq for mcr20a\n"); dev_err(&spi->dev, "could not request_irq for mcr20a\n");
ret = -ENODEV; ret = -ENODEV;
goto free_dev; goto free_dev;
} }
/* disable_irq by default and wait for starting hardware */
disable_irq(spi->irq);
ret = ieee802154_register_hw(hw); ret = ieee802154_register_hw(hw);
if (ret) { if (ret) {
dev_crit(&spi->dev, "ieee802154_register_hw failed\n"); dev_crit(&spi->dev, "ieee802154_register_hw failed\n");
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment