diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2014-06-11 08:37:44 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2014-06-11 08:37:44 +0000 |
commit | e2b10b6d131425c395c5fe286ce6fd55d46f7c51 (patch) | |
tree | 4a8fb27c43ffbbfb6e5d9ceef71a048a162b3c48 /thread_win32.c | |
parent | a678de48c5d22bcceda459401bf74a9c7578ab7a (diff) | |
download | ruby-e2b10b6d131425c395c5fe286ce6fd55d46f7c51.tar.gz |
thread_pthread.c: timer thread flag
* thread_pthread.c (timer_thread): add a flag to tell timer thread
is created, since 0 may be a valid value as pthread_t.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@46405 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'thread_win32.c')
-rw-r--r-- | thread_win32.c | 33 |
1 files changed, 18 insertions, 15 deletions
diff --git a/thread_win32.c b/thread_win32.c index feadede50d..a0b26e3d4a 100644 --- a/thread_win32.c +++ b/thread_win32.c @@ -692,14 +692,17 @@ ubf_handle(void *ptr) w32_set_event(th->native_thread_data.interrupt_event); } -static HANDLE timer_thread_id = 0; -static HANDLE timer_thread_lock; +static struct { + HANDLE id; + HANDLE lock; +} timer_thread; +#define TIMER_THREAD_CREATED_P() (timer_thread.id != 0) static unsigned long __stdcall timer_thread_func(void *dummy) { thread_debug("timer_thread\n"); - while (WaitForSingleObject(timer_thread_lock, TIME_QUANTUM_USEC/1000) == + while (WaitForSingleObject(timer_thread.lock, TIME_QUANTUM_USEC/1000) == WAIT_TIMEOUT) { timer_thread_function(dummy); } @@ -716,13 +719,13 @@ rb_thread_wakeup_timer_thread(void) static void rb_thread_create_timer_thread(void) { - if (timer_thread_id == 0) { - if (!timer_thread_lock) { - timer_thread_lock = CreateEvent(0, TRUE, FALSE, 0); + if (timer_thread.id == 0) { + if (!timer_thread.lock) { + timer_thread.lock = CreateEvent(0, TRUE, FALSE, 0); } - timer_thread_id = w32_create_thread(1024 + (THREAD_DEBUG ? BUFSIZ : 0), + timer_thread.id = w32_create_thread(1024 + (THREAD_DEBUG ? BUFSIZ : 0), timer_thread_func, 0); - w32_resume_thread(timer_thread_id); + w32_resume_thread(timer_thread.id); } } @@ -731,10 +734,10 @@ native_stop_timer_thread(int close_anyway) { int stopped = --system_working <= 0; if (stopped) { - SetEvent(timer_thread_lock); - native_thread_join(timer_thread_id); - CloseHandle(timer_thread_lock); - timer_thread_lock = 0; + SetEvent(timer_thread.lock); + native_thread_join(timer_thread.id); + CloseHandle(timer_thread.lock); + timer_thread.lock = 0; } return stopped; } @@ -742,9 +745,9 @@ native_stop_timer_thread(int close_anyway) static void native_reset_timer_thread(void) { - if (timer_thread_id) { - CloseHandle(timer_thread_id); - timer_thread_id = 0; + if (timer_thread.id) { + CloseHandle(timer_thread.id); + timer_thread.id = 0; } } |