IOS: Check if libusb can be used instead of asserting

This prevents panic alerts from showing up three times when starting
Wii emulation whenever libusb could not be initialized. The user has
already seen a warning at startup -- no need to warn them 3 more times.
This commit is contained in:
Léo Lam 2017-02-06 22:09:43 +01:00
parent d244597b42
commit f5a3aac8e1
2 changed files with 30 additions and 25 deletions

View File

@ -61,8 +61,6 @@ BluetoothReal::BluetoothReal(u32 device_id, const std::string& device_name)
: BluetoothBase(device_id, device_name) : BluetoothBase(device_id, device_name)
{ {
m_libusb_context = LibusbContext::Get(); m_libusb_context = LibusbContext::Get();
_assert_msg_(IOS_WIIMOTE, m_libusb_context, "Failed to init libusb.");
LoadLinkKeys(); LoadLinkKeys();
} }
@ -84,6 +82,9 @@ BluetoothReal::~BluetoothReal()
ReturnCode BluetoothReal::Open(const OpenRequest& request) ReturnCode BluetoothReal::Open(const OpenRequest& request)
{ {
if (!m_libusb_context)
return IPC_EACCES;
libusb_device** list; libusb_device** list;
const ssize_t cnt = libusb_get_device_list(m_libusb_context.get(), &list); const ssize_t cnt = libusb_get_device_list(m_libusb_context.get(), &list);
_dbg_assert_msg_(IOS, cnt > 0, "Couldn't get device list"); _dbg_assert_msg_(IOS, cnt > 0, "Couldn't get device list");

View File

@ -32,7 +32,6 @@ USBHost::USBHost(u32 device_id, const std::string& device_name) : Device(device_
{ {
#ifdef __LIBUSB__ #ifdef __LIBUSB__
m_libusb_context = LibusbContext::Get(); m_libusb_context = LibusbContext::Get();
_assert_msg_(IOS_USB, m_libusb_context, "Failed to init libusb.");
#endif #endif
} }
@ -117,31 +116,36 @@ bool USBHost::AddNewDevices(std::set<u64>& new_devices, DeviceChangeHooks& hooks
const bool always_add_hooks) const bool always_add_hooks)
{ {
#ifdef __LIBUSB__ #ifdef __LIBUSB__
libusb_device** list; if (m_libusb_context)
const ssize_t count = libusb_get_device_list(m_libusb_context.get(), &list);
if (count < 0)
{ {
WARN_LOG(IOS_USB, "Failed to get device list: %s", libusb_error_name(static_cast<int>(count))); libusb_device** list;
return false; const ssize_t count = libusb_get_device_list(m_libusb_context.get(), &list);
} if (count < 0)
{
WARN_LOG(IOS_USB, "Failed to get device list: %s",
libusb_error_name(static_cast<int>(count)));
return false;
}
for (ssize_t i = 0; i < count; ++i) for (ssize_t i = 0; i < count; ++i)
{ {
libusb_device* device = list[i]; libusb_device* device = list[i];
libusb_device_descriptor descriptor; libusb_device_descriptor descriptor;
libusb_get_device_descriptor(device, &descriptor); libusb_get_device_descriptor(device, &descriptor);
if (!SConfig::GetInstance().IsUSBDeviceWhitelisted({descriptor.idVendor, descriptor.idProduct})) if (!SConfig::GetInstance().IsUSBDeviceWhitelisted(
continue; {descriptor.idVendor, descriptor.idProduct}))
continue;
auto usb_device = std::make_unique<USB::LibusbDevice>(device, descriptor); auto usb_device = std::make_unique<USB::LibusbDevice>(device, descriptor);
if (!ShouldAddDevice(*usb_device)) if (!ShouldAddDevice(*usb_device))
continue; continue;
const u64 id = usb_device->GetId(); const u64 id = usb_device->GetId();
new_devices.insert(id); new_devices.insert(id);
if (AddDevice(std::move(usb_device)) || always_add_hooks) if (AddDevice(std::move(usb_device)) || always_add_hooks)
hooks.emplace(GetDeviceById(id), ChangeEvent::Inserted); hooks.emplace(GetDeviceById(id), ChangeEvent::Inserted);
}
libusb_free_device_list(list, 1);
} }
libusb_free_device_list(list, 1);
#endif #endif
return true; return true;
} }
@ -195,7 +199,7 @@ void USBHost::StartThreads()
} }
#ifdef __LIBUSB__ #ifdef __LIBUSB__
if (!m_event_thread_running.IsSet()) if (m_libusb_context && !m_event_thread_running.IsSet())
{ {
m_event_thread_running.Set(); m_event_thread_running.Set();
m_event_thread = std::thread([this] { m_event_thread = std::thread([this] {