14 #if (CRYPTOPP_ARM_NEON_AVAILABLE) 15 # include <arm_neon.h> 20 #if (CRYPTOPP_ARM_ACLE_AVAILABLE) 22 # include <arm_acle.h> 25 #ifdef CRYPTOPP_GNU_STYLE_INLINE_ASSEMBLY 30 #ifndef EXCEPTION_EXECUTE_HANDLER 31 # define EXCEPTION_EXECUTE_HANDLER 1 35 extern const char NEON_SIMD_FNAME[] = __FILE__;
39 #ifdef CRYPTOPP_GNU_STYLE_INLINE_ASSEMBLY 41 typedef void (*SigHandler)(int);
43 static jmp_buf s_jmpSIGILL;
44 static void SigIllHandler(
int)
46 longjmp(s_jmpSIGILL, 1);
49 #endif // Not CRYPTOPP_MS_STYLE_INLINE_ASSEMBLY 53 #if defined(__aarch32__) || defined(__aarch64__) 55 #elif defined(CRYPTOPP_NO_CPU_FEATURE_PROBES) 57 #elif (CRYPTOPP_ARM_NEON_AVAILABLE) 58 # if defined(CRYPTOPP_MS_STYLE_INLINE_ASSEMBLY) 59 volatile bool result =
true;
65 __except (EXCEPTION_EXECUTE_HANDLER)
70 # elif defined(__arm__) && (__ARM_ARCH >= 7) 73 volatile bool result =
true;
75 volatile SigHandler oldHandler = signal(SIGILL, SigIllHandler);
76 if (oldHandler == SIG_ERR)
79 volatile sigset_t oldMask;
80 if (sigprocmask(0, NULLPTR, (sigset_t*)&oldMask))
83 if (setjmp(s_jmpSIGILL))
89 asm volatile(
"movw %0,%1 \n" 91 :
"=r"(a) :
"i"(0x1234));
92 result = (a == 0x12341234);
95 sigprocmask(SIG_SETMASK, (sigset_t*)&oldMask, NULLPTR);
96 signal(SIGILL, oldHandler);
103 #endif // CRYPTOPP_ARM_NEON_AVAILABLE 108 #if defined(__aarch32__) || defined(__aarch64__) 110 #elif defined(CRYPTOPP_NO_CPU_FEATURE_PROBES) 112 #elif (CRYPTOPP_ARM_NEON_AVAILABLE) 113 # if defined(CRYPTOPP_MS_STYLE_INLINE_ASSEMBLY) 114 volatile bool result =
true;
117 uint32_t v1[4] = {1,1,1,1};
118 uint32x4_t x1 = vld1q_u32(v1);
119 uint64_t v2[2] = {1,1};
120 uint64x2_t x2 = vld1q_u64(v2);
122 uint32x4_t x3 = vdupq_n_u32(2);
123 x3 = vsetq_lane_u32(vgetq_lane_u32(x1,0),x3,0);
124 x3 = vsetq_lane_u32(vgetq_lane_u32(x1,3),x3,3);
125 uint64x2_t x4 = vdupq_n_u64(2);
126 x4 = vsetq_lane_u64(vgetq_lane_u64(x2,0),x4,0);
127 x4 = vsetq_lane_u64(vgetq_lane_u64(x2,1),x4,1);
129 result = !!(vgetq_lane_u32(x3,0) | vgetq_lane_u64(x4,1));
131 __except (EXCEPTION_EXECUTE_HANDLER)
140 volatile bool result =
true;
142 volatile SigHandler oldHandler = signal(SIGILL, SigIllHandler);
143 if (oldHandler == SIG_ERR)
146 volatile sigset_t oldMask;
147 if (sigprocmask(0, NULLPTR, (sigset_t*)&oldMask))
150 if (setjmp(s_jmpSIGILL))
154 uint32_t v1[4] = {1,1,1,1};
155 uint32x4_t x1 = vld1q_u32(v1);
156 uint64_t v2[2] = {1,1};
157 uint64x2_t x2 = vld1q_u64(v2);
159 uint32x4_t x3 = {0,0,0,0};
160 x3 = vsetq_lane_u32(vgetq_lane_u32(x1,0),x3,0);
161 x3 = vsetq_lane_u32(vgetq_lane_u32(x1,3),x3,3);
162 uint64x2_t x4 = {0,0};
163 x4 = vsetq_lane_u64(vgetq_lane_u64(x2,0),x4,0);
164 x4 = vsetq_lane_u64(vgetq_lane_u64(x2,1),x4,1);
167 result = !!(vgetq_lane_u32(x3,0) | vgetq_lane_u64(x4,1));
170 sigprocmask(SIG_SETMASK, (sigset_t*)&oldMask, NULLPTR);
171 signal(SIGILL, oldHandler);
176 #endif // CRYPTOPP_ARM_NEON_AVAILABLE Library configuration file.
Crypto++ library namespace.