Commit a90ef69c authored by Laurent Pinchart's avatar Laurent Pinchart Committed by Mauro Carvalho Chehab

V4L/DVB: uvcvideo: Flag relative controls as write-only

The UVC relative controls (exposure time, iris, focus, zoom, pan/tilt)
are write-only (despite the UVC specification stating that the GET_CUR
request is mandatory). Mark the controls as such, and report the related
V4L2 controls V4L2_CTRL_FLAG_WRITE_ONLY.
Signed-off-by: default avatarLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent 61421206
...@@ -217,8 +217,7 @@ static struct uvc_control_info uvc_ctrls[] = { ...@@ -217,8 +217,7 @@ static struct uvc_control_info uvc_ctrls[] = {
.selector = UVC_CT_EXPOSURE_TIME_RELATIVE_CONTROL, .selector = UVC_CT_EXPOSURE_TIME_RELATIVE_CONTROL,
.index = 4, .index = 4,
.size = 1, .size = 1,
.flags = UVC_CONTROL_SET_CUR | UVC_CONTROL_GET_CUR .flags = UVC_CONTROL_SET_CUR | UVC_CONTROL_RESTORE,
| UVC_CONTROL_RESTORE,
}, },
{ {
.entity = UVC_GUID_UVC_CAMERA, .entity = UVC_GUID_UVC_CAMERA,
...@@ -233,8 +232,9 @@ static struct uvc_control_info uvc_ctrls[] = { ...@@ -233,8 +232,9 @@ static struct uvc_control_info uvc_ctrls[] = {
.selector = UVC_CT_FOCUS_RELATIVE_CONTROL, .selector = UVC_CT_FOCUS_RELATIVE_CONTROL,
.index = 6, .index = 6,
.size = 2, .size = 2,
.flags = UVC_CONTROL_SET_CUR | UVC_CONTROL_GET_RANGE .flags = UVC_CONTROL_SET_CUR | UVC_CONTROL_GET_MIN
| UVC_CONTROL_AUTO_UPDATE, | UVC_CONTROL_GET_MAX | UVC_CONTROL_GET_RES
| UVC_CONTROL_GET_DEF | UVC_CONTROL_AUTO_UPDATE,
}, },
{ {
.entity = UVC_GUID_UVC_CAMERA, .entity = UVC_GUID_UVC_CAMERA,
...@@ -249,8 +249,7 @@ static struct uvc_control_info uvc_ctrls[] = { ...@@ -249,8 +249,7 @@ static struct uvc_control_info uvc_ctrls[] = {
.selector = UVC_CT_IRIS_RELATIVE_CONTROL, .selector = UVC_CT_IRIS_RELATIVE_CONTROL,
.index = 8, .index = 8,
.size = 1, .size = 1,
.flags = UVC_CONTROL_SET_CUR | UVC_CONTROL_GET_CUR .flags = UVC_CONTROL_SET_CUR | UVC_CONTROL_AUTO_UPDATE,
| UVC_CONTROL_AUTO_UPDATE,
}, },
{ {
.entity = UVC_GUID_UVC_CAMERA, .entity = UVC_GUID_UVC_CAMERA,
...@@ -265,8 +264,9 @@ static struct uvc_control_info uvc_ctrls[] = { ...@@ -265,8 +264,9 @@ static struct uvc_control_info uvc_ctrls[] = {
.selector = UVC_CT_ZOOM_RELATIVE_CONTROL, .selector = UVC_CT_ZOOM_RELATIVE_CONTROL,
.index = 10, .index = 10,
.size = 3, .size = 3,
.flags = UVC_CONTROL_SET_CUR | UVC_CONTROL_GET_RANGE .flags = UVC_CONTROL_SET_CUR | UVC_CONTROL_GET_MIN
| UVC_CONTROL_AUTO_UPDATE, | UVC_CONTROL_GET_MAX | UVC_CONTROL_GET_RES
| UVC_CONTROL_GET_DEF | UVC_CONTROL_AUTO_UPDATE,
}, },
{ {
.entity = UVC_GUID_UVC_CAMERA, .entity = UVC_GUID_UVC_CAMERA,
...@@ -281,8 +281,9 @@ static struct uvc_control_info uvc_ctrls[] = { ...@@ -281,8 +281,9 @@ static struct uvc_control_info uvc_ctrls[] = {
.selector = UVC_CT_PANTILT_RELATIVE_CONTROL, .selector = UVC_CT_PANTILT_RELATIVE_CONTROL,
.index = 12, .index = 12,
.size = 4, .size = 4,
.flags = UVC_CONTROL_SET_CUR | UVC_CONTROL_GET_RANGE .flags = UVC_CONTROL_SET_CUR | UVC_CONTROL_GET_MIN
| UVC_CONTROL_AUTO_UPDATE, | UVC_CONTROL_GET_MAX | UVC_CONTROL_GET_RES
| UVC_CONTROL_GET_DEF | UVC_CONTROL_AUTO_UPDATE,
}, },
{ {
.entity = UVC_GUID_UVC_CAMERA, .entity = UVC_GUID_UVC_CAMERA,
...@@ -297,8 +298,9 @@ static struct uvc_control_info uvc_ctrls[] = { ...@@ -297,8 +298,9 @@ static struct uvc_control_info uvc_ctrls[] = {
.selector = UVC_CT_ROLL_RELATIVE_CONTROL, .selector = UVC_CT_ROLL_RELATIVE_CONTROL,
.index = 14, .index = 14,
.size = 2, .size = 2,
.flags = UVC_CONTROL_SET_CUR | UVC_CONTROL_GET_RANGE .flags = UVC_CONTROL_SET_CUR | UVC_CONTROL_GET_MIN
| UVC_CONTROL_AUTO_UPDATE, | UVC_CONTROL_GET_MAX | UVC_CONTROL_GET_RES
| UVC_CONTROL_GET_DEF | UVC_CONTROL_AUTO_UPDATE,
}, },
{ {
.entity = UVC_GUID_UVC_CAMERA, .entity = UVC_GUID_UVC_CAMERA,
...@@ -842,6 +844,8 @@ int uvc_query_v4l2_ctrl(struct uvc_video_chain *chain, ...@@ -842,6 +844,8 @@ int uvc_query_v4l2_ctrl(struct uvc_video_chain *chain,
strlcpy(v4l2_ctrl->name, mapping->name, sizeof v4l2_ctrl->name); strlcpy(v4l2_ctrl->name, mapping->name, sizeof v4l2_ctrl->name);
v4l2_ctrl->flags = 0; v4l2_ctrl->flags = 0;
if (!(ctrl->info->flags & UVC_CONTROL_GET_CUR))
v4l2_ctrl->flags |= V4L2_CTRL_FLAG_WRITE_ONLY;
if (!(ctrl->info->flags & UVC_CONTROL_SET_CUR)) if (!(ctrl->info->flags & UVC_CONTROL_SET_CUR))
v4l2_ctrl->flags |= V4L2_CTRL_FLAG_READ_ONLY; v4l2_ctrl->flags |= V4L2_CTRL_FLAG_READ_ONLY;
......
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