Input: omap4-keypad - switch to using pm_runtime_resume_and_get()
authorMinghao Chi <chi.minghao@zte.com.cn>
Mon, 25 Apr 2022 03:49:01 +0000 (20:49 -0700)
committerDmitry Torokhov <dmitry.torokhov@gmail.com>
Sat, 28 May 2022 04:38:32 +0000 (21:38 -0700)
Use pm_runtime_resume_and_get() to replace pm_runtime_get_sync and
pm_runtime_put_noidle. This change is just to simplify the code, no
actual functional changes.

Reported-by: Zeal Robot <zealci@zte.com.cn>
Signed-off-by: Minghao Chi <chi.minghao@zte.com.cn>
Link: https://lore.kernel.org/r/20220414085710.2541867-1-chi.minghao@zte.com.cn
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
drivers/input/keyboard/omap4-keypad.c

index 8a7ce41b8c56e1b62bd8e8fe4f51204ca55c54c8..ee9d04a3f0d5b04b1de2d4a5500cd529a9ef583c 100644 (file)
@@ -179,11 +179,9 @@ static irqreturn_t omap4_keypad_irq_thread_fn(int irq, void *dev_id)
        int error;
        u64 keys;
 
-       error = pm_runtime_get_sync(dev);
-       if (error < 0) {
-               pm_runtime_put_noidle(dev);
+       error = pm_runtime_resume_and_get(dev);
+       if (error)
                return IRQ_NONE;
-       }
 
        low = kbd_readl(keypad_data, OMAP4_KBD_FULLCODE31_0);
        high = kbd_readl(keypad_data, OMAP4_KBD_FULLCODE63_32);
@@ -207,11 +205,9 @@ static int omap4_keypad_open(struct input_dev *input)
        struct device *dev = input->dev.parent;
        int error;
 
-       error = pm_runtime_get_sync(dev);
-       if (error < 0) {
-               pm_runtime_put_noidle(dev);
+       error = pm_runtime_resume_and_get(dev);
+       if (error)
                return error;
-       }
 
        disable_irq(keypad_data->irq);
 
@@ -254,9 +250,10 @@ static void omap4_keypad_close(struct input_dev *input)
        struct device *dev = input->dev.parent;
        int error;
 
-       error = pm_runtime_get_sync(dev);
-       if (error < 0)
-               pm_runtime_put_noidle(dev);
+       error = pm_runtime_resume_and_get(dev);
+       if (error)
+               dev_err(dev, "%s: pm_runtime_resume_and_get() failed: %d\n",
+                       __func__, error);
 
        disable_irq(keypad_data->irq);
        omap4_keypad_stop(keypad_data);
@@ -392,10 +389,9 @@ static int omap4_keypad_probe(struct platform_device *pdev)
         * Enable clocks for the keypad module so that we can read
         * revision register.
         */
-       error = pm_runtime_get_sync(dev);
-       if (error < 0) {
-               dev_err(dev, "pm_runtime_get_sync() failed\n");
-               pm_runtime_put_noidle(dev);
+       error = pm_runtime_resume_and_get(dev);
+       if (error) {
+               dev_err(dev, "pm_runtime_resume_and_get() failed\n");
                return error;
        }