]> git.sesse.net Git - ffmpeg/commitdiff
os2threads: Add pthread_once()
authorKO Myung-Hun <komh78@gmail.com>
Thu, 12 Nov 2015 03:31:51 +0000 (12:31 +0900)
committerMichael Niedermayer <michael@niedermayer.cc>
Thu, 12 Nov 2015 21:31:46 +0000 (22:31 +0100)
Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
compat/os2threads.h

index 5b6ca5579df3bc51d546c993bd452efb771a7c9e..f8fb2c8c6372b9ff3ca1cc1c50787c8b918297d0 100644 (file)
@@ -32,6 +32,8 @@
 #undef __STRICT_ANSI__          /* for _beginthread() */
 #include <stdlib.h>
 
+#include <sys/fmutex.h>
+
 #include "libavutil/mem.h"
 
 typedef TID  pthread_t;
@@ -47,6 +49,13 @@ typedef struct {
 
 typedef void pthread_condattr_t;
 
+typedef struct {
+    volatile int done;
+    _fmutex mtx;
+} pthread_once_t;
+
+#define PTHREAD_ONCE_INIT {0, _FMUTEX_INITIALIZER}
+
 struct thread_arg {
     void *(*start_routine)(void *);
     void *arg;
@@ -163,4 +172,22 @@ static av_always_inline int pthread_cond_wait(pthread_cond_t *cond, pthread_mute
     return 0;
 }
 
+static av_always_inline int pthread_once(pthread_once_t *once_control, void (*init_routine)(void))
+{
+    if (!once_control->done)
+    {
+        _fmutex_request(&once_control->mtx, 0);
+
+        if (!once_control->done)
+        {
+            init_routine();
+
+            once_control->done = 1;
+        }
+
+        _fmutex_release(&once_control->mtx);
+    }
+
+    return 0;
+}
 #endif /* AVCODEC_OS2PTHREADS_H */