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

V4L/DVB (12185): uvcvideo: Prefix all UVC constants with UVC_

In preparation to moving UVC constants to a public location, prefix all
constants with UVC_ to avoid namespace clashes.
Signed-off-by: NLaurent Pinchart <laurent.pinchart@skynet.be>
Signed-off-by: NMauro Carvalho Chehab <mchehab@redhat.com>
上级 042e143e
此差异已折叠。
...@@ -249,23 +249,23 @@ static struct uvc_entity *uvc_entity_by_reference(struct uvc_device *dev, ...@@ -249,23 +249,23 @@ static struct uvc_entity *uvc_entity_by_reference(struct uvc_device *dev,
list_for_each_entry_continue(entity, &dev->entities, list) { list_for_each_entry_continue(entity, &dev->entities, list) {
switch (UVC_ENTITY_TYPE(entity)) { switch (UVC_ENTITY_TYPE(entity)) {
case TT_STREAMING: case UVC_TT_STREAMING:
if (entity->output.bSourceID == id) if (entity->output.bSourceID == id)
return entity; return entity;
break; break;
case VC_PROCESSING_UNIT: case UVC_VC_PROCESSING_UNIT:
if (entity->processing.bSourceID == id) if (entity->processing.bSourceID == id)
return entity; return entity;
break; break;
case VC_SELECTOR_UNIT: case UVC_VC_SELECTOR_UNIT:
for (i = 0; i < entity->selector.bNrInPins; ++i) for (i = 0; i < entity->selector.bNrInPins; ++i)
if (entity->selector.baSourceID[i] == id) if (entity->selector.baSourceID[i] == id)
return entity; return entity;
break; break;
case VC_EXTENSION_UNIT: case UVC_VC_EXTENSION_UNIT:
for (i = 0; i < entity->extension.bNrInPins; ++i) for (i = 0; i < entity->extension.bNrInPins; ++i)
if (entity->extension.baSourceID[i] == id) if (entity->extension.baSourceID[i] == id)
return entity; return entity;
...@@ -297,9 +297,9 @@ static int uvc_parse_format(struct uvc_device *dev, ...@@ -297,9 +297,9 @@ static int uvc_parse_format(struct uvc_device *dev,
format->index = buffer[3]; format->index = buffer[3];
switch (buffer[2]) { switch (buffer[2]) {
case VS_FORMAT_UNCOMPRESSED: case UVC_VS_FORMAT_UNCOMPRESSED:
case VS_FORMAT_FRAME_BASED: case UVC_VS_FORMAT_FRAME_BASED:
n = buffer[2] == VS_FORMAT_UNCOMPRESSED ? 27 : 28; n = buffer[2] == UVC_VS_FORMAT_UNCOMPRESSED ? 27 : 28;
if (buflen < n) { if (buflen < n) {
uvc_trace(UVC_TRACE_DESCR, "device %d videostreaming " uvc_trace(UVC_TRACE_DESCR, "device %d videostreaming "
"interface %d FORMAT error\n", "interface %d FORMAT error\n",
...@@ -325,16 +325,16 @@ static int uvc_parse_format(struct uvc_device *dev, ...@@ -325,16 +325,16 @@ static int uvc_parse_format(struct uvc_device *dev,
} }
format->bpp = buffer[21]; format->bpp = buffer[21];
if (buffer[2] == VS_FORMAT_UNCOMPRESSED) { if (buffer[2] == UVC_VS_FORMAT_UNCOMPRESSED) {
ftype = VS_FRAME_UNCOMPRESSED; ftype = UVC_VS_FRAME_UNCOMPRESSED;
} else { } else {
ftype = VS_FRAME_FRAME_BASED; ftype = UVC_VS_FRAME_FRAME_BASED;
if (buffer[27]) if (buffer[27])
format->flags = UVC_FMT_FLAG_COMPRESSED; format->flags = UVC_FMT_FLAG_COMPRESSED;
} }
break; break;
case VS_FORMAT_MJPEG: case UVC_VS_FORMAT_MJPEG:
if (buflen < 11) { if (buflen < 11) {
uvc_trace(UVC_TRACE_DESCR, "device %d videostreaming " uvc_trace(UVC_TRACE_DESCR, "device %d videostreaming "
"interface %d FORMAT error\n", "interface %d FORMAT error\n",
...@@ -347,10 +347,10 @@ static int uvc_parse_format(struct uvc_device *dev, ...@@ -347,10 +347,10 @@ static int uvc_parse_format(struct uvc_device *dev,
format->fcc = V4L2_PIX_FMT_MJPEG; format->fcc = V4L2_PIX_FMT_MJPEG;
format->flags = UVC_FMT_FLAG_COMPRESSED; format->flags = UVC_FMT_FLAG_COMPRESSED;
format->bpp = 0; format->bpp = 0;
ftype = VS_FRAME_MJPEG; ftype = UVC_VS_FRAME_MJPEG;
break; break;
case VS_FORMAT_DV: case UVC_VS_FORMAT_DV:
if (buflen < 9) { if (buflen < 9) {
uvc_trace(UVC_TRACE_DESCR, "device %d videostreaming " uvc_trace(UVC_TRACE_DESCR, "device %d videostreaming "
"interface %d FORMAT error\n", "interface %d FORMAT error\n",
...@@ -395,8 +395,8 @@ static int uvc_parse_format(struct uvc_device *dev, ...@@ -395,8 +395,8 @@ static int uvc_parse_format(struct uvc_device *dev,
format->nframes = 1; format->nframes = 1;
break; break;
case VS_FORMAT_MPEG2TS: case UVC_VS_FORMAT_MPEG2TS:
case VS_FORMAT_STREAM_BASED: case UVC_VS_FORMAT_STREAM_BASED:
/* Not supported yet. */ /* Not supported yet. */
default: default:
uvc_trace(UVC_TRACE_DESCR, "device %d videostreaming " uvc_trace(UVC_TRACE_DESCR, "device %d videostreaming "
...@@ -416,7 +416,7 @@ static int uvc_parse_format(struct uvc_device *dev, ...@@ -416,7 +416,7 @@ static int uvc_parse_format(struct uvc_device *dev,
*/ */
while (buflen > 2 && buffer[2] == ftype) { while (buflen > 2 && buffer[2] == ftype) {
frame = &format->frame[format->nframes]; frame = &format->frame[format->nframes];
if (ftype != VS_FRAME_FRAME_BASED) if (ftype != UVC_VS_FRAME_FRAME_BASED)
n = buflen > 25 ? buffer[25] : 0; n = buflen > 25 ? buffer[25] : 0;
else else
n = buflen > 21 ? buffer[21] : 0; n = buflen > 21 ? buffer[21] : 0;
...@@ -436,7 +436,7 @@ static int uvc_parse_format(struct uvc_device *dev, ...@@ -436,7 +436,7 @@ static int uvc_parse_format(struct uvc_device *dev,
frame->wHeight = get_unaligned_le16(&buffer[7]); frame->wHeight = get_unaligned_le16(&buffer[7]);
frame->dwMinBitRate = get_unaligned_le32(&buffer[9]); frame->dwMinBitRate = get_unaligned_le32(&buffer[9]);
frame->dwMaxBitRate = get_unaligned_le32(&buffer[13]); frame->dwMaxBitRate = get_unaligned_le32(&buffer[13]);
if (ftype != VS_FRAME_FRAME_BASED) { if (ftype != UVC_VS_FRAME_FRAME_BASED) {
frame->dwMaxVideoFrameBufferSize = frame->dwMaxVideoFrameBufferSize =
get_unaligned_le32(&buffer[17]); get_unaligned_le32(&buffer[17]);
frame->dwDefaultFrameInterval = frame->dwDefaultFrameInterval =
...@@ -491,12 +491,12 @@ static int uvc_parse_format(struct uvc_device *dev, ...@@ -491,12 +491,12 @@ static int uvc_parse_format(struct uvc_device *dev,
buffer += buffer[0]; buffer += buffer[0];
} }
if (buflen > 2 && buffer[2] == VS_STILL_IMAGE_FRAME) { if (buflen > 2 && buffer[2] == UVC_VS_STILL_IMAGE_FRAME) {
buflen -= buffer[0]; buflen -= buffer[0];
buffer += buffer[0]; buffer += buffer[0];
} }
if (buflen > 2 && buffer[2] == VS_COLORFORMAT) { if (buflen > 2 && buffer[2] == UVC_VS_COLORFORMAT) {
if (buflen < 6) { if (buflen < 6) {
uvc_trace(UVC_TRACE_DESCR, "device %d videostreaming " uvc_trace(UVC_TRACE_DESCR, "device %d videostreaming "
"interface %d COLORFORMAT error\n", "interface %d COLORFORMAT error\n",
...@@ -530,7 +530,7 @@ static int uvc_parse_streaming(struct uvc_device *dev, ...@@ -530,7 +530,7 @@ static int uvc_parse_streaming(struct uvc_device *dev,
int ret = -EINVAL; int ret = -EINVAL;
if (intf->cur_altsetting->desc.bInterfaceSubClass if (intf->cur_altsetting->desc.bInterfaceSubClass
!= SC_VIDEOSTREAMING) { != UVC_SC_VIDEOSTREAMING) {
uvc_trace(UVC_TRACE_DESCR, "device %d interface %d isn't a " uvc_trace(UVC_TRACE_DESCR, "device %d interface %d isn't a "
"video streaming interface\n", dev->udev->devnum, "video streaming interface\n", dev->udev->devnum,
intf->altsetting[0].desc.bInterfaceNumber); intf->altsetting[0].desc.bInterfaceNumber);
...@@ -589,12 +589,12 @@ static int uvc_parse_streaming(struct uvc_device *dev, ...@@ -589,12 +589,12 @@ static int uvc_parse_streaming(struct uvc_device *dev,
/* Parse the header descriptor. */ /* Parse the header descriptor. */
switch (buffer[2]) { switch (buffer[2]) {
case VS_OUTPUT_HEADER: case UVC_VS_OUTPUT_HEADER:
streaming->type = V4L2_BUF_TYPE_VIDEO_OUTPUT; streaming->type = V4L2_BUF_TYPE_VIDEO_OUTPUT;
size = 9; size = 9;
break; break;
case VS_INPUT_HEADER: case UVC_VS_INPUT_HEADER:
streaming->type = V4L2_BUF_TYPE_VIDEO_CAPTURE; streaming->type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
size = 13; size = 13;
break; break;
...@@ -618,7 +618,7 @@ static int uvc_parse_streaming(struct uvc_device *dev, ...@@ -618,7 +618,7 @@ static int uvc_parse_streaming(struct uvc_device *dev,
streaming->header.bNumFormats = p; streaming->header.bNumFormats = p;
streaming->header.bEndpointAddress = buffer[6]; streaming->header.bEndpointAddress = buffer[6];
if (buffer[2] == VS_INPUT_HEADER) { if (buffer[2] == UVC_VS_INPUT_HEADER) {
streaming->header.bmInfo = buffer[7]; streaming->header.bmInfo = buffer[7];
streaming->header.bTerminalLink = buffer[8]; streaming->header.bTerminalLink = buffer[8];
streaming->header.bStillCaptureMethod = buffer[9]; streaming->header.bStillCaptureMethod = buffer[9];
...@@ -646,13 +646,13 @@ static int uvc_parse_streaming(struct uvc_device *dev, ...@@ -646,13 +646,13 @@ static int uvc_parse_streaming(struct uvc_device *dev,
/* Count the format and frame descriptors. */ /* Count the format and frame descriptors. */
while (_buflen > 2 && _buffer[1] == USB_DT_CS_INTERFACE) { while (_buflen > 2 && _buffer[1] == USB_DT_CS_INTERFACE) {
switch (_buffer[2]) { switch (_buffer[2]) {
case VS_FORMAT_UNCOMPRESSED: case UVC_VS_FORMAT_UNCOMPRESSED:
case VS_FORMAT_MJPEG: case UVC_VS_FORMAT_MJPEG:
case VS_FORMAT_FRAME_BASED: case UVC_VS_FORMAT_FRAME_BASED:
nformats++; nformats++;
break; break;
case VS_FORMAT_DV: case UVC_VS_FORMAT_DV:
/* DV format has no frame descriptor. We will create a /* DV format has no frame descriptor. We will create a
* dummy frame descriptor with a dummy frame interval. * dummy frame descriptor with a dummy frame interval.
*/ */
...@@ -661,22 +661,22 @@ static int uvc_parse_streaming(struct uvc_device *dev, ...@@ -661,22 +661,22 @@ static int uvc_parse_streaming(struct uvc_device *dev,
nintervals++; nintervals++;
break; break;
case VS_FORMAT_MPEG2TS: case UVC_VS_FORMAT_MPEG2TS:
case VS_FORMAT_STREAM_BASED: case UVC_VS_FORMAT_STREAM_BASED:
uvc_trace(UVC_TRACE_DESCR, "device %d videostreaming " uvc_trace(UVC_TRACE_DESCR, "device %d videostreaming "
"interface %d FORMAT %u is not supported.\n", "interface %d FORMAT %u is not supported.\n",
dev->udev->devnum, dev->udev->devnum,
alts->desc.bInterfaceNumber, _buffer[2]); alts->desc.bInterfaceNumber, _buffer[2]);
break; break;
case VS_FRAME_UNCOMPRESSED: case UVC_VS_FRAME_UNCOMPRESSED:
case VS_FRAME_MJPEG: case UVC_VS_FRAME_MJPEG:
nframes++; nframes++;
if (_buflen > 25) if (_buflen > 25)
nintervals += _buffer[25] ? _buffer[25] : 3; nintervals += _buffer[25] ? _buffer[25] : 3;
break; break;
case VS_FRAME_FRAME_BASED: case UVC_VS_FRAME_FRAME_BASED:
nframes++; nframes++;
if (_buflen > 21) if (_buflen > 21)
nintervals += _buffer[21] ? _buffer[21] : 3; nintervals += _buffer[21] ? _buffer[21] : 3;
...@@ -711,10 +711,10 @@ static int uvc_parse_streaming(struct uvc_device *dev, ...@@ -711,10 +711,10 @@ static int uvc_parse_streaming(struct uvc_device *dev,
/* Parse the format descriptors. */ /* Parse the format descriptors. */
while (buflen > 2 && buffer[1] == USB_DT_CS_INTERFACE) { while (buflen > 2 && buffer[1] == USB_DT_CS_INTERFACE) {
switch (buffer[2]) { switch (buffer[2]) {
case VS_FORMAT_UNCOMPRESSED: case UVC_VS_FORMAT_UNCOMPRESSED:
case VS_FORMAT_MJPEG: case UVC_VS_FORMAT_MJPEG:
case VS_FORMAT_DV: case UVC_VS_FORMAT_DV:
case VS_FORMAT_FRAME_BASED: case UVC_VS_FORMAT_FRAME_BASED:
format->frame = frame; format->frame = frame;
ret = uvc_parse_format(dev, streaming, format, ret = uvc_parse_format(dev, streaming, format,
&interval, buffer, buflen); &interval, buffer, buflen);
...@@ -819,7 +819,7 @@ static int uvc_parse_vendor_control(struct uvc_device *dev, ...@@ -819,7 +819,7 @@ static int uvc_parse_vendor_control(struct uvc_device *dev,
return -ENOMEM; return -ENOMEM;
unit->id = buffer[3]; unit->id = buffer[3];
unit->type = VC_EXTENSION_UNIT; unit->type = UVC_VC_EXTENSION_UNIT;
memcpy(unit->extension.guidExtensionCode, &buffer[4], 16); memcpy(unit->extension.guidExtensionCode, &buffer[4], 16);
unit->extension.bNumControls = buffer[20]; unit->extension.bNumControls = buffer[20];
unit->extension.bNrInPins = get_unaligned_le16(&buffer[21]); unit->extension.bNrInPins = get_unaligned_le16(&buffer[21]);
...@@ -856,7 +856,7 @@ static int uvc_parse_standard_control(struct uvc_device *dev, ...@@ -856,7 +856,7 @@ static int uvc_parse_standard_control(struct uvc_device *dev,
__u16 type; __u16 type;
switch (buffer[2]) { switch (buffer[2]) {
case VC_HEADER: case UVC_VC_HEADER:
n = buflen >= 12 ? buffer[11] : 0; n = buflen >= 12 ? buffer[11] : 0;
if (buflen < 12 || buflen < 12 + n) { if (buflen < 12 || buflen < 12 + n) {
...@@ -883,7 +883,7 @@ static int uvc_parse_standard_control(struct uvc_device *dev, ...@@ -883,7 +883,7 @@ static int uvc_parse_standard_control(struct uvc_device *dev,
} }
break; break;
case VC_INPUT_TERMINAL: case UVC_VC_INPUT_TERMINAL:
if (buflen < 8) { if (buflen < 8) {
uvc_trace(UVC_TRACE_DESCR, "device %d videocontrol " uvc_trace(UVC_TRACE_DESCR, "device %d videocontrol "
"interface %d INPUT_TERMINAL error\n", "interface %d INPUT_TERMINAL error\n",
...@@ -908,11 +908,11 @@ static int uvc_parse_standard_control(struct uvc_device *dev, ...@@ -908,11 +908,11 @@ static int uvc_parse_standard_control(struct uvc_device *dev,
p = 0; p = 0;
len = 8; len = 8;
if (type == ITT_CAMERA) { if (type == UVC_ITT_CAMERA) {
n = buflen >= 15 ? buffer[14] : 0; n = buflen >= 15 ? buffer[14] : 0;
len = 15; len = 15;
} else if (type == ITT_MEDIA_TRANSPORT_INPUT) { } else if (type == UVC_ITT_MEDIA_TRANSPORT_INPUT) {
n = buflen >= 9 ? buffer[8] : 0; n = buflen >= 9 ? buffer[8] : 0;
p = buflen >= 10 + n ? buffer[9+n] : 0; p = buflen >= 10 + n ? buffer[9+n] : 0;
len = 10; len = 10;
...@@ -932,7 +932,7 @@ static int uvc_parse_standard_control(struct uvc_device *dev, ...@@ -932,7 +932,7 @@ static int uvc_parse_standard_control(struct uvc_device *dev,
term->id = buffer[3]; term->id = buffer[3];
term->type = type | UVC_TERM_INPUT; term->type = type | UVC_TERM_INPUT;
if (UVC_ENTITY_TYPE(term) == ITT_CAMERA) { if (UVC_ENTITY_TYPE(term) == UVC_ITT_CAMERA) {
term->camera.bControlSize = n; term->camera.bControlSize = n;
term->camera.bmControls = (__u8 *)term + sizeof *term; term->camera.bmControls = (__u8 *)term + sizeof *term;
term->camera.wObjectiveFocalLengthMin = term->camera.wObjectiveFocalLengthMin =
...@@ -942,7 +942,8 @@ static int uvc_parse_standard_control(struct uvc_device *dev, ...@@ -942,7 +942,8 @@ static int uvc_parse_standard_control(struct uvc_device *dev,
term->camera.wOcularFocalLength = term->camera.wOcularFocalLength =
get_unaligned_le16(&buffer[12]); get_unaligned_le16(&buffer[12]);
memcpy(term->camera.bmControls, &buffer[15], n); memcpy(term->camera.bmControls, &buffer[15], n);
} else if (UVC_ENTITY_TYPE(term) == ITT_MEDIA_TRANSPORT_INPUT) { } else if (UVC_ENTITY_TYPE(term) ==
UVC_ITT_MEDIA_TRANSPORT_INPUT) {
term->media.bControlSize = n; term->media.bControlSize = n;
term->media.bmControls = (__u8 *)term + sizeof *term; term->media.bmControls = (__u8 *)term + sizeof *term;
term->media.bTransportModeSize = p; term->media.bTransportModeSize = p;
...@@ -955,9 +956,9 @@ static int uvc_parse_standard_control(struct uvc_device *dev, ...@@ -955,9 +956,9 @@ static int uvc_parse_standard_control(struct uvc_device *dev,
if (buffer[7] != 0) if (buffer[7] != 0)
usb_string(udev, buffer[7], term->name, usb_string(udev, buffer[7], term->name,
sizeof term->name); sizeof term->name);
else if (UVC_ENTITY_TYPE(term) == ITT_CAMERA) else if (UVC_ENTITY_TYPE(term) == UVC_ITT_CAMERA)
sprintf(term->name, "Camera %u", buffer[3]); sprintf(term->name, "Camera %u", buffer[3]);
else if (UVC_ENTITY_TYPE(term) == ITT_MEDIA_TRANSPORT_INPUT) else if (UVC_ENTITY_TYPE(term) == UVC_ITT_MEDIA_TRANSPORT_INPUT)
sprintf(term->name, "Media %u", buffer[3]); sprintf(term->name, "Media %u", buffer[3]);
else else
sprintf(term->name, "Input %u", buffer[3]); sprintf(term->name, "Input %u", buffer[3]);
...@@ -965,7 +966,7 @@ static int uvc_parse_standard_control(struct uvc_device *dev, ...@@ -965,7 +966,7 @@ static int uvc_parse_standard_control(struct uvc_device *dev,
list_add_tail(&term->list, &dev->entities); list_add_tail(&term->list, &dev->entities);
break; break;
case VC_OUTPUT_TERMINAL: case UVC_VC_OUTPUT_TERMINAL:
if (buflen < 9) { if (buflen < 9) {
uvc_trace(UVC_TRACE_DESCR, "device %d videocontrol " uvc_trace(UVC_TRACE_DESCR, "device %d videocontrol "
"interface %d OUTPUT_TERMINAL error\n", "interface %d OUTPUT_TERMINAL error\n",
...@@ -1002,7 +1003,7 @@ static int uvc_parse_standard_control(struct uvc_device *dev, ...@@ -1002,7 +1003,7 @@ static int uvc_parse_standard_control(struct uvc_device *dev,
list_add_tail(&term->list, &dev->entities); list_add_tail(&term->list, &dev->entities);
break; break;
case VC_SELECTOR_UNIT: case UVC_VC_SELECTOR_UNIT:
p = buflen >= 5 ? buffer[4] : 0; p = buflen >= 5 ? buffer[4] : 0;
if (buflen < 5 || buflen < 6 + p) { if (buflen < 5 || buflen < 6 + p) {
...@@ -1031,7 +1032,7 @@ static int uvc_parse_standard_control(struct uvc_device *dev, ...@@ -1031,7 +1032,7 @@ static int uvc_parse_standard_control(struct uvc_device *dev,
list_add_tail(&unit->list, &dev->entities); list_add_tail(&unit->list, &dev->entities);
break; break;
case VC_PROCESSING_UNIT: case UVC_VC_PROCESSING_UNIT:
n = buflen >= 8 ? buffer[7] : 0; n = buflen >= 8 ? buffer[7] : 0;
p = dev->uvc_version >= 0x0110 ? 10 : 9; p = dev->uvc_version >= 0x0110 ? 10 : 9;
...@@ -1066,7 +1067,7 @@ static int uvc_parse_standard_control(struct uvc_device *dev, ...@@ -1066,7 +1067,7 @@ static int uvc_parse_standard_control(struct uvc_device *dev,
list_add_tail(&unit->list, &dev->entities); list_add_tail(&unit->list, &dev->entities);
break; break;
case VC_EXTENSION_UNIT: case UVC_VC_EXTENSION_UNIT:
p = buflen >= 22 ? buffer[21] : 0; p = buflen >= 22 ? buffer[21] : 0;
n = buflen >= 24 + p ? buffer[22+p] : 0; n = buflen >= 24 + p ? buffer[22+p] : 0;
...@@ -1194,7 +1195,7 @@ static int uvc_scan_chain_entity(struct uvc_video_device *video, ...@@ -1194,7 +1195,7 @@ static int uvc_scan_chain_entity(struct uvc_video_device *video,
struct uvc_entity *entity) struct uvc_entity *entity)
{ {
switch (UVC_ENTITY_TYPE(entity)) { switch (UVC_ENTITY_TYPE(entity)) {
case VC_EXTENSION_UNIT: case UVC_VC_EXTENSION_UNIT:
if (uvc_trace_param & UVC_TRACE_PROBE) if (uvc_trace_param & UVC_TRACE_PROBE)
printk(" <- XU %d", entity->id); printk(" <- XU %d", entity->id);
...@@ -1207,7 +1208,7 @@ static int uvc_scan_chain_entity(struct uvc_video_device *video, ...@@ -1207,7 +1208,7 @@ static int uvc_scan_chain_entity(struct uvc_video_device *video,
list_add_tail(&entity->chain, &video->extensions); list_add_tail(&entity->chain, &video->extensions);
break; break;
case VC_PROCESSING_UNIT: case UVC_VC_PROCESSING_UNIT:
if (uvc_trace_param & UVC_TRACE_PROBE) if (uvc_trace_param & UVC_TRACE_PROBE)
printk(" <- PU %d", entity->id); printk(" <- PU %d", entity->id);
...@@ -1220,7 +1221,7 @@ static int uvc_scan_chain_entity(struct uvc_video_device *video, ...@@ -1220,7 +1221,7 @@ static int uvc_scan_chain_entity(struct uvc_video_device *video,
video->processing = entity; video->processing = entity;
break; break;
case VC_SELECTOR_UNIT: case UVC_VC_SELECTOR_UNIT:
if (uvc_trace_param & UVC_TRACE_PROBE) if (uvc_trace_param & UVC_TRACE_PROBE)
printk(" <- SU %d", entity->id); printk(" <- SU %d", entity->id);
...@@ -1237,16 +1238,16 @@ static int uvc_scan_chain_entity(struct uvc_video_device *video, ...@@ -1237,16 +1238,16 @@ static int uvc_scan_chain_entity(struct uvc_video_device *video,
video->selector = entity; video->selector = entity;
break; break;
case ITT_VENDOR_SPECIFIC: case UVC_ITT_VENDOR_SPECIFIC:
case ITT_CAMERA: case UVC_ITT_CAMERA:
case ITT_MEDIA_TRANSPORT_INPUT: case UVC_ITT_MEDIA_TRANSPORT_INPUT:
if (uvc_trace_param & UVC_TRACE_PROBE) if (uvc_trace_param & UVC_TRACE_PROBE)
printk(" <- IT %d\n", entity->id); printk(" <- IT %d\n", entity->id);
list_add_tail(&entity->chain, &video->iterms); list_add_tail(&entity->chain, &video->iterms);
break; break;
case TT_STREAMING: case UVC_TT_STREAMING:
if (uvc_trace_param & UVC_TRACE_PROBE) if (uvc_trace_param & UVC_TRACE_PROBE)
printk(" <- IT %d\n", entity->id); printk(" <- IT %d\n", entity->id);
...@@ -1291,7 +1292,7 @@ static int uvc_scan_chain_forward(struct uvc_video_device *video, ...@@ -1291,7 +1292,7 @@ static int uvc_scan_chain_forward(struct uvc_video_device *video,
if (forward == NULL) if (forward == NULL)
break; break;
if (UVC_ENTITY_TYPE(forward) != VC_EXTENSION_UNIT || if (UVC_ENTITY_TYPE(forward) != UVC_VC_EXTENSION_UNIT ||
forward == prev) forward == prev)
continue; continue;
...@@ -1323,15 +1324,15 @@ static int uvc_scan_chain_backward(struct uvc_video_device *video, ...@@ -1323,15 +1324,15 @@ static int uvc_scan_chain_backward(struct uvc_video_device *video,
int id = -1, i; int id = -1, i;
switch (UVC_ENTITY_TYPE(entity)) { switch (UVC_ENTITY_TYPE(entity)) {
case VC_EXTENSION_UNIT: case UVC_VC_EXTENSION_UNIT:
id = entity->extension.baSourceID[0]; id = entity->extension.baSourceID[0];
break; break;
case VC_PROCESSING_UNIT: case UVC_VC_PROCESSING_UNIT:
id = entity->processing.bSourceID; id = entity->processing.bSourceID;
break; break;
case VC_SELECTOR_UNIT: case UVC_VC_SELECTOR_UNIT:
/* Single-input selector units are ignored. */ /* Single-input selector units are ignored. */
if (entity->selector.bNrInPins == 1) { if (entity->selector.bNrInPins == 1) {
id = entity->selector.baSourceID[0]; id = entity->selector.baSourceID[0];
...@@ -1377,7 +1378,7 @@ static int uvc_scan_chain(struct uvc_video_device *video) ...@@ -1377,7 +1378,7 @@ static int uvc_scan_chain(struct uvc_video_device *video)
entity = video->oterm; entity = video->oterm;
uvc_trace(UVC_TRACE_PROBE, "Scanning UVC chain: OT %d", entity->id); uvc_trace(UVC_TRACE_PROBE, "Scanning UVC chain: OT %d", entity->id);
if (UVC_ENTITY_TYPE(entity) == TT_STREAMING) if (UVC_ENTITY_TYPE(entity) == UVC_TT_STREAMING)
video->sterm = entity; video->sterm = entity;
id = entity->output.bSourceID; id = entity->output.bSourceID;
...@@ -1664,7 +1665,8 @@ static void uvc_disconnect(struct usb_interface *intf) ...@@ -1664,7 +1665,8 @@ static void uvc_disconnect(struct usb_interface *intf)
*/ */
usb_set_intfdata(intf, NULL); usb_set_intfdata(intf, NULL);
if (intf->cur_altsetting->desc.bInterfaceSubClass == SC_VIDEOSTREAMING) if (intf->cur_altsetting->desc.bInterfaceSubClass ==
UVC_SC_VIDEOSTREAMING)
return; return;
/* uvc_v4l2_open() might race uvc_disconnect(). A static driver-wide /* uvc_v4l2_open() might race uvc_disconnect(). A static driver-wide
...@@ -1692,7 +1694,8 @@ static int uvc_suspend(struct usb_interface *intf, pm_message_t message) ...@@ -1692,7 +1694,8 @@ static int uvc_suspend(struct usb_interface *intf, pm_message_t message)
intf->cur_altsetting->desc.bInterfaceNumber); intf->cur_altsetting->desc.bInterfaceNumber);
/* Controls are cached on the fly so they don't need to be saved. */ /* Controls are cached on the fly so they don't need to be saved. */
if (intf->cur_altsetting->desc.bInterfaceSubClass == SC_VIDEOCONTROL) if (intf->cur_altsetting->desc.bInterfaceSubClass ==
UVC_SC_VIDEOCONTROL)
return uvc_status_suspend(dev); return uvc_status_suspend(dev);
if (dev->video.streaming->intf != intf) { if (dev->video.streaming->intf != intf) {
...@@ -1711,7 +1714,8 @@ static int __uvc_resume(struct usb_interface *intf, int reset) ...@@ -1711,7 +1714,8 @@ static int __uvc_resume(struct usb_interface *intf, int reset)
uvc_trace(UVC_TRACE_SUSPEND, "Resuming interface %u\n", uvc_trace(UVC_TRACE_SUSPEND, "Resuming interface %u\n",
intf->cur_altsetting->desc.bInterfaceNumber); intf->cur_altsetting->desc.bInterfaceNumber);
if (intf->cur_altsetting->desc.bInterfaceSubClass == SC_VIDEOCONTROL) { if (intf->cur_altsetting->desc.bInterfaceSubClass ==
UVC_SC_VIDEOCONTROL) {
if (reset) { if (reset) {
int ret = uvc_ctrl_resume_device(dev); int ret = uvc_ctrl_resume_device(dev);
......
...@@ -648,7 +648,7 @@ static long uvc_v4l2_do_ioctl(struct file *file, unsigned int cmd, void *arg) ...@@ -648,7 +648,7 @@ static long uvc_v4l2_do_ioctl(struct file *file, unsigned int cmd, void *arg)
memset(input, 0, sizeof *input); memset(input, 0, sizeof *input);
input->index = index; input->index = index;
strlcpy(input->name, iterm->name, sizeof input->name); strlcpy(input->name, iterm->name, sizeof input->name);
if (UVC_ENTITY_TYPE(iterm) == ITT_CAMERA) if (UVC_ENTITY_TYPE(iterm) == UVC_ITT_CAMERA)
input->type = V4L2_INPUT_TYPE_CAMERA; input->type = V4L2_INPUT_TYPE_CAMERA;
break; break;
} }
...@@ -663,9 +663,9 @@ static long uvc_v4l2_do_ioctl(struct file *file, unsigned int cmd, void *arg) ...@@ -663,9 +663,9 @@ static long uvc_v4l2_do_ioctl(struct file *file, unsigned int cmd, void *arg)
break; break;
} }
ret = uvc_query_ctrl(video->dev, GET_CUR, video->selector->id, ret = uvc_query_ctrl(video->dev, UVC_GET_CUR,
video->dev->intfnum, SU_INPUT_SELECT_CONTROL, video->selector->id, video->dev->intfnum,
&input, 1); UVC_SU_INPUT_SELECT_CONTROL, &input, 1);
if (ret < 0) if (ret < 0)
return ret; return ret;
...@@ -690,9 +690,9 @@ static long uvc_v4l2_do_ioctl(struct file *file, unsigned int cmd, void *arg) ...@@ -690,9 +690,9 @@ static long uvc_v4l2_do_ioctl(struct file *file, unsigned int cmd, void *arg)
if (input == 0 || input > video->selector->selector.bNrInPins) if (input == 0 || input > video->selector->selector.bNrInPins)
return -EINVAL; return -EINVAL;
return uvc_query_ctrl(video->dev, SET_CUR, video->selector->id, return uvc_query_ctrl(video->dev, UVC_SET_CUR,
video->dev->intfnum, SU_INPUT_SELECT_CONTROL, video->selector->id, video->dev->intfnum,
&input, 1); UVC_SU_INPUT_SELECT_CONTROL, &input, 1);
} }
/* Try, Get, Set & Enum format */ /* Try, Get, Set & Enum format */
......
...@@ -129,10 +129,10 @@ static int uvc_get_video_ctrl(struct uvc_video_device *video, ...@@ -129,10 +129,10 @@ static int uvc_get_video_ctrl(struct uvc_video_device *video,
return -ENOMEM; return -ENOMEM;
ret = __uvc_query_ctrl(video->dev, query, 0, video->streaming->intfnum, ret = __uvc_query_ctrl(video->dev, query, 0, video->streaming->intfnum,
probe ? VS_PROBE_CONTROL : VS_COMMIT_CONTROL, data, size, probe ? UVC_VS_PROBE_CONTROL : UVC_VS_COMMIT_CONTROL, data,
UVC_CTRL_STREAMING_TIMEOUT); size, UVC_CTRL_STREAMING_TIMEOUT);
if ((query == GET_MIN || query == GET_MAX) && ret == 2) { if ((query == UVC_GET_MIN || query == UVC_GET_MAX) && ret == 2) {
/* Some cameras, mostly based on Bison Electronics chipsets, /* Some cameras, mostly based on Bison Electronics chipsets,
* answer a GET_MIN or GET_MAX request with the wCompQuality * answer a GET_MIN or GET_MAX request with the wCompQuality
* field only. * field only.
...@@ -144,7 +144,7 @@ static int uvc_get_video_ctrl(struct uvc_video_device *video, ...@@ -144,7 +144,7 @@ static int uvc_get_video_ctrl(struct uvc_video_device *video,
ctrl->wCompQuality = le16_to_cpup((__le16 *)data); ctrl->wCompQuality = le16_to_cpup((__le16 *)data);
ret = 0; ret = 0;
goto out; goto out;
} else if (query == GET_DEF && probe == 1 && ret != size) { } else if (query == UVC_GET_DEF && probe == 1 && ret != size) {
/* Many cameras don't support the GET_DEF request on their /* Many cameras don't support the GET_DEF request on their
* video probe control. Warn once and return, the caller will * video probe control. Warn once and return, the caller will
* fall back to GET_CUR. * fall back to GET_CUR.
...@@ -232,10 +232,10 @@ static int uvc_set_video_ctrl(struct uvc_video_device *video, ...@@ -232,10 +232,10 @@ static int uvc_set_video_ctrl(struct uvc_video_device *video,
data[33] = ctrl->bMaxVersion; data[33] = ctrl->bMaxVersion;
} }
ret = __uvc_query_ctrl(video->dev, SET_CUR, 0, ret = __uvc_query_ctrl(video->dev, UVC_SET_CUR, 0,
video->streaming->intfnum, video->streaming->intfnum,
probe ? VS_PROBE_CONTROL : VS_COMMIT_CONTROL, data, size, probe ? UVC_VS_PROBE_CONTROL : UVC_VS_COMMIT_CONTROL, data,
UVC_CTRL_STREAMING_TIMEOUT); size, UVC_CTRL_STREAMING_TIMEOUT);
if (ret != size) { if (ret != size) {
uvc_printk(KERN_ERR, "Failed to set UVC %s control : " uvc_printk(KERN_ERR, "Failed to set UVC %s control : "
"%d (exp. %u).\n", probe ? "probe" : "commit", "%d (exp. %u).\n", probe ? "probe" : "commit",
...@@ -269,10 +269,10 @@ int uvc_probe_video(struct uvc_video_device *video, ...@@ -269,10 +269,10 @@ int uvc_probe_video(struct uvc_video_device *video,
/* Get the minimum and maximum values for compression settings. */ /* Get the minimum and maximum values for compression settings. */
if (!(video->dev->quirks & UVC_QUIRK_PROBE_MINMAX)) { if (!(video->dev->quirks & UVC_QUIRK_PROBE_MINMAX)) {
ret = uvc_get_video_ctrl(video, &probe_min, 1, GET_MIN); ret = uvc_get_video_ctrl(video, &probe_min, 1, UVC_GET_MIN);
if (ret < 0) if (ret < 0)
goto done; goto done;
ret = uvc_get_video_ctrl(video, &probe_max, 1, GET_MAX); ret = uvc_get_video_ctrl(video, &probe_max, 1, UVC_GET_MAX);
if (ret < 0) if (ret < 0)
goto done; goto done;
...@@ -280,8 +280,11 @@ int uvc_probe_video(struct uvc_video_device *video, ...@@ -280,8 +280,11 @@ int uvc_probe_video(struct uvc_video_device *video,
} }
for (i = 0; i < 2; ++i) { for (i = 0; i < 2; ++i) {
if ((ret = uvc_set_video_ctrl(video, probe, 1)) < 0 || ret = uvc_set_video_ctrl(video, probe, 1);
(ret = uvc_get_video_ctrl(video, probe, 1, GET_CUR)) < 0) if (ret < 0)
goto done;
ret = uvc_get_video_ctrl(video, probe, 1, UVC_GET_CUR);
if (ret < 0)
goto done; goto done;
if (video->streaming->intf->num_altsetting == 1) if (video->streaming->intf->num_altsetting == 1)
...@@ -1065,7 +1068,7 @@ int uvc_video_init(struct uvc_video_device *video) ...@@ -1065,7 +1068,7 @@ int uvc_video_init(struct uvc_video_device *video)
* requests on the probe control will just keep their current streaming * requests on the probe control will just keep their current streaming
* parameters. * parameters.
*/ */
if (uvc_get_video_ctrl(video, probe, 1, GET_DEF) == 0) if (uvc_get_video_ctrl(video, probe, 1, UVC_GET_DEF) == 0)
uvc_set_video_ctrl(video, probe, 1); uvc_set_video_ctrl(video, probe, 1);
/* Initialize the streaming parameters with the probe control current /* Initialize the streaming parameters with the probe control current
...@@ -1073,7 +1076,8 @@ int uvc_video_init(struct uvc_video_device *video) ...@@ -1073,7 +1076,8 @@ int uvc_video_init(struct uvc_video_device *video)
* control will always use values retrieved from a successful GET_CUR * control will always use values retrieved from a successful GET_CUR
* request on the probe control, as required by the UVC specification. * request on the probe control, as required by the UVC specification.
*/ */
if ((ret = uvc_get_video_ctrl(video, probe, 1, GET_CUR)) < 0) ret = uvc_get_video_ctrl(video, probe, 1, UVC_GET_CUR);
if (ret < 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
......
...@@ -72,142 +72,142 @@ struct uvc_xu_control { ...@@ -72,142 +72,142 @@ struct uvc_xu_control {
* UVC constants * UVC constants
*/ */
#define SC_UNDEFINED 0x00 #define UVC_SC_UNDEFINED 0x00
#define SC_VIDEOCONTROL 0x01 #define UVC_SC_VIDEOCONTROL 0x01
#define SC_VIDEOSTREAMING 0x02 #define UVC_SC_VIDEOSTREAMING 0x02
#define SC_VIDEO_INTERFACE_COLLECTION 0x03 #define UVC_SC_VIDEO_INTERFACE_COLLECTION 0x03
#define PC_PROTOCOL_UNDEFINED 0x00 #define UVC_PC_PROTOCOL_UNDEFINED 0x00
/* VideoControl class specific interface descriptor */ /* VideoControl class specific interface descriptor */
#define VC_DESCRIPTOR_UNDEFINED 0x00 #define UVC_VC_DESCRIPTOR_UNDEFINED 0x00
#define VC_HEADER 0x01 #define UVC_VC_HEADER 0x01
#define VC_INPUT_TERMINAL 0x02 #define UVC_VC_INPUT_TERMINAL 0x02
#define VC_OUTPUT_TERMINAL 0x03 #define UVC_VC_OUTPUT_TERMINAL 0x03
#define VC_SELECTOR_UNIT 0x04 #define UVC_VC_SELECTOR_UNIT 0x04
#define VC_PROCESSING_UNIT 0x05 #define UVC_VC_PROCESSING_UNIT 0x05
#define VC_EXTENSION_UNIT 0x06 #define UVC_VC_EXTENSION_UNIT 0x06
/* VideoStreaming class specific interface descriptor */ /* VideoStreaming class specific interface descriptor */
#define VS_UNDEFINED 0x00 #define UVC_VS_UNDEFINED 0x00
#define VS_INPUT_HEADER 0x01 #define UVC_VS_INPUT_HEADER 0x01
#define VS_OUTPUT_HEADER 0x02 #define UVC_VS_OUTPUT_HEADER 0x02
#define VS_STILL_IMAGE_FRAME 0x03 #define UVC_VS_STILL_IMAGE_FRAME 0x03
#define VS_FORMAT_UNCOMPRESSED 0x04 #define UVC_VS_FORMAT_UNCOMPRESSED 0x04
#define VS_FRAME_UNCOMPRESSED 0x05 #define UVC_VS_FRAME_UNCOMPRESSED 0x05
#define VS_FORMAT_MJPEG 0x06 #define UVC_VS_FORMAT_MJPEG 0x06
#define VS_FRAME_MJPEG 0x07 #define UVC_VS_FRAME_MJPEG 0x07
#define VS_FORMAT_MPEG2TS 0x0a #define UVC_VS_FORMAT_MPEG2TS 0x0a
#define VS_FORMAT_DV 0x0c #define UVC_VS_FORMAT_DV 0x0c
#define VS_COLORFORMAT 0x0d #define UVC_VS_COLORFORMAT 0x0d
#define VS_FORMAT_FRAME_BASED 0x10 #define UVC_VS_FORMAT_FRAME_BASED 0x10
#define VS_FRAME_FRAME_BASED 0x11 #define UVC_VS_FRAME_FRAME_BASED 0x11
#define VS_FORMAT_STREAM_BASED 0x12 #define UVC_VS_FORMAT_STREAM_BASED 0x12
/* Endpoint type */ /* Endpoint type */
#define EP_UNDEFINED 0x00 #define UVC_EP_UNDEFINED 0x00
#define EP_GENERAL 0x01 #define UVC_EP_GENERAL 0x01
#define EP_ENDPOINT 0x02 #define UVC_EP_ENDPOINT 0x02
#define EP_INTERRUPT 0x03 #define UVC_EP_INTERRUPT 0x03
/* Request codes */ /* Request codes */
#define RC_UNDEFINED 0x00 #define UVC_RC_UNDEFINED 0x00
#define SET_CUR 0x01 #define UVC_SET_CUR 0x01
#define GET_CUR 0x81 #define UVC_GET_CUR 0x81
#define GET_MIN 0x82 #define UVC_GET_MIN 0x82
#define GET_MAX 0x83 #define UVC_GET_MAX 0x83
#define GET_RES 0x84 #define UVC_GET_RES 0x84
#define GET_LEN 0x85 #define UVC_GET_LEN 0x85
#define GET_INFO 0x86 #define UVC_GET_INFO 0x86
#define GET_DEF 0x87 #define UVC_GET_DEF 0x87
/* VideoControl interface controls */ /* VideoControl interface controls */
#define VC_CONTROL_UNDEFINED 0x00 #define UVC_VC_CONTROL_UNDEFINED 0x00
#define VC_VIDEO_POWER_MODE_CONTROL 0x01 #define UVC_VC_VIDEO_POWER_MODE_CONTROL 0x01
#define VC_REQUEST_ERROR_CODE_CONTROL 0x02 #define UVC_VC_REQUEST_ERROR_CODE_CONTROL 0x02
/* Terminal controls */ /* Terminal controls */
#define TE_CONTROL_UNDEFINED 0x00 #define UVC_TE_CONTROL_UNDEFINED 0x00
/* Selector Unit controls */ /* Selector Unit controls */
#define SU_CONTROL_UNDEFINED 0x00 #define UVC_SU_CONTROL_UNDEFINED 0x00
#define SU_INPUT_SELECT_CONTROL 0x01 #define UVC_SU_INPUT_SELECT_CONTROL 0x01
/* Camera Terminal controls */ /* Camera Terminal controls */
#define CT_CONTROL_UNDEFINED 0x00 #define UVC_CT_CONTROL_UNDEFINED 0x00
#define CT_SCANNING_MODE_CONTROL 0x01 #define UVC_CT_SCANNING_MODE_CONTROL 0x01
#define CT_AE_MODE_CONTROL 0x02 #define UVC_CT_AE_MODE_CONTROL 0x02
#define CT_AE_PRIORITY_CONTROL 0x03 #define UVC_CT_AE_PRIORITY_CONTROL 0x03
#define CT_EXPOSURE_TIME_ABSOLUTE_CONTROL 0x04 #define UVC_CT_EXPOSURE_TIME_ABSOLUTE_CONTROL 0x04
#define CT_EXPOSURE_TIME_RELATIVE_CONTROL 0x05 #define UVC_CT_EXPOSURE_TIME_RELATIVE_CONTROL 0x05
#define CT_FOCUS_ABSOLUTE_CONTROL 0x06 #define UVC_CT_FOCUS_ABSOLUTE_CONTROL 0x06
#define CT_FOCUS_RELATIVE_CONTROL 0x07 #define UVC_CT_FOCUS_RELATIVE_CONTROL 0x07
#define CT_FOCUS_AUTO_CONTROL 0x08 #define UVC_CT_FOCUS_AUTO_CONTROL 0x08
#define CT_IRIS_ABSOLUTE_CONTROL 0x09 #define UVC_CT_IRIS_ABSOLUTE_CONTROL 0x09
#define CT_IRIS_RELATIVE_CONTROL 0x0a #define UVC_CT_IRIS_RELATIVE_CONTROL 0x0a
#define CT_ZOOM_ABSOLUTE_CONTROL 0x0b #define UVC_CT_ZOOM_ABSOLUTE_CONTROL 0x0b
#define CT_ZOOM_RELATIVE_CONTROL 0x0c #define UVC_CT_ZOOM_RELATIVE_CONTROL 0x0c
#define CT_PANTILT_ABSOLUTE_CONTROL 0x0d #define UVC_CT_PANTILT_ABSOLUTE_CONTROL 0x0d
#define CT_PANTILT_RELATIVE_CONTROL 0x0e #define UVC_CT_PANTILT_RELATIVE_CONTROL 0x0e
#define CT_ROLL_ABSOLUTE_CONTROL 0x0f #define UVC_CT_ROLL_ABSOLUTE_CONTROL 0x0f
#define CT_ROLL_RELATIVE_CONTROL 0x10 #define UVC_CT_ROLL_RELATIVE_CONTROL 0x10
#define CT_PRIVACY_CONTROL 0x11 #define UVC_CT_PRIVACY_CONTROL 0x11
/* Processing Unit controls */ /* Processing Unit controls */
#define PU_CONTROL_UNDEFINED 0x00 #define UVC_PU_CONTROL_UNDEFINED 0x00
#define PU_BACKLIGHT_COMPENSATION_CONTROL 0x01 #define UVC_PU_BACKLIGHT_COMPENSATION_CONTROL 0x01
#define PU_BRIGHTNESS_CONTROL 0x02 #define UVC_PU_BRIGHTNESS_CONTROL 0x02
#define PU_CONTRAST_CONTROL 0x03 #define UVC_PU_CONTRAST_CONTROL 0x03
#define PU_GAIN_CONTROL 0x04 #define UVC_PU_GAIN_CONTROL 0x04
#define PU_POWER_LINE_FREQUENCY_CONTROL 0x05 #define UVC_PU_POWER_LINE_FREQUENCY_CONTROL 0x05
#define PU_HUE_CONTROL 0x06 #define UVC_PU_HUE_CONTROL 0x06
#define PU_SATURATION_CONTROL 0x07 #define UVC_PU_SATURATION_CONTROL 0x07
#define PU_SHARPNESS_CONTROL 0x08 #define UVC_PU_SHARPNESS_CONTROL 0x08
#define PU_GAMMA_CONTROL 0x09 #define UVC_PU_GAMMA_CONTROL 0x09
#define PU_WHITE_BALANCE_TEMPERATURE_CONTROL 0x0a #define UVC_PU_WHITE_BALANCE_TEMPERATURE_CONTROL 0x0a
#define PU_WHITE_BALANCE_TEMPERATURE_AUTO_CONTROL 0x0b #define UVC_PU_WHITE_BALANCE_TEMPERATURE_AUTO_CONTROL 0x0b
#define PU_WHITE_BALANCE_COMPONENT_CONTROL 0x0c #define UVC_PU_WHITE_BALANCE_COMPONENT_CONTROL 0x0c
#define PU_WHITE_BALANCE_COMPONENT_AUTO_CONTROL 0x0d #define UVC_PU_WHITE_BALANCE_COMPONENT_AUTO_CONTROL 0x0d
#define PU_DIGITAL_MULTIPLIER_CONTROL 0x0e #define UVC_PU_DIGITAL_MULTIPLIER_CONTROL 0x0e
#define PU_DIGITAL_MULTIPLIER_LIMIT_CONTROL 0x0f #define UVC_PU_DIGITAL_MULTIPLIER_LIMIT_CONTROL 0x0f
#define PU_HUE_AUTO_CONTROL 0x10 #define UVC_PU_HUE_AUTO_CONTROL 0x10
#define PU_ANALOG_VIDEO_STANDARD_CONTROL 0x11 #define UVC_PU_ANALOG_VIDEO_STANDARD_CONTROL 0x11
#define PU_ANALOG_LOCK_STATUS_CONTROL 0x12 #define UVC_PU_ANALOG_LOCK_STATUS_CONTROL 0x12
#define LXU_MOTOR_PANTILT_RELATIVE_CONTROL 0x01 #define UVC_LXU_MOTOR_PANTILT_RELATIVE_CONTROL 0x01
#define LXU_MOTOR_PANTILT_RESET_CONTROL 0x02 #define UVC_LXU_MOTOR_PANTILT_RESET_CONTROL 0x02
#define LXU_MOTOR_FOCUS_MOTOR_CONTROL 0x03 #define UVC_LXU_MOTOR_FOCUS_MOTOR_CONTROL 0x03
/* VideoStreaming interface controls */ /* VideoStreaming interface controls */
#define VS_CONTROL_UNDEFINED 0x00 #define UVC_VS_CONTROL_UNDEFINED 0x00
#define VS_PROBE_CONTROL 0x01 #define UVC_VS_PROBE_CONTROL 0x01
#define VS_COMMIT_CONTROL 0x02 #define UVC_VS_COMMIT_CONTROL 0x02
#define VS_STILL_PROBE_CONTROL 0x03 #define UVC_VS_STILL_PROBE_CONTROL 0x03
#define VS_STILL_COMMIT_CONTROL 0x04 #define UVC_VS_STILL_COMMIT_CONTROL 0x04
#define VS_STILL_IMAGE_TRIGGER_CONTROL 0x05 #define UVC_VS_STILL_IMAGE_TRIGGER_CONTROL 0x05
#define VS_STREAM_ERROR_CODE_CONTROL 0x06 #define UVC_VS_STREAM_ERROR_CODE_CONTROL 0x06
#define VS_GENERATE_KEY_FRAME_CONTROL 0x07 #define UVC_VS_GENERATE_KEY_FRAME_CONTROL 0x07
#define VS_UPDATE_FRAME_SEGMENT_CONTROL 0x08 #define UVC_VS_UPDATE_FRAME_SEGMENT_CONTROL 0x08
#define VS_SYNC_DELAY_CONTROL 0x09 #define UVC_VS_SYNC_DELAY_CONTROL 0x09
#define TT_VENDOR_SPECIFIC 0x0100 #define UVC_TT_VENDOR_SPECIFIC 0x0100
#define TT_STREAMING 0x0101 #define UVC_TT_STREAMING 0x0101
/* Input Terminal types */ /* Input Terminal types */
#define ITT_VENDOR_SPECIFIC 0x0200 #define UVC_ITT_VENDOR_SPECIFIC 0x0200
#define ITT_CAMERA 0x0201 #define UVC_ITT_CAMERA 0x0201
#define ITT_MEDIA_TRANSPORT_INPUT 0x0202 #define UVC_ITT_MEDIA_TRANSPORT_INPUT 0x0202
/* Output Terminal types */ /* Output Terminal types */
#define OTT_VENDOR_SPECIFIC 0x0300 #define UVC_OTT_VENDOR_SPECIFIC 0x0300
#define OTT_DISPLAY 0x0301 #define UVC_OTT_DISPLAY 0x0301
#define OTT_MEDIA_TRANSPORT_OUTPUT 0x0302 #define UVC_OTT_MEDIA_TRANSPORT_OUTPUT 0x0302
/* External Terminal types */ /* External Terminal types */
#define EXTERNAL_VENDOR_SPECIFIC 0x0400 #define UVC_EXTERNAL_VENDOR_SPECIFIC 0x0400
#define COMPOSITE_CONNECTOR 0x0401 #define UVC_COMPOSITE_CONNECTOR 0x0401
#define SVIDEO_CONNECTOR 0x0402 #define UVC_SVIDEO_CONNECTOR 0x0402
#define COMPONENT_CONNECTOR 0x0403 #define UVC_COMPONENT_CONNECTOR 0x0403
#define UVC_TERM_INPUT 0x0000 #define UVC_TERM_INPUT 0x0000
#define UVC_TERM_OUTPUT 0x8000 #define UVC_TERM_OUTPUT 0x8000
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册