]> git.sesse.net Git - ffmpeg/commitdiff
w32pthreads: Load dynamically loaded functions on demand
authorHendrik Leppkes <h.leppkes@gmail.com>
Wed, 7 Oct 2015 13:15:14 +0000 (15:15 +0200)
committerLuca Barbato <lu_zero@gentoo.org>
Wed, 7 Oct 2015 16:45:50 +0000 (18:45 +0200)
This removes the requirement of calling w32thread_init before being
able to use the threading primitives.

Signed-off-by: Luca Barbato <lu_zero@gentoo.org>
compat/w32pthreads.h

index a1cb396d6ec1461509404d71e6f2b277cc89b1dd..ac9a8142f4390972c2ad9ebfd7b6059a8c5e023f 100644 (file)
@@ -160,6 +160,11 @@ static inline void pthread_cond_signal(pthread_cond_t *cond)
 }
 
 #else // _WIN32_WINNT < 0x0600
+
+/* atomic init state of dynamically loaded functions */
+static LONG w32thread_init_state = 0;
+static av_unused void w32thread_init(void);
+
 /* for pre-Windows 6.0 platforms, define INIT_ONCE struct,
  * compatible to the one used in the native API */
 
@@ -200,6 +205,8 @@ static inline void w32thread_once_fallback(LONG volatile *state, void (*init_rou
 
 static av_unused int pthread_once(pthread_once_t *once_control, void (*init_routine)(void))
 {
+    w32thread_once_fallback(&w32thread_init_state, w32thread_init);
+
     /* Use native functions on Windows 6.0+ */
     if (initonce_begin && initonce_complete) {
         BOOL pending = FALSE;
@@ -236,6 +243,9 @@ static BOOL (WINAPI *cond_wait)(pthread_cond_t *cond, pthread_mutex_t *mutex,
 static av_unused void pthread_cond_init(pthread_cond_t *cond, const void *unused_attr)
 {
     win32_cond_t *win32_cond = NULL;
+
+    w32thread_once_fallback(&w32thread_init_state, w32thread_init);
+
     if (cond_init) {
         cond_init(cond);
         return;