From 363cbc22b57b1a491176dab6b7f4ca5b6f8bdb52 Mon Sep 17 00:00:00 2001 From: Dominik Riebeling Date: Sat, 8 Aug 2009 12:28:47 +0000 Subject: Support libusb-1.0. Use "qmake -config libusb1" to use libusb-1.0 instead of libusb-0.1. git-svn-id: svn://svn.rockbox.org/rockbox/trunk@22205 a1c6a512-1295-4272-9138-f99709370657 --- rbutil/rbutilqt/base/detect.cpp | 43 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 43 insertions(+) (limited to 'rbutil/rbutilqt/base/detect.cpp') diff --git a/rbutil/rbutilqt/base/detect.cpp b/rbutil/rbutilqt/base/detect.cpp index d471c98273..9eaa1c9bb7 100644 --- a/rbutil/rbutilqt/base/detect.cpp +++ b/rbutil/rbutilqt/base/detect.cpp @@ -40,7 +40,11 @@ // Linux and Mac includes #if defined(Q_OS_LINUX) || defined(Q_OS_MACX) +#if defined(LIBUSB1) +#include +#else #include +#endif #include #include #include @@ -190,7 +194,45 @@ QMap Detect::listUsbDevices(void) { QMap usbids; // usb pid detection + qDebug() << "[Detect] Searching for USB devices"; #if defined(Q_OS_LINUX) || defined(Q_OS_MACX) +#if defined(LIBUSB1) + libusb_device **devs; + int res; + ssize_t count; + res = libusb_init(NULL); + + count = libusb_get_device_list(NULL, &devs); + libusb_device *dev; + int i = 0; + while((dev = devs[i++]) != NULL) { + QString name; + unsigned char buf[256]; + uint32_t id; + struct libusb_device_descriptor descriptor; + if(libusb_get_device_descriptor(dev, &descriptor) == 0) { + id = descriptor.idVendor << 16 | descriptor.idProduct; + + libusb_device_handle *dh; + if(libusb_open(dev, &dh) == 0) { + libusb_get_string_descriptor_ascii(dh, descriptor.iManufacturer, buf, 256); + name += QString::fromAscii((char*)buf) + " "; + libusb_get_string_descriptor_ascii(dh, descriptor.iProduct, buf, 256); + name += QString::fromAscii((char*)buf); + libusb_close(dh); + } + if(name.isEmpty()) + name = QObject::tr("(no description available)"); + if(id) { + usbids.insert(id, name); + qDebug("[Detect] USB: 0x%08x, %s", id, name.toLocal8Bit().data()); + } + } + } + + libusb_free_device_list(devs, 1); + libusb_exit(NULL); +#else usb_init(); usb_find_busses(); usb_find_devices(); @@ -237,6 +279,7 @@ QMap Detect::listUsbDevices(void) b = b->next; } #endif +#endif #if defined(Q_OS_WIN32) HDEVINFO deviceInfo; -- cgit v1.2.3