SDL_intrin.h 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. /*
  2. Simple DirectMedia Layer
  3. Copyright (C) 1997-2023 Sam Lantinga <[email protected]>
  4. This software is provided 'as-is', without any express or implied
  5. warranty. In no event will the authors be held liable for any damages
  6. arising from the use of this software.
  7. Permission is granted to anyone to use this software for any purpose,
  8. including commercial applications, and to alter it and redistribute it
  9. freely, subject to the following restrictions:
  10. 1. The origin of this software must not be misrepresented; you must not
  11. claim that you wrote the original software. If you use this software
  12. in a product, an acknowledgment in the product documentation would be
  13. appreciated but is not required.
  14. 2. Altered source versions must be plainly marked as such, and must not be
  15. misrepresented as being the original software.
  16. 3. This notice may not be removed or altered from any source distribution.
  17. */
  18. /**
  19. * \file SDL_intrin.h
  20. *
  21. * \brief Header file for CPU intrinsics for SDL
  22. */
  23. #ifndef SDL_intrin_h_
  24. #define SDL_intrin_h_
  25. #include <SDL3/SDL_stdinc.h>
  26. /* Need to do this here because intrin.h has C++ code in it */
  27. /* Visual Studio 2005 has a bug where intrin.h conflicts with winnt.h */
  28. #if defined(_MSC_VER) && (_MSC_VER >= 1500) && (defined(_M_IX86) || defined(_M_X64))
  29. #ifdef __clang__
  30. /* As of Clang 11, '_m_prefetchw' is conflicting with the winnt.h's version,
  31. so we define the needed '_m_prefetch' here as a pseudo-header, until the issue is fixed. */
  32. #ifndef __PRFCHWINTRIN_H
  33. #define __PRFCHWINTRIN_H
  34. static __inline__ void __attribute__((__always_inline__, __nodebug__))
  35. _m_prefetch(void *__P)
  36. {
  37. __builtin_prefetch (__P, 0, 3 /* _MM_HINT_T0 */);
  38. }
  39. #endif /* __PRFCHWINTRIN_H */
  40. #endif /* __clang__ */
  41. #include <intrin.h>
  42. #ifndef _WIN64
  43. #ifndef __MMX__
  44. #define __MMX__
  45. #endif
  46. #endif
  47. #ifndef __SSE__
  48. #define __SSE__
  49. #endif
  50. #ifndef __SSE2__
  51. #define __SSE2__
  52. #endif
  53. #ifndef __SSE3__
  54. #define __SSE3__
  55. #endif
  56. #elif defined(__MINGW64_VERSION_MAJOR)
  57. #include <intrin.h>
  58. #if defined(__ARM_NEON) && !defined(SDL_DISABLE_NEON)
  59. # define SDL_NEON_INTRINSICS 1
  60. # include <arm_neon.h>
  61. #endif
  62. #else
  63. /* altivec.h redefining bool causes a number of problems, see bugs 3993 and 4392, so you need to explicitly define SDL_ENABLE_ALTIVEC to have it included. */
  64. #if defined(__ALTIVEC__) && defined(SDL_ENABLE_ALTIVEC)
  65. #define SDL_ALTIVEC_INTRINSICS 1
  66. #include <altivec.h>
  67. #endif
  68. #if !defined(SDL_DISABLE_NEON)
  69. # if defined(__ARM_NEON)
  70. # define SDL_NEON_INTRINSICS 1
  71. # include <arm_neon.h>
  72. # elif defined(__WINDOWS__) || defined(__WINRT__) || defined(__GDK__)
  73. /* Visual Studio doesn't define __ARM_ARCH, but _M_ARM (if set, always 7), and _M_ARM64 (if set, always 1). */
  74. # if defined(_M_ARM)
  75. # define SDL_NEON_INTRINSICS 1
  76. # include <armintr.h>
  77. # include <arm_neon.h>
  78. # define __ARM_NEON 1 /* Set __ARM_NEON so that it can be used elsewhere, at compile time */
  79. # endif
  80. # if defined (_M_ARM64)
  81. # define SDL_NEON_INTRINSICS 1
  82. # include <arm64intr.h>
  83. # include <arm64_neon.h>
  84. # define __ARM_NEON 1 /* Set __ARM_NEON so that it can be used elsewhere, at compile time */
  85. # define __ARM_ARCH 8
  86. # endif
  87. # endif
  88. #endif
  89. #endif /* compiler version */
  90. #if defined(__clang__) && defined(__has_attribute)
  91. # if __has_attribute(target)
  92. # define SDL_HAS_TARGET_ATTRIBS
  93. # endif
  94. #elif defined(__GNUC__) && (__GNUC__ + (__GNUC_MINOR__ >= 9) > 4) /* gcc >= 4.9 */
  95. # define SDL_HAS_TARGET_ATTRIBS
  96. #endif
  97. #ifdef SDL_HAS_TARGET_ATTRIBS
  98. # define SDL_TARGETING(x) __attribute__((target(x)))
  99. #else
  100. # define SDL_TARGETING(x)
  101. #endif
  102. #if defined(__loongarch_sx) && !defined(SDL_DISABLE_LSX)
  103. # define SDL_LSX_INTRINSICS 1
  104. # include <lsxintrin.h>
  105. #endif
  106. #if defined(__loongarch_asx) && !defined(SDL_DISABLE_LASX)
  107. # define SDL_LASX_INTRINSICS 1
  108. # include <lasxintrin.h>
  109. #endif
  110. #if defined(__x86_64__) || defined(_M_X64) || defined(__i386__) || defined(_M_IX86)
  111. # if (defined(__AVX__) || defined(SDL_HAS_TARGET_ATTRIBS)) && !defined(SDL_DISABLE_AVX)
  112. # define SDL_AVX_INTRINSICS
  113. # include <immintrin.h>
  114. # endif
  115. # if (defined(__MMX__) || defined(SDL_HAS_TARGET_ATTRIBS)) && !defined(SDL_DISABLE_MMX)
  116. # define SDL_MMX_INTRINSICS 1
  117. # include <mmintrin.h>
  118. # endif
  119. # if ((defined(_MSC_VER) && defined(_M_IX86) && _M_IX86_FP == 1) || defined(_M_X64) || defined(__SSE__) || defined(SDL_HAS_TARGET_ATTRIBS)) && !defined(SDL_DISABLE_SSE)
  120. /* x86 MSVC defines _M_IX86_FP == 1 when compiled with /arch:SSE */
  121. # define SDL_SSE_INTRINSICS 1
  122. # include <xmmintrin.h>
  123. # endif
  124. # if ((defined(_MSC_VER) && defined(_M_IX86) && _M_IX86_FP >= 1) || defined(_M_X64) || defined(__SSE2__) || defined(SDL_HAS_TARGET_ATTRIBS)) && !defined(SDL_DISABLE_SSE2)
  125. /* x86 MSVC defines _M_IX86_FP == 2 when compiled with /arch:SSE2 */
  126. # define SDL_SSE2_INTRINSICS 1
  127. # include <emmintrin.h>
  128. # endif
  129. # if (defined(_M_X64) || defined(__SSE3__) || defined(SDL_HAS_TARGET_ATTRIBS)) && !defined(SDL_DISABLE_SSE3)
  130. /* x86 MSVC does not provide macro's to detect SSE3/SSE4 */
  131. # define SDL_SSE3_INTRINSICS 1
  132. # include <pmmintrin.h>
  133. # endif
  134. #endif /* defined(__x86_64__) || defined(_M_X64) || defined(__i386__) || defined(_M_IX86) */
  135. #endif /* SDL_intrin_h_ */