mirror of https://github.com/encounter/SDL.git
configure/cmake: Hook up Emscripten threads (disabled by default).
Fixes #3795.
This commit is contained in:
parent
354cabd4a7
commit
a81fe27271
|
@ -153,7 +153,14 @@ else()
|
||||||
set(UNIX_OR_MAC_SYS OFF)
|
set(UNIX_OR_MAC_SYS OFF)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if (UNIX_OR_MAC_SYS AND NOT EMSCRIPTEN) # JavaScript does not yet have threading support, so disable pthreads when building for Emscripten.
|
# Emscripten pthreads work, but you need to have a non-pthread fallback build
|
||||||
|
# for systems without support. It's not currently enough to not use
|
||||||
|
# pthread functions in a pthread-build; it won't start up on unsupported
|
||||||
|
# browsers. As such, you have to explicitly enable it on Emscripten builds
|
||||||
|
# for the time being. This default with change to ON once this becomes
|
||||||
|
# commonly supported in browsers or the Emscripten teams makes a single
|
||||||
|
# binary work everywhere.
|
||||||
|
if (UNIX_OR_MAC_SYS AND NOT EMSCRIPTEN)
|
||||||
set(SDL_PTHREADS_ENABLED_BY_DEFAULT ON)
|
set(SDL_PTHREADS_ENABLED_BY_DEFAULT ON)
|
||||||
else()
|
else()
|
||||||
set(SDL_PTHREADS_ENABLED_BY_DEFAULT OFF)
|
set(SDL_PTHREADS_ENABLED_BY_DEFAULT OFF)
|
||||||
|
@ -289,11 +296,14 @@ set(OPT_DEF_ASM TRUE)
|
||||||
if(EMSCRIPTEN)
|
if(EMSCRIPTEN)
|
||||||
# Set up default values for the currently supported set of subsystems:
|
# Set up default values for the currently supported set of subsystems:
|
||||||
# Emscripten/Javascript does not have assembly support, a dynamic library
|
# Emscripten/Javascript does not have assembly support, a dynamic library
|
||||||
# loading architecture, low-level CPU inspection or multithreading.
|
# loading architecture, or low-level CPU inspection.
|
||||||
|
|
||||||
|
# SDL_THREADS_ENABLED_BY_DEFAULT now defaults to ON, but pthread support might be disabled by default.
|
||||||
|
# !!! FIXME: most of these subsystems should default to ON if there are dummy implementations to be used.
|
||||||
|
|
||||||
set(OPT_DEF_ASM FALSE)
|
set(OPT_DEF_ASM FALSE)
|
||||||
set(SDL_SHARED_ENABLED_BY_DEFAULT OFF)
|
set(SDL_SHARED_ENABLED_BY_DEFAULT OFF)
|
||||||
set(SDL_ATOMIC_ENABLED_BY_DEFAULT OFF)
|
set(SDL_ATOMIC_ENABLED_BY_DEFAULT OFF)
|
||||||
set(SDL_THREADS_ENABLED_BY_DEFAULT OFF)
|
|
||||||
set(SDL_LOADSO_ENABLED_BY_DEFAULT OFF)
|
set(SDL_LOADSO_ENABLED_BY_DEFAULT OFF)
|
||||||
set(SDL_CPUINFO_ENABLED_BY_DEFAULT OFF)
|
set(SDL_CPUINFO_ENABLED_BY_DEFAULT OFF)
|
||||||
set(SDL_DLOPEN_ENABLED_BY_DEFAULT OFF)
|
set(SDL_DLOPEN_ENABLED_BY_DEFAULT OFF)
|
||||||
|
@ -1154,6 +1164,8 @@ elseif(EMSCRIPTEN)
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
CheckPTHREAD()
|
||||||
|
|
||||||
elseif(UNIX AND NOT APPLE AND NOT ANDROID AND NOT RISCOS)
|
elseif(UNIX AND NOT APPLE AND NOT ANDROID AND NOT RISCOS)
|
||||||
if(SDL_AUDIO)
|
if(SDL_AUDIO)
|
||||||
if(SYSV5 OR SOLARIS OR HPUX)
|
if(SYSV5 OR SOLARIS OR HPUX)
|
||||||
|
|
|
@ -919,6 +919,9 @@ macro(CheckPTHREAD)
|
||||||
elseif(HAIKU)
|
elseif(HAIKU)
|
||||||
set(PTHREAD_CFLAGS "-D_REENTRANT")
|
set(PTHREAD_CFLAGS "-D_REENTRANT")
|
||||||
set(PTHREAD_LDFLAGS "")
|
set(PTHREAD_LDFLAGS "")
|
||||||
|
elseif(EMSCRIPTEN)
|
||||||
|
set(PTHREAD_CFLAGS "-D_REENTRANT -pthread")
|
||||||
|
set(PTHREAD_LDFLAGS "-pthread")
|
||||||
else()
|
else()
|
||||||
set(PTHREAD_CFLAGS "-D_REENTRANT")
|
set(PTHREAD_CFLAGS "-D_REENTRANT")
|
||||||
set(PTHREAD_LDFLAGS "-lpthread")
|
set(PTHREAD_LDFLAGS "-lpthread")
|
||||||
|
|
|
@ -771,6 +771,7 @@ infodir
|
||||||
docdir
|
docdir
|
||||||
oldincludedir
|
oldincludedir
|
||||||
includedir
|
includedir
|
||||||
|
runstatedir
|
||||||
localstatedir
|
localstatedir
|
||||||
sharedstatedir
|
sharedstatedir
|
||||||
sysconfdir
|
sysconfdir
|
||||||
|
@ -986,6 +987,7 @@ datadir='${datarootdir}'
|
||||||
sysconfdir='${prefix}/etc'
|
sysconfdir='${prefix}/etc'
|
||||||
sharedstatedir='${prefix}/com'
|
sharedstatedir='${prefix}/com'
|
||||||
localstatedir='${prefix}/var'
|
localstatedir='${prefix}/var'
|
||||||
|
runstatedir='${localstatedir}/run'
|
||||||
includedir='${prefix}/include'
|
includedir='${prefix}/include'
|
||||||
oldincludedir='/usr/include'
|
oldincludedir='/usr/include'
|
||||||
docdir='${datarootdir}/doc/${PACKAGE}'
|
docdir='${datarootdir}/doc/${PACKAGE}'
|
||||||
|
@ -1238,6 +1240,15 @@ do
|
||||||
| -silent | --silent | --silen | --sile | --sil)
|
| -silent | --silent | --silen | --sile | --sil)
|
||||||
silent=yes ;;
|
silent=yes ;;
|
||||||
|
|
||||||
|
-runstatedir | --runstatedir | --runstatedi | --runstated \
|
||||||
|
| --runstate | --runstat | --runsta | --runst | --runs \
|
||||||
|
| --run | --ru | --r)
|
||||||
|
ac_prev=runstatedir ;;
|
||||||
|
-runstatedir=* | --runstatedir=* | --runstatedi=* | --runstated=* \
|
||||||
|
| --runstate=* | --runstat=* | --runsta=* | --runst=* | --runs=* \
|
||||||
|
| --run=* | --ru=* | --r=*)
|
||||||
|
runstatedir=$ac_optarg ;;
|
||||||
|
|
||||||
-sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb)
|
-sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb)
|
||||||
ac_prev=sbindir ;;
|
ac_prev=sbindir ;;
|
||||||
-sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \
|
-sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \
|
||||||
|
@ -1375,7 +1386,7 @@ fi
|
||||||
for ac_var in exec_prefix prefix bindir sbindir libexecdir datarootdir \
|
for ac_var in exec_prefix prefix bindir sbindir libexecdir datarootdir \
|
||||||
datadir sysconfdir sharedstatedir localstatedir includedir \
|
datadir sysconfdir sharedstatedir localstatedir includedir \
|
||||||
oldincludedir docdir infodir htmldir dvidir pdfdir psdir \
|
oldincludedir docdir infodir htmldir dvidir pdfdir psdir \
|
||||||
libdir localedir mandir
|
libdir localedir mandir runstatedir
|
||||||
do
|
do
|
||||||
eval ac_val=\$$ac_var
|
eval ac_val=\$$ac_var
|
||||||
# Remove trailing slashes.
|
# Remove trailing slashes.
|
||||||
|
@ -1528,6 +1539,7 @@ Fine tuning of the installation directories:
|
||||||
--sysconfdir=DIR read-only single-machine data [PREFIX/etc]
|
--sysconfdir=DIR read-only single-machine data [PREFIX/etc]
|
||||||
--sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com]
|
--sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com]
|
||||||
--localstatedir=DIR modifiable single-machine data [PREFIX/var]
|
--localstatedir=DIR modifiable single-machine data [PREFIX/var]
|
||||||
|
--runstatedir=DIR modifiable per-process data [LOCALSTATEDIR/run]
|
||||||
--libdir=DIR object code libraries [EPREFIX/lib]
|
--libdir=DIR object code libraries [EPREFIX/lib]
|
||||||
--includedir=DIR C header files [PREFIX/include]
|
--includedir=DIR C header files [PREFIX/include]
|
||||||
--oldincludedir=DIR C header files for non-gcc [/usr/include]
|
--oldincludedir=DIR C header files for non-gcc [/usr/include]
|
||||||
|
@ -1682,8 +1694,9 @@ Optional Features:
|
||||||
--enable-ibus enable IBus support [default=yes]
|
--enable-ibus enable IBus support [default=yes]
|
||||||
--enable-fcitx enable fcitx support [default=yes]
|
--enable-fcitx enable fcitx support [default=yes]
|
||||||
--enable-joystick-mfi include macOS MFI joystick support [default=yes]
|
--enable-joystick-mfi include macOS MFI joystick support [default=yes]
|
||||||
--enable-pthreads use POSIX threads for multi-threading [default=yes]
|
--enable-pthreads use POSIX threads for multi-threading
|
||||||
--enable-pthread-sem use pthread semaphores [default=yes]
|
[default=maybe]
|
||||||
|
--enable-pthread-sem use pthread semaphores [default=maybe]
|
||||||
--enable-directx use DirectX for Windows audio/video [default=yes]
|
--enable-directx use DirectX for Windows audio/video [default=yes]
|
||||||
--enable-xinput use Xinput for Windows [default=yes]
|
--enable-xinput use Xinput for Windows [default=yes]
|
||||||
--enable-wasapi use the Windows WASAPI audio driver [default=yes]
|
--enable-wasapi use the Windows WASAPI audio driver [default=yes]
|
||||||
|
@ -20257,33 +20270,7 @@ else
|
||||||
$as_echo_n "(cached) " >&6
|
$as_echo_n "(cached) " >&6
|
||||||
else
|
else
|
||||||
# One or both of the vars are not set, and there is no cached value.
|
# One or both of the vars are not set, and there is no cached value.
|
||||||
ac_x_includes=no
|
ac_x_includes=no ac_x_libraries=no
|
||||||
ac_x_libraries=no
|
|
||||||
# Do we need to do anything special at all?
|
|
||||||
ac_save_LIBS=$LIBS
|
|
||||||
LIBS="-lX11 $LIBS"
|
|
||||||
cat confdefs.h - <<_ACEOF >conftest.$ac_ext
|
|
||||||
/* end confdefs.h. */
|
|
||||||
#include <X11/Xlib.h>
|
|
||||||
int
|
|
||||||
main ()
|
|
||||||
{
|
|
||||||
XrmInitialize ()
|
|
||||||
;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
_ACEOF
|
|
||||||
if ac_fn_c_try_link "$LINENO"; then :
|
|
||||||
# We can compile and link X programs with no special options.
|
|
||||||
ac_x_includes=
|
|
||||||
ac_x_libraries=
|
|
||||||
fi
|
|
||||||
rm -f core conftest.err conftest.$ac_objext \
|
|
||||||
conftest$ac_exeext conftest.$ac_ext
|
|
||||||
LIBS="$ac_save_LIBS"
|
|
||||||
# If that didn't work, only try xmkmf and filesystem searches
|
|
||||||
# for native compilation.
|
|
||||||
if test x"$ac_x_includes" = xno && test "$cross_compiling" = no; then :
|
|
||||||
rm -f -r conftest.dir
|
rm -f -r conftest.dir
|
||||||
if mkdir conftest.dir; then
|
if mkdir conftest.dir; then
|
||||||
cd conftest.dir
|
cd conftest.dir
|
||||||
|
@ -20350,8 +20337,6 @@ ac_x_header_dirs='
|
||||||
/usr/local/include/X11R5
|
/usr/local/include/X11R5
|
||||||
/usr/local/include/X11R4
|
/usr/local/include/X11R4
|
||||||
|
|
||||||
/opt/X11/include
|
|
||||||
|
|
||||||
/usr/X386/include
|
/usr/X386/include
|
||||||
/usr/x386/include
|
/usr/x386/include
|
||||||
/usr/XFree86/include/X11
|
/usr/XFree86/include/X11
|
||||||
|
@ -20425,17 +20410,15 @@ rm -f core conftest.err conftest.$ac_objext \
|
||||||
conftest$ac_exeext conftest.$ac_ext
|
conftest$ac_exeext conftest.$ac_ext
|
||||||
fi # $ac_x_libraries = no
|
fi # $ac_x_libraries = no
|
||||||
|
|
||||||
fi
|
|
||||||
# Record the results.
|
|
||||||
case $ac_x_includes,$ac_x_libraries in #(
|
case $ac_x_includes,$ac_x_libraries in #(
|
||||||
no,* | *,no | *\'*) :
|
no,* | *,no | *\'*)
|
||||||
# Didn't find X, or a directory has "'" in its name.
|
# Didn't find X, or a directory has "'" in its name.
|
||||||
ac_cv_have_x="have_x=no";; #(
|
ac_cv_have_x="have_x=no";; #(
|
||||||
*) :
|
*)
|
||||||
# Record where we found X for the cache.
|
# Record where we found X for the cache.
|
||||||
ac_cv_have_x="have_x=yes\
|
ac_cv_have_x="have_x=yes\
|
||||||
ac_x_includes='$ac_x_includes'\
|
ac_x_includes='$ac_x_includes'\
|
||||||
ac_x_libraries='$ac_x_libraries'" ;;
|
ac_x_libraries='$ac_x_libraries'"
|
||||||
esac
|
esac
|
||||||
fi
|
fi
|
||||||
;; #(
|
;; #(
|
||||||
|
@ -23541,18 +23524,37 @@ $as_echo "#define SDL_JOYSTICK_MFI 1" >>confdefs.h
|
||||||
|
|
||||||
CheckPTHREAD()
|
CheckPTHREAD()
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|
||||||
|
case "$host" in
|
||||||
|
*-*-emscripten*)
|
||||||
|
enable_pthreads_default=no
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
enable_pthreads_default=yes
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
# Check whether --enable-pthreads was given.
|
# Check whether --enable-pthreads was given.
|
||||||
if test "${enable_pthreads+set}" = set; then :
|
if test "${enable_pthreads+set}" = set; then :
|
||||||
enableval=$enable_pthreads;
|
enableval=$enable_pthreads;
|
||||||
else
|
else
|
||||||
enable_pthreads=yes
|
enable_pthreads=maybe
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Check whether --enable-pthread-sem was given.
|
# Check whether --enable-pthread-sem was given.
|
||||||
if test "${enable_pthread_sem+set}" = set; then :
|
if test "${enable_pthread_sem+set}" = set; then :
|
||||||
enableval=$enable_pthread_sem;
|
enableval=$enable_pthread_sem;
|
||||||
else
|
else
|
||||||
enable_pthread_sem=yes
|
enable_pthread_sem=maybe
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
if test x$enable_pthreads = xmaybe; then
|
||||||
|
enable_pthreads=$enable_pthreads_default
|
||||||
|
fi
|
||||||
|
if test x$enable_pthread_sem = xmaybe; then
|
||||||
|
enable_pthread_sem=$enable_pthreads
|
||||||
fi
|
fi
|
||||||
|
|
||||||
case "$host" in
|
case "$host" in
|
||||||
|
@ -23620,6 +23622,10 @@ fi
|
||||||
pthread_cflags="-D_REENTRANT"
|
pthread_cflags="-D_REENTRANT"
|
||||||
pthread_lib=""
|
pthread_lib=""
|
||||||
;;
|
;;
|
||||||
|
*-*-emscripten*)
|
||||||
|
pthread_cflags="-D_REENTRANT -pthread"
|
||||||
|
pthread_lib="-pthread"
|
||||||
|
;;
|
||||||
*)
|
*)
|
||||||
pthread_cflags="-D_REENTRANT"
|
pthread_cflags="-D_REENTRANT"
|
||||||
pthread_lib="-lpthread"
|
pthread_lib="-lpthread"
|
||||||
|
@ -25868,6 +25874,7 @@ $as_echo "#define SDL_AUDIO_DRIVER_EMSCRIPTEN 1" >>confdefs.h
|
||||||
CheckDummyVideo
|
CheckDummyVideo
|
||||||
CheckDiskAudio
|
CheckDiskAudio
|
||||||
CheckDummyAudio
|
CheckDummyAudio
|
||||||
|
CheckPTHREAD
|
||||||
CheckDLOPEN
|
CheckDLOPEN
|
||||||
CheckClockGettime
|
CheckClockGettime
|
||||||
CheckEmscriptenGLES
|
CheckEmscriptenGLES
|
||||||
|
|
39
configure.ac
39
configure.ac
|
@ -2941,13 +2941,39 @@ dnl See what type of thread model to use on Linux and Solaris
|
||||||
CheckPTHREAD()
|
CheckPTHREAD()
|
||||||
{
|
{
|
||||||
dnl Check for pthread support
|
dnl Check for pthread support
|
||||||
|
|
||||||
|
dnl Emscripten pthreads work, but you need to have a non-pthread fallback build
|
||||||
|
dnl for systems without support. It's not currently enough to not use
|
||||||
|
dnl pthread functions in a pthread-build; it won't start up on unsupported
|
||||||
|
dnl browsers. As such, you have to explicitly enable it on Emscripten builds
|
||||||
|
dnl for the time being. This default with change to ON once this becomes
|
||||||
|
dnl commonly supported in browsers or the Emscripten teams makes a single
|
||||||
|
dnl binary work everywhere.
|
||||||
|
|
||||||
|
case "$host" in
|
||||||
|
*-*-emscripten*)
|
||||||
|
enable_pthreads_default=no
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
enable_pthreads_default=yes
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
AC_ARG_ENABLE(pthreads,
|
AC_ARG_ENABLE(pthreads,
|
||||||
[AS_HELP_STRING([--enable-pthreads], [use POSIX threads for multi-threading [default=yes]])],
|
[AS_HELP_STRING([--enable-pthreads], [use POSIX threads for multi-threading [default=maybe]])],
|
||||||
, enable_pthreads=yes)
|
, enable_pthreads=maybe)
|
||||||
dnl This is used on Linux for glibc binary compatibility (Doh!)
|
dnl This is used on Linux for glibc binary compatibility (Doh!)
|
||||||
AC_ARG_ENABLE(pthread-sem,
|
AC_ARG_ENABLE(pthread-sem,
|
||||||
[AS_HELP_STRING([--enable-pthread-sem], [use pthread semaphores [default=yes]])],
|
[AS_HELP_STRING([--enable-pthread-sem], [use pthread semaphores [default=maybe]])],
|
||||||
, enable_pthread_sem=yes)
|
, enable_pthread_sem=maybe)
|
||||||
|
|
||||||
|
if test x$enable_pthreads = xmaybe; then
|
||||||
|
enable_pthreads=$enable_pthreads_default
|
||||||
|
fi
|
||||||
|
if test x$enable_pthread_sem = xmaybe; then
|
||||||
|
enable_pthread_sem=$enable_pthreads
|
||||||
|
fi
|
||||||
|
|
||||||
case "$host" in
|
case "$host" in
|
||||||
*-*-android*)
|
*-*-android*)
|
||||||
pthread_cflags="-D_REENTRANT -D_THREAD_SAFE"
|
pthread_cflags="-D_REENTRANT -D_THREAD_SAFE"
|
||||||
|
@ -3013,6 +3039,10 @@ CheckPTHREAD()
|
||||||
pthread_cflags="-D_REENTRANT"
|
pthread_cflags="-D_REENTRANT"
|
||||||
pthread_lib=""
|
pthread_lib=""
|
||||||
;;
|
;;
|
||||||
|
*-*-emscripten*)
|
||||||
|
pthread_cflags="-D_REENTRANT -pthread"
|
||||||
|
pthread_lib="-pthread"
|
||||||
|
;;
|
||||||
*)
|
*)
|
||||||
pthread_cflags="-D_REENTRANT"
|
pthread_cflags="-D_REENTRANT"
|
||||||
pthread_lib="-lpthread"
|
pthread_lib="-lpthread"
|
||||||
|
@ -4302,6 +4332,7 @@ case "$host" in
|
||||||
CheckDummyVideo
|
CheckDummyVideo
|
||||||
CheckDiskAudio
|
CheckDiskAudio
|
||||||
CheckDummyAudio
|
CheckDummyAudio
|
||||||
|
CheckPTHREAD
|
||||||
CheckDLOPEN
|
CheckDLOPEN
|
||||||
CheckClockGettime
|
CheckClockGettime
|
||||||
CheckEmscriptenGLES
|
CheckEmscriptenGLES
|
||||||
|
|
Loading…
Reference in New Issue