]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
[media] ov9640: avoid calling ov9640_res_roundup() twice
authorHans Verkuil <hans.verkuil@cisco.com>
Mon, 4 May 2015 10:25:54 +0000 (07:25 -0300)
committerMauro Carvalho Chehab <mchehab@s-opensource.com>
Sat, 15 Apr 2017 01:31:47 +0000 (22:31 -0300)
Simplify ov9640_s_fmt and ov9640_set_fmt

Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
Acked-by: Guennadi Liakhovetski <g.liakhovetski@gmx.de>
Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
drivers/media/i2c/soc_camera/ov9640.c

index 0a69e49de459642c77f6c6e7565c261bd34ad1d1..0146d1f7aacb0967a41ac5df3dcd785514ea77cf 100644 (file)
@@ -486,11 +486,8 @@ static int ov9640_s_fmt(struct v4l2_subdev *sd,
 {
        struct i2c_client *client = v4l2_get_subdevdata(sd);
        struct ov9640_reg_alt alts = {0};
-       enum v4l2_colorspace cspace;
-       u32 code = mf->code;
        int ret;
 
-       ov9640_res_roundup(&mf->width, &mf->height);
        ov9640_alter_regs(mf->code, &alts);
 
        ov9640_reset(client);
@@ -499,24 +496,7 @@ static int ov9640_s_fmt(struct v4l2_subdev *sd,
        if (ret)
                return ret;
 
-       switch (code) {
-       case MEDIA_BUS_FMT_RGB555_2X8_PADHI_LE:
-       case MEDIA_BUS_FMT_RGB565_2X8_LE:
-               cspace = V4L2_COLORSPACE_SRGB;
-               break;
-       default:
-               code = MEDIA_BUS_FMT_UYVY8_2X8;
-       case MEDIA_BUS_FMT_UYVY8_2X8:
-               cspace = V4L2_COLORSPACE_JPEG;
-       }
-
-       ret = ov9640_write_regs(client, mf->width, code, &alts);
-       if (!ret) {
-               mf->code        = code;
-               mf->colorspace  = cspace;
-       }
-
-       return ret;
+       return ov9640_write_regs(client, mf->width, mf->code, &alts);
 }
 
 static int ov9640_set_fmt(struct v4l2_subdev *sd,
@@ -539,8 +519,10 @@ static int ov9640_set_fmt(struct v4l2_subdev *sd,
                break;
        default:
                mf->code = MEDIA_BUS_FMT_UYVY8_2X8;
+               /* fall through */
        case MEDIA_BUS_FMT_UYVY8_2X8:
                mf->colorspace = V4L2_COLORSPACE_JPEG;
+               break;
        }
 
        if (format->which == V4L2_SUBDEV_FORMAT_ACTIVE)