diff mbox series

input: gpio-keys - use spin_lock()

Message ID 20230903160349.3919-1-sensor1010@163.com (mailing list archive)
State New, archived
Headers show
Series input: gpio-keys - use spin_lock() | expand

Commit Message

李哲 Sept. 3, 2023, 4:03 p.m. UTC
Use the spin_lock() and spin_unlock() instead of spin_lock_irqsave()
and spin_unlock_restore()

Signed-off-by: Lizhe <sensor1010@163.com>
---
 drivers/input/keyboard/gpio_keys.c | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)

Comments

Geert Uytterhoeven Sept. 4, 2023, 7:46 a.m. UTC | #1
Hi Lizhe,

Thanks for your patch!

On Sun, Sep 3, 2023 at 6:04 PM Lizhe <sensor1010@163.com> wrote:
> Use the spin_lock() and spin_unlock() instead of spin_lock_irqsave()
> and spin_unlock_restore()

Please explain why...

> Signed-off-by: Lizhe <sensor1010@163.com>

> --- a/drivers/input/keyboard/gpio_keys.c
> +++ b/drivers/input/keyboard/gpio_keys.c
> @@ -468,11 +468,10 @@ static irqreturn_t gpio_keys_irq_isr(int irq, void *dev_id)
>  {
>         struct gpio_button_data *bdata = dev_id;
>         struct input_dev *input = bdata->input;
> -       unsigned long flags;
>
>         BUG_ON(irq != bdata->irq);
>
> -       spin_lock_irqsave(&bdata->lock, flags);
> +       spin_lock(&bdata->lock);
>
>         if (!bdata->key_pressed) {
>                 if (bdata->button->wakeup)
> @@ -495,7 +494,7 @@ static irqreturn_t gpio_keys_irq_isr(int irq, void *dev_id)
>                               ms_to_ktime(bdata->release_delay),
>                               HRTIMER_MODE_REL_HARD);
>  out:
> -       spin_unlock_irqrestore(&bdata->lock, flags);
> +       spin_unlock(&bdata->lock);
>         return IRQ_HANDLED;
>  }

Are you sure this is safe, given the interrupt is requested with
devm_request_any_context_irq(), and thus the handler may be registered
using either request_irq() or request_threaded_irq()?

Gr{oetje,eeting}s,

                        Geert
diff mbox series

Patch

diff --git a/drivers/input/keyboard/gpio_keys.c b/drivers/input/keyboard/gpio_keys.c
index c928829a8b0c..a55d62e1ff6d 100644
--- a/drivers/input/keyboard/gpio_keys.c
+++ b/drivers/input/keyboard/gpio_keys.c
@@ -468,11 +468,10 @@  static irqreturn_t gpio_keys_irq_isr(int irq, void *dev_id)
 {
 	struct gpio_button_data *bdata = dev_id;
 	struct input_dev *input = bdata->input;
-	unsigned long flags;
 
 	BUG_ON(irq != bdata->irq);
 
-	spin_lock_irqsave(&bdata->lock, flags);
+	spin_lock(&bdata->lock);
 
 	if (!bdata->key_pressed) {
 		if (bdata->button->wakeup)
@@ -495,7 +494,7 @@  static irqreturn_t gpio_keys_irq_isr(int irq, void *dev_id)
 			      ms_to_ktime(bdata->release_delay),
 			      HRTIMER_MODE_REL_HARD);
 out:
-	spin_unlock_irqrestore(&bdata->lock, flags);
+	spin_unlock(&bdata->lock);
 	return IRQ_HANDLED;
 }