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:
JosJuice 2025-01-02 17:37:57 +01:00
parent 812ed34dc3
commit 44f1c2010c

View File

@ -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
{ {