diff options
author | Paul Fertser <fercerpav@gmail.com> | 2009-07-28 00:41:15 +0400 |
---|---|---|
committer | Paul Fertser <fercerpav@gmail.com> | 2009-10-07 01:02:43 +0400 |
commit | 28df6018ad21a834b4ca507b3c5ec4332bb20fc8 (patch) | |
tree | 705129b4468f359b9de6759a1739786bd50068df /include/linux | |
parent | 74fca6a42863ffacaf7ba6f1936a9f228950f657 (diff) |
pcf50633: use a dedicated workqueue for irq processing
Using the default kernel "events" workqueue causes problems with
synchronous adc readings if initiated from some task on the same
workqueue.
I had a deadlock trying to use pcf50633_adc_sync_read from a
power_supply class driver because the reading was initiated from the
workqueue and it waited for the irq processing to complete (to get the
result) and that was put on the same workqueue.
Signed-off-by: Paul Fertser <fercerpav@gmail.com>
Diffstat (limited to 'include/linux')
-rw-r--r-- | include/linux/mfd/pcf50633/core.h | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/include/linux/mfd/pcf50633/core.h b/include/linux/mfd/pcf50633/core.h index c8f51c3c0a7..9aba7b779fb 100644 --- a/include/linux/mfd/pcf50633/core.h +++ b/include/linux/mfd/pcf50633/core.h @@ -136,6 +136,7 @@ struct pcf50633 { int irq; struct pcf50633_irq irq_handler[PCF50633_NUM_IRQ]; struct work_struct irq_work; + struct workqueue_struct *work_queue; struct mutex lock; u8 mask_regs[5]; |