media: i2c: imx290: Factor out format retrieval to separate function
authorLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Sun, 16 Oct 2022 06:15:21 +0000 (09:15 +0300)
committerSakari Ailus <sakari.ailus@linux.intel.com>
Thu, 27 Oct 2022 11:38:03 +0000 (14:38 +0300)
The driver duplicates the same pattern to access the try or active
format in multiple locations. Factor it out to a separate function.

Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
drivers/media/i2c/imx290.c

index ba46d321a83a5314d1fb635fabb4dcdf333534f8..0af5ad8a824d64bd6ed24da6b8f96149b8c4dfa1 100644 (file)
@@ -519,6 +519,16 @@ static const struct v4l2_ctrl_ops imx290_ctrl_ops = {
        .s_ctrl = imx290_set_ctrl,
 };
 
+static struct v4l2_mbus_framefmt *
+imx290_get_pad_format(struct imx290 *imx290, struct v4l2_subdev_state *state,
+                     u32 which)
+{
+       if (which == V4L2_SUBDEV_FORMAT_ACTIVE)
+               return &imx290->current_format;
+       else
+               return v4l2_subdev_get_try_format(&imx290->sd, state, 0);
+}
+
 static int imx290_enum_mbus_code(struct v4l2_subdev *sd,
                                 struct v4l2_subdev_state *sd_state,
                                 struct v4l2_subdev_mbus_code_enum *code)
@@ -562,12 +572,7 @@ static int imx290_get_fmt(struct v4l2_subdev *sd,
 
        mutex_lock(&imx290->lock);
 
-       if (fmt->which == V4L2_SUBDEV_FORMAT_TRY)
-               framefmt = v4l2_subdev_get_try_format(&imx290->sd, sd_state,
-                                                     fmt->pad);
-       else
-               framefmt = &imx290->current_format;
-
+       framefmt = imx290_get_pad_format(imx290, sd_state, fmt->which);
        fmt->format = *framefmt;
 
        mutex_unlock(&imx290->lock);
@@ -627,10 +632,9 @@ static int imx290_set_fmt(struct v4l2_subdev *sd,
        fmt->format.code = imx290_formats[i].code;
        fmt->format.field = V4L2_FIELD_NONE;
 
-       if (fmt->which == V4L2_SUBDEV_FORMAT_TRY) {
-               format = v4l2_subdev_get_try_format(sd, sd_state, fmt->pad);
-       } else {
-               format = &imx290->current_format;
+       format = imx290_get_pad_format(imx290, sd_state, fmt->which);
+
+       if (fmt->which == V4L2_SUBDEV_FORMAT_ACTIVE) {
                imx290->current_mode = mode;
                imx290->bpp = imx290_formats[i].bpp;