summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/dev/usb/uvideo.c52
-rw-r--r--sys/dev/usb/uvideo.h18
2 files changed, 60 insertions, 10 deletions
diff --git a/sys/dev/usb/uvideo.c b/sys/dev/usb/uvideo.c
index 9f5396971ac..4eb28399acc 100644
--- a/sys/dev/usb/uvideo.c
+++ b/sys/dev/usb/uvideo.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: uvideo.c,v 1.8 2008/04/18 13:49:55 mglocker Exp $ */
+/* $OpenBSD: uvideo.c,v 1.9 2008/04/18 21:19:15 mglocker Exp $ */
/*
* Copyright (c) 2008 Robert Nagy <robert@openbsd.org>
@@ -93,7 +93,9 @@ int uvideo_vs_decode_stream_header(struct uvideo_softc *,
uint8_t *, int);
void uvideo_dump_desc_all(struct uvideo_softc *);
-void uvideo_dump_desc_vcheader(struct uvideo_softc *,
+void uvideo_dump_desc_vc_header(struct uvideo_softc *,
+ const usb_descriptor_t *);
+void uvideo_dump_desc_input_header(struct uvideo_softc *,
const usb_descriptor_t *);
void uvideo_dump_desc_input(struct uvideo_softc *,
const usb_descriptor_t *);
@@ -114,7 +116,7 @@ void uvideo_dump_desc_frame_mjpeg(struct uvideo_softc *,
void uvideo_dump_desc_format_mjpeg(struct uvideo_softc *,
const usb_descriptor_t *);
-int uvideo_desc_len(const usb_descriptor_t *, int, int, int);
+int uvideo_desc_len(const usb_descriptor_t *, int, int, int, int);
int uvideo_debug_file_open(struct uvideo_softc *);
void uvideo_debug_file_write_sample(void *);
@@ -369,7 +371,7 @@ uvideo_vc_parse_desc(struct uvideo_softc *sc)
switch (desc->bDescriptorSubtype) {
case UDESCSUB_VC_HEADER:
- if (!uvideo_desc_len(desc, 12, 11, 1))
+ if (!uvideo_desc_len(desc, 12, 11, 1, 0))
break;
if (vc_header_found) {
printf("%s: too many VC_HEADERs!\n",
@@ -1106,10 +1108,16 @@ uvideo_dump_desc_all(struct uvideo_softc *sc)
case UDESCSUB_VC_HEADER:
printf("bDescriptorSubtype=0x%02x",
desc->bDescriptorSubtype);
- if (uvideo_desc_len(desc, 12, 11, 1)) {
+ if (uvideo_desc_len(desc, 12, 11, 1, 0)) {
printf(" (UDESCSUB_VC_HEADER)\n");
printf("|\n");
- uvideo_dump_desc_vcheader(sc, desc);
+ uvideo_dump_desc_vc_header(sc, desc);
+ break;
+ }
+ if (uvideo_desc_len(desc, 13, 3, 0, 12)) {
+ printf(" (UDESCSUB_VS_INPUT_HEADER)\n");
+ printf("|\n");
+ uvideo_dump_desc_input_header(sc, desc);
break;
}
printf(" (unknown)\n");
@@ -1220,7 +1228,7 @@ uvideo_dump_desc_all(struct uvideo_softc *sc)
}
void
-uvideo_dump_desc_vcheader(struct uvideo_softc *sc,
+uvideo_dump_desc_vc_header(struct uvideo_softc *sc,
const usb_descriptor_t *desc)
{
struct usb_video_header_desc *d;
@@ -1234,7 +1242,28 @@ uvideo_dump_desc_vcheader(struct uvideo_softc *sc,
printf("wTotalLength=%d\n", UGETW(d->wTotalLength));
printf("dwClockFrequency=%d\n", UGETDW(d->dwClockFrequency));
printf("bInCollection=0x%02x\n", d->bInCollection);
- //printf("baInterfaceNr=0x%02x\n", d->baInterfaceNr[0]);
+}
+
+void
+uvideo_dump_desc_input_header(struct uvideo_softc *sc,
+ const usb_descriptor_t *desc)
+{
+ struct usb_video_input_header_desc *d;
+
+ d = (struct usb_video_input_header_desc *)(uint8_t *)desc;
+
+ printf("bLength=%d\n", d->bLength);
+ printf("bDescriptorType=0x%02x\n", d->bDescriptorType);
+ printf("bDescriptorSubtype=0x%02x\n", d->bDescriptorSubtype);
+ printf("bNumFormats=%d\n", d->bNumFormats);
+ printf("wTotalLength=%d\n", UGETW(d->wTotalLength));
+ printf("bEndpointAddress=0x%02x\n", d->bEndpointAddress);
+ printf("bmInfo=0x%02x\n", d->bmInfo);
+ printf("bTerminalLink=0x%02x\n", d->bTerminalLink);
+ printf("bStillCaptureMethod=0x%02x\n", d->bStillCaptureMethod);
+ printf("bTriggerSupport=0x%02x\n", d->bTriggerSupport);
+ printf("bTriggerUsage=0x%02x\n", d->bTriggerUsage);
+ printf("bControlSize=%d\n", d->bControlSize);
}
void
@@ -1429,10 +1458,12 @@ uvideo_dump_desc_format_mjpeg(struct uvideo_softc *sc,
* size_fix: total size of the fixed structure part
* off_num_elements: offset which tells the number of following elements
* size_element: size of a single element
+ * off_size_element: if size_element is 0 the element size is taken from
+ * this offset in the descriptor
*/
int
uvideo_desc_len(const usb_descriptor_t *desc,
- int size_fix, int off_num_elements, int size_element)
+ int size_fix, int off_num_elements, int size_element, int off_size_element)
{
uint8_t *buf;
int size_elements, size_total;
@@ -1442,6 +1473,9 @@ uvideo_desc_len(const usb_descriptor_t *desc,
buf = (uint8_t *)desc;
+ if (size_element == 0)
+ size_element = buf[off_size_element];
+
size_elements = buf[off_num_elements] * size_element;
size_total = size_fix + size_elements;
diff --git a/sys/dev/usb/uvideo.h b/sys/dev/usb/uvideo.h
index 2ba71a2f77e..eb6a5f161a5 100644
--- a/sys/dev/usb/uvideo.h
+++ b/sys/dev/usb/uvideo.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: uvideo.h,v 1.5 2008/04/16 20:45:24 mglocker Exp $ */
+/* $OpenBSD: uvideo.h,v 1.6 2008/04/18 21:19:15 mglocker Exp $ */
/*
* Copyright (c) 2007 Robert Nagy <robert@openbsd.org>
@@ -215,6 +215,22 @@ struct usb_video_vc_endpoint_desc {
uWord wMaxTransferSize;
};
+/* Table 3-13: Interface Input Header Descriptor */
+struct usb_video_input_header_desc {
+ uByte bLength;
+ uByte bDescriptorType;
+ uByte bDescriptorSubtype;
+ uByte bNumFormats;
+ uWord wTotalLength;
+ uByte bEndpointAddress;
+ uByte bmInfo;
+ uByte bTerminalLink;
+ uByte bStillCaptureMethod;
+ uByte bTriggerSupport;
+ uByte bTriggerUsage;
+ uByte bControlSize;
+};
+
/* Table 3-18: Color Matching Descriptor */
struct usb_video_color_matching_descr {
uByte bLength;