From: Alan Ott Date: Sun, 6 Oct 2013 03:52:24 +0000 (-0400) Subject: mrf24j40: Use level-triggered interrupts X-Git-Tag: firefly_0821_release~176^2~5117^2~60^2 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=40afbb657352e92726c40cc4ddf3cf0be6800dba;p=firefly-linux-kernel-4.4.55.git mrf24j40: Use level-triggered interrupts The mrf24j40 generates level interrupts. There are rare cases where it appears that the interrupt line never gets de-asserted between interrupts, causing interrupts to be lost, and causing a hung device from the driver's perspective. Switching the driver to interpret these interrupts as level-triggered fixes this issue. Signed-off-by: Alan Ott Signed-off-by: David S. Miller --- diff --git a/drivers/net/ieee802154/mrf24j40.c b/drivers/net/ieee802154/mrf24j40.c index c1bc68836346..0632d34905c7 100644 --- a/drivers/net/ieee802154/mrf24j40.c +++ b/drivers/net/ieee802154/mrf24j40.c @@ -678,7 +678,7 @@ static int mrf24j40_probe(struct spi_device *spi) ret = request_threaded_irq(spi->irq, NULL, mrf24j40_isr, - IRQF_TRIGGER_FALLING|IRQF_ONESHOT, + IRQF_TRIGGER_LOW|IRQF_ONESHOT, dev_name(&spi->dev), devrec);