[FFmpeg-cvslog] w32pthread: help compiler figure out undeeded code

Rafaël Carré git at videolan.org
Thu Aug 22 13:14:16 CEST 2013


ffmpeg | branch: master | Rafaël Carré <funman at videolan.org> | Tue Aug 20 19:25:22 2013 +0200| [4622f11f9c83db8a2e08408c71ff901826ca652c] | committer: Martin Storsjö

w32pthread: help compiler figure out undeeded code

The emulation code is not needed when targetting Vista+
This helps getting rid of CreateSemaphore symbol, which is
forbidden in Windows Store apps.

Signed-off-by: Martin Storsjö <martin at martin.st>

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=4622f11f9c83db8a2e08408c71ff901826ca652c
---

 compat/w32pthreads.h |   10 +++++-----
 1 file changed, 5 insertions(+), 5 deletions(-)

diff --git a/compat/w32pthreads.h b/compat/w32pthreads.h
index 8b7ff6b..f570801 100644
--- a/compat/w32pthreads.h
+++ b/compat/w32pthreads.h
@@ -129,7 +129,7 @@ typedef struct  win32_cond_t {
 static void pthread_cond_init(pthread_cond_t *cond, const void *unused_attr)
 {
     win32_cond_t *win32_cond = NULL;
-    if (cond_init) {
+    if (_WIN32_WINNT >= 0x0600 || cond_init) {
         cond_init(cond);
         return;
     }
@@ -154,7 +154,7 @@ static void pthread_cond_destroy(pthread_cond_t *cond)
 {
     win32_cond_t *win32_cond = cond->ptr;
     /* native condition variables do not destroy */
-    if (cond_init)
+    if (_WIN32_WINNT >= 0x0600 || cond_init)
         return;
 
     /* non native condition variables */
@@ -171,7 +171,7 @@ static void pthread_cond_broadcast(pthread_cond_t *cond)
     win32_cond_t *win32_cond = cond->ptr;
     int have_waiter;
 
-    if (cond_broadcast) {
+    if (_WIN32_WINNT >= 0x0600 || cond_broadcast) {
         cond_broadcast(cond);
         return;
     }
@@ -201,7 +201,7 @@ static int pthread_cond_wait(pthread_cond_t *cond, pthread_mutex_t *mutex)
 {
     win32_cond_t *win32_cond = cond->ptr;
     int last_waiter;
-    if (cond_wait) {
+    if (_WIN32_WINNT >= 0x0600 || cond_wait) {
         cond_wait(cond, mutex, INFINITE);
         return 0;
     }
@@ -233,7 +233,7 @@ static void pthread_cond_signal(pthread_cond_t *cond)
 {
     win32_cond_t *win32_cond = cond->ptr;
     int have_waiter;
-    if (cond_signal) {
+    if (_WIN32_WINNT >= 0x0600 || cond_signal) {
         cond_signal(cond);
         return;
     }



More information about the ffmpeg-cvslog mailing list