Commit af0b0baa authored by Krzysztof Kozlowski's avatar Krzysztof Kozlowski

pinctrl: samsung: Fix invalid register offset used for Exynos5433 external interrupts

When setting the pin function for external interrupts, the driver used
wrong IO memory address base.  The pin function register is always under
pctl_base, not the eint_base.

By updating wrong register, the external interrupts for chosen GPIO
would not work at all and some other GPIO might be configured to wrong
value.  For example on Exynos5433-based boards, the external interrupts
for gpf{1-5}-X GPIOs should not work at all (driver toggled reserved
registers from ALIVE bank instead).

Platforms other than Exynos5433 should not be affected as eint_base
equals pctl_base in such case.

Fixes: 8b1bd11c ("pinctrl: samsung: Add the support the multiple IORESOURCE_MEM for one pin-bank")
Cc: <stable@vger.kernel.org>
Reported-by: default avatarTomasz Figa <tomasz.figa@gmail.com>
Signed-off-by: default avatarKrzysztof Kozlowski <krzk@kernel.org>
Reviewed-by: default avatarSylwester Nawrocki <s.nawrocki@samsung.com>
Tested-by: default avatarSylwester Nawrocki <s.nawrocki@samsung.com>
parent cee7413d
...@@ -174,10 +174,10 @@ static int exynos_irq_request_resources(struct irq_data *irqd) ...@@ -174,10 +174,10 @@ static int exynos_irq_request_resources(struct irq_data *irqd)
spin_lock_irqsave(&bank->slock, flags); spin_lock_irqsave(&bank->slock, flags);
con = readl(bank->eint_base + reg_con); con = readl(bank->pctl_base + reg_con);
con &= ~(mask << shift); con &= ~(mask << shift);
con |= EXYNOS_EINT_FUNC << shift; con |= EXYNOS_EINT_FUNC << shift;
writel(con, bank->eint_base + reg_con); writel(con, bank->pctl_base + reg_con);
spin_unlock_irqrestore(&bank->slock, flags); spin_unlock_irqrestore(&bank->slock, flags);
...@@ -202,10 +202,10 @@ static void exynos_irq_release_resources(struct irq_data *irqd) ...@@ -202,10 +202,10 @@ static void exynos_irq_release_resources(struct irq_data *irqd)
spin_lock_irqsave(&bank->slock, flags); spin_lock_irqsave(&bank->slock, flags);
con = readl(bank->eint_base + reg_con); con = readl(bank->pctl_base + reg_con);
con &= ~(mask << shift); con &= ~(mask << shift);
con |= FUNC_INPUT << shift; con |= FUNC_INPUT << shift;
writel(con, bank->eint_base + reg_con); writel(con, bank->pctl_base + reg_con);
spin_unlock_irqrestore(&bank->slock, flags); spin_unlock_irqrestore(&bank->slock, flags);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment