From 4622f11f9c83db8a2e08408c71ff901826ca652c Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Rafa=C3=ABl=20Carr=C3=A9?= <funman@videolan.org>
Date: Tue, 20 Aug 2013 19:25:22 +0200
Subject: [PATCH] w32pthread: help compiler figure out undeeded code
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

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@martin.st>
---
 compat/w32pthreads.h | 10 +++++-----
 1 file changed, 5 insertions(+), 5 deletions(-)

diff --git a/compat/w32pthreads.h b/compat/w32pthreads.h
index 8b7ff6ba7aa..f5708018328 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;
     }
-- 
GitLab