summaryrefslogtreecommitdiff
path: root/sys/dev
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev')
-rw-r--r--sys/dev/usb/uvideo.c43
-rw-r--r--sys/dev/usb/uvideo.h4
2 files changed, 29 insertions, 18 deletions
diff --git a/sys/dev/usb/uvideo.c b/sys/dev/usb/uvideo.c
index cb2bd5382c1..329114f46ef 100644
--- a/sys/dev/usb/uvideo.c
+++ b/sys/dev/usb/uvideo.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: uvideo.c,v 1.109 2008/12/17 08:39:01 mglocker Exp $ */
+/* $OpenBSD: uvideo.c,v 1.110 2008/12/17 18:14:46 mglocker Exp $ */
/*
* Copyright (c) 2008 Robert Nagy <robert@openbsd.org>
@@ -240,19 +240,31 @@ struct video_hw_if uvideo_hw_if = {
* Devices which either fail to declare themselves as UICLASS_VIDEO,
* or which need firmware uploads or other quirk handling later on.
*/
+#define UVIDEO_FLAG_ISIGHT_STREAM_HEADER 0x1
struct uvideo_devs {
- struct usb_devno uv_dev;
- char *ucode_name;
- usbd_status (*ucode_loader)(struct uvideo_softc *);
+ struct usb_devno uv_dev;
+ char *ucode_name;
+ usbd_status (*ucode_loader)(struct uvideo_softc *);
+ int flags;
} uvideo_devs[] = {
{
{ USB_VENDOR_RICOH, USB_PRODUCT_RICOH_VGPVCC7 },
"r5u87x-05ca-183a.fw",
- uvideo_ucode_loader_ricoh
+ uvideo_ucode_loader_ricoh,
+ 0
},
- { /* Incorrectly reports as UICLASS_VENDOR */
+ { /* Incorrectly reports as UICLASS_VENDOR */
{ USB_VENDOR_LOGITECH, USB_PRODUCT_LOGITECH_QUICKCAMOEM_1 },
- NULL, NULL
+ NULL,
+ NULL,
+ 0
+ },
+ {
+ /* Has a own streaming header format */
+ { USB_VENDOR_APPLE, USB_PRODUCT_APPLE_ISIGHT_1 },
+ NULL,
+ NULL,
+ UVIDEO_FLAG_ISIGHT_STREAM_HEADER
}
};
#define uvideo_lookup(v, p) \
@@ -355,9 +367,7 @@ uvideo_match(struct device *parent, void *match, void *aux)
id->bInterfaceSubClass == UISUBCLASS_VIDEOCONTROL)
return (UMATCH_VENDOR_PRODUCT_CONF_IFACE);
- if (uvideo_lookup(uaa->vendor, uaa->product) != NULL &&
- id->bInterfaceClass == UICLASS_VENDOR &&
- id->bInterfaceSubClass == UISUBCLASS_VIDEOCONTROL)
+ if (uvideo_lookup(uaa->vendor, uaa->product) != NULL)
return (UMATCH_VENDOR_PRODUCT_CONF_IFACE);
return (UMATCH_NONE);
@@ -393,10 +403,11 @@ uvideo_attach(struct device *parent, struct device *self, void *aux)
if (error != USBD_NORMAL_COMPLETION)
return;
- /* if the device needs ucode do mountroothook */
- sc->sc_ucode = uvideo_lookup(uaa->vendor, uaa->product);
+ /* maybe the device has quirks */
+ sc->sc_quirk = uvideo_lookup(uaa->vendor, uaa->product);
- if ((sc->sc_ucode && sc->sc_ucode->ucode_name) && rootvp == NULL)
+ /* if the device needs ucode do mountroothook */
+ if ((sc->sc_quirk && sc->sc_quirk->ucode_name) && rootvp == NULL)
mountroothook_establish(uvideo_attach_hook, sc);
else
uvideo_attach_hook(sc);
@@ -408,8 +419,8 @@ uvideo_attach_hook(void *arg)
struct uvideo_softc *sc = arg;
usbd_status error;
- if (sc->sc_ucode && sc->sc_ucode->ucode_name) {
- error = (sc->sc_ucode->ucode_loader)(sc);
+ if (sc->sc_quirk && sc->sc_quirk->ucode_name) {
+ error = (sc->sc_quirk->ucode_loader)(sc);
if (error != USBD_NORMAL_COMPLETION)
return;
}
@@ -3055,7 +3066,7 @@ uvideo_ucode_loader_ricoh(struct uvideo_softc *sc)
}
/* open microcode file */
- error = loadfirmware(sc->sc_ucode->ucode_name, &ucode, &ucode_size);
+ error = loadfirmware(sc->sc_quirk->ucode_name, &ucode, &ucode_size);
if (error != 0) {
printf("%s: loadfirmware error=%d!\n", DEVNAME(sc), error);
return (USBD_INVAL);
diff --git a/sys/dev/usb/uvideo.h b/sys/dev/usb/uvideo.h
index 9ff2bbdb3e3..350845792f2 100644
--- a/sys/dev/usb/uvideo.h
+++ b/sys/dev/usb/uvideo.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: uvideo.h,v 1.41 2008/12/08 22:02:39 deraadt Exp $ */
+/* $OpenBSD: uvideo.h,v 1.42 2008/12/17 18:14:46 mglocker Exp $ */
/*
* Copyright (c) 2007 Robert Nagy <robert@openbsd.org>
@@ -600,5 +600,5 @@ struct uvideo_softc {
uint8_t *sc_uplayer_fbuffer;
void (*sc_uplayer_intr)(void *);
- struct uvideo_devs *sc_ucode;
+ struct uvideo_devs *sc_quirk;
};