diff options
author | Josh Blum <josh@joshknows.com> | 2010-09-24 18:14:32 -0700 |
---|---|---|
committer | Josh Blum <josh@joshknows.com> | 2010-09-24 18:14:32 -0700 |
commit | 1dffd5bb5fe16cd35ba54e44e927888e0192e905 (patch) | |
tree | 08da412307cd9aecb885671035db5b8b68eb2978 /host/lib/transport/libusb1_device_handle.cpp | |
parent | f2f4840ff9e15ed21344a5a19d676d548b542e91 (diff) | |
download | uhd-1dffd5bb5fe16cd35ba54e44e927888e0192e905.tar.gz uhd-1dffd5bb5fe16cd35ba54e44e927888e0192e905.tar.bz2 uhd-1dffd5bb5fe16cd35ba54e44e927888e0192e905.zip |
usb: tweaks to usb code to cleanup properly and/or in error conditions
Diffstat (limited to 'host/lib/transport/libusb1_device_handle.cpp')
-rw-r--r-- | host/lib/transport/libusb1_device_handle.cpp | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/host/lib/transport/libusb1_device_handle.cpp b/host/lib/transport/libusb1_device_handle.cpp index 7efddd410..6bef37ed2 100644 --- a/host/lib/transport/libusb1_device_handle.cpp +++ b/host/lib/transport/libusb1_device_handle.cpp @@ -77,7 +77,7 @@ usb_device_handle::sptr make_usb_device_handle(libusb_device *dev) libusb_device_descriptor desc; if (libusb_get_device_descriptor(dev, &desc) < 0) { - UHD_ASSERT_THROW("USB: failed to get device descriptor"); + throw std::runtime_error("USB: failed to get device descriptor"); } std::string serial = libusb::get_serial(dev); @@ -104,14 +104,15 @@ std::vector<usb_device_handle::sptr> usb_device_handle::get_device_list(boost::u size_t dev_size = libusb_get_device_list(ctx, &libusb_device_list); for (size_t i = 0; i < dev_size; i++) { libusb_device *dev = libusb_device_list[i]; - if(libusb_get_device_descriptor(dev, &desc) < 0) { - UHD_ASSERT_THROW("USB: failed to get device descriptor"); + if(libusb_get_device_descriptor(dev, &desc) != 0) { + continue; //just try the next device, do not throw } if(desc.idVendor == vid && desc.idProduct == pid) { - device_handle_list.push_back(make_usb_device_handle(dev)); + device_handle_list.push_back(make_usb_device_handle(dev)); } } + libusb_free_device_list(libusb_device_list, true); libusb_exit(ctx); return device_handle_list; } |