15 #if (CRYPTOPP_ARM_NEON_AVAILABLE) && !defined(_M_ARM64) 16 # include <arm_neon.h> 19 #if (CRYPTOPP_ARM_ACLE_AVAILABLE) 21 # include <arm_acle.h> 24 #ifdef CRYPTOPP_GNU_STYLE_INLINE_ASSEMBLY 29 #ifndef EXCEPTION_EXECUTE_HANDLER 30 # define EXCEPTION_EXECUTE_HANDLER 1 34 extern const char NEON_SIMD_FNAME[] = __FILE__;
38 #ifdef CRYPTOPP_GNU_STYLE_INLINE_ASSEMBLY 40 typedef void (*SigHandler)(int);
42 static jmp_buf s_jmpSIGILL;
43 static void SigIllHandler(
int)
45 longjmp(s_jmpSIGILL, 1);
48 #endif // Not CRYPTOPP_MS_STYLE_INLINE_ASSEMBLY 52 #if defined(__aarch32__) || defined(__aarch64__) 54 #elif defined(CRYPTOPP_NO_CPU_FEATURE_PROBES) 56 #elif (CRYPTOPP_ARM_NEON_AVAILABLE) 57 # if defined(CRYPTOPP_MS_STYLE_INLINE_ASSEMBLY) 58 volatile bool result =
true;
64 __except (EXCEPTION_EXECUTE_HANDLER)
69 # elif defined(__arm__) && (__ARM_ARCH >= 7) 72 volatile bool result =
true;
74 volatile SigHandler oldHandler = signal(SIGILL, SigIllHandler);
75 if (oldHandler == SIG_ERR)
78 volatile sigset_t oldMask;
79 if (sigprocmask(0, NULLPTR, (sigset_t*)&oldMask))
82 if (setjmp(s_jmpSIGILL))
88 asm volatile(
"movw %0,%1 \n" 90 :
"=r"(a) :
"i"(0x1234));
91 result = (a == 0x12341234);
94 sigprocmask(SIG_SETMASK, (sigset_t*)&oldMask, NULLPTR);
95 signal(SIGILL, oldHandler);
102 #endif // CRYPTOPP_ARM_NEON_AVAILABLE 107 #if defined(__aarch32__) || defined(__aarch64__) 109 #elif defined(CRYPTOPP_NO_CPU_FEATURE_PROBES) 111 #elif (CRYPTOPP_ARM_NEON_AVAILABLE) 112 # if defined(CRYPTOPP_MS_STYLE_INLINE_ASSEMBLY) 113 volatile bool result =
true;
116 uint32_t v1[4] = {1,1,1,1};
117 uint32x4_t x1 = vld1q_u32(v1);
118 uint64_t v2[2] = {1,1};
119 uint64x2_t x2 = vld1q_u64(v2);
121 uint32x4_t x3 = vdupq_n_u32(2);
122 x3 = vsetq_lane_u32(vgetq_lane_u32(x1,0),x3,0);
123 x3 = vsetq_lane_u32(vgetq_lane_u32(x1,3),x3,3);
124 uint64x2_t x4 = vdupq_n_u64(2);
125 x4 = vsetq_lane_u64(vgetq_lane_u64(x2,0),x4,0);
126 x4 = vsetq_lane_u64(vgetq_lane_u64(x2,1),x4,1);
128 result = !!(vgetq_lane_u32(x3,0) | vgetq_lane_u64(x4,1));
130 __except (EXCEPTION_EXECUTE_HANDLER)
139 volatile bool result =
true;
141 volatile SigHandler oldHandler = signal(SIGILL, SigIllHandler);
142 if (oldHandler == SIG_ERR)
145 volatile sigset_t oldMask;
146 if (sigprocmask(0, NULLPTR, (sigset_t*)&oldMask))
149 if (setjmp(s_jmpSIGILL))
153 uint32_t v1[4] = {1,1,1,1};
154 uint32x4_t x1 = vld1q_u32(v1);
155 uint64_t v2[2] = {1,1};
156 uint64x2_t x2 = vld1q_u64(v2);
158 uint32x4_t x3 = {0,0,0,0};
159 x3 = vsetq_lane_u32(vgetq_lane_u32(x1,0),x3,0);
160 x3 = vsetq_lane_u32(vgetq_lane_u32(x1,3),x3,3);
161 uint64x2_t x4 = {0,0};
162 x4 = vsetq_lane_u64(vgetq_lane_u64(x2,0),x4,0);
163 x4 = vsetq_lane_u64(vgetq_lane_u64(x2,1),x4,1);
166 result = !!(vgetq_lane_u32(x3,0) | vgetq_lane_u64(x4,1));
169 sigprocmask(SIG_SETMASK, (sigset_t*)&oldMask, NULLPTR);
170 signal(SIGILL, oldHandler);
175 #endif // CRYPTOPP_ARM_NEON_AVAILABLE Library configuration file.
Crypto++ library namespace.