summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorMarcus Glocker <mglocker@cvs.openbsd.org>2008-04-11 05:37:37 +0000
committerMarcus Glocker <mglocker@cvs.openbsd.org>2008-04-11 05:37:37 +0000
commita801a417df8b09fefbe229f6112a6055f4e06bc7 (patch)
tree2c8c63ba0a514d1bec1695b9d388ff0f9de71a7d /sys
parent15a7904588661dee128737d8ccff728da3d5b818 (diff)
Correctly initialize the probe sequence buffer.
Diffstat (limited to 'sys')
-rw-r--r--sys/dev/usb/uvideo.c23
1 files changed, 18 insertions, 5 deletions
diff --git a/sys/dev/usb/uvideo.c b/sys/dev/usb/uvideo.c
index cd66ba94bba..d33a8113375 100644
--- a/sys/dev/usb/uvideo.c
+++ b/sys/dev/usb/uvideo.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: uvideo.c,v 1.3 2008/04/10 09:22:15 mglocker Exp $ */
+/* $OpenBSD: uvideo.c,v 1.4 2008/04/11 05:37:36 mglocker Exp $ */
/*
* Copyright (c) 2008 Robert Nagy <robert@openbsd.org>
@@ -166,7 +166,7 @@ uvideo_attach(struct device * parent, struct device * self, void *aux)
struct uvideo_softc *sc = (struct uvideo_softc *) self;
struct usb_attach_arg *uaa = aux;
usb_config_descriptor_t *cdesc;
- usbd_status err;
+ usbd_status err;
uint8_t probe_data[34];
struct uvideo_sample_buffer *fb = &sc->sc_sample_buffer;
@@ -182,8 +182,10 @@ uvideo_attach(struct device * parent, struct device * self, void *aux)
uvideo_dump_desc_all(sc);
+ bzero(probe_data, sizeof(probe_data));
if (uvideo_vs_set_probe(sc, probe_data))
return;
+ bzero(probe_data, sizeof(probe_data));
if (uvideo_vs_get_probe(sc, probe_data))
return;
if (uvideo_vs_set_probe_commit(sc, probe_data))
@@ -513,9 +515,7 @@ uvideo_vs_set_probe(struct uvideo_softc *sc, uint8_t *probe_data)
USETW(req.wIndex, 1);
USETW(req.wLength, 26);
- bzero(probe_data, sizeof(probe_data));
pc = (struct usb_video_probe_commit *)probe_data;
- USETW(pc->bmHint, 8);
//USETW(pc->bmHint, 1);
pc->bFormatIndex = 1;
pc->bFrameIndex = 1;
@@ -530,6 +530,20 @@ uvideo_vs_set_probe(struct uvideo_softc *sc, uint8_t *probe_data)
DPRINTF(1, "%s: SET probe control request successfully\n",
DEVNAME(sc));
+ DPRINTF(1, "bmHint=0x%02x\n", UGETW(pc->bmHint));
+ DPRINTF(1, "bFormatIndex=0x%02x\n", pc->bFormatIndex);
+ DPRINTF(1, "bFrameIndex=0x%02x\n", pc->bFrameIndex);
+ DPRINTF(1, "dwFrameInterval=%d (ns)\n", UGETDW(pc->dwFrameInterval));
+ DPRINTF(1, "wKeyFrameRate=%d\n", UGETW(pc->wKeyFrameRate));
+ DPRINTF(1, "wPFrameRate=0x%d\n", UGETW(pc->wPFrameRate));
+ DPRINTF(1, "wCompQuality=0x%d\n", UGETW(pc->wCompQuality));
+ DPRINTF(1, "wCompWindowSize=0x%04x\n", UGETW(pc->wCompWindowSize));
+ DPRINTF(1, "wDelay=%d (ms)\n", UGETW(pc->wDelay));
+ DPRINTF(1, "dwMaxVideoFrameSize=%d (bytes)\n",
+ UGETDW(pc->dwMaxVideoFrameSize));
+ DPRINTF(1, "dwMaxPayloadTransferSize=%d (bytes)\n",
+ UGETDW(pc->dwMaxPayloadTransferSize));
+
return (0);
}
@@ -549,7 +563,6 @@ uvideo_vs_get_probe(struct uvideo_softc *sc, uint8_t *probe_data)
USETW(req.wIndex, 1);
USETW(req.wLength, 26);
- bzero(probe_data, sizeof(probe_data));
pc = (struct usb_video_probe_commit *)probe_data;
err = usbd_do_request(sc->sc_udev, &req, probe_data);