diff options
author | Marcus Glocker <mglocker@cvs.openbsd.org> | 2008-04-11 05:37:37 +0000 |
---|---|---|
committer | Marcus Glocker <mglocker@cvs.openbsd.org> | 2008-04-11 05:37:37 +0000 |
commit | a801a417df8b09fefbe229f6112a6055f4e06bc7 (patch) | |
tree | 2c8c63ba0a514d1bec1695b9d388ff0f9de71a7d /sys | |
parent | 15a7904588661dee128737d8ccff728da3d5b818 (diff) |
Correctly initialize the probe sequence buffer.
Diffstat (limited to 'sys')
-rw-r--r-- | sys/dev/usb/uvideo.c | 23 |
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); |