GCAdapter: Handle dynamic status updates for non-hotplug libusb
Detect when the setup function found no adapter, or found one but could not connect to it, and report the new status in that case.
This commit is contained in:
parent
2ac1ca133f
commit
9e7d4d2abb
|
@ -177,8 +177,6 @@ static void ScanThreadFunc()
|
||||||
{
|
{
|
||||||
std::lock_guard<std::mutex> lk(s_init_mutex);
|
std::lock_guard<std::mutex> lk(s_init_mutex);
|
||||||
Setup();
|
Setup();
|
||||||
if (s_status == ADAPTER_DETECTED && s_detect_callback != nullptr)
|
|
||||||
s_detect_callback();
|
|
||||||
}
|
}
|
||||||
Common::SleepCurrentThread(500);
|
Common::SleepCurrentThread(500);
|
||||||
}
|
}
|
||||||
|
@ -229,6 +227,12 @@ void StopScanThread()
|
||||||
|
|
||||||
static void Setup()
|
static void Setup()
|
||||||
{
|
{
|
||||||
|
int prev_status = s_status;
|
||||||
|
|
||||||
|
// Reset the error status in case the adapter gets unplugged
|
||||||
|
if (s_status < 0)
|
||||||
|
s_status = NO_ADAPTER_DETECTED;
|
||||||
|
|
||||||
for (int i = 0; i < SerialInterface::MAX_SI_CHANNELS; i++)
|
for (int i = 0; i < SerialInterface::MAX_SI_CHANNELS; i++)
|
||||||
{
|
{
|
||||||
s_controller_type[i] = ControllerTypes::CONTROLLER_NONE;
|
s_controller_type[i] = ControllerTypes::CONTROLLER_NONE;
|
||||||
|
@ -244,6 +248,9 @@ static void Setup()
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
if (s_status != ADAPTER_DETECTED && prev_status != s_status && s_detect_callback != nullptr)
|
||||||
|
s_detect_callback();
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool CheckDeviceAccess(libusb_device* device)
|
static bool CheckDeviceAccess(libusb_device* device)
|
||||||
|
|
Loading…
Reference in New Issue