提交 6a18eaf6 编写于 作者: M Mauro Carvalho Chehab

V4L/DVB (9766): em28xx: improve probe messages

Prints usb speed used by em28xx interface. While there, fixes USB ID's
endiannes.
Signed-off-by: NMauro Carvalho Chehab <mchehab@redhat.com>
上级 017ab4b1
...@@ -2176,6 +2176,7 @@ static int em28xx_usb_probe(struct usb_interface *interface, ...@@ -2176,6 +2176,7 @@ static int em28xx_usb_probe(struct usb_interface *interface,
struct em28xx *dev = NULL; struct em28xx *dev = NULL;
int retval = -ENODEV; int retval = -ENODEV;
int i, nr, ifnum, isoc_pipe; int i, nr, ifnum, isoc_pipe;
char *speed;
udev = usb_get_dev(interface_to_usbdev(interface)); udev = usb_get_dev(interface_to_usbdev(interface));
ifnum = interface->altsetting[0].desc.bInterfaceNumber; ifnum = interface->altsetting[0].desc.bInterfaceNumber;
...@@ -2186,9 +2187,10 @@ static int em28xx_usb_probe(struct usb_interface *interface, ...@@ -2186,9 +2187,10 @@ static int em28xx_usb_probe(struct usb_interface *interface,
/* Don't register audio interfaces */ /* Don't register audio interfaces */
if (interface->altsetting[0].desc.bInterfaceClass == USB_CLASS_AUDIO) { if (interface->altsetting[0].desc.bInterfaceClass == USB_CLASS_AUDIO) {
em28xx_err(DRIVER_NAME " audio device (%04x:%04x): interface %i, class %i\n", em28xx_err(DRIVER_NAME " audio device (%04x:%04x): "
udev->descriptor.idVendor, "interface %i, class %i\n",
udev->descriptor.idProduct, le16_to_cpu(udev->descriptor.idVendor),
le16_to_cpu(udev->descriptor.idProduct),
ifnum, ifnum,
interface->altsetting[0].desc.bInterfaceClass); interface->altsetting[0].desc.bInterfaceClass);
...@@ -2219,8 +2221,8 @@ static int em28xx_usb_probe(struct usb_interface *interface, ...@@ -2219,8 +2221,8 @@ static int em28xx_usb_probe(struct usb_interface *interface,
if (!check_interface) { if (!check_interface) {
em28xx_err(DRIVER_NAME " video device (%04x:%04x): " em28xx_err(DRIVER_NAME " video device (%04x:%04x): "
"interface %i, class %i found.\n", "interface %i, class %i found.\n",
udev->descriptor.idVendor, le16_to_cpu(udev->descriptor.idVendor),
udev->descriptor.idProduct, le16_to_cpu(udev->descriptor.idProduct),
ifnum, ifnum,
interface->altsetting[0].desc.bInterfaceClass); interface->altsetting[0].desc.bInterfaceClass);
...@@ -2230,14 +2232,30 @@ static int em28xx_usb_probe(struct usb_interface *interface, ...@@ -2230,14 +2232,30 @@ static int em28xx_usb_probe(struct usb_interface *interface,
em28xx_devused &= ~(1<<nr); em28xx_devused &= ~(1<<nr);
return -ENODEV; return -ENODEV;
} }
}
switch (udev->speed) {
case USB_SPEED_LOW:
speed = "1.5";
break;
case USB_SPEED_UNKNOWN:
case USB_SPEED_FULL:
speed = "12";
break;
case USB_SPEED_HIGH:
speed = "480";
break;
default:
speed = "unknown";
} }
em28xx_err(DRIVER_NAME " new video device (%04x:%04x): interface %i, class %i\n", printk(DRIVER_NAME ": New video device @ %s Mbps "
udev->descriptor.idVendor, "(%04x:%04x, interface %d, class %d)\n",
udev->descriptor.idProduct, speed,
le16_to_cpu(udev->descriptor.idVendor),
le16_to_cpu(udev->descriptor.idProduct),
ifnum, ifnum,
interface->altsetting[0].desc.bInterfaceClass); interface->altsetting->desc.bInterfaceNumber);
if (nr >= EM28XX_MAXBOARDS) { if (nr >= EM28XX_MAXBOARDS) {
printk(DRIVER_NAME ": Supports only %i em28xx boards.\n", printk(DRIVER_NAME ": Supports only %i em28xx boards.\n",
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册