diff options
author | Anatolij Gustschin <agust@denx.de> | 2012-11-28 15:15:51 -0500 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@redhat.com> | 2012-12-04 11:59:43 -0500 |
commit | 605a410325535e0d9dd3c539ac144fc52e0bda21 (patch) | |
tree | f001a2615def6e21cb9b06e4dab913329760134c /drivers/media/platform/soc_camera | |
parent | 16427faf28674451a7a0485ab0a929402f355ffd (diff) |
[media] soc_camera: fix VIDIOC_S_CROP ioctl
Sometimes VIDIOC_S_CROP ioctl doesn't work, soc-camera driver reports:
soc-camera-pdrv soc-camera-pdrv.0: S_CROP denied: getting current crop failed
The VIDIOC_G_CROP documentation states that the type field needs to be
set to the respective buffer type when querying, so the check in .g_crop()
of the subdevices returns -EINVAL if the type is not set properly. Here the
uninitialized local variable 'current_crop' is passed to the .g_crop() and
this leads to the observed error. Initialize the type field of the local
'current_crop' before get_crop call.
Signed-off-by: Anatolij Gustschin <agust@denx.de>
Signed-off-by: Guennadi Liakhovetski <g.liakhovetski@gmx.de>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media/platform/soc_camera')
-rw-r--r-- | drivers/media/platform/soc_camera/soc_camera.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/media/platform/soc_camera/soc_camera.c b/drivers/media/platform/soc_camera/soc_camera.c index 4e3735679f17..54da3a5f900c 100644 --- a/drivers/media/platform/soc_camera/soc_camera.c +++ b/drivers/media/platform/soc_camera/soc_camera.c | |||
@@ -908,6 +908,8 @@ static int soc_camera_s_crop(struct file *file, void *fh, | |||
908 | dev_dbg(icd->pdev, "S_CROP(%ux%u@%u:%u)\n", | 908 | dev_dbg(icd->pdev, "S_CROP(%ux%u@%u:%u)\n", |
909 | rect->width, rect->height, rect->left, rect->top); | 909 | rect->width, rect->height, rect->left, rect->top); |
910 | 910 | ||
911 | current_crop.type = a->type; | ||
912 | |||
911 | /* If get_crop fails, we'll let host and / or client drivers decide */ | 913 | /* If get_crop fails, we'll let host and / or client drivers decide */ |
912 | ret = ici->ops->get_crop(icd, ¤t_crop); | 914 | ret = ici->ops->get_crop(icd, ¤t_crop); |
913 | 915 | ||