diff options
Diffstat (limited to 'sys/dev')
-rw-r--r-- | sys/dev/usb/uvideo.c | 160 |
1 files changed, 80 insertions, 80 deletions
diff --git a/sys/dev/usb/uvideo.c b/sys/dev/usb/uvideo.c index 71d7334c118..259f672f40b 100644 --- a/sys/dev/usb/uvideo.c +++ b/sys/dev/usb/uvideo.c @@ -1,4 +1,4 @@ -/* $OpenBSD: uvideo.c,v 1.67 2008/08/01 08:20:26 mglocker Exp $ */ +/* $OpenBSD: uvideo.c,v 1.68 2008/08/01 12:16:52 mglocker Exp $ */ /* * Copyright (c) 2008 Robert Nagy <robert@openbsd.org> @@ -65,30 +65,30 @@ void uvideo_attach(struct device *, struct device *, void *); int uvideo_detach(struct device *, int); int uvideo_activate(struct device *, enum devact); -int uvideo_vc_parse_desc(struct uvideo_softc *); -int uvideo_vc_parse_desc_header(struct uvideo_softc *, +usbd_status uvideo_vc_parse_desc(struct uvideo_softc *); +usbd_status uvideo_vc_parse_desc_header(struct uvideo_softc *, const usb_descriptor_t *); -int uvideo_vs_parse_desc(struct uvideo_softc *, +usbd_status uvideo_vs_parse_desc(struct uvideo_softc *, struct usb_attach_arg *, usb_config_descriptor_t *); -int uvideo_vs_parse_desc_input_header(struct uvideo_softc *, +usbd_status uvideo_vs_parse_desc_input_header(struct uvideo_softc *, const usb_descriptor_t *); -int uvideo_vs_parse_desc_format(struct uvideo_softc *); -int uvideo_vs_parse_desc_format_mjpeg(struct uvideo_softc *, +usbd_status uvideo_vs_parse_desc_format(struct uvideo_softc *); +usbd_status uvideo_vs_parse_desc_format_mjpeg(struct uvideo_softc *, const usb_descriptor_t *); -int uvideo_vs_parse_desc_format_uncompressed(struct uvideo_softc *, +usbd_status uvideo_vs_parse_desc_format_uncompressed(struct uvideo_softc *, const usb_descriptor_t *); -int uvideo_vs_parse_desc_frame(struct uvideo_softc *); -int uvideo_vs_parse_desc_frame_mjpeg(struct uvideo_softc *, +usbd_status uvideo_vs_parse_desc_frame(struct uvideo_softc *); +usbd_status uvideo_vs_parse_desc_frame_mjpeg(struct uvideo_softc *, const usb_descriptor_t *); -int uvideo_vs_parse_desc_frame_uncompressed(struct uvideo_softc *, +usbd_status uvideo_vs_parse_desc_frame_uncompressed(struct uvideo_softc *, const usb_descriptor_t *); -int uvideo_vs_parse_desc_alt(struct uvideo_softc *, +usbd_status uvideo_vs_parse_desc_alt(struct uvideo_softc *, struct usb_attach_arg *uaa, int, int, int); -int uvideo_vs_set_alt(struct uvideo_softc *, usbd_interface_handle, +usbd_status uvideo_vs_set_alt(struct uvideo_softc *, usbd_interface_handle, int); int uvideo_desc_len(const usb_descriptor_t *, int, int, int, int); -int uvideo_find_res(struct uvideo_softc *, int, int, int, +void uvideo_find_res(struct uvideo_softc *, int, int, int, struct uvideo_res *); usbd_status uvideo_vs_negotiation(struct uvideo_softc *, int); @@ -105,10 +105,10 @@ usbd_status uvideo_vs_init(struct uvideo_softc *); void uvideo_vs_start(struct uvideo_softc *); void uvideo_vs_cb(usbd_xfer_handle, usbd_private_handle, usbd_status); -int uvideo_vs_decode_stream_header(struct uvideo_softc *, +usbd_status uvideo_vs_decode_stream_header(struct uvideo_softc *, uint8_t *, int); -int uvideo_mmap_queue(struct uvideo_softc *, uint8_t *, int); -int uvideo_read(struct uvideo_softc *, uint8_t *, int); +void uvideo_mmap_queue(struct uvideo_softc *, uint8_t *, int); +void uvideo_read(struct uvideo_softc *, uint8_t *, int); #ifdef UVIDEO_DEBUG void uvideo_dump_desc_all(struct uvideo_softc *); void uvideo_dump_desc_vc_header(struct uvideo_softc *, @@ -422,12 +422,13 @@ uvideo_activate(struct device *self, enum devact act) return (rv); } -int +usbd_status uvideo_vc_parse_desc(struct uvideo_softc *sc) { usbd_desc_iter_t iter; const usb_descriptor_t *desc; int vc_header_found; + usbd_status error; DPRINTF(1, "%s: %s\n", DEVNAME(sc), __func__); @@ -448,10 +449,11 @@ uvideo_vc_parse_desc(struct uvideo_softc *sc) if (vc_header_found) { printf("%s: too many VC_HEADERs!\n", DEVNAME(sc)); - return (-1); + return (USBD_INVAL); } - if (uvideo_vc_parse_desc_header(sc, desc) != 0) - return (-1); + error = uvideo_vc_parse_desc_header(sc, desc); + if (error != USBD_NORMAL_COMPLETION) + return (error); vc_header_found = 1; break; @@ -463,13 +465,13 @@ uvideo_vc_parse_desc(struct uvideo_softc *sc) if (vc_header_found == 0) { printf("%s: no VC_HEADER found!\n", DEVNAME(sc)); - return (-1); + return (USBD_INVAL); } - return (0); + return (USBD_NORMAL_COMPLETION); } -int +usbd_status uvideo_vc_parse_desc_header(struct uvideo_softc *sc, const usb_descriptor_t *desc) { @@ -480,16 +482,16 @@ uvideo_vc_parse_desc_header(struct uvideo_softc *sc, if (d->bInCollection == 0) { printf("%s: no VS interface found!\n", DEVNAME(sc)); - return (-1); + return (USBD_INVAL); } sc->sc_desc_vc_header.fix = d; sc->sc_desc_vc_header.baInterfaceNr = (uByte *)(d + 1); - return (0); + return (USBD_NORMAL_COMPLETION); } -int +usbd_status uvideo_vs_parse_desc(struct uvideo_softc *sc, struct usb_attach_arg *uaa, usb_config_descriptor_t *cdesc) { @@ -516,8 +518,9 @@ uvideo_vs_parse_desc(struct uvideo_softc *sc, struct usb_attach_arg *uaa, case UDESCSUB_VS_INPUT_HEADER: if (!uvideo_desc_len(desc, 13, 3, 0, 12)) break; - if (uvideo_vs_parse_desc_input_header(sc, desc) != 0) - return (-1); + error = uvideo_vs_parse_desc_input_header(sc, desc); + if (error != USBD_NORMAL_COMPLETION) + return (error); break; /* TODO: which VS descriptors do we need else? */ @@ -564,7 +567,7 @@ uvideo_vs_parse_desc(struct uvideo_softc *sc, struct usb_attach_arg *uaa, return (USBD_NORMAL_COMPLETION); } -int +usbd_status uvideo_vs_parse_desc_input_header(struct uvideo_softc *sc, const usb_descriptor_t *desc) { @@ -575,16 +578,16 @@ uvideo_vs_parse_desc_input_header(struct uvideo_softc *sc, /* on some devices bNumFormats is larger than the truth */ if (d->bNumFormats == 0) { printf("%s: no INPUT FORMAT descriptors found!\n", DEVNAME(sc)); - return (-1); + return (USBD_INVAL); } sc->sc_desc_vs_input_header.fix = d; sc->sc_desc_vs_input_header.bmaControls = (uByte *)(d + 1); - return (0); + return (USBD_NORMAL_COMPLETION); } -int +usbd_status uvideo_vs_parse_desc_format(struct uvideo_softc *sc) { usbd_desc_iter_t iter; @@ -603,13 +606,14 @@ uvideo_vs_parse_desc_format(struct uvideo_softc *sc) switch (desc->bDescriptorSubtype) { case UDESCSUB_VS_FORMAT_MJPEG: if (desc->bLength == 11) { - uvideo_vs_parse_desc_format_mjpeg(sc, desc); + (void)uvideo_vs_parse_desc_format_mjpeg( + sc, desc); } break; case UDESCSUB_VS_FORMAT_UNCOMPRESSED: if (desc->bLength == 27) { - uvideo_vs_parse_desc_format_uncompressed(sc, - desc); + (void)uvideo_vs_parse_desc_format_uncompressed( + sc, desc); } break; } @@ -629,7 +633,7 @@ uvideo_vs_parse_desc_format(struct uvideo_softc *sc) return (USBD_NORMAL_COMPLETION); } -int +usbd_status uvideo_vs_parse_desc_format_mjpeg(struct uvideo_softc *sc, const usb_descriptor_t *desc) { @@ -640,12 +644,12 @@ uvideo_vs_parse_desc_format_mjpeg(struct uvideo_softc *sc, if (d->bNumFrameDescriptors == 0) { printf("%s: no MJPEG frame descriptors available!\n", DEVNAME(sc)); - return (-1); + return (USBD_INVAL); } if (sc->sc_fmtgrp_idx > UVIDEO_MAX_FORMAT) { printf("%s: too many format descriptors found!\n", DEVNAME(sc)); - return (-1); + return (USBD_INVAL); } sc->sc_fmtgrp[sc->sc_fmtgrp_idx].format = @@ -661,10 +665,10 @@ uvideo_vs_parse_desc_format_mjpeg(struct uvideo_softc *sc, sc->sc_fmtgrp_idx++; sc->sc_fmtgrp_num++; - return (0); + return (USBD_NORMAL_COMPLETION); } -int +usbd_status uvideo_vs_parse_desc_format_uncompressed(struct uvideo_softc *sc, const usb_descriptor_t *desc) { @@ -676,12 +680,12 @@ uvideo_vs_parse_desc_format_uncompressed(struct uvideo_softc *sc, if (d->bNumFrameDescriptors == 0) { printf("%s: no UNCOMPRESSED frame descriptors available!\n", DEVNAME(sc)); - return (-1); + return (USBD_INVAL); } if (sc->sc_fmtgrp_idx > UVIDEO_MAX_FORMAT) { printf("%s: too many format descriptors found!\n", DEVNAME(sc)); - return (-1); + return (USBD_INVAL); } sc->sc_fmtgrp[sc->sc_fmtgrp_idx].format = @@ -704,14 +708,15 @@ uvideo_vs_parse_desc_format_uncompressed(struct uvideo_softc *sc, sc->sc_fmtgrp_idx++; sc->sc_fmtgrp_num++; - return (0); + return (USBD_NORMAL_COMPLETION); } -int +usbd_status uvideo_vs_parse_desc_frame(struct uvideo_softc *sc) { usbd_desc_iter_t iter; const usb_descriptor_t *desc; + usbd_status error; DPRINTF(1, "%s: %s\n", DEVNAME(sc), __func__); @@ -725,15 +730,16 @@ uvideo_vs_parse_desc_frame(struct uvideo_softc *sc) switch (desc->bDescriptorSubtype) { case UDESCSUB_VS_FRAME_MJPEG: - if (uvideo_vs_parse_desc_frame_mjpeg(sc, desc)) - return (1); + error = uvideo_vs_parse_desc_frame_mjpeg(sc, desc); + if (error != USBD_NORMAL_COMPLETION) + return (error); break; case UDESCSUB_VS_FRAME_UNCOMPRESSED: /* XXX do correct length calculation */ if (desc->bLength > 25) { - if (uvideo_vs_parse_desc_frame_uncompressed(sc, - desc)) - return (1); + error = uvideo_vs_parse_desc_frame_uncompressed( sc, desc); + if (error != USBD_NORMAL_COMPLETION) + return (error); } break; } @@ -741,10 +747,10 @@ uvideo_vs_parse_desc_frame(struct uvideo_softc *sc) desc = usb_desc_iter_next(&iter); } - return (0); + return (USBD_NORMAL_COMPLETION); } -int +usbd_status uvideo_vs_parse_desc_frame_mjpeg(struct uvideo_softc *sc, const usb_descriptor_t *desc) { @@ -756,7 +762,7 @@ uvideo_vs_parse_desc_frame_mjpeg(struct uvideo_softc *sc, if (d->bFrameIndex == UVIDEO_MAX_FRAME) { printf("%s: too many MJPEG frame descriptors found!\n", DEVNAME(sc)); - return (1); + return (USBD_INVAL); } fmtidx = sc->sc_fmtgrp_idx; @@ -782,10 +788,10 @@ uvideo_vs_parse_desc_frame_mjpeg(struct uvideo_softc *sc, sc->sc_fmtgrp[fmtidx].format->bNumFrameDescriptors) sc->sc_fmtgrp_idx++; - return (0); + return (USBD_NORMAL_COMPLETION); } -int +usbd_status uvideo_vs_parse_desc_frame_uncompressed(struct uvideo_softc *sc, const usb_descriptor_t *desc) { @@ -797,7 +803,7 @@ uvideo_vs_parse_desc_frame_uncompressed(struct uvideo_softc *sc, if (d->bFrameIndex == UVIDEO_MAX_FRAME) { printf("%s: too many UNCOMPRESSED frame descriptors found!\n", DEVNAME(sc)); - return (1); + return (USBD_INVAL); } fmtidx = sc->sc_fmtgrp_idx; @@ -824,10 +830,10 @@ uvideo_vs_parse_desc_frame_uncompressed(struct uvideo_softc *sc, sc->sc_fmtgrp[fmtidx].format->bNumFrameDescriptors) sc->sc_fmtgrp_idx++; - return (0); + return (USBD_NORMAL_COMPLETION); } -int +usbd_status uvideo_vs_parse_desc_alt(struct uvideo_softc *sc, struct usb_attach_arg *uaa, int vs_nr, int iface, int numalts) { @@ -891,7 +897,7 @@ next: return (USBD_NORMAL_COMPLETION); } -int +usbd_status uvideo_vs_set_alt(struct uvideo_softc *sc, usbd_interface_handle ifaceh, int max_packet_size) { @@ -988,7 +994,7 @@ uvideo_desc_len(const usb_descriptor_t *desc, * Find the next best matching resolution which we can offer and * return it. */ -int +void uvideo_find_res(struct uvideo_softc *sc, int idx, int width, int height, struct uvideo_res *r) { @@ -1015,8 +1021,6 @@ uvideo_find_res(struct uvideo_softc *sc, int idx, int width, int height, DPRINTF(1, "%s: %s: frame index %d: width=%d, height=%d\n", DEVNAME(sc), __func__, i, w, h); } - - return (0); } usbd_status @@ -1354,20 +1358,20 @@ uvideo_vs_init(struct uvideo_softc *sc) /* open video stream pipe */ error = uvideo_vs_open(sc); if (error != USBD_NORMAL_COMPLETION) - return (EIO); + return (USBD_INVAL); /* allocate video stream xfer buffer */ error = uvideo_vs_alloc(sc); if (error != USBD_NORMAL_COMPLETION) - return (EIO); + return (USBD_INVAL); /* allocate video stream sample buffer */ error = uvideo_vs_alloc_sample(sc); if (error != USBD_NORMAL_COMPLETION) - return (EIO); + return (USBD_INVAL); #ifdef UVIDEO_DUMP if (uvideo_debug_file_open(sc) != 0) - return(EIO); + return (USBD_INVAL); usb_init_task(&sc->sc_task_write, uvideo_debug_file_write_sample, sc); #endif return (USBD_NORMAL_COMPLETION); @@ -1428,14 +1432,14 @@ uvideo_vs_cb(usbd_xfer_handle xfer, usbd_private_handle priv, /* frame is empty */ continue; - uvideo_vs_decode_stream_header(sc, frame, frame_size); + (void)uvideo_vs_decode_stream_header(sc, frame, frame_size); } skip: /* setup new transfer */ uvideo_vs_start(sc); } -int +usbd_status uvideo_vs_decode_stream_header(struct uvideo_softc *sc, uint8_t *frame, int frame_size) { @@ -1445,7 +1449,7 @@ uvideo_vs_decode_stream_header(struct uvideo_softc *sc, uint8_t *frame, if (frame_size < 2) /* frame too small to contain a valid stream header */ - return (-1); + return (USBD_INVAL); header_len = frame[0]; header_flags = frame[1]; @@ -1454,10 +1458,10 @@ uvideo_vs_decode_stream_header(struct uvideo_softc *sc, uint8_t *frame, if (header_len != 12) /* frame header is 12 bytes long */ - return (-1); + return (USBD_INVAL); if (header_len == frame_size && !(header_flags & UVIDEO_STREAM_EOF)) { /* stream header without payload and no EOF */ - return (-1); + return (USBD_INVAL); } DPRINTF(2, "%s: frame_size = %d\n", DEVNAME(sc), frame_size); @@ -1522,10 +1526,10 @@ uvideo_vs_decode_stream_header(struct uvideo_softc *sc, uint8_t *frame, fb->fid = 0; } - return (0); + return (USBD_NORMAL_COMPLETION); } -int +void uvideo_mmap_queue(struct uvideo_softc *sc, uint8_t *buf, int len) { /* find a buffer which is ready for queueing */ @@ -1556,11 +1560,9 @@ uvideo_mmap_queue(struct uvideo_softc *sc, uint8_t *buf, int len) sc->sc_mmap_cur = 0; wakeup(sc); - - return (0); } -int +void uvideo_read(struct uvideo_softc *sc, uint8_t *buf, int len) { /* @@ -1570,8 +1572,6 @@ uvideo_read(struct uvideo_softc *sc, uint8_t *buf, int len) *sc->sc_uplayer_fsize = len; bcopy(buf, sc->sc_uplayer_fbuffer, len); sc->sc_uplayer_intr(sc->sc_uplayer_arg); - - return (0); } #ifdef UVIDEO_DEBUG @@ -2049,14 +2049,14 @@ uvideo_debug_file_open(struct uvideo_softc *sc) if (error) { DPRINTF(1, "%s: %s: can't creat debug file %s!\n", DEVNAME(sc), __func__, name); - return (-1); + return (error); } sc->sc_vp = nd.ni_vp; VOP_UNLOCK(sc->sc_vp, 0, p); if (nd.ni_vp->v_type != VREG) { vn_close(nd.ni_vp, FWRITE, p->p_ucred, p); - return (-1); + return (EIO); } DPRINTF(1, "%s: %s: created debug file %s\n", |