mirror of
https://github.com/Relintai/sdl2_frt.git
synced 2025-01-22 01:57:18 +01:00
audio: Wired up new SSE code to build system.
This commit is contained in:
parent
202ab30c16
commit
3594bf8eeb
@ -262,6 +262,7 @@ set_option(MMX "Use MMX assembly routines" ${OPT_DEF_ASM})
|
|||||||
set_option(3DNOW "Use 3Dnow! MMX assembly routines" ${OPT_DEF_ASM})
|
set_option(3DNOW "Use 3Dnow! MMX assembly routines" ${OPT_DEF_ASM})
|
||||||
set_option(SSE "Use SSE assembly routines" ${OPT_DEF_ASM})
|
set_option(SSE "Use SSE assembly routines" ${OPT_DEF_ASM})
|
||||||
set_option(SSE2 "Use SSE2 assembly routines" ${OPT_DEF_SSEMATH})
|
set_option(SSE2 "Use SSE2 assembly routines" ${OPT_DEF_SSEMATH})
|
||||||
|
set_option(SSE3 "Use SSE3 assembly routines" ${OPT_DEF_SSEMATH})
|
||||||
set_option(ALTIVEC "Use Altivec assembly routines" ${OPT_DEF_ASM})
|
set_option(ALTIVEC "Use Altivec assembly routines" ${OPT_DEF_ASM})
|
||||||
set_option(DISKAUDIO "Support the disk writer audio driver" ON)
|
set_option(DISKAUDIO "Support the disk writer audio driver" ON)
|
||||||
set_option(DUMMYAUDIO "Support the dummy audio driver" ON)
|
set_option(DUMMYAUDIO "Support the dummy audio driver" ON)
|
||||||
@ -516,8 +517,31 @@ if(ASSEMBLY)
|
|||||||
set(CMAKE_REQUIRED_FLAGS ${ORIG_CMAKE_REQUIRED_FLAGS})
|
set(CMAKE_REQUIRED_FLAGS ${ORIG_CMAKE_REQUIRED_FLAGS})
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if(SSE3)
|
||||||
|
set(CMAKE_REQUIRED_FLAGS "-msse3")
|
||||||
|
check_c_source_compiles("
|
||||||
|
#ifdef __MINGW32__
|
||||||
|
#include <_mingw.h>
|
||||||
|
#ifdef __MINGW64_VERSION_MAJOR
|
||||||
|
#include <intrin.h>
|
||||||
|
#else
|
||||||
|
#include <pmmintrin.h>
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
#include <pmmintrin.h>
|
||||||
|
#endif
|
||||||
|
#ifndef __SSE3__
|
||||||
|
#error Assembler CPP flag not enabled
|
||||||
|
#endif
|
||||||
|
int main(int argc, char **argv) { }" HAVE_SSE3)
|
||||||
|
if(HAVE_SSE3)
|
||||||
|
list(APPEND EXTRA_CFLAGS "-msse3")
|
||||||
|
endif()
|
||||||
|
set(CMAKE_REQUIRED_FLAGS ${ORIG_CMAKE_REQUIRED_FLAGS})
|
||||||
|
endif()
|
||||||
|
|
||||||
if(SSEMATH)
|
if(SSEMATH)
|
||||||
if(SSE OR SSE2)
|
if(SSE OR SSE2 OR SSE3)
|
||||||
if(USE_GCC)
|
if(USE_GCC)
|
||||||
list(APPEND EXTRA_CFLAGS "-mfpmath=387")
|
list(APPEND EXTRA_CFLAGS "-mfpmath=387")
|
||||||
endif()
|
endif()
|
||||||
@ -557,12 +581,13 @@ if(ASSEMBLY)
|
|||||||
endif()
|
endif()
|
||||||
set(HAVE_SSE TRUE)
|
set(HAVE_SSE TRUE)
|
||||||
set(HAVE_SSE2 TRUE)
|
set(HAVE_SSE2 TRUE)
|
||||||
|
set(HAVE_SSE3 TRUE)
|
||||||
set(SDL_ASSEMBLY_ROUTINES 1)
|
set(SDL_ASSEMBLY_ROUTINES 1)
|
||||||
endif()
|
endif()
|
||||||
# TODO:
|
# TODO:
|
||||||
#else()
|
#else()
|
||||||
# if(USE_GCC OR USE_CLANG)
|
# if(USE_GCC OR USE_CLANG)
|
||||||
# list(APPEND EXTRA_CFLAGS "-mno-sse" "-mno-sse2" "-mno-mmx")
|
# list(APPEND EXTRA_CFLAGS "-mno-sse" "-mno-sse2" "-mno-sse3" "-mno-mmx")
|
||||||
# endif()
|
# endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
61
configure
vendored
61
configure
vendored
@ -798,6 +798,7 @@ enable_mmx
|
|||||||
enable_3dnow
|
enable_3dnow
|
||||||
enable_sse
|
enable_sse
|
||||||
enable_sse2
|
enable_sse2
|
||||||
|
enable_sse3
|
||||||
enable_altivec
|
enable_altivec
|
||||||
enable_oss
|
enable_oss
|
||||||
enable_alsa
|
enable_alsa
|
||||||
@ -1527,7 +1528,8 @@ Optional Features:
|
|||||||
--enable-mmx use MMX assembly routines [[default=yes]]
|
--enable-mmx use MMX assembly routines [[default=yes]]
|
||||||
--enable-3dnow use 3DNow! assembly routines [[default=yes]]
|
--enable-3dnow use 3DNow! assembly routines [[default=yes]]
|
||||||
--enable-sse use SSE assembly routines [[default=yes]]
|
--enable-sse use SSE assembly routines [[default=yes]]
|
||||||
--enable-sse2 use SSE2 assembly routines [[default=no]]
|
--enable-sse2 use SSE2 assembly routines [[default=maybe]]
|
||||||
|
--enable-sse3 use SSE3 assembly routines [[default=maybe]]
|
||||||
--enable-altivec use Altivec assembly routines [[default=yes]]
|
--enable-altivec use Altivec assembly routines [[default=yes]]
|
||||||
--enable-oss support the OSS audio API [[default=maybe]]
|
--enable-oss support the OSS audio API [[default=maybe]]
|
||||||
--enable-alsa support the ALSA audio API [[default=yes]]
|
--enable-alsa support the ALSA audio API [[default=yes]]
|
||||||
@ -17308,6 +17310,63 @@ $as_echo "$have_gcc_sse2" >&6; }
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Check whether --enable-sse3 was given.
|
||||||
|
if test "${enable_sse3+set}" = set; then :
|
||||||
|
enableval=$enable_sse3;
|
||||||
|
else
|
||||||
|
enable_sse3=$default_ssemath
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test x$enable_sse3 = xyes; then
|
||||||
|
save_CFLAGS="$CFLAGS"
|
||||||
|
have_gcc_sse3=no
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for GCC -msse3 option" >&5
|
||||||
|
$as_echo_n "checking for GCC -msse3 option... " >&6; }
|
||||||
|
sse3_CFLAGS="-msse3"
|
||||||
|
CFLAGS="$save_CFLAGS $sse3_CFLAGS"
|
||||||
|
|
||||||
|
cat confdefs.h - <<_ACEOF >conftest.$ac_ext
|
||||||
|
/* end confdefs.h. */
|
||||||
|
|
||||||
|
#ifdef __MINGW32__
|
||||||
|
#include <_mingw.h>
|
||||||
|
#ifdef __MINGW64_VERSION_MAJOR
|
||||||
|
#include <intrin.h>
|
||||||
|
#else
|
||||||
|
#include <pmmintrin.h>
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
#include <pmmintrin.h>
|
||||||
|
#endif
|
||||||
|
#ifndef __SSE2__
|
||||||
|
#error Assembler CPP flag not enabled
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int
|
||||||
|
main ()
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
_ACEOF
|
||||||
|
if ac_fn_c_try_compile "$LINENO"; then :
|
||||||
|
|
||||||
|
have_gcc_sse3=yes
|
||||||
|
|
||||||
|
fi
|
||||||
|
rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $have_gcc_sse3" >&5
|
||||||
|
$as_echo "$have_gcc_sse3" >&6; }
|
||||||
|
CFLAGS="$save_CFLAGS"
|
||||||
|
|
||||||
|
if test x$have_gcc_sse3 = xyes; then
|
||||||
|
EXTRA_CFLAGS="$EXTRA_CFLAGS $sse3_CFLAGS"
|
||||||
|
SUMMARY_math="${SUMMARY_math} sse3"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
# Check whether --enable-altivec was given.
|
# Check whether --enable-altivec was given.
|
||||||
if test "${enable_altivec+set}" = set; then :
|
if test "${enable_altivec+set}" = set; then :
|
||||||
enableval=$enable_altivec;
|
enableval=$enable_altivec;
|
||||||
|
39
configure.in
39
configure.in
@ -593,7 +593,7 @@ AC_HELP_STRING([--enable-sse], [use SSE assembly routines [[default=yes]]]),
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
AC_ARG_ENABLE(sse2,
|
AC_ARG_ENABLE(sse2,
|
||||||
AC_HELP_STRING([--enable-sse2], [use SSE2 assembly routines [[default=no]]]),
|
AC_HELP_STRING([--enable-sse2], [use SSE2 assembly routines [[default=maybe]]]),
|
||||||
, enable_sse2=$default_ssemath)
|
, enable_sse2=$default_ssemath)
|
||||||
if test x$enable_sse2 = xyes; then
|
if test x$enable_sse2 = xyes; then
|
||||||
save_CFLAGS="$CFLAGS"
|
save_CFLAGS="$CFLAGS"
|
||||||
@ -629,6 +629,43 @@ AC_HELP_STRING([--enable-sse2], [use SSE2 assembly routines [[default=no]]]),
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
AC_ARG_ENABLE(sse3,
|
||||||
|
AC_HELP_STRING([--enable-sse3], [use SSE3 assembly routines [[default=maybe]]]),
|
||||||
|
, enable_sse3=$default_ssemath)
|
||||||
|
if test x$enable_sse3 = xyes; then
|
||||||
|
save_CFLAGS="$CFLAGS"
|
||||||
|
have_gcc_sse3=no
|
||||||
|
AC_MSG_CHECKING(for GCC -msse3 option)
|
||||||
|
sse3_CFLAGS="-msse3"
|
||||||
|
CFLAGS="$save_CFLAGS $sse3_CFLAGS"
|
||||||
|
|
||||||
|
AC_TRY_COMPILE([
|
||||||
|
#ifdef __MINGW32__
|
||||||
|
#include <_mingw.h>
|
||||||
|
#ifdef __MINGW64_VERSION_MAJOR
|
||||||
|
#include <intrin.h>
|
||||||
|
#else
|
||||||
|
#include <pmmintrin.h>
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
#include <pmmintrin.h>
|
||||||
|
#endif
|
||||||
|
#ifndef __SSE2__
|
||||||
|
#error Assembler CPP flag not enabled
|
||||||
|
#endif
|
||||||
|
],[
|
||||||
|
],[
|
||||||
|
have_gcc_sse3=yes
|
||||||
|
])
|
||||||
|
AC_MSG_RESULT($have_gcc_sse3)
|
||||||
|
CFLAGS="$save_CFLAGS"
|
||||||
|
|
||||||
|
if test x$have_gcc_sse3 = xyes; then
|
||||||
|
EXTRA_CFLAGS="$EXTRA_CFLAGS $sse3_CFLAGS"
|
||||||
|
SUMMARY_math="${SUMMARY_math} sse3"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
AC_ARG_ENABLE(altivec,
|
AC_ARG_ENABLE(altivec,
|
||||||
AC_HELP_STRING([--enable-altivec], [use Altivec assembly routines [[default=yes]]]),
|
AC_HELP_STRING([--enable-altivec], [use Altivec assembly routines [[default=yes]]]),
|
||||||
, enable_altivec=yes)
|
, enable_altivec=yes)
|
||||||
|
@ -61,6 +61,9 @@
|
|||||||
#ifdef __SSE2__
|
#ifdef __SSE2__
|
||||||
#include <emmintrin.h>
|
#include <emmintrin.h>
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef __SSE3__
|
||||||
|
#include <pmmintrin.h>
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "begin_code.h"
|
#include "begin_code.h"
|
||||||
|
@ -28,13 +28,10 @@
|
|||||||
#include "SDL_loadso.h"
|
#include "SDL_loadso.h"
|
||||||
#include "SDL_assert.h"
|
#include "SDL_assert.h"
|
||||||
#include "../SDL_dataqueue.h"
|
#include "../SDL_dataqueue.h"
|
||||||
|
|
||||||
/* !!! FIXME: wire this up to the configure script, etc. */
|
|
||||||
#include "SDL_cpuinfo.h"
|
#include "SDL_cpuinfo.h"
|
||||||
#define HAVE_SSE3_INTRINSICS 0
|
|
||||||
|
|
||||||
#if HAVE_SSE3_INTRINSICS
|
#ifdef __SSE3__
|
||||||
#include <pmmintrin.h>
|
#define HAVE_SSE3_INTRINSICS 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if HAVE_SSE3_INTRINSICS
|
#if HAVE_SSE3_INTRINSICS
|
||||||
|
@ -28,11 +28,8 @@
|
|||||||
/* !!! FIXME: write NEON code. */
|
/* !!! FIXME: write NEON code. */
|
||||||
#define HAVE_NEON_INTRINSICS 0
|
#define HAVE_NEON_INTRINSICS 0
|
||||||
|
|
||||||
/* !!! FIXME: wire this up to the configure script, etc. */
|
#ifdef __SSE2__
|
||||||
#define HAVE_SSE2_INTRINSICS 0
|
#define HAVE_SSE2_INTRINSICS 1
|
||||||
|
|
||||||
#if HAVE_SSE2_INTRINSICS
|
|
||||||
#include <emmintrin.h>
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(__x86_64__) && HAVE_SSE2_INTRINSICS
|
#if defined(__x86_64__) && HAVE_SSE2_INTRINSICS
|
||||||
|
Loading…
Reference in New Issue
Block a user