Commit 3c4a7372 authored by Hugues Fruchet's avatar Hugues Fruchet Committed by Mauro Carvalho Chehab

media: ov5640: fix frame interval enumeration

Driver must reject frame interval enumeration of unsupported resolution.
This was detected by v4l2-compliance format ioctl test:
v4l2-compliance Format ioctls:
    info: found 2 frameintervals for pixel format 4745504a and size 176x144
  fail: v4l2-test-formats.cpp(123):
                           found frame intervals for invalid size 177x144
    test VIDIOC_ENUM_FMT/FRAMESIZES/FRAMEINTERVALS: FAIL
Signed-off-by: default avatarHugues Fruchet <hugues.fruchet@st.com>
Signed-off-by: default avatarSakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+samsung@kernel.org>
parent 2bbc46e8
...@@ -1413,24 +1413,16 @@ static const struct ov5640_mode_info * ...@@ -1413,24 +1413,16 @@ static const struct ov5640_mode_info *
ov5640_find_mode(struct ov5640_dev *sensor, enum ov5640_frame_rate fr, ov5640_find_mode(struct ov5640_dev *sensor, enum ov5640_frame_rate fr,
int width, int height, bool nearest) int width, int height, bool nearest)
{ {
const struct ov5640_mode_info *mode = NULL; const struct ov5640_mode_info *mode;
int i;
for (i = OV5640_NUM_MODES - 1; i >= 0; i--) {
mode = &ov5640_mode_data[fr][i];
if (!mode->reg_data)
continue;
if ((nearest && mode->hact <= width && mode = v4l2_find_nearest_size(ov5640_mode_data[fr],
mode->vact <= height) || ARRAY_SIZE(ov5640_mode_data[fr]),
(!nearest && mode->hact == width && hact, vact,
mode->vact == height)) width, height);
break;
}
if (nearest && i < 0) if (!mode ||
mode = &ov5640_mode_data[fr][0]; (!nearest && (mode->hact != width || mode->vact != height)))
return NULL;
return mode; return mode;
} }
...@@ -2509,8 +2501,14 @@ static int ov5640_s_frame_interval(struct v4l2_subdev *sd, ...@@ -2509,8 +2501,14 @@ static int ov5640_s_frame_interval(struct v4l2_subdev *sd,
sensor->current_fr = frame_rate; sensor->current_fr = frame_rate;
sensor->frame_interval = fi->interval; sensor->frame_interval = fi->interval;
sensor->current_mode = ov5640_find_mode(sensor, frame_rate, mode->hact, mode = ov5640_find_mode(sensor, frame_rate, mode->hact,
mode->vact, true); mode->vact, true);
if (!mode) {
ret = -EINVAL;
goto out;
}
sensor->current_mode = mode;
sensor->pending_mode_change = true; sensor->pending_mode_change = true;
out: out:
mutex_unlock(&sensor->lock); mutex_unlock(&sensor->lock);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment