提交 72362422 编写于 作者: L Laurent Pinchart 提交者: Mauro Carvalho Chehab

V4L/DVB (10650): uvcvideo: Initialize streaming parameters with the probe control value

The UVC specification requires SET_CUR requests on the streaming commit control
to use values retrieved from a successful GET_CUR request on the probe control.
Initialize streaming parameters with the probe control current value to make
sure the driver always complies.
Signed-off-by: NLaurent Pinchart <laurent.pinchart@skynet.be>
Signed-off-by: NMauro Carvalho Chehab <mchehab@redhat.com>
上级 4a5aa62b
...@@ -1026,11 +1026,20 @@ int uvc_video_init(struct uvc_video_device *video) ...@@ -1026,11 +1026,20 @@ int uvc_video_init(struct uvc_video_device *video)
*/ */
usb_set_interface(video->dev->udev, video->streaming->intfnum, 0); usb_set_interface(video->dev->udev, video->streaming->intfnum, 0);
/* Some webcams don't suport GET_DEF requests on the probe control. We /* Set the streaming probe control with default streaming parameters
* fall back to GET_CUR if GET_DEF fails. * retrieved from the device. Webcams that don't suport GET_DEF
* requests on the probe control will just keep their current streaming
* parameters.
*/ */
if ((ret = uvc_get_video_ctrl(video, probe, 1, GET_DEF)) < 0 && if (uvc_get_video_ctrl(video, probe, 1, GET_DEF) == 0)
(ret = uvc_get_video_ctrl(video, probe, 1, GET_CUR)) < 0) uvc_set_video_ctrl(video, probe, 1);
/* Initialize the streaming parameters with the probe control current
* value. This makes sure SET_CUR requests on the streaming commit
* control will always use values retrieved from a successful GET_CUR
* request on the probe control, as required by the UVC specification.
*/
if ((ret = uvc_get_video_ctrl(video, probe, 1, GET_CUR)) < 0)
return ret; return ret;
/* Check if the default format descriptor exists. Use the first /* Check if the default format descriptor exists. Use the first
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册