From c0a39006a2ada0d0e034307e17742abe44220448 Mon Sep 17 00:00:00 2001 From: Po Lu Date: Thu, 23 Feb 2023 18:19:32 +0800 Subject: [PATCH] ; * src/android.c (android_run_select_thread): Fix typos. --- src/android.c | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/src/android.c b/src/android.c index ffeb4b659d9..9c600be6cdf 100644 --- a/src/android.c +++ b/src/android.c @@ -344,12 +344,15 @@ android_run_select_thread (void *data) android_pselect_rc = rc; pthread_mutex_unlock (&event_queue.select_mutex); - /* Signal the main thread that there is now data to read. - It is ok to signal this condition variable without holding - the event queue lock, because android_select will always - wait for this to complete before returning. */ + /* Signal the main thread that there is now data to read. Hold + the event queue lock during this process to make sure this + does not happen before the main thread begins to wait for the + condition variable. */ + + pthread_mutex_lock (&event_queue.mutex); android_pselect_completed = true; pthread_cond_broadcast (&event_queue.read_var); + pthread_mutex_unlock (&event_queue.mutex); /* Read a single byte from the select pipe. */ read (select_pipe[0], &byte, 1); @@ -392,10 +395,10 @@ android_run_select_thread (void *data) does not happen before the main thread begins to wait for the condition variable. */ - pthread_mutex_lock (&event_queue.select_mutex); + pthread_mutex_lock (&event_queue.mutex); android_pselect_completed = true; pthread_cond_broadcast (&event_queue.read_var); - pthread_mutex_unlock (&event_queue.select_mutex); + pthread_mutex_unlock (&event_queue.mutex); if (rc != -1 || errno != EINTR) /* Now, wait for SIGUSR1, unless pselect was interrupted and -- 2.39.5