diff options
| author | 2011-02-14 18:08:51 +0100 | |
|---|---|---|
| committer | 2011-02-22 14:59:53 -0700 | |
| commit | 0ff56cd85a2c5104a36d84662b9180c219e8604e (patch) | |
| tree | 2d8826a9743143402a8028a3a1c36f21ff5df755 /drivers/spi/omap2_mcspi.c | |
| parent | spi: New driver for Altera SPI (diff) | |
| download | linux-dev-0ff56cd85a2c5104a36d84662b9180c219e8604e.tar.xz linux-dev-0ff56cd85a2c5104a36d84662b9180c219e8604e.zip | |
gpio/sx150x: Do not access I2C from mask/unmask functions
irq_chip->irq_mask/unmask are called with interrupts disabled and
irq_desc->lock held. So we cannot access i2c from this context. That's
what irq_bus_sync_unlock() is for.
Store the masked information in the chip data structure and update the
i2c bus from the irq_bus_sync_unlock() callback.
This does not need a while(pending) loop because the update to this is
always serialized via the bus lock, so we never have more than one pin
update pending.
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Gregory Bean <gbean@codeaurora.org>
Cc: Jean Delvare <khali@linux-fr.org>
Cc: Lennert Buytenhek <buytenh@secretlab.ca>
Signed-off-by: Grant Likely <grant.likely@secretlab.ca>
Diffstat (limited to 'drivers/spi/omap2_mcspi.c')
0 files changed, 0 insertions, 0 deletions
