forked from simd-everywhere/simde
-
Notifications
You must be signed in to change notification settings - Fork 0
/
aes.c
355 lines (336 loc) · 32.3 KB
/
aes.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
/* MIT License
*
* Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use, copy,
* modify, merge, publish, distribute, sublicense, and/or sell copies
* of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*
*/
#define SIMDE_TESTS_CURRENT_ISAX aes
#include <simde/x86/aes.h>
#include <test/x86/test-sse2.h>
static int
test_simde_mm_aesenc_si128 (SIMDE_MUNIT_TEST_ARGS) {
static const struct {
const int8_t a[16];
const int8_t b[16];
const int8_t r[16];
} test_vec[] = {
{ { INT8_C( 37), INT8_C( 125), -INT8_C( 63), INT8_C( 116), INT8_C( 37), INT8_C( 50), INT8_C( 82), INT8_C( 13),
INT8_C( 3), -INT8_C( 37), -INT8_C( 38), INT8_C( 0), -INT8_C( 51), -INT8_C( 20), -INT8_C( 55), INT8_C( 120) },
{ -INT8_C( 45), -INT8_C( 61), INT8_C( 86), INT8_C( 0), INT8_C( 45), INT8_C( 18), INT8_C( 54), INT8_C( 25),
-INT8_C( 21), -INT8_C( 88), INT8_C( 117), INT8_C( 86), -INT8_C( 38), -INT8_C( 32), -INT8_C( 55), INT8_C( 0) },
{ INT8_C( 35), -INT8_C( 1), INT8_C( 59), INT8_C( 86), -INT8_C( 52), -INT8_C( 86), -INT8_C( 68), INT8_C( 3),
-INT8_C( 5), INT8_C( 11), INT8_C( 82), -INT8_C( 40), -INT8_C( 62), -INT8_C( 37), INT8_C( 46), -INT8_C( 27) } },
{ { INT8_C( 93), -INT8_C( 118), INT8_C( 116), -INT8_C( 126), -INT8_C( 67), -INT8_C( 58), -INT8_C( 113), -INT8_C( 64),
-INT8_C( 95), INT8_C( 105), -INT8_C( 64), INT8_C( 110), INT8_C( 85), -INT8_C( 119), -INT8_C( 25), INT8_C( 41) },
{ INT8_C( 76), INT8_C( 61), INT8_C( 41), INT8_C( 122), INT8_C( 79), INT8_C( 95), -INT8_C( 109), INT8_C( 58),
INT8_C( 8), INT8_C( 8), -INT8_C( 111), -INT8_C( 30), -INT8_C( 24), INT8_C( 90), -INT8_C( 30), INT8_C( 69) },
{ INT8_C( 12), INT8_C( 114), INT8_C( 74), -INT8_C( 15), INT8_C( 44), INT8_C( 120), INT8_C( 22), -INT8_C( 1),
-INT8_C( 74), INT8_C( 120), -INT8_C( 18), -INT8_C( 18), INT8_C( 101), INT8_C( 80), INT8_C( 60), INT8_C( 114) } },
{ { -INT8_C( 27), INT8_C( 86), -INT8_C( 57), -INT8_C( 94), INT8_C( 29), INT8_C( 86), INT8_C( 98), -INT8_C( 66),
-INT8_C( 65), INT8_C( 34), INT8_C( 45), INT8_C( 21), -INT8_C( 85), INT8_C( 20), INT8_C( 62), -INT8_C( 8) },
{ INT8_C( 81), INT8_C( 103), INT8_C( 114), -INT8_C( 95), -INT8_C( 57), INT8_C( 5), -INT8_C( 37), -INT8_C( 49),
INT8_C( 13), INT8_C( 108), -INT8_C( 79), -INT8_C( 11), -INT8_C( 57), -INT8_C( 108), INT8_C( 58), -INT8_C( 84) },
{ -INT8_C( 87), -INT8_C( 11), INT8_C( 114), INT8_C( 58), -INT8_C( 78), INT8_C( 107), -INT8_C( 35), INT8_C( 109),
INT8_C( 96), INT8_C( 116), INT8_C( 61), -INT8_C( 106), INT8_C( 56), INT8_C( 51), INT8_C( 77), -INT8_C( 93) } },
{ { -INT8_C( 22), INT8_C( 1), INT8_C( 78), INT8_C( 7), INT8_C( 87), -INT8_C( 80), -INT8_C( 58), INT8_C( 22),
-INT8_C( 46), -INT8_C( 13), INT8_C( 43), INT8_C( 125), INT8_C( 7), INT8_C( 105), INT8_C( 117), INT8_C( 88) },
{ -INT8_C( 47), -INT8_C( 25), -INT8_C( 7), -INT8_C( 104), -INT8_C( 20), -INT8_C( 43), INT8_C( 103), -INT8_C( 7),
INT8_C( 65), INT8_C( 24), -INT8_C( 18), INT8_C( 8), -INT8_C( 84), INT8_C( 40), -INT8_C( 76), -INT8_C( 105) },
{ INT8_C( 109), -INT8_C( 41), -INT8_C( 34), -INT8_C( 56), INT8_C( 21), -INT8_C( 19), INT8_C( 68), INT8_C( 21),
INT8_C( 72), INT8_C( 114), INT8_C( 53), -INT8_C( 108), -INT8_C( 14), INT8_C( 45), INT8_C( 100), -INT8_C( 18) } },
{ { INT8_C( 41), INT8_C( 2), -INT8_C( 98), INT8_MIN, -INT8_C( 78), INT8_C( 100), -INT8_C( 105), -INT8_C( 124),
INT8_C( 87), -INT8_C( 62), INT8_C( 2), INT8_C( 94), INT8_C( 44), INT8_C( 119), -INT8_C( 73), -INT8_C( 3) },
{ INT8_C( 95), -INT8_C( 80), -INT8_C( 107), INT8_C( 75), -INT8_C( 123), -INT8_C( 4), INT8_C( 69), -INT8_C( 57),
INT8_C( 20), INT8_C( 51), -INT8_C( 49), -INT8_C( 63), INT8_C( 92), -INT8_C( 124), INT8_C( 88), -INT8_C( 123) },
{ -INT8_C( 24), INT8_C( 94), INT8_C( 97), INT8_C( 35), -INT8_C( 32), -INT8_C( 84), INT8_C( 82), -INT8_C( 109),
-INT8_C( 14), -INT8_C( 37), -INT8_C( 106), INT8_C( 108), -INT8_C( 9), -INT8_C( 64), -INT8_C( 67), INT8_C( 89) } },
{ { -INT8_C( 122), -INT8_C( 10), INT8_C( 6), INT8_C( 57), INT8_C( 91), -INT8_C( 99), -INT8_C( 67), -INT8_C( 78),
INT8_C( 95), -INT8_C( 65), INT8_C( 17), -INT8_C( 117), INT8_C( 55), -INT8_C( 56), -INT8_C( 120), -INT8_C( 106) },
{ INT8_C( 120), INT8_C( 29), -INT8_C( 31), -INT8_C( 2), INT8_C( 25), INT8_C( 38), -INT8_C( 59), INT8_C( 46),
INT8_C( 90), -INT8_C( 108), -INT8_C( 17), -INT8_C( 74), INT8_C( 24), INT8_C( 71), INT8_C( 59), -INT8_C( 97) },
{ INT8_C( 0), -INT8_C( 24), INT8_C( 79), -INT8_C( 43), -INT8_C( 91), INT8_C( 74), INT8_C( 81), -INT8_C( 115),
-INT8_C( 92), INT8_C( 22), INT8_C( 79), INT8_C( 21), -INT8_C( 74), -INT8_C( 22), INT8_C( 80), INT8_C( 104) } },
{ { INT8_C( 61), INT8_C( 65), -INT8_C( 40), -INT8_C( 104), -INT8_C( 34), -INT8_C( 107), INT8_C( 75), INT8_C( 62),
INT8_C( 85), INT8_C( 92), -INT8_C( 55), -INT8_C( 116), INT8_C( 36), INT8_C( 82), INT8_C( 34), -INT8_C( 100) },
{ INT8_C( 111), INT8_C( 3), -INT8_C( 102), -INT8_C( 119), INT8_C( 42), INT8_C( 95), -INT8_C( 73), -INT8_C( 124),
-INT8_C( 12), -INT8_C( 90), INT8_C( 58), INT8_C( 12), -INT8_C( 19), INT8_C( 117), -INT8_C( 85), INT8_C( 42) },
{ INT8_C( 92), -INT8_C( 46), INT8_C( 79), -INT8_C( 80), INT8_C( 27), INT8_C( 62), INT8_C( 23), -INT8_C( 10),
-INT8_C( 60), INT8_C( 75), -INT8_C( 55), INT8_C( 13), -INT8_C( 56), -INT8_C( 12), -INT8_C( 49), -INT8_C( 120) } },
{ { -INT8_C( 73), -INT8_C( 125), -INT8_C( 61), -INT8_C( 107), INT8_C( 25), INT8_C( 14), -INT8_C( 45), INT8_C( 110),
INT8_C( 106), -INT8_C( 99), -INT8_C( 6), -INT8_C( 114), -INT8_C( 17), INT8_C( 28), INT8_C( 42), INT8_C( 94) },
{ INT8_C( 31), -INT8_C( 59), -INT8_C( 25), INT8_C( 73), INT8_C( 36), -INT8_C( 98), -INT8_C( 51), INT8_C( 24),
INT8_C( 68), INT8_C( 7), INT8_C( 37), INT8_C( 49), INT8_C( 125), -INT8_C( 48), INT8_C( 92), INT8_C( 52) },
{ -INT8_C( 59), INT8_C( 14), INT8_C( 87), -INT8_C( 97), -INT8_C( 70), -INT8_C( 24), -INT8_C( 24), -INT8_C( 112),
INT8_C( 78), -INT8_C( 53), INT8_C( 93), -INT8_C( 96), -INT8_C( 120), INT8_MAX, -INT8_C( 120), -INT8_C( 10) } },
};
for (size_t i = 0 ; i < (sizeof(test_vec) / sizeof(test_vec[0])) ; i++) {
simde__m128i a = simde_mm_loadu_si128(test_vec[i].a);
simde__m128i b = simde_mm_loadu_si128(test_vec[i].b);
simde__m128i r = simde_mm_aesenc_si128(a, b);
simde_test_x86_assert_equal_i8x16(r, simde_mm_loadu_si128(test_vec[i].r));
}
return 0;
}
static int
test_simde_mm_aesdec_si128 (SIMDE_MUNIT_TEST_ARGS) {
static const struct {
const int8_t a[16];
const int8_t b[16];
const int8_t r[16];
} test_vec[] = {
{ { -INT8_C( 43), INT8_C( 108), INT8_C( 53), INT8_C( 64), -INT8_C( 13), -INT8_C( 126), -INT8_C( 116), -INT8_C( 116),
-INT8_C( 40), -INT8_C( 10), -INT8_C( 19), -INT8_C( 9), INT8_C( 93), -INT8_C( 43), INT8_C( 55), INT8_C( 38) },
{ INT8_C( 119), INT8_C( 40), -INT8_C( 23), INT8_C( 74), -INT8_C( 100), -INT8_C( 113), INT8_C( 36), INT8_C( 45),
-INT8_C( 97), -INT8_C( 65), -INT8_C( 115), -INT8_C( 17), INT8_C( 75), INT8_C( 105), -INT8_C( 3), INT8_C( 33) },
{ -INT8_C( 69), -INT8_C( 119), -INT8_C( 98), -INT8_C( 13), -INT8_C( 100), -INT8_C( 103), INT8_C( 76), INT8_C( 1),
-INT8_C( 101), INT8_C( 65), -INT8_C( 22), -INT8_C( 76), -INT8_C( 44), INT8_C( 30), -INT8_C( 74), INT8_C( 91) } },
{ { -INT8_C( 43), INT8_C( 50), INT8_C( 97), -INT8_C( 55), -INT8_C( 75), -INT8_C( 19), INT8_C( 85), -INT8_C( 115),
-INT8_C( 29), INT8_C( 66), -INT8_C( 124), INT8_C( 64), INT8_C( 23), -INT8_C( 68), INT8_C( 102), -INT8_C( 113) },
{ -INT8_C( 28), INT8_C( 80), -INT8_C( 39), -INT8_C( 127), -INT8_C( 33), -INT8_C( 3), -INT8_C( 82), INT8_MAX,
-INT8_C( 68), INT8_C( 59), INT8_C( 110), INT8_C( 7), -INT8_C( 92), INT8_C( 108), INT8_C( 40), INT8_C( 122) },
{ -INT8_C( 120), -INT8_C( 58), INT8_C( 35), -INT8_C( 73), -INT8_C( 9), -INT8_C( 63), INT8_C( 56), INT8_C( 47),
-INT8_C( 59), -INT8_C( 113), -INT8_C( 13), -INT8_C( 30), -INT8_C( 32), -INT8_C( 125), INT8_C( 1), INT8_C( 118) } },
{ { -INT8_C( 98), -INT8_C( 119), INT8_C( 67), INT8_C( 83), INT8_C( 118), -INT8_C( 104), -INT8_C( 32), INT8_C( 90),
-INT8_C( 38), INT8_C( 101), -INT8_C( 102), -INT8_C( 15), INT8_C( 33), INT8_C( 1), INT8_MIN, INT8_C( 5) },
{ INT8_C( 81), INT8_C( 89), -INT8_C( 122), INT8_C( 48), INT8_C( 86), INT8_C( 52), -INT8_C( 81), INT8_C( 18),
INT8_C( 111), INT8_C( 30), INT8_C( 26), INT8_C( 20), -INT8_C( 118), INT8_C( 66), -INT8_C( 114), INT8_C( 40) },
{ INT8_C( 92), -INT8_C( 29), INT8_C( 54), -INT8_C( 112), -INT8_C( 95), -INT8_C( 55), -INT8_C( 82), -INT8_C( 11),
-INT8_C( 122), INT8_C( 86), INT8_C( 98), INT8_C( 7), -INT8_C( 79), -INT8_C( 49), INT8_C( 0), INT8_C( 39) } },
{ { -INT8_C( 52), -INT8_C( 47), INT8_C( 124), INT8_C( 66), INT8_C( 105), INT8_C( 92), -INT8_C( 100), INT8_C( 67),
-INT8_C( 63), INT8_C( 55), INT8_C( 52), -INT8_C( 30), INT8_C( 56), -INT8_C( 75), -INT8_C( 24), -INT8_C( 119) },
{ INT8_C( 14), INT8_C( 110), -INT8_C( 71), INT8_C( 101), -INT8_C( 93), INT8_C( 105), INT8_C( 119), INT8_C( 18),
-INT8_C( 121), -INT8_C( 111), INT8_C( 38), INT8_C( 17), -INT8_C( 44), -INT8_C( 76), INT8_C( 57), -INT8_C( 96) },
{ -INT8_C( 30), -INT8_C( 69), INT8_C( 51), INT8_C( 111), -INT8_C( 58), -INT8_C( 30), -INT8_C( 78), INT8_MAX,
INT8_C( 94), -INT8_C( 125), INT8_C( 42), INT8_C( 95), -INT8_C( 57), INT8_C( 15), INT8_C( 28), INT8_C( 3) } },
{ { -INT8_C( 123), -INT8_C( 75), -INT8_C( 30), -INT8_C( 18), INT8_C( 18), INT8_MAX, INT8_C( 49), -INT8_C( 45),
-INT8_C( 74), INT8_C( 102), -INT8_C( 74), -INT8_C( 18), INT8_C( 27), -INT8_C( 98), INT8_C( 119), INT8_C( 41) },
{ INT8_C( 12), INT8_C( 48), -INT8_C( 114), -INT8_C( 81), -INT8_C( 103), INT8_C( 6), -INT8_C( 62), INT8_C( 32),
-INT8_C( 105), -INT8_C( 24), INT8_C( 49), INT8_C( 107), -INT8_C( 99), INT8_C( 107), INT8_C( 11), INT8_C( 34) },
{ INT8_C( 125), INT8_C( 126), INT8_C( 49), INT8_C( 71), INT8_C( 92), -INT8_C( 123), -INT8_C( 36), INT8_C( 8),
-INT8_C( 71), -INT8_C( 33), -INT8_C( 105), -INT8_C( 79), INT8_C( 100), INT8_C( 81), -INT8_C( 40), INT8_C( 18) } },
{ { INT8_C( 32), -INT8_C( 18), INT8_C( 17), INT8_C( 50), INT8_C( 109), INT8_C( 66), INT8_C( 6), INT8_C( 35),
-INT8_C( 88), -INT8_C( 68), INT8_C( 17), -INT8_C( 61), INT8_C( 90), -INT8_C( 120), -INT8_C( 19), INT8_C( 102) },
{ -INT8_C( 72), INT8_C( 123), INT8_C( 22), INT8_C( 82), -INT8_C( 127), -INT8_C( 40), INT8_C( 114), INT8_C( 25),
-INT8_C( 64), -INT8_C( 92), -INT8_C( 124), INT8_C( 93), INT8_C( 15), -INT8_C( 112), INT8_MIN, INT8_C( 47) },
{ INT8_C( 25), INT8_C( 36), INT8_C( 36), -INT8_C( 116), -INT8_C( 25), INT8_C( 124), INT8_C( 96), -INT8_C( 125),
INT8_C( 22), INT8_C( 122), -INT8_C( 105), -INT8_C( 17), INT8_C( 101), -INT8_C( 15), INT8_C( 125), -INT8_C( 29) } },
{ { INT8_C( 126), -INT8_C( 111), INT8_C( 98), -INT8_C( 21), -INT8_C( 45), INT8_C( 104), INT8_C( 14), INT8_C( 124),
INT8_C( 36), INT8_C( 31), INT8_C( 63), INT8_C( 126), -INT8_C( 89), INT8_C( 44), -INT8_C( 28), INT8_C( 95) },
{ -INT8_C( 88), -INT8_C( 6), -INT8_C( 79), INT8_C( 41), -INT8_C( 46), INT8_C( 36), INT8_C( 66), -INT8_C( 109),
-INT8_C( 56), -INT8_C( 57), -INT8_C( 16), -INT8_C( 41), INT8_C( 87), INT8_C( 112), INT8_C( 6), -INT8_C( 43) },
{ -INT8_C( 18), -INT8_C( 84), -INT8_C( 101), -INT8_C( 1), INT8_C( 95), INT8_C( 38), -INT8_C( 118), -INT8_C( 11),
INT8_C( 91), -INT8_C( 4), -INT8_C( 110), INT8_C( 99), -INT8_C( 81), -INT8_C( 28), -INT8_C( 23), -INT8_C( 1) } },
{ { INT8_C( 1), INT8_C( 104), -INT8_C( 64), -INT8_C( 43), -INT8_C( 48), -INT8_C( 50), INT8_C( 81), -INT8_C( 12),
-INT8_C( 19), -INT8_C( 112), INT8_C( 114), -INT8_C( 108), -INT8_C( 67), INT8_C( 87), -INT8_C( 13), INT8_C( 101) },
{ INT8_C( 81), -INT8_C( 91), -INT8_C( 114), INT8_C( 36), -INT8_C( 55), -INT8_C( 47), -INT8_C( 73), -INT8_C( 111),
-INT8_C( 104), -INT8_C( 89), INT8_C( 104), -INT8_C( 17), INT8_C( 24), INT8_C( 110), -INT8_C( 60), INT8_C( 25) },
{ INT8_C( 91), -INT8_C( 107), INT8_C( 125), -INT8_C( 102), -INT8_C( 102), INT8_C( 17), -INT8_C( 26), INT8_C( 93),
INT8_C( 121), INT8_C( 17), -INT8_C( 3), INT8_C( 49), -INT8_C( 93), -INT8_C( 95), -INT8_C( 27), -INT8_C( 46) } },
};
for (size_t i = 0 ; i < (sizeof(test_vec) / sizeof(test_vec[0])) ; i++) {
simde__m128i a = simde_mm_loadu_si128(test_vec[i].a);
simde__m128i b = simde_mm_loadu_si128(test_vec[i].b);
simde__m128i r = simde_mm_aesdec_si128(a, b);
simde_test_x86_assert_equal_i8x16(r, simde_mm_loadu_si128(test_vec[i].r));
}
return 0;
}
static int
test_simde_mm_aesenclast_si128 (SIMDE_MUNIT_TEST_ARGS) {
static const struct {
const int8_t a[16];
const int8_t b[16];
const int8_t r[16];
} test_vec[] = {
{ { -INT8_C( 103), -INT8_C( 11), -INT8_C( 16), -INT8_C( 107), INT8_C( 124), INT8_C( 121), -INT8_C( 15), -INT8_C( 8),
-INT8_C( 36), INT8_C( 89), INT8_C( 37), INT8_C( 86), -INT8_C( 25), INT8_C( 86), INT8_C( 30), -INT8_C( 103) },
{ -INT8_C( 111), -INT8_C( 57), -INT8_C( 123), INT8_C( 69), -INT8_C( 68), INT8_C( 104), INT8_C( 4), INT8_C( 9),
-INT8_C( 62), -INT8_C( 92), INT8_C( 81), -INT8_C( 14), INT8_C( 41), INT8_C( 59), -INT8_C( 56), -INT8_C( 62) },
{ INT8_MAX, INT8_C( 113), -INT8_C( 70), -INT8_C( 85), -INT8_C( 84), -INT8_C( 93), INT8_C( 118), INT8_C( 35),
INT8_C( 68), INT8_C( 21), -INT8_C( 35), -INT8_C( 77), -INT8_C( 67), -INT8_C( 35), INT8_C( 105), INT8_C( 115) } },
{ { INT8_C( 48), -INT8_C( 72), INT8_C( 87), -INT8_C( 84), INT8_C( 49), INT8_C( 72), -INT8_C( 91), INT8_C( 14),
-INT8_C( 95), -INT8_C( 54), INT8_C( 100), -INT8_C( 119), INT8_C( 32), -INT8_C( 126), INT8_C( 34), -INT8_C( 79) },
{ INT8_C( 73), -INT8_C( 88), -INT8_C( 10), INT8_C( 5), INT8_C( 16), -INT8_C( 5), INT8_C( 15), -INT8_C( 46),
-INT8_C( 97), INT8_C( 96), -INT8_C( 59), -INT8_C( 55), -INT8_C( 101), -INT8_C( 115), -INT8_C( 117), -INT8_C( 53) },
{ INT8_C( 77), -INT8_C( 6), -INT8_C( 75), -INT8_C( 51), -INT8_C( 41), -INT8_C( 113), -INT8_C( 100), INT8_C( 67),
-INT8_C( 83), INT8_C( 115), -INT8_C( 98), INT8_C( 98), INT8_C( 44), -INT8_C( 31), -INT8_C( 115), INT8_C( 108) } },
{ { INT8_C( 70), -INT8_C( 29), INT8_C( 120), INT8_C( 119), INT8_C( 43), INT8_C( 29), -INT8_C( 123), -INT8_C( 51),
-INT8_C( 25), -INT8_C( 22), INT8_C( 86), INT8_C( 7), INT8_C( 108), INT8_C( 120), -INT8_C( 71), -INT8_C( 74) },
{ INT8_C( 32), -INT8_C( 81), -INT8_C( 69), INT8_C( 49), -INT8_C( 86), -INT8_C( 54), INT8_C( 3), INT8_C( 74),
INT8_C( 42), -INT8_C( 56), INT8_C( 19), -INT8_C( 59), INT8_C( 86), -INT8_C( 98), -INT8_C( 111), -INT8_C( 100) },
{ INT8_C( 122), INT8_C( 11), INT8_C( 10), INT8_MAX, INT8_C( 91), INT8_C( 77), INT8_C( 85), -INT8_C( 65),
-INT8_C( 66), INT8_C( 116), -INT8_C( 81), INT8_C( 120), INT8_C( 6), -INT8_C( 113), INT8_C( 6), INT8_C( 89) } },
{ { -INT8_C( 127), INT8_C( 9), INT8_C( 19), -INT8_C( 83), INT8_C( 38), -INT8_C( 103), INT8_C( 122), INT8_C( 13),
-INT8_C( 125), -INT8_C( 48), INT8_C( 20), -INT8_C( 17), INT8_C( 72), -INT8_C( 51), -INT8_C( 91), INT8_C( 105) },
{ INT8_C( 125), INT8_C( 97), -INT8_C( 102), INT8_C( 39), INT8_C( 43), -INT8_C( 99), INT8_C( 113), INT8_C( 86),
INT8_C( 102), -INT8_C( 124), INT8_C( 27), -INT8_C( 68), INT8_C( 35), -INT8_C( 84), INT8_C( 88), -INT8_C( 92) },
{ INT8_C( 113), -INT8_C( 113), INT8_C( 96), -INT8_C( 34), -INT8_C( 36), -INT8_C( 19), INT8_C( 119), -INT8_C( 61),
-INT8_C( 118), INT8_C( 57), INT8_C( 102), INT8_C( 107), INT8_C( 113), -INT8_C( 83), -INT8_C( 126), INT8_C( 123) } },
{ { -INT8_C( 75), INT8_C( 107), INT8_C( 81), -INT8_C( 37), INT8_C( 4), -INT8_C( 53), -INT8_C( 24), -INT8_C( 121),
-INT8_C( 101), -INT8_C( 3), INT8_C( 119), -INT8_C( 28), -INT8_C( 54), INT8_C( 28), INT8_C( 77), INT8_C( 71) },
{ INT8_C( 125), -INT8_C( 25), INT8_C( 111), -INT8_C( 87), -INT8_C( 124), -INT8_C( 32), -INT8_C( 1), -INT8_C( 22),
INT8_C( 101), INT8_C( 26), -INT8_C( 90), -INT8_C( 120), -INT8_C( 57), -INT8_C( 2), INT8_C( 44), INT8_C( 124) },
{ -INT8_C( 88), -INT8_C( 8), -INT8_C( 102), INT8_C( 9), INT8_C( 118), -INT8_C( 76), INT8_C( 28), INT8_C( 83),
INT8_C( 113), -INT8_C( 122), INT8_C( 119), -INT8_C( 97), -INT8_C( 77), -INT8_C( 127), -INT8_C( 73), INT8_C( 21) } },
{ { INT8_C( 106), INT8_C( 126), INT8_C( 88), INT8_C( 110), INT8_C( 73), INT8_C( 64), -INT8_C( 10), -INT8_C( 27),
INT8_C( 61), INT8_C( 109), -INT8_C( 55), INT8_C( 8), -INT8_C( 119), INT8_C( 22), INT8_C( 79), INT8_C( 7) },
{ -INT8_C( 3), -INT8_C( 66), -INT8_C( 80), -INT8_C( 127), -INT8_C( 97), -INT8_C( 81), INT8_C( 108), INT8_C( 4),
-INT8_C( 55), INT8_C( 18), -INT8_C( 116), -INT8_C( 112), INT8_C( 17), -INT8_C( 72), INT8_C( 13), INT8_C( 123) },
{ -INT8_C( 1), -INT8_C( 73), INT8_C( 109), INT8_C( 68), -INT8_C( 92), -INT8_C( 109), -INT8_C( 24), -INT8_C( 101),
-INT8_C( 18), INT8_C( 85), -INT8_C( 26), INT8_C( 73), -INT8_C( 74), INT8_C( 75), INT8_C( 79), INT8_C( 75) } },
{ { INT8_C( 54), INT8_C( 101), -INT8_C( 23), INT8_MIN, -INT8_C( 91), -INT8_C( 33), INT8_C( 101), -INT8_C( 29),
INT8_C( 76), INT8_C( 46), -INT8_C( 21), -INT8_C( 42), INT8_C( 68), INT8_C( 58), -INT8_C( 35), INT8_C( 65) },
{ -INT8_C( 7), -INT8_C( 115), -INT8_C( 62), -INT8_C( 104), INT8_C( 60), INT8_C( 46), -INT8_C( 100), INT8_C( 5),
INT8_C( 65), INT8_C( 40), -INT8_C( 106), INT8_C( 82), -INT8_C( 32), -INT8_C( 93), -INT8_C( 51), INT8_C( 23) },
{ -INT8_C( 4), INT8_C( 19), INT8_C( 43), INT8_C( 27), INT8_C( 58), INT8_C( 31), INT8_C( 93), -INT8_C( 56),
INT8_C( 104), -INT8_C( 88), -INT8_C( 120), INT8_C( 67), -INT8_C( 5), -INT8_C( 18), INT8_MIN, -INT8_C( 31) } },
{ { INT8_C( 8), -INT8_C( 74), -INT8_C( 105), -INT8_C( 83), -INT8_C( 106), -INT8_C( 4), -INT8_C( 112), -INT8_C( 30),
INT8_C( 42), INT8_C( 123), -INT8_C( 72), INT8_C( 110), -INT8_C( 74), -INT8_C( 107), -INT8_C( 81), -INT8_C( 81) },
{ INT8_C( 34), INT8_C( 113), INT8_C( 71), INT8_C( 94), -INT8_C( 96), -INT8_C( 29), INT8_C( 100), -INT8_C( 31),
INT8_C( 11), -INT8_C( 6), INT8_C( 51), -INT8_C( 21), -INT8_C( 99), INT8_C( 0), INT8_C( 2), -INT8_C( 91) },
{ INT8_C( 18), -INT8_C( 63), INT8_C( 43), INT8_C( 39), INT8_C( 48), -INT8_C( 62), INT8_C( 29), INT8_C( 116),
-INT8_C( 18), -INT8_C( 48), -INT8_C( 69), INT8_C( 115), -INT8_C( 45), INT8_C( 78), INT8_C( 98), INT8_C( 58) } },
};
for (size_t i = 0 ; i < (sizeof(test_vec) / sizeof(test_vec[0])) ; i++) {
simde__m128i a = simde_mm_loadu_si128(test_vec[i].a);
simde__m128i b = simde_mm_loadu_si128(test_vec[i].b);
simde__m128i r = simde_mm_aesenclast_si128(a, b);
simde_test_x86_assert_equal_i8x16(r, simde_mm_loadu_si128(test_vec[i].r));
}
return 0;
}
static int
test_simde_mm_aesdeclast_si128 (SIMDE_MUNIT_TEST_ARGS) {
static const struct {
const int8_t a[16];
const int8_t b[16];
const int8_t r[16];
} test_vec[] = {
{ { INT8_C( 103), INT8_C( 70), -INT8_C( 95), INT8_C( 25), -INT8_C( 19), INT8_C( 60), INT8_C( 54), INT8_C( 17),
INT8_C( 55), -INT8_C( 114), INT8_C( 43), INT8_MAX, -INT8_C( 62), -INT8_C( 27), -INT8_C( 48), -INT8_C( 113) },
{ INT8_C( 10), -INT8_C( 103), INT8_C( 110), INT8_C( 74), -INT8_C( 80), -INT8_C( 49), INT8_C( 59), -INT8_C( 69),
-INT8_C( 123), INT8_C( 56), INT8_C( 65), -INT8_C( 77), INT8_C( 111), -INT8_C( 55), INT8_C( 99), -INT8_C( 42) },
{ INT8_C( 0), -INT8_C( 77), INT8_C( 101), -INT8_C( 87), -INT8_C( 29), INT8_C( 87), INT8_C( 91), -INT8_C( 48),
INT8_C( 55), INT8_C( 85), -INT8_C( 80), -INT8_C( 64), -INT8_C( 57), INT8_C( 47), INT8_C( 71), INT8_C( 88) } },
{ { INT8_C( 15), INT8_C( 4), -INT8_C( 17), -INT8_C( 3), INT8_C( 65), INT8_C( 37), INT8_C( 14), INT8_C( 120),
-INT8_C( 77), INT8_C( 57), -INT8_C( 9), INT8_C( 117), INT8_C( 30), -INT8_C( 56), INT8_C( 5), INT8_C( 40) },
{ INT8_C( 97), INT8_C( 115), INT8_C( 114), INT8_C( 18), INT8_C( 66), -INT8_C( 82), -INT8_C( 51), -INT8_C( 57),
-INT8_C( 26), INT8_C( 14), INT8_C( 122), INT8_C( 85), -INT8_C( 40), -INT8_C( 34), INT8_C( 43), -INT8_C( 25) },
{ -INT8_C( 102), -INT8_C( 62), INT8_C( 84), -INT8_C( 45), -INT8_C( 70), -INT8_C( 98), -INT8_C( 5), -INT8_C( 8),
-INT8_C( 83), -INT8_C( 52), INT8_C( 27), -INT8_C( 69), INT8_C( 49), -INT8_C( 123), -INT8_C( 4), -INT8_C( 58) } },
{ { -INT8_C( 30), INT8_C( 26), -INT8_C( 28), INT8_C( 35), INT8_C( 63), -INT8_C( 14), -INT8_C( 101), -INT8_C( 13),
INT8_C( 43), -INT8_C( 109), INT8_C( 104), INT8_C( 73), INT8_C( 91), INT8_C( 109), INT8_C( 114), -INT8_C( 68) },
{ -INT8_C( 32), -INT8_C( 28), -INT8_C( 50), INT8_C( 34), -INT8_C( 110), -INT8_C( 100), -INT8_C( 22), INT8_C( 121),
-INT8_C( 86), INT8_C( 100), -INT8_C( 50), -INT8_C( 126), INT8_C( 66), -INT8_C( 6), INT8_C( 106), INT8_C( 37) },
{ -INT8_C( 37), INT8_C( 87), INT8_C( 57), INT8_C( 92), -INT8_C( 73), -INT8_C( 33), -INT8_C( 12), -INT8_C( 35),
-INT8_C( 95), INT8_C( 96), INT8_C( 96), -INT8_C( 6), INT8_C( 21), -INT8_C( 40), -INT8_C( 126), INT8_C( 23) } },
{ { INT8_C( 20), INT8_C( 78), INT8_C( 72), INT8_C( 84), INT8_C( 65), -INT8_C( 28), INT8_C( 71), INT8_C( 108),
INT8_C( 119), -INT8_C( 81), -INT8_C( 74), -INT8_C( 46), INT8_C( 29), INT8_C( 40), -INT8_C( 114), -INT8_C( 3) },
{ INT8_C( 12), INT8_C( 93), INT8_C( 32), -INT8_C( 97), -INT8_C( 7), INT8_C( 10), INT8_C( 24), -INT8_C( 93),
INT8_C( 110), -INT8_C( 26), INT8_C( 38), -INT8_C( 79), -INT8_C( 32), -INT8_C( 112), -INT8_C( 42), -INT8_C( 11) },
{ -INT8_C( 105), -INT8_C( 77), INT8_C( 89), INT8_C( 39), INT8_C( 1), -INT8_C( 68), -INT8_C( 2), -INT8_C( 36),
INT8_C( 108), INT8_C( 72), -INT8_C( 14), -INT8_C( 112), INT8_C( 62), -INT8_C( 117), -INT8_C( 64), INT8_C( 8) } },
{ { -INT8_C( 34), INT8_C( 30), INT8_C( 73), INT8_C( 31), INT8_C( 2), -INT8_C( 112), -INT8_C( 116), INT8_C( 121),
INT8_C( 63), INT8_C( 66), INT8_C( 75), INT8_C( 92), INT8_C( 106), -INT8_C( 38), INT8_C( 90), INT8_C( 118) },
{ INT8_C( 55), INT8_C( 122), INT8_C( 21), INT8_C( 48), -INT8_C( 124), INT8_C( 45), -INT8_C( 45), -INT8_C( 14),
INT8_C( 20), -INT8_C( 7), -INT8_C( 93), -INT8_C( 12), -INT8_C( 119), INT8_C( 121), -INT8_C( 23), INT8_C( 104) },
{ -INT8_C( 85), INT8_C( 0), -INT8_C( 39), -INT8_C( 97), -INT8_C( 18), -INT8_C( 60), -INT8_C( 107), INT8_C( 85),
INT8_C( 49), INT8_C( 111), INT8_C( 7), -INT8_C( 5), -INT8_C( 47), -INT8_C( 113), INT8_C( 25), -INT8_C( 93) } },
{ { -INT8_C( 104), INT8_C( 50), -INT8_C( 121), -INT8_C( 102), -INT8_C( 62), INT8_C( 19), INT8_C( 20), INT8_C( 2),
INT8_C( 85), INT8_C( 95), INT8_C( 94), -INT8_C( 65), INT8_C( 57), -INT8_C( 72), INT8_C( 54), INT8_C( 112) },
{ INT8_C( 50), INT8_C( 75), -INT8_C( 96), -INT8_C( 74), INT8_C( 121), INT8_C( 116), -INT8_C( 87), -INT8_C( 115),
INT8_C( 109), INT8_C( 76), -INT8_C( 127), -INT8_C( 9), -INT8_C( 58), INT8_C( 107), INT8_C( 95), INT8_C( 94) },
{ -INT8_C( 48), -INT8_C( 47), INT8_C( 61), -INT8_C( 36), -INT8_C( 47), -INT8_C( 43), -INT8_C( 115), INT8_C( 121),
INT8_MIN, -INT8_C( 50), INT8_C( 107), INT8_C( 39), -INT8_C( 99), -INT8_C( 17), -INT8_C( 60), INT8_C( 105) } },
{ { -INT8_C( 99), -INT8_C( 26), -INT8_C( 8), INT8_C( 96), -INT8_C( 6), INT8_C( 12), INT8_C( 98), INT8_C( 79),
INT8_C( 108), -INT8_C( 64), INT8_C( 15), -INT8_C( 91), INT8_C( 121), INT8_C( 69), INT8_C( 22), -INT8_C( 85) },
{ -INT8_C( 112), -INT8_C( 74), INT8_C( 98), INT8_C( 9), INT8_C( 42), INT8_C( 11), -INT8_C( 106), -INT8_C( 104),
INT8_C( 87), INT8_C( 24), -INT8_C( 113), INT8_C( 29), -INT8_C( 125), -INT8_C( 18), INT8_C( 123), INT8_C( 32) },
{ -INT8_C( 27), -INT8_C( 34), -INT8_C( 103), -INT8_C( 101), INT8_C( 62), -INT8_C( 2), INT8_C( 105), -INT8_C( 79),
-INT8_C( 17), -INT8_C( 103), INT8_C( 110), INT8_C( 19), INT8_C( 44), -INT8_C( 15), -INT8_C( 48), -INT8_C( 80) } },
{ { -INT8_C( 44), INT8_C( 116), INT8_MIN, -INT8_C( 50), INT8_MIN, -INT8_C( 30), INT8_C( 30), -INT8_C( 20),
-INT8_C( 93), INT8_C( 45), -INT8_C( 110), INT8_C( 28), INT8_C( 114), -INT8_C( 88), -INT8_C( 57), INT8_C( 2) },
{ INT8_C( 94), INT8_C( 41), INT8_C( 12), -INT8_C( 119), INT8_C( 52), -INT8_C( 94), INT8_C( 33), -INT8_C( 116),
-INT8_C( 70), -INT8_C( 80), -INT8_C( 87), INT8_C( 61), -INT8_C( 98), INT8_C( 37), INT8_C( 94), INT8_C( 114) },
{ INT8_C( 71), INT8_C( 70), INT8_C( 120), INT8_C( 10), INT8_C( 14), INT8_C( 104), INT8_C( 16), INT8_C( 72),
-INT8_C( 53), -INT8_C( 117), -INT8_C( 109), INT8_C( 87), INT8_MIN, -INT8_C( 33), -INT8_C( 73), -INT8_C( 98) } },
};
for (size_t i = 0 ; i < (sizeof(test_vec) / sizeof(test_vec[0])) ; i++) {
simde__m128i a = simde_mm_loadu_si128(test_vec[i].a);
simde__m128i b = simde_mm_loadu_si128(test_vec[i].b);
simde__m128i r = simde_mm_aesdeclast_si128(a, b);
simde_test_x86_assert_equal_i8x16(r, simde_mm_loadu_si128(test_vec[i].r));
}
return 0;
}
static int
test_simde_mm_aesimc_si128 (SIMDE_MUNIT_TEST_ARGS) {
static const struct {
const int8_t a[16];
const int8_t r[16];
} test_vec[] = {
{ { INT8_C( 11), INT8_C( 100), INT8_C( 93), -INT8_C( 105), -INT8_C( 56), INT8_C( 49), INT8_C( 0), INT8_C( 43),
-INT8_C( 38), INT8_C( 64), INT8_C( 10), INT8_C( 0), -INT8_C( 98), -INT8_C( 76), -INT8_C( 1), -INT8_C( 20) },
{ INT8_C( 108), INT8_C( 13), INT8_C( 107), -INT8_C( 81), INT8_C( 52), INT8_C( 35), INT8_C( 67), -INT8_C( 122),
-INT8_C( 28), -INT8_C( 77), INT8_C( 15), -INT8_C( 56), -INT8_C( 65), -INT8_C( 77), -INT8_C( 84), -INT8_C( 103) } },
{ { -INT8_C( 62), INT8_C( 41), INT8_C( 28), INT8_C( 57), INT8_C( 95), -INT8_C( 10), -INT8_C( 41), INT8_MAX,
INT8_C( 49), -INT8_C( 124), -INT8_C( 87), -INT8_C( 20), INT8_C( 69), INT8_C( 41), -INT8_C( 92), INT8_C( 80) },
{ -INT8_C( 66), -INT8_C( 25), -INT8_C( 25), INT8_C( 112), INT8_C( 9), -INT8_C( 81), -INT8_C( 125), INT8_C( 36),
INT8_C( 39), INT8_C( 84), INT8_C( 68), -INT8_C( 57), INT8_C( 0), -INT8_C( 29), -INT8_C( 54), -INT8_C( 79) } },
{ { -INT8_C( 115), INT8_C( 2), -INT8_C( 24), INT8_C( 86), INT8_C( 51), -INT8_C( 24), -INT8_C( 127), INT8_C( 13),
INT8_C( 40), -INT8_C( 117), INT8_C( 13), -INT8_C( 58), INT8_C( 64), INT8_C( 13), -INT8_C( 78), INT8_C( 2) },
{ -INT8_C( 91), INT8_C( 36), -INT8_C( 94), INT8_C( 18), -INT8_C( 71), INT8_C( 90), -INT8_C( 91), INT8_C( 17),
-INT8_C( 28), -INT8_C( 74), INT8_C( 17), INT8_C( 43), INT8_C( 107), INT8_C( 0), INT8_C( 120), -INT8_C( 18) } },
{ { INT8_C( 54), -INT8_C( 50), INT8_C( 59), -INT8_C( 107), -INT8_C( 59), INT8_C( 18), INT8_C( 20), -INT8_C( 10),
-INT8_C( 105), -INT8_C( 67), -INT8_C( 30), -INT8_C( 36), -INT8_C( 25), -INT8_C( 121), INT8_C( 44), INT8_C( 116) },
{ INT8_C( 57), -INT8_C( 104), -INT8_C( 104), INT8_C( 111), -INT8_C( 97), INT8_C( 37), INT8_C( 36), -INT8_C( 85),
-INT8_C( 72), INT8_C( 40), -INT8_C( 27), INT8_C( 97), -INT8_C( 59), -INT8_C( 56), INT8_C( 126), INT8_C( 75) } },
{ { -INT8_C( 119), INT8_C( 20), -INT8_C( 54), -INT8_C( 68), -INT8_C( 4), INT8_C( 75), -INT8_C( 55), INT8_C( 36),
-INT8_C( 41), -INT8_C( 42), -INT8_C( 22), INT8_C( 23), -INT8_C( 29), -INT8_C( 99), INT8_C( 25), INT8_C( 26) },
{ INT8_C( 77), -INT8_C( 41), -INT8_C( 61), -INT8_C( 78), -INT8_C( 31), INT8_C( 79), INT8_C( 96), -INT8_C( 108),
INT8_C( 124), -INT8_C( 38), -INT8_C( 94), -INT8_C( 8), INT8_C( 98), INT8_C( 28), INT8_C( 98), INT8_C( 97) } },
{ { INT8_C( 107), INT8_C( 84), -INT8_C( 81), INT8_C( 48), INT8_C( 102), -INT8_C( 60), INT8_C( 38), -INT8_C( 3),
-INT8_C( 127), INT8_C( 9), -INT8_C( 39), INT8_C( 104), -INT8_C( 112), INT8_C( 6), -INT8_C( 35), INT8_C( 25) },
{ -INT8_C( 1), -INT8_C( 27), INT8_C( 96), -INT8_C( 38), -INT8_C( 66), INT8_C( 99), INT8_C( 12), -INT8_C( 88),
INT8_C( 27), -INT8_C( 57), INT8_C( 49), -INT8_C( 44), INT8_C( 124), INT8_C( 35), -INT8_C( 107), -INT8_C( 104) } },
{ { INT8_C( 26), -INT8_C( 89), -INT8_C( 43), INT8_C( 23), -INT8_C( 13), -INT8_C( 98), INT8_C( 59), -INT8_C( 54),
INT8_C( 116), INT8_C( 38), -INT8_C( 31), INT8_C( 88), -INT8_C( 61), -INT8_C( 6), INT8_C( 114), INT8_C( 46) },
{ -INT8_C( 64), INT8_C( 31), -INT8_C( 15), INT8_C( 81), INT8_C( 52), -INT8_C( 108), -INT8_C( 33), -INT8_C( 29),
INT8_C( 64), -INT8_C( 94), INT8_C( 24), INT8_C( 17), INT8_C( 35), -INT8_C( 20), INT8_C( 88), -INT8_C( 14) } },
{ { INT8_C( 78), INT8_C( 33), INT8_C( 95), -INT8_C( 76), -INT8_C( 27), -INT8_C( 123), -INT8_C( 78), INT8_C( 103),
-INT8_C( 114), -INT8_C( 117), -INT8_C( 49), INT8_C( 30), -INT8_C( 111), -INT8_C( 84), INT8_C( 55), -INT8_C( 84) },
{ INT8_C( 28), INT8_C( 119), INT8_C( 30), -INT8_C( 15), INT8_C( 8), INT8_C( 36), INT8_C( 46), -INT8_C( 73),
-INT8_C( 75), INT8_C( 79), INT8_C( 71), INT8_C( 105), -INT8_C( 92), INT8_C( 96), INT8_C( 85), INT8_C( 55) } },
};
for (size_t i = 0 ; i < (sizeof(test_vec) / sizeof(test_vec[0])) ; i++) {
simde__m128i a = simde_mm_loadu_si128(test_vec[i].a);
simde__m128i r = simde_mm_aesimc_si128(a);
simde_test_x86_assert_equal_i8x16(r, simde_mm_loadu_si128(test_vec[i].r));
}
return 0;
}
SIMDE_TEST_FUNC_LIST_BEGIN
SIMDE_TEST_FUNC_LIST_ENTRY(mm_aesenc_si128)
SIMDE_TEST_FUNC_LIST_ENTRY(mm_aesdec_si128)
SIMDE_TEST_FUNC_LIST_ENTRY(mm_aesenclast_si128)
SIMDE_TEST_FUNC_LIST_ENTRY(mm_aesdeclast_si128)
SIMDE_TEST_FUNC_LIST_ENTRY(mm_aesimc_si128)
SIMDE_TEST_FUNC_LIST_END
#include <test/x86/test-x86-footer.h>