capabilities.h 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. /* Copyright (C) 2017 Povilas Kanapickas <[email protected]>
  2. Distributed under the Boost Software License, Version 1.0.
  3. (See accompanying file LICENSE_1_0.txt or copy at
  4. http://www.boost.org/LICENSE_1_0.txt)
  5. */
  6. #ifndef LIBSIMDPP_SIMD_CAPABILITIES_H
  7. #define LIBSIMDPP_SIMD_CAPABILITIES_H
  8. #ifndef LIBSIMDPP_SIMD_H
  9. #error "This file must be included through simd.h"
  10. #endif
  11. #include <simdpp/setup_arch.h>
  12. #if SIMDPP_USE_SSE2 || SIMDPP_USE_NEON || SIMDPP_USE_ALTIVEC || SIMDPP_USE_MSA
  13. #define SIMDPP_HAS_INT8_SIMD 1
  14. #define SIMDPP_HAS_INT16_SIMD 1
  15. #define SIMDPP_HAS_INT32_SIMD 1
  16. #else
  17. #define SIMDPP_HAS_INT8_SIMD 0
  18. #define SIMDPP_HAS_INT16_SIMD 0
  19. #define SIMDPP_HAS_INT32_SIMD 0
  20. #endif
  21. #if SIMDPP_USE_SSE2 || SIMDPP_USE_NEON || SIMDPP_USE_VSX_207 || SIMDPP_USE_MSA
  22. #define SIMDPP_HAS_INT64_SIMD 1
  23. #else
  24. #define SIMDPP_HAS_INT64_SIMD 0
  25. #endif
  26. #if SIMDPP_USE_SSE2 || SIMDPP_USE_NEON_FLT_SP || (SIMDPP_USE_NEON && SIMDPP_64_BITS) || SIMDPP_USE_ALTIVEC || SIMDPP_USE_MSA
  27. #define SIMDPP_HAS_FLOAT32_SIMD 1
  28. #else
  29. #define SIMDPP_HAS_FLOAT32_SIMD 0
  30. #endif
  31. #if SIMDPP_USE_SSE2 || (SIMDPP_USE_NEON && SIMDPP_64_BITS) || SIMDPP_USE_VSX_206 || SIMDPP_USE_MSA
  32. #define SIMDPP_HAS_FLOAT64_SIMD 1
  33. #else
  34. #define SIMDPP_HAS_FLOAT64_SIMD 0
  35. #endif
  36. #if SIMDPP_USE_NULL || SIMDPP_USE_AVX512F || (SIMDPP_USE_NEON && SIMDPP_64_BITS) || SIMDPP_USE_VSX_206 || SIMDPP_USE_MSA
  37. #define SIMDPP_HAS_FLOAT64_TO_UINT32_CONVERSION 1
  38. #else
  39. #define SIMDPP_HAS_FLOAT64_TO_UINT32_CONVERSION 0
  40. #endif
  41. #if SIMDPP_USE_NULL || SIMDPP_USE_AVX512DQ || (SIMDPP_USE_NEON && SIMDPP_64_BITS) || SIMDPP_USE_VSX_207 || SIMDPP_USE_MSA
  42. #define SIMDPP_HAS_INT64_TO_FLOAT64_CONVERSION 1
  43. #define SIMDPP_HAS_INT64_TO_FLOAT32_CONVERSION 1
  44. #define SIMDPP_HAS_UINT64_TO_FLOAT64_CONVERSION 1
  45. #define SIMDPP_HAS_UINT64_TO_FLOAT32_CONVERSION 1
  46. #define SIMDPP_HAS_FLOAT32_TO_INT64_CONVERSION 1
  47. #define SIMDPP_HAS_FLOAT32_TO_UINT64_CONVERSION 1
  48. #define SIMDPP_HAS_FLOAT64_TO_INT64_CONVERSION 1
  49. #define SIMDPP_HAS_FLOAT64_TO_UINT64_CONVERSION 1
  50. #else
  51. #define SIMDPP_HAS_INT64_TO_FLOAT64_CONVERSION 0
  52. #define SIMDPP_HAS_INT64_TO_FLOAT32_CONVERSION 0
  53. #define SIMDPP_HAS_UINT64_TO_FLOAT64_CONVERSION 0
  54. #define SIMDPP_HAS_UINT64_TO_FLOAT32_CONVERSION 0
  55. #define SIMDPP_HAS_FLOAT32_TO_INT64_CONVERSION 0
  56. #define SIMDPP_HAS_FLOAT32_TO_UINT64_CONVERSION 0
  57. #define SIMDPP_HAS_FLOAT64_TO_INT64_CONVERSION 0
  58. #define SIMDPP_HAS_FLOAT64_TO_UINT64_CONVERSION 0
  59. #endif
  60. #if SIMDPP_USE_NULL || SIMDPP_USE_SSSE3 || SIMDPP_USE_NEON || SIMDPP_USE_ALTIVEC || SIMDPP_USE_MSA
  61. #define SIMDPP_HAS_INT8_SHIFT_L_BY_VECTOR 1
  62. #define SIMDPP_HAS_UINT8_SHIFT_L_BY_VECTOR 1
  63. #define SIMDPP_HAS_INT16_SHIFT_L_BY_VECTOR 1
  64. #define SIMDPP_HAS_UINT16_SHIFT_L_BY_VECTOR 1
  65. #else
  66. #define SIMDPP_HAS_INT8_SHIFT_L_BY_VECTOR 0
  67. #define SIMDPP_HAS_UINT8_SHIFT_L_BY_VECTOR 0
  68. #define SIMDPP_HAS_INT16_SHIFT_L_BY_VECTOR 0
  69. #define SIMDPP_HAS_UINT16_SHIFT_L_BY_VECTOR 0
  70. #endif
  71. #if SIMDPP_USE_NULL || SIMDPP_USE_SSE2 || SIMDPP_USE_NEON || SIMDPP_USE_ALTIVEC || SIMDPP_USE_MSA
  72. #define SIMDPP_HAS_INT32_SHIFT_L_BY_VECTOR 1
  73. #define SIMDPP_HAS_UINT32_SHIFT_L_BY_VECTOR 1
  74. #else
  75. #define SIMDPP_HAS_INT32_SHIFT_L_BY_VECTOR 0
  76. #define SIMDPP_HAS_UINT32_SHIFT_L_BY_VECTOR 0
  77. #endif
  78. #if SIMDPP_USE_NULL || SIMDPP_USE_SSSE3 || SIMDPP_USE_NEON || SIMDPP_USE_ALTIVEC || SIMDPP_USE_MSA
  79. #define SIMDPP_HAS_INT8_SHIFT_R_BY_VECTOR 1
  80. #define SIMDPP_HAS_UINT8_SHIFT_R_BY_VECTOR 1
  81. #define SIMDPP_HAS_UINT16_SHIFT_R_BY_VECTOR 1
  82. #else
  83. #define SIMDPP_HAS_INT8_SHIFT_R_BY_VECTOR 0
  84. #define SIMDPP_HAS_UINT8_SHIFT_R_BY_VECTOR 0
  85. #define SIMDPP_HAS_UINT16_SHIFT_R_BY_VECTOR 0
  86. #endif
  87. #if SIMDPP_USE_NULL || SIMDPP_USE_AVX512BW || SIMDPP_USE_NEON || SIMDPP_USE_ALTIVEC || SIMDPP_USE_MSA
  88. #define SIMDPP_HAS_INT16_SHIFT_R_BY_VECTOR 1
  89. #else
  90. #define SIMDPP_HAS_INT16_SHIFT_R_BY_VECTOR 0
  91. #endif
  92. #if SIMDPP_USE_NULL || SIMDPP_USE_SSE2 || SIMDPP_USE_NEON || SIMDPP_USE_ALTIVEC || SIMDPP_USE_MSA
  93. #define SIMDPP_HAS_INT32_SHIFT_R_BY_VECTOR 1
  94. #define SIMDPP_HAS_UINT32_SHIFT_R_BY_VECTOR 1
  95. #else
  96. #define SIMDPP_HAS_INT32_SHIFT_R_BY_VECTOR 0
  97. #define SIMDPP_HAS_UINT32_SHIFT_R_BY_VECTOR 0
  98. #endif
  99. #endif