aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media
diff options
context:
space:
mode:
authorTrent Piepho <xyzzy@speakeasy.org>2009-03-28 21:25:36 -0400
committerMauro Carvalho Chehab <mchehab@redhat.com>2009-03-30 11:43:45 -0400
commit2509e1cb3360961113117f25ae482c430f3bd03d (patch)
tree44b4a0d4fea286262a09ca75136eed9f72035d35 /drivers/media
parent020b882b1d34e8787658a15e00f2ea0d4651605b (diff)
V4L/DVB (11265): stkwebcam: Remove buffer type check from g_parm and q/dq/reqbufs
The v4l2-ioctl core only allows buffer types for which the corresponding ->vidioc_try_fmt_xxx() methods are defined to be used with vidioc_(q|dq|query)bufs(), vidioc_reqbufs() and now vidioc_(s|g)_parm. This driver only defines ->vidioc_try_fmt_vid_cap() so only VIDEO_CAPTURE buffers are allowed to be used with vidioc_g_parm(), vidioc_qbuf(), vidioc_dqbuf(), and vidioc_reqbufs(). Cc: Jaime Velasco Juan <jsagarribay@gmail.com> Signed-off-by: Trent Piepho <xyzzy@speakeasy.org> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media')
-rw-r--r--drivers/media/video/stk-webcam.c10
1 files changed, 1 insertions, 9 deletions
diff --git a/drivers/media/video/stk-webcam.c b/drivers/media/video/stk-webcam.c
index 6b7f0da9b515..1a6d39cbd6f3 100644
--- a/drivers/media/video/stk-webcam.c
+++ b/drivers/media/video/stk-webcam.c
@@ -1112,8 +1112,6 @@ static int stk_vidioc_reqbufs(struct file *filp,
1112 1112
1113 if (dev == NULL) 1113 if (dev == NULL)
1114 return -ENODEV; 1114 return -ENODEV;
1115 if (rb->type != V4L2_BUF_TYPE_VIDEO_CAPTURE)
1116 return -EINVAL;
1117 if (rb->memory != V4L2_MEMORY_MMAP) 1115 if (rb->memory != V4L2_MEMORY_MMAP)
1118 return -EINVAL; 1116 return -EINVAL;
1119 if (is_streaming(dev) 1117 if (is_streaming(dev)
@@ -1152,8 +1150,6 @@ static int stk_vidioc_qbuf(struct file *filp,
1152 struct stk_camera *dev = priv; 1150 struct stk_camera *dev = priv;
1153 struct stk_sio_buffer *sbuf; 1151 struct stk_sio_buffer *sbuf;
1154 unsigned long flags; 1152 unsigned long flags;
1155 if (buf->type != V4L2_BUF_TYPE_VIDEO_CAPTURE)
1156 return -EINVAL;
1157 1153
1158 if (buf->memory != V4L2_MEMORY_MMAP) 1154 if (buf->memory != V4L2_MEMORY_MMAP)
1159 return -EINVAL; 1155 return -EINVAL;
@@ -1180,8 +1176,7 @@ static int stk_vidioc_dqbuf(struct file *filp,
1180 unsigned long flags; 1176 unsigned long flags;
1181 int ret; 1177 int ret;
1182 1178
1183 if (buf->type != V4L2_BUF_TYPE_VIDEO_CAPTURE 1179 if (!is_streaming(dev))
1184 || !is_streaming(dev))
1185 return -EINVAL; 1180 return -EINVAL;
1186 1181
1187 if (filp->f_flags & O_NONBLOCK && list_empty(&dev->sio_full)) 1182 if (filp->f_flags & O_NONBLOCK && list_empty(&dev->sio_full))
@@ -1240,9 +1235,6 @@ static int stk_vidioc_streamoff(struct file *filp,
1240static int stk_vidioc_g_parm(struct file *filp, 1235static int stk_vidioc_g_parm(struct file *filp,
1241 void *priv, struct v4l2_streamparm *sp) 1236 void *priv, struct v4l2_streamparm *sp)
1242{ 1237{
1243 if (sp->type != V4L2_BUF_TYPE_VIDEO_CAPTURE)
1244 return -EINVAL;
1245
1246 /*FIXME This is not correct */ 1238 /*FIXME This is not correct */
1247 sp->parm.capture.timeperframe.numerator = 1; 1239 sp->parm.capture.timeperframe.numerator = 1;
1248 sp->parm.capture.timeperframe.denominator = 30; 1240 sp->parm.capture.timeperframe.denominator = 30;