diff options
author | Lee Jones <lee.jones@linaro.org> | 2013-01-31 04:45:17 -0500 |
---|---|---|
committer | Linus Walleij <linus.walleij@linaro.org> | 2013-02-06 16:38:40 -0500 |
commit | b9fab6e45d2d41de5495f7d40808e9e131652f92 (patch) | |
tree | d832b21acfd75e63982c6031e5b20998febf760a /drivers/pinctrl/pinctrl-abx500.c | |
parent | fa1ec996ac1a42e46ec7dca089252f124c81d7bd (diff) |
pinctrl/abx500: align GPIO cluster boundaries
Not quite sure how this ever worked. In ab8500_gpio_to_irq() the
GPIO for conversion is passed through as the second argument. If
GPIO13, which is a valid GPIO for IRQ functionality, was received;
it would be rejected by the following guard:
GPIO_IRQ_CLUSTER(5, 12, 0); /* GPIO numbers start from 1 */
if (offset >= cluster->start && offset <= cluster->end)
/* Valid GPIO for IRQ use */
Signed-off-by: Lee Jones <lee.jones@linaro.org>
[Augmented to account for off-by-one problem]
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Diffstat (limited to 'drivers/pinctrl/pinctrl-abx500.c')
-rw-r--r-- | drivers/pinctrl/pinctrl-abx500.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/drivers/pinctrl/pinctrl-abx500.c b/drivers/pinctrl/pinctrl-abx500.c index 9bdfcb97ef57..a9e720ffabfb 100644 --- a/drivers/pinctrl/pinctrl-abx500.c +++ b/drivers/pinctrl/pinctrl-abx500.c | |||
@@ -272,6 +272,8 @@ static int abx500_gpio_direction_input(struct gpio_chip *chip, unsigned offset) | |||
272 | static int abx500_gpio_to_irq(struct gpio_chip *chip, unsigned offset) | 272 | static int abx500_gpio_to_irq(struct gpio_chip *chip, unsigned offset) |
273 | { | 273 | { |
274 | struct abx500_pinctrl *pct = to_abx500_pinctrl(chip); | 274 | struct abx500_pinctrl *pct = to_abx500_pinctrl(chip); |
275 | /* The AB8500 GPIO numbers are off by one */ | ||
276 | int gpio = offset + 1; | ||
275 | int base = pct->irq_base; | 277 | int base = pct->irq_base; |
276 | int i; | 278 | int i; |
277 | 279 | ||
@@ -279,8 +281,8 @@ static int abx500_gpio_to_irq(struct gpio_chip *chip, unsigned offset) | |||
279 | struct abx500_gpio_irq_cluster *cluster = | 281 | struct abx500_gpio_irq_cluster *cluster = |
280 | &pct->irq_cluster[i]; | 282 | &pct->irq_cluster[i]; |
281 | 283 | ||
282 | if (offset >= cluster->start && offset <= cluster->end) | 284 | if (gpio >= cluster->start && gpio <= cluster->end) |
283 | return base + offset - cluster->start; | 285 | return base + gpio - cluster->start; |
284 | 286 | ||
285 | /* Advance by the number of gpios in this cluster */ | 287 | /* Advance by the number of gpios in this cluster */ |
286 | base += cluster->end + cluster->offset - cluster->start + 1; | 288 | base += cluster->end + cluster->offset - cluster->start + 1; |