From 9a6c96ee569510d4b0a9d92e5cafb7d1477b3b13 Mon Sep 17 00:00:00 2001 From: Cedric BAIL Date: Tue, 27 Sep 2011 06:16:11 +0000 Subject: [PATCH] ecore: prevent one last spurious wakeup. SVN revision: 63619 --- legacy/ecore/src/lib/ecore/ecore.c | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/legacy/ecore/src/lib/ecore/ecore.c b/legacy/ecore/src/lib/ecore/ecore.c index 2560d912d9..b9ab179546 100644 --- a/legacy/ecore/src/lib/ecore/ecore.c +++ b/legacy/ecore/src/lib/ecore/ecore.c @@ -406,7 +406,7 @@ ecore_thread_main_loop_end(void) eina_lock_release(&_thread_mutex); eina_lock_take(&_thread_feedback_mutex); - while (current_id == _thread_id) + while (current_id == _thread_id && _thread_id != -1) eina_condition_wait(&_thread_feedback_cond); eina_lock_release(&_thread_feedback_mutex); @@ -686,11 +686,12 @@ _thread_callback(void *data __UNUSED__, eina_condition_wait(&_thread_cond); eina_lock_release(&_thread_mutex); - _thread_id = -1; - eina_main_loop_define(); eina_lock_take(&_thread_feedback_mutex); + + _thread_id = -1; + eina_condition_broadcast(&_thread_feedback_cond); eina_lock_release(&_thread_feedback_mutex);