diff options
author | Kevin Hilman <khilman@ti.com> | 2011-04-22 10:59:07 -0400 |
---|---|---|
committer | Kevin Hilman <khilman@ti.com> | 2011-06-16 14:13:32 -0400 |
commit | 129fd2230733ff0457e76d6aabde136cf8666bc0 (patch) | |
tree | d2f1d90f4629e93cd02d17211eb2643962bdad8f | |
parent | c390aad0330f330ce9818ef5269169bbae335da9 (diff) |
gpio/omap: replace get_gpio_index() by using bank width
The get_gpio_index() function, littered with cpu_is_* checks can be easily
replaced by using bitops based on the GPIO bank width. Do so.
Signed-off-by: Kevin Hilman <khilman@ti.com>
-rw-r--r-- | drivers/gpio/gpio-omap.c | 42 |
1 files changed, 17 insertions, 25 deletions
diff --git a/drivers/gpio/gpio-omap.c b/drivers/gpio/gpio-omap.c index 0766aa1c3f31..72811a3b9158 100644 --- a/drivers/gpio/gpio-omap.c +++ b/drivers/gpio/gpio-omap.c | |||
@@ -83,6 +83,9 @@ static struct gpio_bank *gpio_bank; | |||
83 | /* TODO: Analyze removing gpio_bank_count usage from driver code */ | 83 | /* TODO: Analyze removing gpio_bank_count usage from driver code */ |
84 | int gpio_bank_count; | 84 | int gpio_bank_count; |
85 | 85 | ||
86 | #define GPIO_INDEX(bank, gpio) (gpio % bank->width) | ||
87 | #define GPIO_BIT(bank, gpio) (1 << GPIO_INDEX(bank, gpio)) | ||
88 | |||
86 | static inline struct gpio_bank *get_gpio_bank(int gpio) | 89 | static inline struct gpio_bank *get_gpio_bank(int gpio) |
87 | { | 90 | { |
88 | if (cpu_is_omap15xx()) { | 91 | if (cpu_is_omap15xx()) { |
@@ -108,17 +111,6 @@ static inline struct gpio_bank *get_gpio_bank(int gpio) | |||
108 | return NULL; | 111 | return NULL; |
109 | } | 112 | } |
110 | 113 | ||
111 | static inline int get_gpio_index(int gpio) | ||
112 | { | ||
113 | if (cpu_is_omap7xx()) | ||
114 | return gpio & 0x1f; | ||
115 | if (cpu_is_omap24xx()) | ||
116 | return gpio & 0x1f; | ||
117 | if (cpu_is_omap34xx() || cpu_is_omap44xx()) | ||
118 | return gpio & 0x1f; | ||
119 | return gpio & 0x0f; | ||
120 | } | ||
121 | |||
122 | static inline int gpio_valid(int gpio) | 114 | static inline int gpio_valid(int gpio) |
123 | { | 115 | { |
124 | if (gpio < 0) | 116 | if (gpio < 0) |
@@ -313,7 +305,7 @@ static int _get_gpio_datain(struct gpio_bank *bank, int gpio) | |||
313 | return -EINVAL; | 305 | return -EINVAL; |
314 | } | 306 | } |
315 | return (__raw_readl(reg) | 307 | return (__raw_readl(reg) |
316 | & (1 << get_gpio_index(gpio))) != 0; | 308 | & (GPIO_BIT(bank, gpio))) != 0; |
317 | } | 309 | } |
318 | 310 | ||
319 | static int _get_gpio_dataout(struct gpio_bank *bank, int gpio) | 311 | static int _get_gpio_dataout(struct gpio_bank *bank, int gpio) |
@@ -359,7 +351,7 @@ static int _get_gpio_dataout(struct gpio_bank *bank, int gpio) | |||
359 | return -EINVAL; | 351 | return -EINVAL; |
360 | } | 352 | } |
361 | 353 | ||
362 | return (__raw_readl(reg) & (1 << get_gpio_index(gpio))) != 0; | 354 | return (__raw_readl(reg) & GPIO_BIT(bank, gpio)) != 0; |
363 | } | 355 | } |
364 | 356 | ||
365 | #define MOD_REG_BIT(reg, bit_mask, set) \ | 357 | #define MOD_REG_BIT(reg, bit_mask, set) \ |
@@ -396,7 +388,7 @@ static void _set_gpio_debounce(struct gpio_bank *bank, unsigned gpio, | |||
396 | else | 388 | else |
397 | debounce = (debounce / 0x1f) - 1; | 389 | debounce = (debounce / 0x1f) - 1; |
398 | 390 | ||
399 | l = 1 << get_gpio_index(gpio); | 391 | l = GPIO_BIT(bank, gpio); |
400 | 392 | ||
401 | if (bank->method == METHOD_GPIO_44XX) | 393 | if (bank->method == METHOD_GPIO_44XX) |
402 | reg += OMAP4_GPIO_DEBOUNCINGTIME; | 394 | reg += OMAP4_GPIO_DEBOUNCINGTIME; |
@@ -640,7 +632,7 @@ static int gpio_irq_type(struct irq_data *d, unsigned type) | |||
640 | 632 | ||
641 | bank = irq_data_get_irq_chip_data(d); | 633 | bank = irq_data_get_irq_chip_data(d); |
642 | spin_lock_irqsave(&bank->lock, flags); | 634 | spin_lock_irqsave(&bank->lock, flags); |
643 | retval = _set_gpio_triggering(bank, get_gpio_index(gpio), type); | 635 | retval = _set_gpio_triggering(bank, GPIO_INDEX(bank, gpio), type); |
644 | spin_unlock_irqrestore(&bank->lock, flags); | 636 | spin_unlock_irqrestore(&bank->lock, flags); |
645 | 637 | ||
646 | if (type & (IRQ_TYPE_LEVEL_LOW | IRQ_TYPE_LEVEL_HIGH)) | 638 | if (type & (IRQ_TYPE_LEVEL_LOW | IRQ_TYPE_LEVEL_HIGH)) |
@@ -702,7 +694,7 @@ static void _clear_gpio_irqbank(struct gpio_bank *bank, int gpio_mask) | |||
702 | 694 | ||
703 | static inline void _clear_gpio_irqstatus(struct gpio_bank *bank, int gpio) | 695 | static inline void _clear_gpio_irqstatus(struct gpio_bank *bank, int gpio) |
704 | { | 696 | { |
705 | _clear_gpio_irqbank(bank, 1 << get_gpio_index(gpio)); | 697 | _clear_gpio_irqbank(bank, GPIO_BIT(bank, gpio)); |
706 | } | 698 | } |
707 | 699 | ||
708 | static u32 _get_gpio_irqbank_mask(struct gpio_bank *bank) | 700 | static u32 _get_gpio_irqbank_mask(struct gpio_bank *bank) |
@@ -830,7 +822,7 @@ static void _enable_gpio_irqbank(struct gpio_bank *bank, int gpio_mask, int enab | |||
830 | 822 | ||
831 | static inline void _set_gpio_irqenable(struct gpio_bank *bank, int gpio, int enable) | 823 | static inline void _set_gpio_irqenable(struct gpio_bank *bank, int gpio, int enable) |
832 | { | 824 | { |
833 | _enable_gpio_irqbank(bank, 1 << get_gpio_index(gpio), enable); | 825 | _enable_gpio_irqbank(bank, GPIO_BIT(bank, gpio), enable); |
834 | } | 826 | } |
835 | 827 | ||
836 | /* | 828 | /* |
@@ -883,10 +875,10 @@ static int _set_gpio_wakeup(struct gpio_bank *bank, int gpio, int enable) | |||
883 | 875 | ||
884 | static void _reset_gpio(struct gpio_bank *bank, int gpio) | 876 | static void _reset_gpio(struct gpio_bank *bank, int gpio) |
885 | { | 877 | { |
886 | _set_gpio_direction(bank, get_gpio_index(gpio), 1); | 878 | _set_gpio_direction(bank, GPIO_INDEX(bank, gpio), 1); |
887 | _set_gpio_irqenable(bank, gpio, 0); | 879 | _set_gpio_irqenable(bank, gpio, 0); |
888 | _clear_gpio_irqstatus(bank, gpio); | 880 | _clear_gpio_irqstatus(bank, gpio); |
889 | _set_gpio_triggering(bank, get_gpio_index(gpio), IRQ_TYPE_NONE); | 881 | _set_gpio_triggering(bank, GPIO_INDEX(bank, gpio), IRQ_TYPE_NONE); |
890 | } | 882 | } |
891 | 883 | ||
892 | /* Use disable_irq_wake() and enable_irq_wake() functions from drivers */ | 884 | /* Use disable_irq_wake() and enable_irq_wake() functions from drivers */ |
@@ -899,7 +891,7 @@ static int gpio_wake_enable(struct irq_data *d, unsigned int enable) | |||
899 | if (check_gpio(gpio) < 0) | 891 | if (check_gpio(gpio) < 0) |
900 | return -ENODEV; | 892 | return -ENODEV; |
901 | bank = irq_data_get_irq_chip_data(d); | 893 | bank = irq_data_get_irq_chip_data(d); |
902 | retval = _set_gpio_wakeup(bank, get_gpio_index(gpio), enable); | 894 | retval = _set_gpio_wakeup(bank, GPIO_INDEX(bank, gpio), enable); |
903 | 895 | ||
904 | return retval; | 896 | return retval; |
905 | } | 897 | } |
@@ -1079,7 +1071,7 @@ static void gpio_irq_handler(unsigned int irq, struct irq_desc *desc) | |||
1079 | 1071 | ||
1080 | gpio_irq = bank->virtual_irq_start; | 1072 | gpio_irq = bank->virtual_irq_start; |
1081 | for (; isr != 0; isr >>= 1, gpio_irq++) { | 1073 | for (; isr != 0; isr >>= 1, gpio_irq++) { |
1082 | gpio_index = get_gpio_index(irq_to_gpio(gpio_irq)); | 1074 | gpio_index = GPIO_INDEX(bank, irq_to_gpio(gpio_irq)); |
1083 | 1075 | ||
1084 | if (!(isr & 1)) | 1076 | if (!(isr & 1)) |
1085 | continue; | 1077 | continue; |
@@ -1135,7 +1127,7 @@ static void gpio_mask_irq(struct irq_data *d) | |||
1135 | 1127 | ||
1136 | spin_lock_irqsave(&bank->lock, flags); | 1128 | spin_lock_irqsave(&bank->lock, flags); |
1137 | _set_gpio_irqenable(bank, gpio, 0); | 1129 | _set_gpio_irqenable(bank, gpio, 0); |
1138 | _set_gpio_triggering(bank, get_gpio_index(gpio), IRQ_TYPE_NONE); | 1130 | _set_gpio_triggering(bank, GPIO_INDEX(bank, gpio), IRQ_TYPE_NONE); |
1139 | spin_unlock_irqrestore(&bank->lock, flags); | 1131 | spin_unlock_irqrestore(&bank->lock, flags); |
1140 | } | 1132 | } |
1141 | 1133 | ||
@@ -1143,13 +1135,13 @@ static void gpio_unmask_irq(struct irq_data *d) | |||
1143 | { | 1135 | { |
1144 | unsigned int gpio = d->irq - IH_GPIO_BASE; | 1136 | unsigned int gpio = d->irq - IH_GPIO_BASE; |
1145 | struct gpio_bank *bank = irq_data_get_irq_chip_data(d); | 1137 | struct gpio_bank *bank = irq_data_get_irq_chip_data(d); |
1146 | unsigned int irq_mask = 1 << get_gpio_index(gpio); | 1138 | unsigned int irq_mask = GPIO_BIT(bank, gpio); |
1147 | u32 trigger = irqd_get_trigger_type(d); | 1139 | u32 trigger = irqd_get_trigger_type(d); |
1148 | unsigned long flags; | 1140 | unsigned long flags; |
1149 | 1141 | ||
1150 | spin_lock_irqsave(&bank->lock, flags); | 1142 | spin_lock_irqsave(&bank->lock, flags); |
1151 | if (trigger) | 1143 | if (trigger) |
1152 | _set_gpio_triggering(bank, get_gpio_index(gpio), trigger); | 1144 | _set_gpio_triggering(bank, GPIO_INDEX(bank, gpio), trigger); |
1153 | 1145 | ||
1154 | /* For level-triggered GPIOs, the clearing must be done after | 1146 | /* For level-triggered GPIOs, the clearing must be done after |
1155 | * the HW source is cleared, thus after the handler has run */ | 1147 | * the HW source is cleared, thus after the handler has run */ |
@@ -1352,7 +1344,7 @@ static int gpio_get(struct gpio_chip *chip, unsigned offset) | |||
1352 | gpio = chip->base + offset; | 1344 | gpio = chip->base + offset; |
1353 | bank = get_gpio_bank(gpio); | 1345 | bank = get_gpio_bank(gpio); |
1354 | reg = bank->base; | 1346 | reg = bank->base; |
1355 | mask = 1 << get_gpio_index(gpio); | 1347 | mask = GPIO_BIT(bank, gpio); |
1356 | 1348 | ||
1357 | if (gpio_is_input(bank, mask)) | 1349 | if (gpio_is_input(bank, mask)) |
1358 | return _get_gpio_datain(bank, gpio); | 1350 | return _get_gpio_datain(bank, gpio); |