Input: imx6ul_tsc - clean up some errors in imx6ul_tsc_resume()
authorDan Carpenter <dan.carpenter@oracle.com>
Mon, 14 Sep 2020 17:17:01 +0000 (10:17 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 29 Oct 2020 08:05:40 +0000 (09:05 +0100)
[ Upstream commit 30df23c5ecdfb8da5b0bc17ceef67eff9e1b0957 ]

If imx6ul_tsc_init() fails then we need to clean up the clocks.

I reversed the "if (input_dev->users) {" condition to make the code a
bit simpler.

Fixes: 6cc527b05847 ("Input: imx6ul_tsc - propagate the errors")
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Link: https://lore.kernel.org/r/20200905124942.GC183976@mwanda
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/input/touchscreen/imx6ul_tsc.c

index 8275267eac25441f308e6103e82d48830d1feb71..4be7ddc04af0fd05aee3c0b01b8ab50a9c270a22 100644 (file)
@@ -490,20 +490,25 @@ static int __maybe_unused imx6ul_tsc_resume(struct device *dev)
 
        mutex_lock(&input_dev->mutex);
 
-       if (input_dev->users) {
-               retval = clk_prepare_enable(tsc->adc_clk);
-               if (retval)
-                       goto out;
-
-               retval = clk_prepare_enable(tsc->tsc_clk);
-               if (retval) {
-                       clk_disable_unprepare(tsc->adc_clk);
-                       goto out;
-               }
+       if (!input_dev->users)
+               goto out;
 
-               retval = imx6ul_tsc_init(tsc);
+       retval = clk_prepare_enable(tsc->adc_clk);
+       if (retval)
+               goto out;
+
+       retval = clk_prepare_enable(tsc->tsc_clk);
+       if (retval) {
+               clk_disable_unprepare(tsc->adc_clk);
+               goto out;
        }
 
+       retval = imx6ul_tsc_init(tsc);
+       if (retval) {
+               clk_disable_unprepare(tsc->tsc_clk);
+               clk_disable_unprepare(tsc->adc_clk);
+               goto out;
+       }
 out:
        mutex_unlock(&input_dev->mutex);
        return retval;