]> git.baikalelectronics.ru Git - kernel.git/commitdiff
media: imx: imx-mipi-csis: Simplify mipi_csis_s_stream()
authorJacopo Mondi <jacopo@jmondi.org>
Mon, 14 Mar 2022 10:39:37 +0000 (10:39 +0000)
committerMauro Carvalho Chehab <mchehab@kernel.org>
Sun, 24 Apr 2022 08:05:56 +0000 (09:05 +0100)
Simplify the mipi_csis_s_stream() function.

This actually fixes a bug, as if calling the subdev's s_stream(1) fails,
mipi_csis_stop_stream() was not called.

Signed-off-by: Jacopo Mondi <jacopo@jmondi.org>
Acked-by: Rui Miguel Silva <rmfrfs@gmail.com>
Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@kernel.org>
drivers/media/platform/nxp/imx-mipi-csis.c

index f4b32edd8dfda34b656378dffdc2c491f5967e3c..8a2250684913e81a9a7bee746ef723c324c7cf9c 100644 (file)
@@ -926,43 +926,51 @@ static struct mipi_csis_device *sd_to_mipi_csis_device(struct v4l2_subdev *sdev)
 static int mipi_csis_s_stream(struct v4l2_subdev *sd, int enable)
 {
        struct mipi_csis_device *csis = sd_to_mipi_csis_device(sd);
-       int ret = 0;
+       int ret;
 
-       if (enable) {
-               ret = mipi_csis_calculate_params(csis);
-               if (ret < 0)
-                       return ret;
+       if (!enable) {
+               mutex_lock(&csis->lock);
 
-               mipi_csis_clear_counters(csis);
+               v4l2_subdev_call(csis->src_sd, video, s_stream, 0);
 
-               ret = pm_runtime_resume_and_get(csis->dev);
-               if (ret < 0)
-                       return ret;
+               mipi_csis_stop_stream(csis);
+               if (csis->debug.enable)
+                       mipi_csis_log_counters(csis, true);
+
+               mutex_unlock(&csis->lock);
+
+               pm_runtime_put(csis->dev);
+
+               return 0;
        }
 
-       mutex_lock(&csis->lock);
+       ret = mipi_csis_calculate_params(csis);
+       if (ret < 0)
+               return ret;
 
-       if (enable) {
-               mipi_csis_start_stream(csis);
-               ret = v4l2_subdev_call(csis->src_sd, video, s_stream, 1);
-               if (ret < 0)
-                       goto unlock;
+       mipi_csis_clear_counters(csis);
 
-               mipi_csis_log_counters(csis, true);
-       } else {
-               v4l2_subdev_call(csis->src_sd, video, s_stream, 0);
+       ret = pm_runtime_resume_and_get(csis->dev);
+       if (ret < 0)
+               return ret;
 
-               mipi_csis_stop_stream(csis);
+       mutex_lock(&csis->lock);
 
-               if (csis->debug.enable)
-                       mipi_csis_log_counters(csis, true);
-       }
+       mipi_csis_start_stream(csis);
+       ret = v4l2_subdev_call(csis->src_sd, video, s_stream, 1);
+       if (ret < 0)
+               goto error;
+
+       mipi_csis_log_counters(csis, true);
 
-unlock:
        mutex_unlock(&csis->lock);
 
-       if (!enable || ret < 0)
-               pm_runtime_put(csis->dev);
+       return 0;
+
+error:
+       mipi_csis_stop_stream(csis);
+       mutex_unlock(&csis->lock);
+       pm_runtime_put(csis->dev);
 
        return ret;
 }