aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/arm/plat-omap/include/plat/gpio.h22
-rw-r--r--drivers/gpio/gpio-omap.c33
2 files changed, 20 insertions, 35 deletions
diff --git a/arch/arm/plat-omap/include/plat/gpio.h b/arch/arm/plat-omap/include/plat/gpio.h
index cb75b657b04b..b8a96c6a1a30 100644
--- a/arch/arm/plat-omap/include/plat/gpio.h
+++ b/arch/arm/plat-omap/include/plat/gpio.h
@@ -218,30 +218,14 @@ extern void omap_set_gpio_debounce(int gpio, int enable);
218extern void omap_set_gpio_debounce_time(int gpio, int enable); 218extern void omap_set_gpio_debounce_time(int gpio, int enable);
219/*-------------------------------------------------------------------------*/ 219/*-------------------------------------------------------------------------*/
220 220
221/* Wrappers for "new style" GPIO calls, using the new infrastructure 221/*
222 * Wrappers for "new style" GPIO calls, using the new infrastructure
222 * which lets us plug in FPGA, I2C, and other implementations. 223 * which lets us plug in FPGA, I2C, and other implementations.
223 * * 224 *
224 * The original OMAP-specific calls should eventually be removed. 225 * The original OMAP-specific calls should eventually be removed.
225 */ 226 */
226 227
227#include <linux/errno.h> 228#include <linux/errno.h>
228#include <asm-generic/gpio.h> 229#include <asm-generic/gpio.h>
229 230
230static inline int irq_to_gpio(unsigned irq)
231{
232 int tmp;
233
234 /* omap1 SOC mpuio */
235 if (cpu_class_is_omap1() && (irq < (IH_MPUIO_BASE + 16)))
236 return (irq - IH_MPUIO_BASE) + OMAP_MAX_GPIO_LINES;
237
238 /* SOC gpio */
239 tmp = irq - IH_GPIO_BASE;
240 if (tmp < OMAP_MAX_GPIO_LINES)
241 return tmp;
242
243 /* we don't supply reverse mappings for non-SOC gpios */
244 return -EIO;
245}
246
247#endif 231#endif
diff --git a/drivers/gpio/gpio-omap.c b/drivers/gpio/gpio-omap.c
index bc2bd698ff2a..afef0f7c8adf 100644
--- a/drivers/gpio/gpio-omap.c
+++ b/drivers/gpio/gpio-omap.c
@@ -93,6 +93,11 @@ struct gpio_bank {
93#define GPIO_BIT(bank, gpio) (1 << GPIO_INDEX(bank, gpio)) 93#define GPIO_BIT(bank, gpio) (1 << GPIO_INDEX(bank, gpio))
94#define GPIO_MOD_CTRL_BIT BIT(0) 94#define GPIO_MOD_CTRL_BIT BIT(0)
95 95
96static int irq_to_gpio(struct gpio_bank *bank, unsigned int gpio_irq)
97{
98 return gpio_irq - bank->irq_base + bank->chip.base;
99}
100
96static void _set_gpio_direction(struct gpio_bank *bank, int gpio, int is_input) 101static void _set_gpio_direction(struct gpio_bank *bank, int gpio, int is_input)
97{ 102{
98 void __iomem *reg = bank->base; 103 void __iomem *reg = bank->base;
@@ -369,7 +374,7 @@ static int _set_gpio_triggering(struct gpio_bank *bank, int gpio, int trigger)
369 374
370static int gpio_irq_type(struct irq_data *d, unsigned type) 375static int gpio_irq_type(struct irq_data *d, unsigned type)
371{ 376{
372 struct gpio_bank *bank; 377 struct gpio_bank *bank = irq_data_get_irq_chip_data(d);
373 unsigned gpio; 378 unsigned gpio;
374 int retval; 379 int retval;
375 unsigned long flags; 380 unsigned long flags;
@@ -377,13 +382,11 @@ static int gpio_irq_type(struct irq_data *d, unsigned type)
377 if (!cpu_class_is_omap2() && d->irq > IH_MPUIO_BASE) 382 if (!cpu_class_is_omap2() && d->irq > IH_MPUIO_BASE)
378 gpio = OMAP_MPUIO(d->irq - IH_MPUIO_BASE); 383 gpio = OMAP_MPUIO(d->irq - IH_MPUIO_BASE);
379 else 384 else
380 gpio = d->irq - IH_GPIO_BASE; 385 gpio = irq_to_gpio(bank, d->irq);
381 386
382 if (type & ~IRQ_TYPE_SENSE_MASK) 387 if (type & ~IRQ_TYPE_SENSE_MASK)
383 return -EINVAL; 388 return -EINVAL;
384 389
385 bank = irq_data_get_irq_chip_data(d);
386
387 if (!bank->regs->leveldetect0 && 390 if (!bank->regs->leveldetect0 &&
388 (type & (IRQ_TYPE_LEVEL_LOW|IRQ_TYPE_LEVEL_HIGH))) 391 (type & (IRQ_TYPE_LEVEL_LOW|IRQ_TYPE_LEVEL_HIGH)))
389 return -EINVAL; 392 return -EINVAL;
@@ -524,14 +527,10 @@ static void _reset_gpio(struct gpio_bank *bank, int gpio)
524/* Use disable_irq_wake() and enable_irq_wake() functions from drivers */ 527/* Use disable_irq_wake() and enable_irq_wake() functions from drivers */
525static int gpio_wake_enable(struct irq_data *d, unsigned int enable) 528static int gpio_wake_enable(struct irq_data *d, unsigned int enable)
526{ 529{
527 unsigned int gpio = d->irq - IH_GPIO_BASE; 530 struct gpio_bank *bank = irq_data_get_irq_chip_data(d);
528 struct gpio_bank *bank; 531 unsigned int gpio = irq_to_gpio(bank, d->irq);
529 int retval;
530
531 bank = irq_data_get_irq_chip_data(d);
532 retval = _set_gpio_wakeup(bank, gpio, enable);
533 532
534 return retval; 533 return _set_gpio_wakeup(bank, gpio, enable);
535} 534}
536 535
537static int omap_gpio_request(struct gpio_chip *chip, unsigned offset) 536static int omap_gpio_request(struct gpio_chip *chip, unsigned offset)
@@ -675,11 +674,13 @@ static void gpio_irq_handler(unsigned int irq, struct irq_desc *desc)
675 674
676 gpio_irq = bank->irq_base; 675 gpio_irq = bank->irq_base;
677 for (; isr != 0; isr >>= 1, gpio_irq++) { 676 for (; isr != 0; isr >>= 1, gpio_irq++) {
678 gpio_index = GPIO_INDEX(bank, irq_to_gpio(gpio_irq)); 677 int gpio = irq_to_gpio(bank, gpio_irq);
679 678
680 if (!(isr & 1)) 679 if (!(isr & 1))
681 continue; 680 continue;
682 681
682 gpio_index = GPIO_INDEX(bank, gpio);
683
683 /* 684 /*
684 * Some chips can't respond to both rising and falling 685 * Some chips can't respond to both rising and falling
685 * at the same time. If this irq was requested with 686 * at the same time. If this irq was requested with
@@ -705,8 +706,8 @@ exit:
705 706
706static void gpio_irq_shutdown(struct irq_data *d) 707static void gpio_irq_shutdown(struct irq_data *d)
707{ 708{
708 unsigned int gpio = d->irq - IH_GPIO_BASE;
709 struct gpio_bank *bank = irq_data_get_irq_chip_data(d); 709 struct gpio_bank *bank = irq_data_get_irq_chip_data(d);
710 unsigned int gpio = irq_to_gpio(bank, d->irq);
710 unsigned long flags; 711 unsigned long flags;
711 712
712 spin_lock_irqsave(&bank->lock, flags); 713 spin_lock_irqsave(&bank->lock, flags);
@@ -716,16 +717,16 @@ static void gpio_irq_shutdown(struct irq_data *d)
716 717
717static void gpio_ack_irq(struct irq_data *d) 718static void gpio_ack_irq(struct irq_data *d)
718{ 719{
719 unsigned int gpio = d->irq - IH_GPIO_BASE;
720 struct gpio_bank *bank = irq_data_get_irq_chip_data(d); 720 struct gpio_bank *bank = irq_data_get_irq_chip_data(d);
721 unsigned int gpio = irq_to_gpio(bank, d->irq);
721 722
722 _clear_gpio_irqstatus(bank, gpio); 723 _clear_gpio_irqstatus(bank, gpio);
723} 724}
724 725
725static void gpio_mask_irq(struct irq_data *d) 726static void gpio_mask_irq(struct irq_data *d)
726{ 727{
727 unsigned int gpio = d->irq - IH_GPIO_BASE;
728 struct gpio_bank *bank = irq_data_get_irq_chip_data(d); 728 struct gpio_bank *bank = irq_data_get_irq_chip_data(d);
729 unsigned int gpio = irq_to_gpio(bank, d->irq);
729 unsigned long flags; 730 unsigned long flags;
730 731
731 spin_lock_irqsave(&bank->lock, flags); 732 spin_lock_irqsave(&bank->lock, flags);
@@ -736,8 +737,8 @@ static void gpio_mask_irq(struct irq_data *d)
736 737
737static void gpio_unmask_irq(struct irq_data *d) 738static void gpio_unmask_irq(struct irq_data *d)
738{ 739{
739 unsigned int gpio = d->irq - IH_GPIO_BASE;
740 struct gpio_bank *bank = irq_data_get_irq_chip_data(d); 740 struct gpio_bank *bank = irq_data_get_irq_chip_data(d);
741 unsigned int gpio = irq_to_gpio(bank, d->irq);
741 unsigned int irq_mask = GPIO_BIT(bank, gpio); 742 unsigned int irq_mask = GPIO_BIT(bank, gpio);
742 u32 trigger = irqd_get_trigger_type(d); 743 u32 trigger = irqd_get_trigger_type(d);
743 unsigned long flags; 744 unsigned long flags;