Thomas Gleixner 0ff56cd85a 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>
2011-02-22 14:59:53 -07:00
..
2011-01-14 12:38:11 +01:00
2011-01-13 08:03:14 -08:00
2011-01-13 08:03:14 -08:00
2011-01-13 08:03:13 -08:00
2011-01-13 08:03:13 -08:00
2010-10-27 18:03:07 -07:00
2011-01-13 08:03:13 -08:00
2010-03-07 22:17:37 +01:00
2010-10-29 00:29:51 +02:00