mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-09 23:59:27 +01:00
Android: Detect GCAdapter disconnection using BroadcastReceiver
This lets us get rid of the Reset call in ProcessInputPayload, which was causing us some threading headaches (see 74ed5e5532). Instead we handle disconnection in the same way as the libusb implementation does.
This commit is contained in:
parent
812ed34dc3
commit
44f1c2010c
@ -134,10 +134,9 @@ static std::thread s_write_adapter_thread;
|
|||||||
static Common::Flag s_write_adapter_thread_running;
|
static Common::Flag s_write_adapter_thread_running;
|
||||||
static Common::Event s_write_happened;
|
static Common::Event s_write_happened;
|
||||||
|
|
||||||
static std::mutex s_read_mutex;
|
|
||||||
#if GCADAPTER_USE_LIBUSB_IMPLEMENTATION
|
|
||||||
static std::mutex s_init_mutex;
|
static std::mutex s_init_mutex;
|
||||||
#elif GCADAPTER_USE_ANDROID_IMPLEMENTATION
|
static std::mutex s_read_mutex;
|
||||||
|
#if GCADAPTER_USE_ANDROID_IMPLEMENTATION
|
||||||
static std::mutex s_write_mutex;
|
static std::mutex s_write_mutex;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -359,6 +358,8 @@ JNIEXPORT void JNICALL
|
|||||||
Java_org_dolphinemu_dolphinemu_utils_GCAdapter_onAdapterDisconnected(JNIEnv* env, jclass)
|
Java_org_dolphinemu_dolphinemu_utils_GCAdapter_onAdapterDisconnected(JNIEnv* env, jclass)
|
||||||
{
|
{
|
||||||
INFO_LOG_FMT(CONTROLLERINTERFACE, "GC adapter disconnected");
|
INFO_LOG_FMT(CONTROLLERINTERFACE, "GC adapter disconnected");
|
||||||
|
if (s_detected)
|
||||||
|
Reset(CalledFromReadThread::No);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -422,6 +423,7 @@ static void ScanThreadFunc()
|
|||||||
if (!s_detected && UseAdapter() &&
|
if (!s_detected && UseAdapter() &&
|
||||||
env->CallStaticBooleanMethod(s_adapter_class, is_usb_device_available_func))
|
env->CallStaticBooleanMethod(s_adapter_class, is_usb_device_available_func))
|
||||||
{
|
{
|
||||||
|
std::lock_guard lk(s_init_mutex);
|
||||||
Setup();
|
Setup();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -737,10 +739,10 @@ void Shutdown()
|
|||||||
|
|
||||||
static void Reset(CalledFromReadThread called_from_read_thread)
|
static void Reset(CalledFromReadThread called_from_read_thread)
|
||||||
{
|
{
|
||||||
#if GCADAPTER_USE_LIBUSB_IMPLEMENTATION
|
|
||||||
std::unique_lock lock(s_init_mutex, std::defer_lock);
|
std::unique_lock lock(s_init_mutex, std::defer_lock);
|
||||||
if (!lock.try_lock())
|
if (!lock.try_lock())
|
||||||
return;
|
return;
|
||||||
|
#if GCADAPTER_USE_LIBUSB_IMPLEMENTATION
|
||||||
if (s_status != AdapterStatus::Detected)
|
if (s_status != AdapterStatus::Detected)
|
||||||
return;
|
return;
|
||||||
#elif GCADAPTER_USE_ANDROID_IMPLEMENTATION
|
#elif GCADAPTER_USE_ANDROID_IMPLEMENTATION
|
||||||
@ -836,9 +838,6 @@ void ProcessInputPayload(const u8* data, std::size_t size)
|
|||||||
// This can occur for a few frames on initialization.
|
// This can occur for a few frames on initialization.
|
||||||
ERROR_LOG_FMT(CONTROLLERINTERFACE, "error reading payload (size: {}, type: {:02x})", size,
|
ERROR_LOG_FMT(CONTROLLERINTERFACE, "error reading payload (size: {}, type: {:02x})", size,
|
||||||
data[0]);
|
data[0]);
|
||||||
#if GCADAPTER_USE_ANDROID_IMPLEMENTATION
|
|
||||||
Reset(CalledFromReadThread::Yes);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user