2013-03-04 16:40:31 +01:00
|
|
|
diff -u /src/cpu_detect_x86.cpp /src/cpu_detect_x86.cpp
|
|
|
|
--- /src/cpu_detect_x86.cpp
|
|
|
|
+++ /src/cpu_detect_x86.cpp
|
2014-04-10 10:37:07 +02:00
|
|
|
@@ -44,9 +44,8 @@
|
|
|
|
|
2013-03-04 16:40:31 +01:00
|
|
|
|
|
|
|
#if defined(SOUNDTOUCH_ALLOW_X86_OPTIMIZATIONS)
|
|
|
|
-
|
2014-04-10 10:37:07 +02:00
|
|
|
- #if defined(__GNUC__) && defined(__i386__)
|
|
|
|
- // gcc
|
|
|
|
+ #if defined(__GNUC__) && defined(HAVE_CPUID_H)
|
|
|
|
+ // gcc and clang
|
|
|
|
#include "cpuid.h"
|
|
|
|
#elif defined(_M_IX86)
|
|
|
|
// windows non-gcc
|
|
|
|
@@ -97,18 +96,7 @@
|
2013-03-04 16:40:31 +01:00
|
|
|
|
|
|
|
uint res = 0;
|
|
|
|
|
|
|
|
-#if defined(__GNUC__)
|
|
|
|
- // GCC version of cpuid. Requires GCC 4.3.0 or later for __cpuid intrinsic support.
|
|
|
|
- uint eax, ebx, ecx, edx; // unsigned int is the standard type. uint is defined by the compiler and not guaranteed to be portable.
|
|
|
|
-
|
|
|
|
- // Check if no cpuid support.
|
|
|
|
- if (!__get_cpuid (1, &eax, &ebx, &ecx, &edx)) return 0; // always disable extensions.
|
|
|
|
-
|
|
|
|
- if (edx & bit_MMX) res = res | SUPPORT_MMX;
|
|
|
|
- if (edx & bit_SSE) res = res | SUPPORT_SSE;
|
|
|
|
- if (edx & bit_SSE2) res = res | SUPPORT_SSE2;
|
|
|
|
-
|
|
|
|
-#else
|
|
|
|
+#if !defined(__GNUC__)
|
|
|
|
// Window / VS version of cpuid. Notice that Visual Studio 2005 or later required
|
|
|
|
// for __cpuid intrinsic support.
|
|
|
|
int reg[4] = {-1};
|
2014-04-10 10:37:07 +02:00
|
|
|
@@ -121,7 +109,19 @@
|
2013-03-04 16:40:31 +01:00
|
|
|
if ((unsigned int)reg[3] & bit_MMX) res = res | SUPPORT_MMX;
|
|
|
|
if ((unsigned int)reg[3] & bit_SSE) res = res | SUPPORT_SSE;
|
|
|
|
if ((unsigned int)reg[3] & bit_SSE2) res = res | SUPPORT_SSE2;
|
|
|
|
+#elif defined(HAVE_CPUID_H)
|
|
|
|
+ // GCC version of cpuid. Requires GCC 4.3.0 or later for __cpuid intrinsic support.
|
|
|
|
+ uint eax, ebx, ecx, edx; // unsigned int is the standard type. uint is defined by the compiler and not guaranteed to be portable.
|
|
|
|
+
|
|
|
|
+ // Check if no cpuid support.
|
|
|
|
+ if (!__get_cpuid (1, &eax, &ebx, &ecx, &edx)) return 0; // always disable extensions.
|
|
|
|
|
|
|
|
+ if (edx & bit_MMX) res = res | SUPPORT_MMX;
|
|
|
|
+ if (edx & bit_SSE) res = res | SUPPORT_SSE;
|
|
|
|
+ if (edx & bit_SSE2) res = res | SUPPORT_SSE2;
|
|
|
|
+#else
|
|
|
|
+ // Compatible with GCC but no cpuid.h.
|
|
|
|
+ return 0;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
return res & ~_dwDisabledISA;
|
2014-04-10 10:37:07 +02:00
|
|
|
diff -u /src/STTypes.h /src/STTypes.h
|
|
|
|
--- /src/STTypes.h
|
2012-08-26 22:36:44 -07:00
|
|
|
+++ /src/STTypes.h
|
2014-04-10 10:37:07 +02:00
|
|
|
@@ -54,12 +54,17 @@
|
|
|
|
#define SOUNDTOUCH_ALIGN_POINTER_16(x) ( ( (ulongptr)(x) + 15 ) & ~(ulongptr)15 )
|
|
|
|
|
2012-08-26 22:36:44 -07:00
|
|
|
|
2014-04-10 10:37:07 +02:00
|
|
|
-#if (defined(__GNUC__) && !defined(ANDROID))
|
|
|
|
- // In GCC, include soundtouch_config.h made by config scritps.
|
|
|
|
- // Skip this in Android compilation that uses GCC but without configure scripts.
|
2012-08-26 22:36:44 -07:00
|
|
|
- #include "soundtouch_config.h"
|
|
|
|
-#endif
|
|
|
|
+#include "soundtouch_config.h"
|
|
|
|
|
|
|
|
+#ifdef WIN32
|
2014-03-03 13:25:21 -05:00
|
|
|
+#ifdef BUILDING_SOUNDTOUCH
|
2012-08-26 22:36:44 -07:00
|
|
|
+#define EXPORT __declspec(dllexport)
|
|
|
|
+#else
|
2014-03-03 13:25:21 -05:00
|
|
|
+#define EXPORT __declspec(dllimport)
|
|
|
|
+#endif
|
|
|
|
+#else
|
2012-08-26 22:36:44 -07:00
|
|
|
+#define EXPORT
|
|
|
|
+#endif
|
|
|
|
|
|
|
|
namespace soundtouch
|
|
|
|
{
|
2014-04-10 10:37:07 +02:00
|
|
|
@@ -164,7 +169,7 @@
|
|
|
|
};
|
2012-08-26 22:36:44 -07:00
|
|
|
|
|
|
|
// define ST_NO_EXCEPTION_HANDLING switch to disable throwing std exceptions:
|
|
|
|
-// #define ST_NO_EXCEPTION_HANDLING 1
|
|
|
|
+#define ST_NO_EXCEPTION_HANDLING 1
|
|
|
|
#ifdef ST_NO_EXCEPTION_HANDLING
|
|
|
|
// Exceptions disabled. Throw asserts instead if enabled.
|
|
|
|
#include <assert.h>
|
2014-04-10 10:37:07 +02:00
|
|
|
diff -u /src/SoundTouch.h /src/SoundTouch.h
|
|
|
|
--- /src/SoundTouch.h
|
2012-08-26 22:36:44 -07:00
|
|
|
+++ /src/SoundTouch.h
|
|
|
|
@@ -141,7 +141,7 @@
|
|
|
|
/// tempo/pitch/rate/samplerate settings.
|
|
|
|
#define SETTING_NOMINAL_OUTPUT_SEQUENCE 7
|
|
|
|
|
|
|
|
-class SoundTouch : public FIFOProcessor
|
|
|
|
+class EXPORT SoundTouch : public FIFOProcessor
|
|
|
|
{
|
|
|
|
private:
|
|
|
|
/// Rate transposer class instance
|
2014-04-10 10:37:07 +02:00
|
|
|
diff -u /src/FIRFilter.cpp /src/FIRFilter.cpp
|
2014-03-24 11:02:35 +01:00
|
|
|
--- /src/FIRFilter.cpp
|
|
|
|
+++ /src/FIRFilter.cpp
|
2014-04-10 10:37:07 +02:00
|
|
|
@@ -46,6 +46,11 @@
|
|
|
|
#include "FIRFilter.h"
|
|
|
|
#include "cpu_detect.h"
|
2014-03-24 11:02:35 +01:00
|
|
|
|
2014-04-10 10:37:07 +02:00
|
|
|
+#ifdef _MSC_VER
|
|
|
|
+#include <malloc.h>
|
|
|
|
+#define alloca _alloca
|
|
|
|
+#endif
|
|
|
|
+
|
|
|
|
using namespace soundtouch;
|
|
|
|
|
|
|
|
/*****************************************************************************
|
|
|
|
@@ -291,9 +296,11 @@
|
2014-03-24 11:02:35 +01:00
|
|
|
|
|
|
|
FIRFilter * FIRFilter::newInstance()
|
|
|
|
{
|
|
|
|
+#if defined(SOUNDTOUCH_ALLOW_MMX) || defined(SOUNDTOUCH_ALLOW_SSE)
|
|
|
|
uint uExtensions;
|
|
|
|
|
|
|
|
uExtensions = detectCPUextensions();
|
|
|
|
+#endif
|
|
|
|
|
|
|
|
// Check if MMX/SSE instruction set extensions supported by CPU
|
|
|
|
|
2014-04-10 10:37:07 +02:00
|
|
|
diff -u /src/TDStretch.cpp /src/TDStretch.cpp
|
2014-03-24 11:02:35 +01:00
|
|
|
--- /src/TDStretch.cpp
|
|
|
|
+++ /src/TDStretch.cpp
|
2014-04-10 10:37:07 +02:00
|
|
|
@@ -624,9 +624,11 @@
|
2014-03-24 11:02:35 +01:00
|
|
|
|
|
|
|
TDStretch * TDStretch::newInstance()
|
|
|
|
{
|
|
|
|
+#if defined(SOUNDTOUCH_ALLOW_MMX) || defined(SOUNDTOUCH_ALLOW_SSE)
|
|
|
|
uint uExtensions;
|
|
|
|
|
|
|
|
uExtensions = detectCPUextensions();
|
|
|
|
+#endif
|
|
|
|
|
|
|
|
// Check if MMX/SSE instruction set extensions supported by CPU
|
|
|
|
|
2014-04-10 10:37:07 +02:00
|
|
|
diff -u /src/SoundTouch.cpp /src/SoundTouch.cpp
|
|
|
|
--- /src/SoundTouch.cpp
|
|
|
|
+++ /src/SoundTouch.cpp
|
|
|
|
@@ -80,6 +80,11 @@
|
|
|
|
#include "RateTransposer.h"
|
|
|
|
#include "cpu_detect.h"
|
|
|
|
|
|
|
|
+#ifdef _MSC_VER
|
|
|
|
+#include <malloc.h>
|
|
|
|
+#define alloca _alloca
|
|
|
|
+#endif
|
|
|
|
+
|
|
|
|
using namespace soundtouch;
|
|
|
|
|
|
|
|
/// test if two floating point numbers are equal
|