summaryrefslogtreecommitdiffstats
path: root/common/thread.c
diff options
context:
space:
mode:
authorGravatar Nikias Bassen2014-03-21 20:41:56 +0100
committerGravatar Nikias Bassen2014-03-21 20:41:56 +0100
commita406cfaa4724b3a78683b732f016c9ad33cad187 (patch)
treeb635afe13c5544e58e5385da448d36a54e1b2d56 /common/thread.c
parent982bc6a5ec6395151501175be2e16d5c056e166d (diff)
downloadlibimobiledevice-a406cfaa4724b3a78683b732f016c9ad33cad187.tar.gz
libimobiledevice-a406cfaa4724b3a78683b732f016c9ad33cad187.tar.bz2
common: add thread_once() implementation
Diffstat (limited to 'common/thread.c')
-rw-r--r--common/thread.c16
1 files changed, 16 insertions, 0 deletions
diff --git a/common/thread.c b/common/thread.c
index 2cf4321..d6d6c1a 100644
--- a/common/thread.c
+++ b/common/thread.c
@@ -81,3 +81,19 @@ void mutex_unlock(mutex_t* mutex)
81 pthread_mutex_unlock(mutex); 81 pthread_mutex_unlock(mutex);
82#endif 82#endif
83} 83}
84
85void thread_once(thread_once_t *once_control, void (*init_routine)(void))
86{
87#ifdef WIN32
88 while (InterlockedExchange(&(once_control->lock), 1) != 0) {
89 Sleep(1);
90 }
91 if (!once_control->state) {
92 once_control->state = 1;
93 init_routine();
94 }
95 InterlockedExchange(&(once_control->lock), 0);
96#else
97 pthread_once(once_control, init_routine);
98#endif
99}