From: Fabien Dessenne <fabien.desse...@st.com>

Use the hwspin_lock_timeout_in_atomic() API which is the most appropriated
here. Indeed:
- hwspin_lock_() is called after spin_lock_irqsave()
- the hwspin_lock_timeout() API relies on jiffies count which won't work
  if IRQs are disabled which is the case here.

Signed-off-by: Fabien Dessenne <fabien.desse...@st.com>
Signed-off-by: Alexandre Torgue <alexandre.tor...@st.com>

diff --git a/drivers/pinctrl/stm32/pinctrl-stm32.c 
b/drivers/pinctrl/stm32/pinctrl-stm32.c
index a657cd829ce6..1f7fff84aa9d 100644
--- a/drivers/pinctrl/stm32/pinctrl-stm32.c
+++ b/drivers/pinctrl/stm32/pinctrl-stm32.c
@@ -64,7 +64,7 @@
 #define gpio_range_to_bank(chip) \
                container_of(chip, struct stm32_gpio_bank, range)
 
-#define HWSPINLOCK_TIMEOUT     5 /* msec */
+#define HWSPNLCK_TIMEOUT       1000 /* usec */
 
 static const char * const stm32_gpio_functions[] = {
        "gpio", "af0", "af1",
@@ -420,12 +420,14 @@ static int stm32_gpio_domain_activate(struct irq_domain 
*d,
         * to avoid overriding.
         */
        spin_lock_irqsave(&pctl->irqmux_lock, flags);
-       if (pctl->hwlock)
-               ret = hwspin_lock_timeout(pctl->hwlock, HWSPINLOCK_TIMEOUT);
 
-       if (ret) {
-               dev_err(pctl->dev, "Can't get hwspinlock\n");
-               goto unlock;
+       if (pctl->hwlock) {
+               ret = hwspin_lock_timeout_in_atomic(pctl->hwlock,
+                                                   HWSPNLCK_TIMEOUT);
+               if (ret) {
+                       dev_err(pctl->dev, "Can't get hwspinlock\n");
+                       goto unlock;
+               }
        }
 
        if (pctl->irqmux_map & BIT(irq_data->hwirq)) {
@@ -433,7 +435,7 @@ static int stm32_gpio_domain_activate(struct irq_domain *d,
                        irq_data->hwirq);
                ret = -EBUSY;
                if (pctl->hwlock)
-                       hwspin_unlock(pctl->hwlock);
+                       hwspin_unlock_in_atomic(pctl->hwlock);
                goto unlock;
        } else {
                pctl->irqmux_map |= BIT(irq_data->hwirq);
@@ -442,7 +444,7 @@ static int stm32_gpio_domain_activate(struct irq_domain *d,
        regmap_field_write(pctl->irqmux[irq_data->hwirq], bank->bank_ioport_nr);
 
        if (pctl->hwlock)
-               hwspin_unlock(pctl->hwlock);
+               hwspin_unlock_in_atomic(pctl->hwlock);
 
 unlock:
        spin_unlock_irqrestore(&pctl->irqmux_lock, flags);
@@ -750,12 +752,13 @@ static int stm32_pmx_set_mode(struct stm32_gpio_bank 
*bank,
        clk_enable(bank->clk);
        spin_lock_irqsave(&bank->lock, flags);
 
-       if (pctl->hwlock)
-               err = hwspin_lock_timeout(pctl->hwlock, HWSPINLOCK_TIMEOUT);
-
-       if (err) {
-               dev_err(pctl->dev, "Can't get hwspinlock\n");
-               goto unlock;
+       if (pctl->hwlock) {
+               err = hwspin_lock_timeout_in_atomic(pctl->hwlock,
+                                                   HWSPNLCK_TIMEOUT);
+               if (err) {
+                       dev_err(pctl->dev, "Can't get hwspinlock\n");
+                       goto unlock;
+               }
        }
 
        val = readl_relaxed(bank->base + alt_offset);
@@ -769,7 +772,7 @@ static int stm32_pmx_set_mode(struct stm32_gpio_bank *bank,
        writel_relaxed(val, bank->base + STM32_GPIO_MODER);
 
        if (pctl->hwlock)
-               hwspin_unlock(pctl->hwlock);
+               hwspin_unlock_in_atomic(pctl->hwlock);
 
        stm32_gpio_backup_mode(bank, pin, mode, alt);
 
@@ -869,12 +872,13 @@ static int stm32_pconf_set_driving(struct stm32_gpio_bank 
*bank,
        clk_enable(bank->clk);
        spin_lock_irqsave(&bank->lock, flags);
 
-       if (pctl->hwlock)
-               err = hwspin_lock_timeout(pctl->hwlock, HWSPINLOCK_TIMEOUT);
-
-       if (err) {
-               dev_err(pctl->dev, "Can't get hwspinlock\n");
-               goto unlock;
+       if (pctl->hwlock) {
+               err = hwspin_lock_timeout_in_atomic(pctl->hwlock,
+                                                   HWSPNLCK_TIMEOUT);
+               if (err) {
+                       dev_err(pctl->dev, "Can't get hwspinlock\n");
+                       goto unlock;
+               }
        }
 
        val = readl_relaxed(bank->base + STM32_GPIO_TYPER);
@@ -883,7 +887,7 @@ static int stm32_pconf_set_driving(struct stm32_gpio_bank 
*bank,
        writel_relaxed(val, bank->base + STM32_GPIO_TYPER);
 
        if (pctl->hwlock)
-               hwspin_unlock(pctl->hwlock);
+               hwspin_unlock_in_atomic(pctl->hwlock);
 
        stm32_gpio_backup_driving(bank, offset, drive);
 
@@ -923,12 +927,13 @@ static int stm32_pconf_set_speed(struct stm32_gpio_bank 
*bank,
        clk_enable(bank->clk);
        spin_lock_irqsave(&bank->lock, flags);
 
-       if (pctl->hwlock)
-               err = hwspin_lock_timeout(pctl->hwlock, HWSPINLOCK_TIMEOUT);
-
-       if (err) {
-               dev_err(pctl->dev, "Can't get hwspinlock\n");
-               goto unlock;
+       if (pctl->hwlock) {
+               err = hwspin_lock_timeout_in_atomic(pctl->hwlock,
+                                                   HWSPNLCK_TIMEOUT);
+               if (err) {
+                       dev_err(pctl->dev, "Can't get hwspinlock\n");
+                       goto unlock;
+               }
        }
 
        val = readl_relaxed(bank->base + STM32_GPIO_SPEEDR);
@@ -937,7 +942,7 @@ static int stm32_pconf_set_speed(struct stm32_gpio_bank 
*bank,
        writel_relaxed(val, bank->base + STM32_GPIO_SPEEDR);
 
        if (pctl->hwlock)
-               hwspin_unlock(pctl->hwlock);
+               hwspin_unlock_in_atomic(pctl->hwlock);
 
        stm32_gpio_backup_speed(bank, offset, speed);
 
@@ -977,12 +982,13 @@ static int stm32_pconf_set_bias(struct stm32_gpio_bank 
*bank,
        clk_enable(bank->clk);
        spin_lock_irqsave(&bank->lock, flags);
 
-       if (pctl->hwlock)
-               err = hwspin_lock_timeout(pctl->hwlock, HWSPINLOCK_TIMEOUT);
-
-       if (err) {
-               dev_err(pctl->dev, "Can't get hwspinlock\n");
-               goto unlock;
+       if (pctl->hwlock) {
+               err = hwspin_lock_timeout_in_atomic(pctl->hwlock,
+                                                   HWSPNLCK_TIMEOUT);
+               if (err) {
+                       dev_err(pctl->dev, "Can't get hwspinlock\n");
+                       goto unlock;
+               }
        }
 
        val = readl_relaxed(bank->base + STM32_GPIO_PUPDR);
@@ -991,7 +997,7 @@ static int stm32_pconf_set_bias(struct stm32_gpio_bank 
*bank,
        writel_relaxed(val, bank->base + STM32_GPIO_PUPDR);
 
        if (pctl->hwlock)
-               hwspin_unlock(pctl->hwlock);
+               hwspin_unlock_in_atomic(pctl->hwlock);
 
        stm32_gpio_backup_bias(bank, offset, bias);
 
-- 
2.17.1

Reply via email to