diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-01-13 23:43:32 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-01-13 23:43:32 -0500 |
commit | 21ebd6c68b5511b55f4f456e4ba17c2d711e3617 (patch) | |
tree | 2f4f98568a7a52ab6734fb190d0cbf6f9c1c6492 /drivers/gpio | |
parent | 4b8be38cf782f8ebebc089083fa0572ade79d7ca (diff) | |
parent | 74d836c4142e5d100f8d9a1b2ee3003c2ed7109d (diff) |
Merge branch 'for-next' of git://git.kernel.org/pub/scm/linux/kernel/git/sameo/mfd-2.6
* 'for-next' of git://git.kernel.org/pub/scm/linux/kernel/git/sameo/mfd-2.6: (59 commits)
rtc: max8925: Add function to work as wakeup source
mfd: Add pm ops to max8925
mfd: Convert aat2870 to dev_pm_ops
mfd: Still check other interrupts if we get a wm831x touchscreen IRQ
mfd: Introduce missing kfree in 88pm860x probe routine
mfd: Add S5M series configuration
mfd: Add s5m series irq driver
mfd: Add S5M core driver
mfd: Improve mc13xxx dt binding document
mfd: Fix stmpe section mismatch
mfd: Fix stmpe build warning
mfd: Fix STMPE I2c build failure
mfd: Constify aat2870-core i2c_device_id table
gpio: Add support for stmpe variant 801
mfd: Add support for stmpe variant 801
mfd: Add support for stmpe variant 610
mfd: Add support for STMPE SPI interface
mfd: Separate out STMPE controller and interface specific code
misc: Remove max8997-muic sysfs attributes
mfd: Remove unused wm831x_irq_data_to_mask_reg()
...
Fix up trivial conflict in drivers/leds/Kconfig due to addition of
LEDS_MAX8997 and LEDS_TCA6507 next to each other.
Diffstat (limited to 'drivers/gpio')
-rw-r--r-- | drivers/gpio/gpio-stmpe.c | 25 |
1 files changed, 22 insertions, 3 deletions
diff --git a/drivers/gpio/gpio-stmpe.c b/drivers/gpio/gpio-stmpe.c index 4c980b573328..87a68a896abf 100644 --- a/drivers/gpio/gpio-stmpe.c +++ b/drivers/gpio/gpio-stmpe.c | |||
@@ -65,7 +65,14 @@ static void stmpe_gpio_set(struct gpio_chip *chip, unsigned offset, int val) | |||
65 | u8 reg = stmpe->regs[which] - (offset / 8); | 65 | u8 reg = stmpe->regs[which] - (offset / 8); |
66 | u8 mask = 1 << (offset % 8); | 66 | u8 mask = 1 << (offset % 8); |
67 | 67 | ||
68 | stmpe_reg_write(stmpe, reg, mask); | 68 | /* |
69 | * Some variants have single register for gpio set/clear functionality. | ||
70 | * For them we need to write 0 to clear and 1 to set. | ||
71 | */ | ||
72 | if (stmpe->regs[STMPE_IDX_GPSR_LSB] == stmpe->regs[STMPE_IDX_GPCR_LSB]) | ||
73 | stmpe_set_bits(stmpe, reg, mask, val ? mask : 0); | ||
74 | else | ||
75 | stmpe_reg_write(stmpe, reg, mask); | ||
69 | } | 76 | } |
70 | 77 | ||
71 | static int stmpe_gpio_direction_output(struct gpio_chip *chip, | 78 | static int stmpe_gpio_direction_output(struct gpio_chip *chip, |
@@ -132,6 +139,10 @@ static int stmpe_gpio_irq_set_type(struct irq_data *d, unsigned int type) | |||
132 | if (type == IRQ_TYPE_LEVEL_LOW || type == IRQ_TYPE_LEVEL_HIGH) | 139 | if (type == IRQ_TYPE_LEVEL_LOW || type == IRQ_TYPE_LEVEL_HIGH) |
133 | return -EINVAL; | 140 | return -EINVAL; |
134 | 141 | ||
142 | /* STMPE801 doesn't have RE and FE registers */ | ||
143 | if (stmpe_gpio->stmpe->partnum == STMPE801) | ||
144 | return 0; | ||
145 | |||
135 | if (type == IRQ_TYPE_EDGE_RISING) | 146 | if (type == IRQ_TYPE_EDGE_RISING) |
136 | stmpe_gpio->regs[REG_RE][regoffset] |= mask; | 147 | stmpe_gpio->regs[REG_RE][regoffset] |= mask; |
137 | else | 148 | else |
@@ -165,6 +176,11 @@ static void stmpe_gpio_irq_sync_unlock(struct irq_data *d) | |||
165 | int i, j; | 176 | int i, j; |
166 | 177 | ||
167 | for (i = 0; i < CACHE_NR_REGS; i++) { | 178 | for (i = 0; i < CACHE_NR_REGS; i++) { |
179 | /* STMPE801 doesn't have RE and FE registers */ | ||
180 | if ((stmpe->partnum == STMPE801) && | ||
181 | (i != REG_IE)) | ||
182 | continue; | ||
183 | |||
168 | for (j = 0; j < num_banks; j++) { | 184 | for (j = 0; j < num_banks; j++) { |
169 | u8 old = stmpe_gpio->oldregs[i][j]; | 185 | u8 old = stmpe_gpio->oldregs[i][j]; |
170 | u8 new = stmpe_gpio->regs[i][j]; | 186 | u8 new = stmpe_gpio->regs[i][j]; |
@@ -241,8 +257,11 @@ static irqreturn_t stmpe_gpio_irq(int irq, void *dev) | |||
241 | } | 257 | } |
242 | 258 | ||
243 | stmpe_reg_write(stmpe, statmsbreg + i, status[i]); | 259 | stmpe_reg_write(stmpe, statmsbreg + i, status[i]); |
244 | stmpe_reg_write(stmpe, stmpe->regs[STMPE_IDX_GPEDR_MSB] + i, | 260 | |
245 | status[i]); | 261 | /* Edge detect register is not present on 801 */ |
262 | if (stmpe->partnum != STMPE801) | ||
263 | stmpe_reg_write(stmpe, stmpe->regs[STMPE_IDX_GPEDR_MSB] | ||
264 | + i, status[i]); | ||
246 | } | 265 | } |
247 | 266 | ||
248 | return IRQ_HANDLED; | 267 | return IRQ_HANDLED; |