Check for sem_timedwait(), which isn't available on some systems (including OpenBSD
This commit is contained in:
parent
9033bb050f
commit
6654546b2a
4 changed files with 90 additions and 0 deletions
61
configure
vendored
61
configure
vendored
|
@ -24485,6 +24485,67 @@ rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext
|
||||||
{ echo "$as_me:$LINENO: result: $have_pthread_sem" >&5
|
{ echo "$as_me:$LINENO: result: $have_pthread_sem" >&5
|
||||||
echo "${ECHO_T}$have_pthread_sem" >&6; }
|
echo "${ECHO_T}$have_pthread_sem" >&6; }
|
||||||
fi
|
fi
|
||||||
|
if test x$have_pthread_sem = xyes; then
|
||||||
|
{ echo "$as_me:$LINENO: checking for sem_timedwait" >&5
|
||||||
|
echo $ECHO_N "checking for sem_timedwait... $ECHO_C" >&6; }
|
||||||
|
have_sem_timedwait=no
|
||||||
|
cat >conftest.$ac_ext <<_ACEOF
|
||||||
|
/* confdefs.h. */
|
||||||
|
_ACEOF
|
||||||
|
cat confdefs.h >>conftest.$ac_ext
|
||||||
|
cat >>conftest.$ac_ext <<_ACEOF
|
||||||
|
/* end confdefs.h. */
|
||||||
|
|
||||||
|
#include <pthread.h>
|
||||||
|
#include <semaphore.h>
|
||||||
|
|
||||||
|
int
|
||||||
|
main ()
|
||||||
|
{
|
||||||
|
|
||||||
|
sem_timedwait(NULL, NULL);
|
||||||
|
|
||||||
|
;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
_ACEOF
|
||||||
|
rm -f conftest.$ac_objext conftest$ac_exeext
|
||||||
|
if { (ac_try="$ac_link"
|
||||||
|
case "(($ac_try" in
|
||||||
|
*\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
|
||||||
|
*) ac_try_echo=$ac_try;;
|
||||||
|
esac
|
||||||
|
eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5
|
||||||
|
(eval "$ac_link") 2>conftest.er1
|
||||||
|
ac_status=$?
|
||||||
|
grep -v '^ *+' conftest.er1 >conftest.err
|
||||||
|
rm -f conftest.er1
|
||||||
|
cat conftest.err >&5
|
||||||
|
echo "$as_me:$LINENO: \$? = $ac_status" >&5
|
||||||
|
(exit $ac_status); } && {
|
||||||
|
test -z "$ac_c_werror_flag" ||
|
||||||
|
test ! -s conftest.err
|
||||||
|
} && test -s conftest$ac_exeext &&
|
||||||
|
$as_test_x conftest$ac_exeext; then
|
||||||
|
|
||||||
|
have_sem_timedwait=yes
|
||||||
|
cat >>confdefs.h <<\_ACEOF
|
||||||
|
#define HAVE_SEM_TIMEDWAIT 1
|
||||||
|
_ACEOF
|
||||||
|
|
||||||
|
|
||||||
|
else
|
||||||
|
echo "$as_me: failed program was:" >&5
|
||||||
|
sed 's/^/| /' conftest.$ac_ext >&5
|
||||||
|
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
|
||||||
|
conftest$ac_exeext conftest.$ac_ext
|
||||||
|
{ echo "$as_me:$LINENO: result: $have_sem_timedwait" >&5
|
||||||
|
echo "${ECHO_T}$have_sem_timedwait" >&6; }
|
||||||
|
fi
|
||||||
|
|
||||||
{ echo "$as_me:$LINENO: checking for pthread_spin_trylock" >&5
|
{ echo "$as_me:$LINENO: checking for pthread_spin_trylock" >&5
|
||||||
echo $ECHO_N "checking for pthread_spin_trylock... $ECHO_C" >&6; }
|
echo $ECHO_N "checking for pthread_spin_trylock... $ECHO_C" >&6; }
|
||||||
|
|
14
configure.in
14
configure.in
|
@ -1742,6 +1742,20 @@ AC_HELP_STRING([--enable-pthread-sem], [use pthread semaphores [[default=yes]]])
|
||||||
])
|
])
|
||||||
AC_MSG_RESULT($have_pthread_sem)
|
AC_MSG_RESULT($have_pthread_sem)
|
||||||
fi
|
fi
|
||||||
|
if test x$have_pthread_sem = xyes; then
|
||||||
|
AC_MSG_CHECKING(for sem_timedwait)
|
||||||
|
have_sem_timedwait=no
|
||||||
|
AC_TRY_LINK([
|
||||||
|
#include <pthread.h>
|
||||||
|
#include <semaphore.h>
|
||||||
|
],[
|
||||||
|
sem_timedwait(NULL, NULL);
|
||||||
|
],[
|
||||||
|
have_sem_timedwait=yes
|
||||||
|
AC_DEFINE(HAVE_SEM_TIMEDWAIT)
|
||||||
|
])
|
||||||
|
AC_MSG_RESULT($have_sem_timedwait)
|
||||||
|
fi
|
||||||
|
|
||||||
AC_MSG_CHECKING(for pthread_spin_trylock)
|
AC_MSG_CHECKING(for pthread_spin_trylock)
|
||||||
AC_TRY_LINK_FUNC(pthread_spin_trylock, [
|
AC_TRY_LINK_FUNC(pthread_spin_trylock, [
|
||||||
|
|
|
@ -151,6 +151,7 @@
|
||||||
#undef HAVE_ICONV
|
#undef HAVE_ICONV
|
||||||
#undef HAVE_PTHREAD_SETNAME_NP
|
#undef HAVE_PTHREAD_SETNAME_NP
|
||||||
#undef HAVE_PTHREAD_SET_NAME_NP
|
#undef HAVE_PTHREAD_SET_NAME_NP
|
||||||
|
#undef HAVE_SEM_TIMEDWAIT
|
||||||
|
|
||||||
#else
|
#else
|
||||||
/* We may need some replacement for stdarg.h here */
|
/* We may need some replacement for stdarg.h here */
|
||||||
|
|
|
@ -103,8 +103,12 @@ int
|
||||||
SDL_SemWaitTimeout(SDL_sem * sem, Uint32 timeout)
|
SDL_SemWaitTimeout(SDL_sem * sem, Uint32 timeout)
|
||||||
{
|
{
|
||||||
int retval;
|
int retval;
|
||||||
|
#ifdef HAVE_SEM_TIMEDWAIT
|
||||||
struct timeval now;
|
struct timeval now;
|
||||||
struct timespec ts_timeout;
|
struct timespec ts_timeout;
|
||||||
|
#else
|
||||||
|
Uint32 end;
|
||||||
|
#endif
|
||||||
|
|
||||||
if (!sem) {
|
if (!sem) {
|
||||||
SDL_SetError("Passed a NULL semaphore");
|
SDL_SetError("Passed a NULL semaphore");
|
||||||
|
@ -119,6 +123,7 @@ SDL_SemWaitTimeout(SDL_sem * sem, Uint32 timeout)
|
||||||
return SDL_SemWait(sem);
|
return SDL_SemWait(sem);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef HAVE_SEM_TIMEDWAIT
|
||||||
/* Setup the timeout. sem_timedwait doesn't wait for
|
/* Setup the timeout. sem_timedwait doesn't wait for
|
||||||
* a lapse of time, but until we reach a certain time.
|
* a lapse of time, but until we reach a certain time.
|
||||||
* This time is now plus the timeout.
|
* This time is now plus the timeout.
|
||||||
|
@ -147,6 +152,15 @@ SDL_SemWaitTimeout(SDL_sem * sem, Uint32 timeout)
|
||||||
if (retval < 0) {
|
if (retval < 0) {
|
||||||
SDL_SetError("sem_timedwait() failed");
|
SDL_SetError("sem_timedwait() failed");
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
end = SDL_GetTicks() + timeout;
|
||||||
|
while ((retval = SDL_SemTryWait(sem)) == SDL_MUTEX_TIMEDOUT) {
|
||||||
|
if ((SDL_GetTicks() - end) >= 0) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
SDL_Delay(0);
|
||||||
|
}
|
||||||
|
#endif /* HAVE_SEM_TIMEDWAIT */
|
||||||
|
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue