diff options
| author | Lars-Peter Clausen <lars@metafoo.de> | 2012-07-04 13:02:56 -0700 | 
|---|---|---|
| committer | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2012-07-04 13:12:19 -0700 | 
| commit | 9b7e31bbf4bb58b12e11a7f24b7c3e48bbd2f4da (patch) | |
| tree | ca55c470f22dbccb53f3c3ed4683342cbd92c515 /drivers/input/touchscreen/tsc2005.c | |
| parent | 1cecc5cc0658e128bcad0b29edb96f286066571d (diff) | |
| download | linux-9b7e31bbf4bb58b12e11a7f24b7c3e48bbd2f4da.tar.bz2 | |
Input: request threaded-only IRQs with IRQF_ONESHOT
Since commit 1c6c69525b ("genirq: Reject bogus threaded irq requests")
threaded IRQs without a primary handler need to be requested with
IRQF_ONESHOT, otherwise the request will fail. This patch adds the
IRQF_ONESHOT to input drivers where it is missing. Not modified by
this patch are those drivers where the requested IRQ will always be a
nested IRQ (e.g. because it's part of an MFD), since for this special
case IRQF_ONESHOT is not required to be specified when requesting the
IRQ.
Signed-off-by: Lars-Peter Clausen <lars@metafoo.de>
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
Diffstat (limited to 'drivers/input/touchscreen/tsc2005.c')
| -rw-r--r-- | drivers/input/touchscreen/tsc2005.c | 3 | 
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/input/touchscreen/tsc2005.c b/drivers/input/touchscreen/tsc2005.c index b6adeaee9cc5..5ce3fa8ce646 100644 --- a/drivers/input/touchscreen/tsc2005.c +++ b/drivers/input/touchscreen/tsc2005.c @@ -650,7 +650,8 @@ static int __devinit tsc2005_probe(struct spi_device *spi)  	tsc2005_stop_scan(ts);  	error = request_threaded_irq(spi->irq, NULL, tsc2005_irq_thread, -				     IRQF_TRIGGER_RISING, "tsc2005", ts); +				     IRQF_TRIGGER_RISING | IRQF_ONESHOT, +				     "tsc2005", ts);  	if (error) {  		dev_err(&spi->dev, "Failed to request irq, err: %d\n", error);  		goto err_free_mem;  |