1*2c2f96dcSApple OSS Distributions #ifdef T_NAMESPACE
2*2c2f96dcSApple OSS Distributions #undef T_NAMESPACE
3*2c2f96dcSApple OSS Distributions #endif
4*2c2f96dcSApple OSS Distributions
5*2c2f96dcSApple OSS Distributions #include <darwintest.h>
6*2c2f96dcSApple OSS Distributions #include <unistd.h>
7*2c2f96dcSApple OSS Distributions #include <signal.h>
8*2c2f96dcSApple OSS Distributions #include <sys/time.h>
9*2c2f96dcSApple OSS Distributions #include <sys/mman.h>
10*2c2f96dcSApple OSS Distributions #include <immintrin.h>
11*2c2f96dcSApple OSS Distributions #include <mach/mach.h>
12*2c2f96dcSApple OSS Distributions #include <stdio.h>
13*2c2f96dcSApple OSS Distributions #include <string.h>
14*2c2f96dcSApple OSS Distributions #include <err.h>
15*2c2f96dcSApple OSS Distributions #include <i386/cpu_capabilities.h>
16*2c2f96dcSApple OSS Distributions
17*2c2f96dcSApple OSS Distributions T_GLOBAL_META(
18*2c2f96dcSApple OSS Distributions T_META_NAMESPACE("xnu.intel"),
19*2c2f96dcSApple OSS Distributions T_META_CHECK_LEAKS(false),
20*2c2f96dcSApple OSS Distributions T_META_RADAR_COMPONENT_NAME("xnu"),
21*2c2f96dcSApple OSS Distributions T_META_RADAR_COMPONENT_VERSION("intel"),
22*2c2f96dcSApple OSS Distributions T_META_OWNER("seth_goldberg"),
23*2c2f96dcSApple OSS Distributions T_META_RUN_CONCURRENTLY(true)
24*2c2f96dcSApple OSS Distributions );
25*2c2f96dcSApple OSS Distributions
26*2c2f96dcSApple OSS Distributions #define QUICK_RUN_TIME (2)
27*2c2f96dcSApple OSS Distributions #define NORMAL_RUN_TIME (10)
28*2c2f96dcSApple OSS Distributions #define LONG_RUN_TIME (10*60)
29*2c2f96dcSApple OSS Distributions #define TIMEOUT_OVERHEAD (10)
30*2c2f96dcSApple OSS Distributions
31*2c2f96dcSApple OSS Distributions volatile boolean_t checking = true;
32*2c2f96dcSApple OSS Distributions char vec_str_buf[8196];
33*2c2f96dcSApple OSS Distributions char karray_str_buf[1024];
34*2c2f96dcSApple OSS Distributions
35*2c2f96dcSApple OSS Distributions /*
36*2c2f96dcSApple OSS Distributions * ymm defines/globals/prototypes
37*2c2f96dcSApple OSS Distributions */
38*2c2f96dcSApple OSS Distributions #define STOP_COOKIE_256 0x01234567
39*2c2f96dcSApple OSS Distributions #if defined(__x86_64__)
40*2c2f96dcSApple OSS Distributions #define YMM_MAX 16
41*2c2f96dcSApple OSS Distributions #define X86_AVX_STATE_T x86_avx_state64_t
42*2c2f96dcSApple OSS Distributions #define X86_AVX_STATE_COUNT x86_AVX_STATE64_COUNT
43*2c2f96dcSApple OSS Distributions #define X86_AVX_STATE_FLAVOR x86_AVX_STATE64
44*2c2f96dcSApple OSS Distributions #define MCONTEXT_SIZE_256 sizeof(struct __darwin_mcontext_avx64)
45*2c2f96dcSApple OSS Distributions #else
46*2c2f96dcSApple OSS Distributions #define YMM_MAX 8
47*2c2f96dcSApple OSS Distributions #define X86_AVX_STATE_T x86_avx_state32_t
48*2c2f96dcSApple OSS Distributions #define X86_AVX_STATE_COUNT x86_AVX_STATE32_COUNT
49*2c2f96dcSApple OSS Distributions #define X86_AVX_STATE_FLAVOR x86_AVX_STATE32
50*2c2f96dcSApple OSS Distributions #define MCONTEXT_SIZE_256 sizeof(struct __darwin_mcontext_avx32)
51*2c2f96dcSApple OSS Distributions #endif
52*2c2f96dcSApple OSS Distributions #define VECTOR256 __m256
53*2c2f96dcSApple OSS Distributions #define VEC256ALIGN __attribute ((aligned(32)))
54*2c2f96dcSApple OSS Distributions static inline void populate_ymm(void);
55*2c2f96dcSApple OSS Distributions static inline void check_ymm(void);
56*2c2f96dcSApple OSS Distributions VECTOR256 vec256array0[YMM_MAX] VEC256ALIGN;
57*2c2f96dcSApple OSS Distributions VECTOR256 vec256array1[YMM_MAX] VEC256ALIGN;
58*2c2f96dcSApple OSS Distributions VECTOR256 vec256array2[YMM_MAX] VEC256ALIGN;
59*2c2f96dcSApple OSS Distributions VECTOR256 vec256array3[YMM_MAX] VEC256ALIGN;
60*2c2f96dcSApple OSS Distributions
61*2c2f96dcSApple OSS Distributions /*
62*2c2f96dcSApple OSS Distributions * zmm defines/globals/prototypes
63*2c2f96dcSApple OSS Distributions */
64*2c2f96dcSApple OSS Distributions #define STOP_COOKIE_512 0x0123456789abcdefULL
65*2c2f96dcSApple OSS Distributions #if defined(__x86_64__)
66*2c2f96dcSApple OSS Distributions #define ZMM_MAX 32
67*2c2f96dcSApple OSS Distributions #define X86_AVX512_STATE_T x86_avx512_state64_t
68*2c2f96dcSApple OSS Distributions #define X86_AVX512_STATE_COUNT x86_AVX512_STATE64_COUNT
69*2c2f96dcSApple OSS Distributions #define X86_AVX512_STATE_FLAVOR x86_AVX512_STATE64
70*2c2f96dcSApple OSS Distributions #define MCONTEXT_SIZE_512 sizeof(struct __darwin_mcontext_avx512_64)
71*2c2f96dcSApple OSS Distributions #else
72*2c2f96dcSApple OSS Distributions #define ZMM_MAX 8
73*2c2f96dcSApple OSS Distributions #define X86_AVX512_STATE_T x86_avx512_state32_t
74*2c2f96dcSApple OSS Distributions #define X86_AVX512_STATE_COUNT x86_AVX512_STATE32_COUNT
75*2c2f96dcSApple OSS Distributions #define X86_AVX512_STATE_FLAVOR x86_AVX512_STATE32
76*2c2f96dcSApple OSS Distributions #define MCONTEXT_SIZE_512 sizeof(struct __darwin_mcontext_avx512_32)
77*2c2f96dcSApple OSS Distributions #endif
78*2c2f96dcSApple OSS Distributions #define VECTOR512 __m512
79*2c2f96dcSApple OSS Distributions #define VEC512ALIGN __attribute ((aligned(64)))
80*2c2f96dcSApple OSS Distributions #define OPMASK uint64_t
81*2c2f96dcSApple OSS Distributions #define KARRAY_MAX 8
82*2c2f96dcSApple OSS Distributions static inline void zero_zmm(void);
83*2c2f96dcSApple OSS Distributions static inline void zero_opmask(void);
84*2c2f96dcSApple OSS Distributions static inline void populate_zmm(void);
85*2c2f96dcSApple OSS Distributions static inline void populate_opmask(void);
86*2c2f96dcSApple OSS Distributions static inline void check_zmm(boolean_t check_cookie);
87*2c2f96dcSApple OSS Distributions VECTOR512 vec512array0[ZMM_MAX] VEC512ALIGN;
88*2c2f96dcSApple OSS Distributions VECTOR512 vec512array1[ZMM_MAX] VEC512ALIGN;
89*2c2f96dcSApple OSS Distributions VECTOR512 vec512array2[ZMM_MAX] VEC512ALIGN;
90*2c2f96dcSApple OSS Distributions VECTOR512 vec512array3[ZMM_MAX] VEC512ALIGN;
91*2c2f96dcSApple OSS Distributions OPMASK karray0[8];
92*2c2f96dcSApple OSS Distributions OPMASK karray1[8];
93*2c2f96dcSApple OSS Distributions OPMASK karray2[8];
94*2c2f96dcSApple OSS Distributions OPMASK karray3[8];
95*2c2f96dcSApple OSS Distributions
96*2c2f96dcSApple OSS Distributions kern_return_t _thread_get_state_avx(thread_t thread, int flavor, thread_state_t state,
97*2c2f96dcSApple OSS Distributions mach_msg_type_number_t *state_count);
98*2c2f96dcSApple OSS Distributions kern_return_t _thread_get_state_avx512(thread_t thread, int flavor, thread_state_t state,
99*2c2f96dcSApple OSS Distributions mach_msg_type_number_t *state_count);
100*2c2f96dcSApple OSS Distributions
101*2c2f96dcSApple OSS Distributions /*
102*2c2f96dcSApple OSS Distributions * Common functions
103*2c2f96dcSApple OSS Distributions */
104*2c2f96dcSApple OSS Distributions
105*2c2f96dcSApple OSS Distributions int
memcmp_unoptimized(const void * s1,const void * s2,size_t n)106*2c2f96dcSApple OSS Distributions memcmp_unoptimized(const void *s1, const void *s2, size_t n)
107*2c2f96dcSApple OSS Distributions {
108*2c2f96dcSApple OSS Distributions if (n != 0) {
109*2c2f96dcSApple OSS Distributions const unsigned char *p1 = s1, *p2 = s2;
110*2c2f96dcSApple OSS Distributions do {
111*2c2f96dcSApple OSS Distributions if (*p1++ != *p2++) {
112*2c2f96dcSApple OSS Distributions return *--p1 - *--p2;
113*2c2f96dcSApple OSS Distributions }
114*2c2f96dcSApple OSS Distributions } while (--n != 0);
115*2c2f96dcSApple OSS Distributions }
116*2c2f96dcSApple OSS Distributions return 0;
117*2c2f96dcSApple OSS Distributions }
118*2c2f96dcSApple OSS Distributions
119*2c2f96dcSApple OSS Distributions void
start_timer(int seconds,void (* handler)(int,siginfo_t *,void *))120*2c2f96dcSApple OSS Distributions start_timer(int seconds, void (*handler)(int, siginfo_t *, void *))
121*2c2f96dcSApple OSS Distributions {
122*2c2f96dcSApple OSS Distributions struct sigaction sigalrm_action = {
123*2c2f96dcSApple OSS Distributions .sa_sigaction = handler,
124*2c2f96dcSApple OSS Distributions .sa_flags = SA_RESTART,
125*2c2f96dcSApple OSS Distributions .sa_mask = 0
126*2c2f96dcSApple OSS Distributions };
127*2c2f96dcSApple OSS Distributions struct itimerval timer = {
128*2c2f96dcSApple OSS Distributions .it_value.tv_sec = seconds,
129*2c2f96dcSApple OSS Distributions .it_value.tv_usec = 0,
130*2c2f96dcSApple OSS Distributions .it_interval.tv_sec = 0,
131*2c2f96dcSApple OSS Distributions .it_interval.tv_usec = 0
132*2c2f96dcSApple OSS Distributions };
133*2c2f96dcSApple OSS Distributions T_QUIET; T_WITH_ERRNO;
134*2c2f96dcSApple OSS Distributions T_ASSERT_NE(sigaction(SIGALRM, &sigalrm_action, NULL), -1, NULL);
135*2c2f96dcSApple OSS Distributions T_QUIET; T_WITH_ERRNO;
136*2c2f96dcSApple OSS Distributions T_ASSERT_NE(setitimer(ITIMER_REAL, &timer, NULL), -1, NULL);
137*2c2f96dcSApple OSS Distributions }
138*2c2f96dcSApple OSS Distributions
139*2c2f96dcSApple OSS Distributions void
require_avx(void)140*2c2f96dcSApple OSS Distributions require_avx(void)
141*2c2f96dcSApple OSS Distributions {
142*2c2f96dcSApple OSS Distributions if ((_get_cpu_capabilities() & kHasAVX1_0) != kHasAVX1_0) {
143*2c2f96dcSApple OSS Distributions T_SKIP("AVX not supported on this system");
144*2c2f96dcSApple OSS Distributions }
145*2c2f96dcSApple OSS Distributions }
146*2c2f96dcSApple OSS Distributions
147*2c2f96dcSApple OSS Distributions void
require_avx512(void)148*2c2f96dcSApple OSS Distributions require_avx512(void)
149*2c2f96dcSApple OSS Distributions {
150*2c2f96dcSApple OSS Distributions if ((_get_cpu_capabilities() & kHasAVX512F) != kHasAVX512F) {
151*2c2f96dcSApple OSS Distributions T_SKIP("AVX-512 not supported on this system");
152*2c2f96dcSApple OSS Distributions }
153*2c2f96dcSApple OSS Distributions }
154*2c2f96dcSApple OSS Distributions
155*2c2f96dcSApple OSS Distributions /*
156*2c2f96dcSApple OSS Distributions * ymm functions
157*2c2f96dcSApple OSS Distributions */
158*2c2f96dcSApple OSS Distributions
159*2c2f96dcSApple OSS Distributions static inline void
store_ymm(VECTOR256 * vec256array)160*2c2f96dcSApple OSS Distributions store_ymm(VECTOR256 *vec256array)
161*2c2f96dcSApple OSS Distributions {
162*2c2f96dcSApple OSS Distributions int i = 0;
163*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %%ymm0, %0" :"=m" (vec256array[i]));
164*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%ymm1, %0" :"=m" (vec256array[i]));
165*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%ymm2, %0" :"=m" (vec256array[i]));
166*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%ymm3, %0" :"=m" (vec256array[i]));
167*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%ymm4, %0" :"=m" (vec256array[i]));
168*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%ymm5, %0" :"=m" (vec256array[i]));
169*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%ymm6, %0" :"=m" (vec256array[i]));
170*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%ymm7, %0" :"=m" (vec256array[i]));
171*2c2f96dcSApple OSS Distributions #if defined(__x86_64__)
172*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%ymm8, %0" :"=m" (vec256array[i]));
173*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%ymm9, %0" :"=m" (vec256array[i]));
174*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%ymm10, %0" :"=m" (vec256array[i]));
175*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%ymm11, %0" :"=m" (vec256array[i]));
176*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%ymm12, %0" :"=m" (vec256array[i]));
177*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%ymm13, %0" :"=m" (vec256array[i]));
178*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%ymm14, %0" :"=m" (vec256array[i]));
179*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%ymm15, %0" :"=m" (vec256array[i]));
180*2c2f96dcSApple OSS Distributions #endif
181*2c2f96dcSApple OSS Distributions }
182*2c2f96dcSApple OSS Distributions
183*2c2f96dcSApple OSS Distributions static inline void
restore_ymm(VECTOR256 * vec256array)184*2c2f96dcSApple OSS Distributions restore_ymm(VECTOR256 *vec256array)
185*2c2f96dcSApple OSS Distributions {
186*2c2f96dcSApple OSS Distributions VECTOR256 *p = vec256array;
187*2c2f96dcSApple OSS Distributions
188*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm0" :: "m" (*(__m256i*)p) : "ymm0"); p++;
189*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm1" :: "m" (*(__m256i*)p) : "ymm1"); p++;
190*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm2" :: "m" (*(__m256i*)p) : "ymm2"); p++;
191*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm3" :: "m" (*(__m256i*)p) : "ymm3"); p++;
192*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm4" :: "m" (*(__m256i*)p) : "ymm4"); p++;
193*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm5" :: "m" (*(__m256i*)p) : "ymm5"); p++;
194*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm6" :: "m" (*(__m256i*)p) : "ymm6"); p++;
195*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm7" :: "m" (*(__m256i*)p) : "ymm7");
196*2c2f96dcSApple OSS Distributions
197*2c2f96dcSApple OSS Distributions #if defined(__x86_64__)
198*2c2f96dcSApple OSS Distributions ++p; __asm__ volatile ("vmovaps %0, %%ymm8" :: "m" (*(__m256i*)p) : "ymm8"); p++;
199*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm9" :: "m" (*(__m256i*)p) : "ymm9"); p++;
200*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm10" :: "m" (*(__m256i*)p) : "ymm10"); p++;
201*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm11" :: "m" (*(__m256i*)p) : "ymm11"); p++;
202*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm12" :: "m" (*(__m256i*)p) : "ymm12"); p++;
203*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm13" :: "m" (*(__m256i*)p) : "ymm13"); p++;
204*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm14" :: "m" (*(__m256i*)p) : "ymm14"); p++;
205*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm15" :: "m" (*(__m256i*)p) : "ymm15");
206*2c2f96dcSApple OSS Distributions #endif
207*2c2f96dcSApple OSS Distributions }
208*2c2f96dcSApple OSS Distributions
209*2c2f96dcSApple OSS Distributions static inline void
populate_ymm(void)210*2c2f96dcSApple OSS Distributions populate_ymm(void)
211*2c2f96dcSApple OSS Distributions {
212*2c2f96dcSApple OSS Distributions int j;
213*2c2f96dcSApple OSS Distributions uint32_t p[8] VEC256ALIGN;
214*2c2f96dcSApple OSS Distributions
215*2c2f96dcSApple OSS Distributions for (j = 0; j < (int) (sizeof(p) / sizeof(p[0])); j++) {
216*2c2f96dcSApple OSS Distributions p[j] = getpid();
217*2c2f96dcSApple OSS Distributions }
218*2c2f96dcSApple OSS Distributions
219*2c2f96dcSApple OSS Distributions p[0] = 0x22222222;
220*2c2f96dcSApple OSS Distributions p[7] = 0x77777777;
221*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm0" :: "m" (*(__m256i*)p) : "ymm0");
222*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm1" :: "m" (*(__m256i*)p) : "ymm1");
223*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm2" :: "m" (*(__m256i*)p) : "ymm2");
224*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm3" :: "m" (*(__m256i*)p) : "ymm3");
225*2c2f96dcSApple OSS Distributions
226*2c2f96dcSApple OSS Distributions p[0] = 0x44444444;
227*2c2f96dcSApple OSS Distributions p[7] = 0xEEEEEEEE;
228*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm4" :: "m" (*(__m256i*)p) : "ymm4");
229*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm5" :: "m" (*(__m256i*)p) : "ymm5");
230*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm6" :: "m" (*(__m256i*)p) : "ymm6");
231*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm7" :: "m" (*(__m256i*)p) : "ymm7");
232*2c2f96dcSApple OSS Distributions
233*2c2f96dcSApple OSS Distributions #if defined(__x86_64__)
234*2c2f96dcSApple OSS Distributions p[0] = 0x88888888;
235*2c2f96dcSApple OSS Distributions p[7] = 0xAAAAAAAA;
236*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm8" :: "m" (*(__m256i*)p) : "ymm8");
237*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm9" :: "m" (*(__m256i*)p) : "ymm9");
238*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm10" :: "m" (*(__m256i*)p) : "ymm10");
239*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm11" :: "m" (*(__m256i*)p) : "ymm11");
240*2c2f96dcSApple OSS Distributions
241*2c2f96dcSApple OSS Distributions p[0] = 0xBBBBBBBB;
242*2c2f96dcSApple OSS Distributions p[7] = 0xCCCCCCCC;
243*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm12" :: "m" (*(__m256i*)p) : "ymm12");
244*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm13" :: "m" (*(__m256i*)p) : "ymm13");
245*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm14" :: "m" (*(__m256i*)p) : "ymm14");
246*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%ymm15" :: "m" (*(__m256i*)p) : "ymm15");
247*2c2f96dcSApple OSS Distributions #endif
248*2c2f96dcSApple OSS Distributions
249*2c2f96dcSApple OSS Distributions store_ymm(vec256array0);
250*2c2f96dcSApple OSS Distributions }
251*2c2f96dcSApple OSS Distributions
252*2c2f96dcSApple OSS Distributions void
vec256_to_string(VECTOR256 * vec,char * buf)253*2c2f96dcSApple OSS Distributions vec256_to_string(VECTOR256 *vec, char *buf)
254*2c2f96dcSApple OSS Distributions {
255*2c2f96dcSApple OSS Distributions unsigned int vec_idx = 0;
256*2c2f96dcSApple OSS Distributions unsigned int buf_idx = 0;
257*2c2f96dcSApple OSS Distributions int ret = 0;
258*2c2f96dcSApple OSS Distributions
259*2c2f96dcSApple OSS Distributions for (vec_idx = 0; vec_idx < YMM_MAX; vec_idx++) {
260*2c2f96dcSApple OSS Distributions uint64_t a[4];
261*2c2f96dcSApple OSS Distributions bcopy(&vec[vec_idx], &a[0], sizeof(a));
262*2c2f96dcSApple OSS Distributions ret = sprintf(
263*2c2f96dcSApple OSS Distributions buf + buf_idx,
264*2c2f96dcSApple OSS Distributions "0x%016llx:%016llx:%016llx:%016llx\n",
265*2c2f96dcSApple OSS Distributions a[0], a[1], a[2], a[3]
266*2c2f96dcSApple OSS Distributions );
267*2c2f96dcSApple OSS Distributions T_QUIET; T_ASSERT_POSIX_SUCCESS(ret, "sprintf()");
268*2c2f96dcSApple OSS Distributions buf_idx += ret;
269*2c2f96dcSApple OSS Distributions }
270*2c2f96dcSApple OSS Distributions }
271*2c2f96dcSApple OSS Distributions
272*2c2f96dcSApple OSS Distributions void
assert_ymm_eq(void * a,void * b,int c)273*2c2f96dcSApple OSS Distributions assert_ymm_eq(void *a, void *b, int c)
274*2c2f96dcSApple OSS Distributions {
275*2c2f96dcSApple OSS Distributions if (memcmp_unoptimized(a, b, c)) {
276*2c2f96dcSApple OSS Distributions vec256_to_string(a, vec_str_buf);
277*2c2f96dcSApple OSS Distributions T_LOG("Compare failed, vector A:\n%s", vec_str_buf);
278*2c2f96dcSApple OSS Distributions vec256_to_string(b, vec_str_buf);
279*2c2f96dcSApple OSS Distributions T_LOG("Compare failed, vector B:\n%s", vec_str_buf);
280*2c2f96dcSApple OSS Distributions T_ASSERT_FAIL("vectors not equal");
281*2c2f96dcSApple OSS Distributions }
282*2c2f96dcSApple OSS Distributions }
283*2c2f96dcSApple OSS Distributions
284*2c2f96dcSApple OSS Distributions void
check_ymm(void)285*2c2f96dcSApple OSS Distributions check_ymm(void)
286*2c2f96dcSApple OSS Distributions {
287*2c2f96dcSApple OSS Distributions uint32_t *p = (uint32_t *) &vec256array1[7];
288*2c2f96dcSApple OSS Distributions store_ymm(vec256array1);
289*2c2f96dcSApple OSS Distributions if (p[0] == STOP_COOKIE_256) {
290*2c2f96dcSApple OSS Distributions return;
291*2c2f96dcSApple OSS Distributions }
292*2c2f96dcSApple OSS Distributions assert_ymm_eq(vec256array0, vec256array1, sizeof(vec256array0));
293*2c2f96dcSApple OSS Distributions }
294*2c2f96dcSApple OSS Distributions
295*2c2f96dcSApple OSS Distributions static void
copy_ymm_state_to_vector(X86_AVX_STATE_T * sp,VECTOR256 * vp)296*2c2f96dcSApple OSS Distributions copy_ymm_state_to_vector(X86_AVX_STATE_T *sp, VECTOR256 *vp)
297*2c2f96dcSApple OSS Distributions {
298*2c2f96dcSApple OSS Distributions int i;
299*2c2f96dcSApple OSS Distributions struct __darwin_xmm_reg *xmm = &sp->__fpu_xmm0;
300*2c2f96dcSApple OSS Distributions struct __darwin_xmm_reg *ymmh = &sp->__fpu_ymmh0;
301*2c2f96dcSApple OSS Distributions
302*2c2f96dcSApple OSS Distributions for (i = 0; i < YMM_MAX; i++) {
303*2c2f96dcSApple OSS Distributions bcopy(&xmm[i], &vp[i], sizeof(*xmm));
304*2c2f96dcSApple OSS Distributions bcopy(&ymmh[i], (void *) ((uint64_t)&vp[i] + sizeof(*ymmh)), sizeof(*ymmh));
305*2c2f96dcSApple OSS Distributions }
306*2c2f96dcSApple OSS Distributions }
307*2c2f96dcSApple OSS Distributions
308*2c2f96dcSApple OSS Distributions static void
ymm_sigalrm_handler(int signum __unused,siginfo_t * info __unused,void * ctx)309*2c2f96dcSApple OSS Distributions ymm_sigalrm_handler(int signum __unused, siginfo_t *info __unused, void *ctx)
310*2c2f96dcSApple OSS Distributions {
311*2c2f96dcSApple OSS Distributions ucontext_t *contextp = (ucontext_t *) ctx;
312*2c2f96dcSApple OSS Distributions mcontext_t mcontext = contextp->uc_mcontext;
313*2c2f96dcSApple OSS Distributions X86_AVX_STATE_T *avx_state = (X86_AVX_STATE_T *) &mcontext->__fs;
314*2c2f96dcSApple OSS Distributions uint32_t *xp = (uint32_t *) &avx_state->__fpu_xmm7;
315*2c2f96dcSApple OSS Distributions uint32_t *yp = (uint32_t *) &avx_state->__fpu_ymmh7;
316*2c2f96dcSApple OSS Distributions
317*2c2f96dcSApple OSS Distributions T_LOG("Got SIGALRM");
318*2c2f96dcSApple OSS Distributions
319*2c2f96dcSApple OSS Distributions /* Check for AVX state */
320*2c2f96dcSApple OSS Distributions T_QUIET;
321*2c2f96dcSApple OSS Distributions T_ASSERT_GE(contextp->uc_mcsize, MCONTEXT_SIZE_256, "check context size");
322*2c2f96dcSApple OSS Distributions
323*2c2f96dcSApple OSS Distributions /* Check that the state in the context is what's set and expected */
324*2c2f96dcSApple OSS Distributions copy_ymm_state_to_vector(avx_state, vec256array3);
325*2c2f96dcSApple OSS Distributions assert_ymm_eq(vec256array3, vec256array0, sizeof(vec256array1));
326*2c2f96dcSApple OSS Distributions
327*2c2f96dcSApple OSS Distributions /* Change the context and break the main loop */
328*2c2f96dcSApple OSS Distributions xp[0] = STOP_COOKIE_256;
329*2c2f96dcSApple OSS Distributions yp[0] = STOP_COOKIE_256;
330*2c2f96dcSApple OSS Distributions checking = FALSE;
331*2c2f96dcSApple OSS Distributions }
332*2c2f96dcSApple OSS Distributions
333*2c2f96dcSApple OSS Distributions kern_return_t
_thread_get_state_avx(thread_t thread,int flavor,thread_state_t state,mach_msg_type_number_t * state_count)334*2c2f96dcSApple OSS Distributions _thread_get_state_avx(
335*2c2f96dcSApple OSS Distributions thread_t thread,
336*2c2f96dcSApple OSS Distributions int flavor,
337*2c2f96dcSApple OSS Distributions thread_state_t state, /* pointer to OUT array */
338*2c2f96dcSApple OSS Distributions mach_msg_type_number_t *state_count) /*IN/OUT*/
339*2c2f96dcSApple OSS Distributions {
340*2c2f96dcSApple OSS Distributions kern_return_t rv;
341*2c2f96dcSApple OSS Distributions VECTOR256 ymms[YMM_MAX];
342*2c2f96dcSApple OSS Distributions
343*2c2f96dcSApple OSS Distributions /*
344*2c2f96dcSApple OSS Distributions * We must save and restore the YMMs across thread_get_state() because
345*2c2f96dcSApple OSS Distributions * code in thread_get_state changes at least one xmm register AFTER the
346*2c2f96dcSApple OSS Distributions * thread_get_state has saved the state in userspace. While it's still
347*2c2f96dcSApple OSS Distributions * possible for something to muck with %xmms BEFORE making the mach
348*2c2f96dcSApple OSS Distributions * system call (and rendering this save/restore useless), that does not
349*2c2f96dcSApple OSS Distributions * currently occur, and since we depend on the avx state saved in the
350*2c2f96dcSApple OSS Distributions * thread_get_state to be the same as that manually copied from YMMs after
351*2c2f96dcSApple OSS Distributions * thread_get_state returns, we have to go through these machinations.
352*2c2f96dcSApple OSS Distributions */
353*2c2f96dcSApple OSS Distributions store_ymm(ymms);
354*2c2f96dcSApple OSS Distributions
355*2c2f96dcSApple OSS Distributions rv = thread_get_state(thread, flavor, state, state_count);
356*2c2f96dcSApple OSS Distributions
357*2c2f96dcSApple OSS Distributions restore_ymm(ymms);
358*2c2f96dcSApple OSS Distributions
359*2c2f96dcSApple OSS Distributions return rv;
360*2c2f96dcSApple OSS Distributions }
361*2c2f96dcSApple OSS Distributions
362*2c2f96dcSApple OSS Distributions void
ymm_integrity(int time)363*2c2f96dcSApple OSS Distributions ymm_integrity(int time)
364*2c2f96dcSApple OSS Distributions {
365*2c2f96dcSApple OSS Distributions mach_msg_type_number_t avx_count = X86_AVX_STATE_COUNT;
366*2c2f96dcSApple OSS Distributions kern_return_t kret;
367*2c2f96dcSApple OSS Distributions X86_AVX_STATE_T avx_state, avx_state2;
368*2c2f96dcSApple OSS Distributions mach_port_t ts = mach_thread_self();
369*2c2f96dcSApple OSS Distributions
370*2c2f96dcSApple OSS Distributions bzero(&avx_state, sizeof(avx_state));
371*2c2f96dcSApple OSS Distributions bzero(&avx_state2, sizeof(avx_state));
372*2c2f96dcSApple OSS Distributions
373*2c2f96dcSApple OSS Distributions kret = _thread_get_state_avx(
374*2c2f96dcSApple OSS Distributions ts, X86_AVX_STATE_FLAVOR, (thread_state_t)&avx_state, &avx_count
375*2c2f96dcSApple OSS Distributions );
376*2c2f96dcSApple OSS Distributions
377*2c2f96dcSApple OSS Distributions store_ymm(vec256array2);
378*2c2f96dcSApple OSS Distributions
379*2c2f96dcSApple OSS Distributions T_QUIET; T_ASSERT_MACH_SUCCESS(kret, "thread_get_state()");
380*2c2f96dcSApple OSS Distributions vec256_to_string(vec256array2, vec_str_buf);
381*2c2f96dcSApple OSS Distributions T_LOG("Initial state:\n%s", vec_str_buf);
382*2c2f96dcSApple OSS Distributions
383*2c2f96dcSApple OSS Distributions copy_ymm_state_to_vector(&avx_state, vec256array1);
384*2c2f96dcSApple OSS Distributions assert_ymm_eq(vec256array2, vec256array1, sizeof(vec256array1));
385*2c2f96dcSApple OSS Distributions
386*2c2f96dcSApple OSS Distributions populate_ymm();
387*2c2f96dcSApple OSS Distributions
388*2c2f96dcSApple OSS Distributions kret = _thread_get_state_avx(
389*2c2f96dcSApple OSS Distributions ts, X86_AVX_STATE_FLAVOR, (thread_state_t)&avx_state2, &avx_count
390*2c2f96dcSApple OSS Distributions );
391*2c2f96dcSApple OSS Distributions
392*2c2f96dcSApple OSS Distributions store_ymm(vec256array2);
393*2c2f96dcSApple OSS Distributions
394*2c2f96dcSApple OSS Distributions T_QUIET; T_ASSERT_MACH_SUCCESS(kret, "thread_get_state()");
395*2c2f96dcSApple OSS Distributions vec256_to_string(vec256array2, vec_str_buf);
396*2c2f96dcSApple OSS Distributions T_LOG("Populated state:\n%s", vec_str_buf);
397*2c2f96dcSApple OSS Distributions
398*2c2f96dcSApple OSS Distributions copy_ymm_state_to_vector(&avx_state2, vec256array1);
399*2c2f96dcSApple OSS Distributions assert_ymm_eq(vec256array2, vec256array1, sizeof(vec256array0));
400*2c2f96dcSApple OSS Distributions
401*2c2f96dcSApple OSS Distributions T_LOG("Running for %ds…", time);
402*2c2f96dcSApple OSS Distributions start_timer(time, ymm_sigalrm_handler);
403*2c2f96dcSApple OSS Distributions
404*2c2f96dcSApple OSS Distributions /* re-populate because printing mucks up XMMs */
405*2c2f96dcSApple OSS Distributions populate_ymm();
406*2c2f96dcSApple OSS Distributions
407*2c2f96dcSApple OSS Distributions /* Check state until timer fires */
408*2c2f96dcSApple OSS Distributions while (checking) {
409*2c2f96dcSApple OSS Distributions check_ymm();
410*2c2f96dcSApple OSS Distributions }
411*2c2f96dcSApple OSS Distributions
412*2c2f96dcSApple OSS Distributions /* Check that the sig handler changed out AVX state */
413*2c2f96dcSApple OSS Distributions store_ymm(vec256array1);
414*2c2f96dcSApple OSS Distributions
415*2c2f96dcSApple OSS Distributions uint32_t *p = (uint32_t *) &vec256array1[7];
416*2c2f96dcSApple OSS Distributions if (p[0] != STOP_COOKIE_256 ||
417*2c2f96dcSApple OSS Distributions p[4] != STOP_COOKIE_256) {
418*2c2f96dcSApple OSS Distributions vec256_to_string(vec256array1, vec_str_buf);
419*2c2f96dcSApple OSS Distributions T_ASSERT_FAIL("sigreturn failed to stick");
420*2c2f96dcSApple OSS Distributions T_LOG("State:\n%s", vec_str_buf);
421*2c2f96dcSApple OSS Distributions }
422*2c2f96dcSApple OSS Distributions
423*2c2f96dcSApple OSS Distributions T_LOG("Ran for %ds", time);
424*2c2f96dcSApple OSS Distributions T_PASS("No ymm register corruption occurred");
425*2c2f96dcSApple OSS Distributions }
426*2c2f96dcSApple OSS Distributions
427*2c2f96dcSApple OSS Distributions /*
428*2c2f96dcSApple OSS Distributions * zmm functions
429*2c2f96dcSApple OSS Distributions */
430*2c2f96dcSApple OSS Distributions
431*2c2f96dcSApple OSS Distributions static inline void
store_opmask(OPMASK k[])432*2c2f96dcSApple OSS Distributions store_opmask(OPMASK k[])
433*2c2f96dcSApple OSS Distributions {
434*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %%k0, %0" :"=m" (k[0]));
435*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %%k1, %0" :"=m" (k[1]));
436*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %%k2, %0" :"=m" (k[2]));
437*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %%k3, %0" :"=m" (k[3]));
438*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %%k4, %0" :"=m" (k[4]));
439*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %%k5, %0" :"=m" (k[5]));
440*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %%k6, %0" :"=m" (k[6]));
441*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %%k7, %0" :"=m" (k[7]));
442*2c2f96dcSApple OSS Distributions }
443*2c2f96dcSApple OSS Distributions
444*2c2f96dcSApple OSS Distributions static inline void
store_zmm(VECTOR512 * vecarray)445*2c2f96dcSApple OSS Distributions store_zmm(VECTOR512 *vecarray)
446*2c2f96dcSApple OSS Distributions {
447*2c2f96dcSApple OSS Distributions int i = 0;
448*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %%zmm0, %0" :"=m" (vecarray[i]));
449*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm1, %0" :"=m" (vecarray[i]));
450*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm2, %0" :"=m" (vecarray[i]));
451*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm3, %0" :"=m" (vecarray[i]));
452*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm4, %0" :"=m" (vecarray[i]));
453*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm5, %0" :"=m" (vecarray[i]));
454*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm6, %0" :"=m" (vecarray[i]));
455*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm7, %0" :"=m" (vecarray[i]));
456*2c2f96dcSApple OSS Distributions #if defined(__x86_64__)
457*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm8, %0" :"=m" (vecarray[i]));
458*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm9, %0" :"=m" (vecarray[i]));
459*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm10, %0" :"=m" (vecarray[i]));
460*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm11, %0" :"=m" (vecarray[i]));
461*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm12, %0" :"=m" (vecarray[i]));
462*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm13, %0" :"=m" (vecarray[i]));
463*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm14, %0" :"=m" (vecarray[i]));
464*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm15, %0" :"=m" (vecarray[i]));
465*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm16, %0" :"=m" (vecarray[i]));
466*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm17, %0" :"=m" (vecarray[i]));
467*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm18, %0" :"=m" (vecarray[i]));
468*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm19, %0" :"=m" (vecarray[i]));
469*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm20, %0" :"=m" (vecarray[i]));
470*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm21, %0" :"=m" (vecarray[i]));
471*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm22, %0" :"=m" (vecarray[i]));
472*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm23, %0" :"=m" (vecarray[i]));
473*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm24, %0" :"=m" (vecarray[i]));
474*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm25, %0" :"=m" (vecarray[i]));
475*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm26, %0" :"=m" (vecarray[i]));
476*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm27, %0" :"=m" (vecarray[i]));
477*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm28, %0" :"=m" (vecarray[i]));
478*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm29, %0" :"=m" (vecarray[i]));
479*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm30, %0" :"=m" (vecarray[i]));
480*2c2f96dcSApple OSS Distributions i++; __asm__ volatile ("vmovaps %%zmm31, %0" :"=m" (vecarray[i]));
481*2c2f96dcSApple OSS Distributions #endif
482*2c2f96dcSApple OSS Distributions }
483*2c2f96dcSApple OSS Distributions
484*2c2f96dcSApple OSS Distributions static inline void
restore_zmm(VECTOR512 * vecarray)485*2c2f96dcSApple OSS Distributions restore_zmm(VECTOR512 *vecarray)
486*2c2f96dcSApple OSS Distributions {
487*2c2f96dcSApple OSS Distributions VECTOR512 *p = vecarray;
488*2c2f96dcSApple OSS Distributions
489*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm0" :: "m" (*(__m512i*)p) : "zmm0"); p++;
490*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm1" :: "m" (*(__m512i*)p) : "zmm1"); p++;
491*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm2" :: "m" (*(__m512i*)p) : "zmm2"); p++;
492*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm3" :: "m" (*(__m512i*)p) : "zmm3"); p++;
493*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm4" :: "m" (*(__m512i*)p) : "zmm4"); p++;
494*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm5" :: "m" (*(__m512i*)p) : "zmm5"); p++;
495*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm6" :: "m" (*(__m512i*)p) : "zmm6"); p++;
496*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm7" :: "m" (*(__m512i*)p) : "zmm7");
497*2c2f96dcSApple OSS Distributions
498*2c2f96dcSApple OSS Distributions #if defined(__x86_64__)
499*2c2f96dcSApple OSS Distributions ++p; __asm__ volatile ("vmovaps %0, %%zmm8" :: "m" (*(__m512i*)p) : "zmm8"); p++;
500*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm9" :: "m" (*(__m512i*)p) : "zmm9"); p++;
501*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm10" :: "m" (*(__m512i*)p) : "zmm10"); p++;
502*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm11" :: "m" (*(__m512i*)p) : "zmm11"); p++;
503*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm12" :: "m" (*(__m512i*)p) : "zmm12"); p++;
504*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm13" :: "m" (*(__m512i*)p) : "zmm13"); p++;
505*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm14" :: "m" (*(__m512i*)p) : "zmm14"); p++;
506*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm15" :: "m" (*(__m512i*)p) : "zmm15"); p++;
507*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm16" :: "m" (*(__m512i*)p) : "zmm16"); p++;
508*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm17" :: "m" (*(__m512i*)p) : "zmm17"); p++;
509*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm18" :: "m" (*(__m512i*)p) : "zmm18"); p++;
510*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm19" :: "m" (*(__m512i*)p) : "zmm19"); p++;
511*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm20" :: "m" (*(__m512i*)p) : "zmm20"); p++;
512*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm21" :: "m" (*(__m512i*)p) : "zmm21"); p++;
513*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm22" :: "m" (*(__m512i*)p) : "zmm22"); p++;
514*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm23" :: "m" (*(__m512i*)p) : "zmm23"); p++;
515*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm24" :: "m" (*(__m512i*)p) : "zmm24"); p++;
516*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm25" :: "m" (*(__m512i*)p) : "zmm25"); p++;
517*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm26" :: "m" (*(__m512i*)p) : "zmm26"); p++;
518*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm27" :: "m" (*(__m512i*)p) : "zmm27"); p++;
519*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm28" :: "m" (*(__m512i*)p) : "zmm28"); p++;
520*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm29" :: "m" (*(__m512i*)p) : "zmm29"); p++;
521*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm30" :: "m" (*(__m512i*)p) : "zmm30"); p++;
522*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm31" :: "m" (*(__m512i*)p) : "zmm31");
523*2c2f96dcSApple OSS Distributions #endif
524*2c2f96dcSApple OSS Distributions }
525*2c2f96dcSApple OSS Distributions
526*2c2f96dcSApple OSS Distributions static inline void
zero_opmask(void)527*2c2f96dcSApple OSS Distributions zero_opmask(void)
528*2c2f96dcSApple OSS Distributions {
529*2c2f96dcSApple OSS Distributions uint64_t zero = 0x0000000000000000ULL;
530*2c2f96dcSApple OSS Distributions
531*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %0, %%k0" : :"m" (zero) : "k0");
532*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %0, %%k1" : :"m" (zero) : "k1");
533*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %0, %%k2" : :"m" (zero) : "k2");
534*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %0, %%k3" : :"m" (zero) : "k3");
535*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %0, %%k4" : :"m" (zero) : "k4");
536*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %0, %%k5" : :"m" (zero) : "k5");
537*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %0, %%k6" : :"m" (zero) : "k6");
538*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %0, %%k7" : :"m" (zero) : "k7");
539*2c2f96dcSApple OSS Distributions store_opmask(karray0);
540*2c2f96dcSApple OSS Distributions }
541*2c2f96dcSApple OSS Distributions
542*2c2f96dcSApple OSS Distributions static inline void
populate_opmask(void)543*2c2f96dcSApple OSS Distributions populate_opmask(void)
544*2c2f96dcSApple OSS Distributions {
545*2c2f96dcSApple OSS Distributions uint64_t k[8];
546*2c2f96dcSApple OSS Distributions
547*2c2f96dcSApple OSS Distributions for (int j = 0; j < 8; j++) {
548*2c2f96dcSApple OSS Distributions k[j] = ((uint64_t) getpid() << 32) + (0x11111111 * j);
549*2c2f96dcSApple OSS Distributions }
550*2c2f96dcSApple OSS Distributions
551*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %0, %%k0" : :"m" (k[0]) : "k0");
552*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %0, %%k1" : :"m" (k[1]) : "k1");
553*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %0, %%k2" : :"m" (k[2]) : "k2");
554*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %0, %%k3" : :"m" (k[3]) : "k3");
555*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %0, %%k4" : :"m" (k[4]) : "k4");
556*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %0, %%k5" : :"m" (k[5]) : "k5");
557*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %0, %%k6" : :"m" (k[6]) : "k6");
558*2c2f96dcSApple OSS Distributions __asm__ volatile ("kmovq %0, %%k7" : :"m" (k[7]) : "k7");
559*2c2f96dcSApple OSS Distributions
560*2c2f96dcSApple OSS Distributions store_opmask(karray0);
561*2c2f96dcSApple OSS Distributions }
562*2c2f96dcSApple OSS Distributions
563*2c2f96dcSApple OSS Distributions kern_return_t
_thread_get_state_avx512(thread_t thread,int flavor,thread_state_t state,mach_msg_type_number_t * state_count)564*2c2f96dcSApple OSS Distributions _thread_get_state_avx512(
565*2c2f96dcSApple OSS Distributions thread_t thread,
566*2c2f96dcSApple OSS Distributions int flavor,
567*2c2f96dcSApple OSS Distributions thread_state_t state, /* pointer to OUT array */
568*2c2f96dcSApple OSS Distributions mach_msg_type_number_t *state_count) /*IN/OUT*/
569*2c2f96dcSApple OSS Distributions {
570*2c2f96dcSApple OSS Distributions kern_return_t rv;
571*2c2f96dcSApple OSS Distributions VECTOR512 zmms[ZMM_MAX];
572*2c2f96dcSApple OSS Distributions
573*2c2f96dcSApple OSS Distributions /*
574*2c2f96dcSApple OSS Distributions * We must save and restore the ZMMs across thread_get_state() because
575*2c2f96dcSApple OSS Distributions * code in thread_get_state changes at least one xmm register AFTER the
576*2c2f96dcSApple OSS Distributions * thread_get_state has saved the state in userspace. While it's still
577*2c2f96dcSApple OSS Distributions * possible for something to muck with %XMMs BEFORE making the mach
578*2c2f96dcSApple OSS Distributions * system call (and rendering this save/restore useless), that does not
579*2c2f96dcSApple OSS Distributions * currently occur, and since we depend on the avx512 state saved in the
580*2c2f96dcSApple OSS Distributions * thread_get_state to be the same as that manually copied from ZMMs after
581*2c2f96dcSApple OSS Distributions * thread_get_state returns, we have to go through these machinations.
582*2c2f96dcSApple OSS Distributions */
583*2c2f96dcSApple OSS Distributions store_zmm(zmms);
584*2c2f96dcSApple OSS Distributions
585*2c2f96dcSApple OSS Distributions rv = thread_get_state(thread, flavor, state, state_count);
586*2c2f96dcSApple OSS Distributions
587*2c2f96dcSApple OSS Distributions restore_zmm(zmms);
588*2c2f96dcSApple OSS Distributions
589*2c2f96dcSApple OSS Distributions return rv;
590*2c2f96dcSApple OSS Distributions }
591*2c2f96dcSApple OSS Distributions
592*2c2f96dcSApple OSS Distributions static inline void
zero_zmm(void)593*2c2f96dcSApple OSS Distributions zero_zmm(void)
594*2c2f96dcSApple OSS Distributions {
595*2c2f96dcSApple OSS Distributions uint64_t zero[8] VEC512ALIGN = {0};
596*2c2f96dcSApple OSS Distributions
597*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm0" :: "m" (zero) : "zmm0");
598*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm1" :: "m" (zero) : "zmm1");
599*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm2" :: "m" (zero) : "zmm2");
600*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm3" :: "m" (zero) : "zmm3");
601*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm4" :: "m" (zero) : "zmm4");
602*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm5" :: "m" (zero) : "zmm5");
603*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm6" :: "m" (zero) : "zmm6");
604*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm7" :: "m" (zero) : "zmm7");
605*2c2f96dcSApple OSS Distributions
606*2c2f96dcSApple OSS Distributions #if defined(__x86_64__)
607*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm8" :: "m" (zero) : "zmm8");
608*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm9" :: "m" (zero) : "zmm9");
609*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm10" :: "m" (zero) : "zmm10");
610*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm11" :: "m" (zero) : "zmm11");
611*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm12" :: "m" (zero) : "zmm12");
612*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm13" :: "m" (zero) : "zmm13");
613*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm14" :: "m" (zero) : "zmm14");
614*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm15" :: "m" (zero) : "zmm15");
615*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm16" :: "m" (zero) : "zmm16");
616*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm17" :: "m" (zero) : "zmm17");
617*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm18" :: "m" (zero) : "zmm18");
618*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm19" :: "m" (zero) : "zmm19");
619*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm20" :: "m" (zero) : "zmm20");
620*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm21" :: "m" (zero) : "zmm21");
621*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm22" :: "m" (zero) : "zmm22");
622*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm23" :: "m" (zero) : "zmm23");
623*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm24" :: "m" (zero) : "zmm24");
624*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm25" :: "m" (zero) : "zmm25");
625*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm26" :: "m" (zero) : "zmm26");
626*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm27" :: "m" (zero) : "zmm27");
627*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm28" :: "m" (zero) : "zmm28");
628*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm29" :: "m" (zero) : "zmm29");
629*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm30" :: "m" (zero) : "zmm30");
630*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm31" :: "m" (zero) : "zmm31");
631*2c2f96dcSApple OSS Distributions #endif
632*2c2f96dcSApple OSS Distributions
633*2c2f96dcSApple OSS Distributions store_zmm(vec512array0);
634*2c2f96dcSApple OSS Distributions }
635*2c2f96dcSApple OSS Distributions
636*2c2f96dcSApple OSS Distributions static inline void
populate_zmm(void)637*2c2f96dcSApple OSS Distributions populate_zmm(void)
638*2c2f96dcSApple OSS Distributions {
639*2c2f96dcSApple OSS Distributions int j;
640*2c2f96dcSApple OSS Distributions uint64_t p[8] VEC512ALIGN;
641*2c2f96dcSApple OSS Distributions
642*2c2f96dcSApple OSS Distributions for (j = 0; j < (int) (sizeof(p) / sizeof(p[0])); j++) {
643*2c2f96dcSApple OSS Distributions p[j] = ((uint64_t) getpid() << 32) + getpid();
644*2c2f96dcSApple OSS Distributions }
645*2c2f96dcSApple OSS Distributions
646*2c2f96dcSApple OSS Distributions p[0] = 0x0000000000000000ULL;
647*2c2f96dcSApple OSS Distributions p[2] = 0x4444444444444444ULL;
648*2c2f96dcSApple OSS Distributions p[4] = 0x8888888888888888ULL;
649*2c2f96dcSApple OSS Distributions p[7] = 0xCCCCCCCCCCCCCCCCULL;
650*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm0" :: "m" (*(__m512i*)p) : "zmm0");
651*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm1" :: "m" (*(__m512i*)p) : "zmm1");
652*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm2" :: "m" (*(__m512i*)p) : "zmm2");
653*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm3" :: "m" (*(__m512i*)p) : "zmm3");
654*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm4" :: "m" (*(__m512i*)p) : "zmm4");
655*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm5" :: "m" (*(__m512i*)p) : "zmm5");
656*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm6" :: "m" (*(__m512i*)p) : "zmm6");
657*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm7" :: "m" (*(__m512i*)p) : "zmm7");
658*2c2f96dcSApple OSS Distributions
659*2c2f96dcSApple OSS Distributions #if defined(__x86_64__)
660*2c2f96dcSApple OSS Distributions p[0] = 0x1111111111111111ULL;
661*2c2f96dcSApple OSS Distributions p[2] = 0x5555555555555555ULL;
662*2c2f96dcSApple OSS Distributions p[4] = 0x9999999999999999ULL;
663*2c2f96dcSApple OSS Distributions p[7] = 0xDDDDDDDDDDDDDDDDULL;
664*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm8" :: "m" (*(__m512i*)p) : "zmm8");
665*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm9" :: "m" (*(__m512i*)p) : "zmm9");
666*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm10" :: "m" (*(__m512i*)p) : "zmm10");
667*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm11" :: "m" (*(__m512i*)p) : "zmm11");
668*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm12" :: "m" (*(__m512i*)p) : "zmm12");
669*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm13" :: "m" (*(__m512i*)p) : "zmm13");
670*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm14" :: "m" (*(__m512i*)p) : "zmm14");
671*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm15" :: "m" (*(__m512i*)p) : "zmm15");
672*2c2f96dcSApple OSS Distributions
673*2c2f96dcSApple OSS Distributions p[0] = 0x2222222222222222ULL;
674*2c2f96dcSApple OSS Distributions p[2] = 0x6666666666666666ULL;
675*2c2f96dcSApple OSS Distributions p[4] = 0xAAAAAAAAAAAAAAAAULL;
676*2c2f96dcSApple OSS Distributions p[7] = 0xEEEEEEEEEEEEEEEEULL;
677*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm16" :: "m" (*(__m512i*)p) : "zmm16");
678*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm17" :: "m" (*(__m512i*)p) : "zmm17");
679*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm18" :: "m" (*(__m512i*)p) : "zmm18");
680*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm19" :: "m" (*(__m512i*)p) : "zmm19");
681*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm20" :: "m" (*(__m512i*)p) : "zmm20");
682*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm21" :: "m" (*(__m512i*)p) : "zmm21");
683*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm22" :: "m" (*(__m512i*)p) : "zmm22");
684*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm23" :: "m" (*(__m512i*)p) : "zmm23");
685*2c2f96dcSApple OSS Distributions
686*2c2f96dcSApple OSS Distributions p[0] = 0x3333333333333333ULL;
687*2c2f96dcSApple OSS Distributions p[2] = 0x7777777777777777ULL;
688*2c2f96dcSApple OSS Distributions p[4] = 0xBBBBBBBBBBBBBBBBULL;
689*2c2f96dcSApple OSS Distributions p[7] = 0xFFFFFFFFFFFFFFFFULL;
690*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm24" :: "m" (*(__m512i*)p) : "zmm24");
691*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm25" :: "m" (*(__m512i*)p) : "zmm25");
692*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm26" :: "m" (*(__m512i*)p) : "zmm26");
693*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm27" :: "m" (*(__m512i*)p) : "zmm27");
694*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm28" :: "m" (*(__m512i*)p) : "zmm28");
695*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm29" :: "m" (*(__m512i*)p) : "zmm29");
696*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm30" :: "m" (*(__m512i*)p) : "zmm30");
697*2c2f96dcSApple OSS Distributions __asm__ volatile ("vmovaps %0, %%zmm31" :: "m" (*(__m512i*)p) : "zmm31");
698*2c2f96dcSApple OSS Distributions #endif
699*2c2f96dcSApple OSS Distributions
700*2c2f96dcSApple OSS Distributions store_zmm(vec512array0);
701*2c2f96dcSApple OSS Distributions }
702*2c2f96dcSApple OSS Distributions
703*2c2f96dcSApple OSS Distributions void
vec512_to_string(VECTOR512 * vec,char * buf)704*2c2f96dcSApple OSS Distributions vec512_to_string(VECTOR512 *vec, char *buf)
705*2c2f96dcSApple OSS Distributions {
706*2c2f96dcSApple OSS Distributions unsigned int vec_idx = 0;
707*2c2f96dcSApple OSS Distributions unsigned int buf_idx = 0;
708*2c2f96dcSApple OSS Distributions int ret = 0;
709*2c2f96dcSApple OSS Distributions
710*2c2f96dcSApple OSS Distributions for (vec_idx = 0; vec_idx < ZMM_MAX; vec_idx++) {
711*2c2f96dcSApple OSS Distributions uint64_t a[8];
712*2c2f96dcSApple OSS Distributions bcopy(&vec[vec_idx], &a[0], sizeof(a));
713*2c2f96dcSApple OSS Distributions ret = sprintf(
714*2c2f96dcSApple OSS Distributions buf + buf_idx,
715*2c2f96dcSApple OSS Distributions "0x%016llx:%016llx:%016llx:%016llx:"
716*2c2f96dcSApple OSS Distributions "%016llx:%016llx:%016llx:%016llx%s",
717*2c2f96dcSApple OSS Distributions a[0], a[1], a[2], a[3], a[4], a[5], a[6], a[7],
718*2c2f96dcSApple OSS Distributions vec_idx < ZMM_MAX - 1 ? "\n" : ""
719*2c2f96dcSApple OSS Distributions );
720*2c2f96dcSApple OSS Distributions T_QUIET; T_ASSERT_POSIX_SUCCESS(ret, "sprintf()");
721*2c2f96dcSApple OSS Distributions buf_idx += ret;
722*2c2f96dcSApple OSS Distributions }
723*2c2f96dcSApple OSS Distributions }
724*2c2f96dcSApple OSS Distributions
725*2c2f96dcSApple OSS Distributions void
opmask_to_string(OPMASK * karray,char * buf)726*2c2f96dcSApple OSS Distributions opmask_to_string(OPMASK *karray, char *buf)
727*2c2f96dcSApple OSS Distributions {
728*2c2f96dcSApple OSS Distributions unsigned int karray_idx = 0;
729*2c2f96dcSApple OSS Distributions unsigned int buf_idx = 0;
730*2c2f96dcSApple OSS Distributions int ret = 0;
731*2c2f96dcSApple OSS Distributions
732*2c2f96dcSApple OSS Distributions for (karray_idx = 0; karray_idx < KARRAY_MAX; karray_idx++) {
733*2c2f96dcSApple OSS Distributions ret = sprintf(
734*2c2f96dcSApple OSS Distributions buf + buf_idx,
735*2c2f96dcSApple OSS Distributions "k%d: 0x%016llx%s",
736*2c2f96dcSApple OSS Distributions karray_idx, karray[karray_idx],
737*2c2f96dcSApple OSS Distributions karray_idx < KARRAY_MAX ? "\n" : ""
738*2c2f96dcSApple OSS Distributions );
739*2c2f96dcSApple OSS Distributions T_QUIET; T_ASSERT_POSIX_SUCCESS(ret, "sprintf()");
740*2c2f96dcSApple OSS Distributions buf_idx += ret;
741*2c2f96dcSApple OSS Distributions }
742*2c2f96dcSApple OSS Distributions }
743*2c2f96dcSApple OSS Distributions
744*2c2f96dcSApple OSS Distributions static void
assert_zmm_eq(void * a,void * b,int c)745*2c2f96dcSApple OSS Distributions assert_zmm_eq(void *a, void *b, int c)
746*2c2f96dcSApple OSS Distributions {
747*2c2f96dcSApple OSS Distributions if (memcmp_unoptimized(a, b, c)) {
748*2c2f96dcSApple OSS Distributions vec512_to_string(a, vec_str_buf);
749*2c2f96dcSApple OSS Distributions T_LOG("Compare failed, vector A:\n%s", vec_str_buf);
750*2c2f96dcSApple OSS Distributions vec512_to_string(b, vec_str_buf);
751*2c2f96dcSApple OSS Distributions T_LOG("Compare failed, vector B:\n%s", vec_str_buf);
752*2c2f96dcSApple OSS Distributions T_ASSERT_FAIL("Vectors not equal");
753*2c2f96dcSApple OSS Distributions }
754*2c2f96dcSApple OSS Distributions }
755*2c2f96dcSApple OSS Distributions
756*2c2f96dcSApple OSS Distributions static void
assert_opmask_eq(OPMASK * a,OPMASK * b)757*2c2f96dcSApple OSS Distributions assert_opmask_eq(OPMASK *a, OPMASK *b)
758*2c2f96dcSApple OSS Distributions {
759*2c2f96dcSApple OSS Distributions for (int i = 0; i < KARRAY_MAX; i++) {
760*2c2f96dcSApple OSS Distributions if (a[i] != b[i]) {
761*2c2f96dcSApple OSS Distributions opmask_to_string(a, karray_str_buf);
762*2c2f96dcSApple OSS Distributions T_LOG("Compare failed, opmask A:\n%s", karray_str_buf);
763*2c2f96dcSApple OSS Distributions opmask_to_string(b, karray_str_buf);
764*2c2f96dcSApple OSS Distributions T_LOG("Compare failed, opmask B:\n%s", karray_str_buf);
765*2c2f96dcSApple OSS Distributions T_ASSERT_FAIL("opmasks not equal");
766*2c2f96dcSApple OSS Distributions }
767*2c2f96dcSApple OSS Distributions }
768*2c2f96dcSApple OSS Distributions }
769*2c2f96dcSApple OSS Distributions
770*2c2f96dcSApple OSS Distributions void
check_zmm(boolean_t check_cookie)771*2c2f96dcSApple OSS Distributions check_zmm(boolean_t check_cookie)
772*2c2f96dcSApple OSS Distributions {
773*2c2f96dcSApple OSS Distributions uint64_t *p = (uint64_t *) &vec512array1[7];
774*2c2f96dcSApple OSS Distributions store_opmask(karray1);
775*2c2f96dcSApple OSS Distributions store_zmm(vec512array1);
776*2c2f96dcSApple OSS Distributions if (check_cookie && p[0] == STOP_COOKIE_512) {
777*2c2f96dcSApple OSS Distributions return;
778*2c2f96dcSApple OSS Distributions }
779*2c2f96dcSApple OSS Distributions
780*2c2f96dcSApple OSS Distributions assert_zmm_eq(vec512array0, vec512array1, sizeof(vec512array0));
781*2c2f96dcSApple OSS Distributions assert_opmask_eq(karray0, karray1);
782*2c2f96dcSApple OSS Distributions }
783*2c2f96dcSApple OSS Distributions
784*2c2f96dcSApple OSS Distributions static void
copy_state_to_opmask(X86_AVX512_STATE_T * sp,OPMASK * op)785*2c2f96dcSApple OSS Distributions copy_state_to_opmask(X86_AVX512_STATE_T *sp, OPMASK *op)
786*2c2f96dcSApple OSS Distributions {
787*2c2f96dcSApple OSS Distributions OPMASK *k = (OPMASK *) &sp->__fpu_k0;
788*2c2f96dcSApple OSS Distributions for (int i = 0; i < KARRAY_MAX; i++) {
789*2c2f96dcSApple OSS Distributions bcopy(&k[i], &op[i], sizeof(*op));
790*2c2f96dcSApple OSS Distributions }
791*2c2f96dcSApple OSS Distributions }
792*2c2f96dcSApple OSS Distributions
793*2c2f96dcSApple OSS Distributions static void
copy_zmm_state_to_vector(X86_AVX512_STATE_T * sp,VECTOR512 * vp)794*2c2f96dcSApple OSS Distributions copy_zmm_state_to_vector(X86_AVX512_STATE_T *sp, VECTOR512 *vp)
795*2c2f96dcSApple OSS Distributions {
796*2c2f96dcSApple OSS Distributions int i;
797*2c2f96dcSApple OSS Distributions struct __darwin_xmm_reg *xmm = &sp->__fpu_xmm0;
798*2c2f96dcSApple OSS Distributions struct __darwin_xmm_reg *ymmh = &sp->__fpu_ymmh0;
799*2c2f96dcSApple OSS Distributions struct __darwin_ymm_reg *zmmh = &sp->__fpu_zmmh0;
800*2c2f96dcSApple OSS Distributions #if defined(__x86_64__)
801*2c2f96dcSApple OSS Distributions struct __darwin_zmm_reg *zmm = &sp->__fpu_zmm16;
802*2c2f96dcSApple OSS Distributions
803*2c2f96dcSApple OSS Distributions for (i = 0; i < ZMM_MAX / 2; i++) {
804*2c2f96dcSApple OSS Distributions bcopy(&xmm[i], &vp[i], sizeof(*xmm));
805*2c2f96dcSApple OSS Distributions bcopy(&ymmh[i], (void *) ((uint64_t)&vp[i] + sizeof(*ymmh)), sizeof(*ymmh));
806*2c2f96dcSApple OSS Distributions bcopy(&zmmh[i], (void *) ((uint64_t)&vp[i] + sizeof(*zmmh)), sizeof(*zmmh));
807*2c2f96dcSApple OSS Distributions bcopy(&zmm[i], &vp[(ZMM_MAX / 2) + i], sizeof(*zmm));
808*2c2f96dcSApple OSS Distributions }
809*2c2f96dcSApple OSS Distributions #else
810*2c2f96dcSApple OSS Distributions for (i = 0; i < ZMM_MAX; i++) {
811*2c2f96dcSApple OSS Distributions bcopy(&xmm[i], &vp[i], sizeof(*xmm));
812*2c2f96dcSApple OSS Distributions bcopy(&ymmh[i], (void *) ((uint64_t)&vp[i] + sizeof(*ymmh)), sizeof(*ymmh));
813*2c2f96dcSApple OSS Distributions bcopy(&zmmh[i], (void *) ((uint64_t)&vp[i] + sizeof(*zmmh)), sizeof(*zmmh));
814*2c2f96dcSApple OSS Distributions }
815*2c2f96dcSApple OSS Distributions #endif
816*2c2f96dcSApple OSS Distributions }
817*2c2f96dcSApple OSS Distributions
818*2c2f96dcSApple OSS Distributions static void
zmm_sigalrm_handler(int signum __unused,siginfo_t * info __unused,void * ctx)819*2c2f96dcSApple OSS Distributions zmm_sigalrm_handler(int signum __unused, siginfo_t *info __unused, void *ctx)
820*2c2f96dcSApple OSS Distributions {
821*2c2f96dcSApple OSS Distributions ucontext_t *contextp = (ucontext_t *) ctx;
822*2c2f96dcSApple OSS Distributions mcontext_t mcontext = contextp->uc_mcontext;
823*2c2f96dcSApple OSS Distributions X86_AVX512_STATE_T *avx_state = (X86_AVX512_STATE_T *) &mcontext->__fs;
824*2c2f96dcSApple OSS Distributions uint64_t *xp = (uint64_t *) &avx_state->__fpu_xmm7;
825*2c2f96dcSApple OSS Distributions uint64_t *yp = (uint64_t *) &avx_state->__fpu_ymmh7;
826*2c2f96dcSApple OSS Distributions uint64_t *zp = (uint64_t *) &avx_state->__fpu_zmmh7;
827*2c2f96dcSApple OSS Distributions uint64_t *kp = (uint64_t *) &avx_state->__fpu_k0;
828*2c2f96dcSApple OSS Distributions
829*2c2f96dcSApple OSS Distributions /* Check for AVX512 state */
830*2c2f96dcSApple OSS Distributions T_QUIET;
831*2c2f96dcSApple OSS Distributions T_ASSERT_GE(contextp->uc_mcsize, MCONTEXT_SIZE_512, "check context size");
832*2c2f96dcSApple OSS Distributions
833*2c2f96dcSApple OSS Distributions /* Check that the state in the context is what's set and expected */
834*2c2f96dcSApple OSS Distributions copy_zmm_state_to_vector(avx_state, vec512array3);
835*2c2f96dcSApple OSS Distributions assert_zmm_eq(vec512array3, vec512array0, sizeof(vec512array3));
836*2c2f96dcSApple OSS Distributions copy_state_to_opmask(avx_state, karray3);
837*2c2f96dcSApple OSS Distributions assert_opmask_eq(karray3, karray0);
838*2c2f96dcSApple OSS Distributions
839*2c2f96dcSApple OSS Distributions /* Change the context and break the main loop */
840*2c2f96dcSApple OSS Distributions xp[0] = STOP_COOKIE_512;
841*2c2f96dcSApple OSS Distributions yp[0] = STOP_COOKIE_512;
842*2c2f96dcSApple OSS Distributions zp[0] = STOP_COOKIE_512;
843*2c2f96dcSApple OSS Distributions kp[7] = STOP_COOKIE_512;
844*2c2f96dcSApple OSS Distributions checking = FALSE;
845*2c2f96dcSApple OSS Distributions }
846*2c2f96dcSApple OSS Distributions
847*2c2f96dcSApple OSS Distributions static void
zmm_sigalrm_handler_no_mod(int signum __unused,siginfo_t * info __unused,void * ctx)848*2c2f96dcSApple OSS Distributions zmm_sigalrm_handler_no_mod(int signum __unused, siginfo_t *info __unused, void *ctx)
849*2c2f96dcSApple OSS Distributions {
850*2c2f96dcSApple OSS Distributions ucontext_t *contextp = (ucontext_t *) ctx;
851*2c2f96dcSApple OSS Distributions mcontext_t mcontext = contextp->uc_mcontext;
852*2c2f96dcSApple OSS Distributions X86_AVX512_STATE_T *avx_state = (X86_AVX512_STATE_T *) &mcontext->__fs;
853*2c2f96dcSApple OSS Distributions uint64_t *xp = (uint64_t *) &avx_state->__fpu_xmm7;
854*2c2f96dcSApple OSS Distributions uint64_t *yp = (uint64_t *) &avx_state->__fpu_ymmh7;
855*2c2f96dcSApple OSS Distributions uint64_t *zp = (uint64_t *) &avx_state->__fpu_zmmh7;
856*2c2f96dcSApple OSS Distributions uint64_t *kp = (uint64_t *) &avx_state->__fpu_k0;
857*2c2f96dcSApple OSS Distributions
858*2c2f96dcSApple OSS Distributions /* Check for AVX512 state */
859*2c2f96dcSApple OSS Distributions T_QUIET;
860*2c2f96dcSApple OSS Distributions T_ASSERT_GE(contextp->uc_mcsize, MCONTEXT_SIZE_512, "check context size");
861*2c2f96dcSApple OSS Distributions
862*2c2f96dcSApple OSS Distributions /* Check that the state in the context is what's set and expected */
863*2c2f96dcSApple OSS Distributions copy_zmm_state_to_vector(avx_state, vec512array3);
864*2c2f96dcSApple OSS Distributions assert_zmm_eq(vec512array3, vec512array0, sizeof(vec512array3));
865*2c2f96dcSApple OSS Distributions copy_state_to_opmask(avx_state, karray3);
866*2c2f96dcSApple OSS Distributions assert_opmask_eq(karray3, karray0);
867*2c2f96dcSApple OSS Distributions
868*2c2f96dcSApple OSS Distributions /* Change the context and break the main loop */
869*2c2f96dcSApple OSS Distributions checking = FALSE;
870*2c2f96dcSApple OSS Distributions }
871*2c2f96dcSApple OSS Distributions
872*2c2f96dcSApple OSS Distributions
873*2c2f96dcSApple OSS Distributions void
zmm_integrity(int time)874*2c2f96dcSApple OSS Distributions zmm_integrity(int time)
875*2c2f96dcSApple OSS Distributions {
876*2c2f96dcSApple OSS Distributions mach_msg_type_number_t avx_count = X86_AVX512_STATE_COUNT;
877*2c2f96dcSApple OSS Distributions kern_return_t kret;
878*2c2f96dcSApple OSS Distributions X86_AVX512_STATE_T avx_state, avx_state2;
879*2c2f96dcSApple OSS Distributions mach_port_t ts = mach_thread_self();
880*2c2f96dcSApple OSS Distributions
881*2c2f96dcSApple OSS Distributions bzero(&avx_state, sizeof(avx_state));
882*2c2f96dcSApple OSS Distributions bzero(&avx_state2, sizeof(avx_state));
883*2c2f96dcSApple OSS Distributions
884*2c2f96dcSApple OSS Distributions store_zmm(vec512array2);
885*2c2f96dcSApple OSS Distributions store_opmask(karray2);
886*2c2f96dcSApple OSS Distributions
887*2c2f96dcSApple OSS Distributions kret = _thread_get_state_avx512(
888*2c2f96dcSApple OSS Distributions ts, X86_AVX512_STATE_FLAVOR, (thread_state_t)&avx_state, &avx_count
889*2c2f96dcSApple OSS Distributions );
890*2c2f96dcSApple OSS Distributions
891*2c2f96dcSApple OSS Distributions T_QUIET; T_ASSERT_MACH_SUCCESS(kret, "thread_get_state()");
892*2c2f96dcSApple OSS Distributions vec512_to_string(vec512array2, vec_str_buf);
893*2c2f96dcSApple OSS Distributions opmask_to_string(karray2, karray_str_buf);
894*2c2f96dcSApple OSS Distributions T_LOG("Initial state:\n%s\n%s", vec_str_buf, karray_str_buf);
895*2c2f96dcSApple OSS Distributions
896*2c2f96dcSApple OSS Distributions copy_zmm_state_to_vector(&avx_state, vec512array1);
897*2c2f96dcSApple OSS Distributions assert_zmm_eq(vec512array2, vec512array1, sizeof(vec512array1));
898*2c2f96dcSApple OSS Distributions copy_state_to_opmask(&avx_state, karray1);
899*2c2f96dcSApple OSS Distributions assert_opmask_eq(karray2, karray1);
900*2c2f96dcSApple OSS Distributions
901*2c2f96dcSApple OSS Distributions populate_zmm();
902*2c2f96dcSApple OSS Distributions populate_opmask();
903*2c2f96dcSApple OSS Distributions
904*2c2f96dcSApple OSS Distributions kret = _thread_get_state_avx512(
905*2c2f96dcSApple OSS Distributions ts, X86_AVX512_STATE_FLAVOR, (thread_state_t)&avx_state2, &avx_count
906*2c2f96dcSApple OSS Distributions );
907*2c2f96dcSApple OSS Distributions
908*2c2f96dcSApple OSS Distributions store_zmm(vec512array2);
909*2c2f96dcSApple OSS Distributions store_opmask(karray2);
910*2c2f96dcSApple OSS Distributions
911*2c2f96dcSApple OSS Distributions T_QUIET; T_ASSERT_MACH_SUCCESS(kret, "thread_get_state()");
912*2c2f96dcSApple OSS Distributions vec512_to_string(vec512array2, vec_str_buf);
913*2c2f96dcSApple OSS Distributions opmask_to_string(karray2, karray_str_buf);
914*2c2f96dcSApple OSS Distributions T_LOG("Populated state:\n%s\n%s", vec_str_buf, karray_str_buf);
915*2c2f96dcSApple OSS Distributions
916*2c2f96dcSApple OSS Distributions copy_zmm_state_to_vector(&avx_state2, vec512array1);
917*2c2f96dcSApple OSS Distributions assert_zmm_eq(vec512array2, vec512array1, sizeof(vec512array1));
918*2c2f96dcSApple OSS Distributions copy_state_to_opmask(&avx_state2, karray1);
919*2c2f96dcSApple OSS Distributions assert_opmask_eq(karray2, karray1);
920*2c2f96dcSApple OSS Distributions
921*2c2f96dcSApple OSS Distributions T_LOG("Running for %ds…", time);
922*2c2f96dcSApple OSS Distributions start_timer(time, zmm_sigalrm_handler);
923*2c2f96dcSApple OSS Distributions
924*2c2f96dcSApple OSS Distributions /* re-populate because printing mucks up XMMs */
925*2c2f96dcSApple OSS Distributions populate_zmm();
926*2c2f96dcSApple OSS Distributions populate_opmask();
927*2c2f96dcSApple OSS Distributions
928*2c2f96dcSApple OSS Distributions /* Check state until timer fires */
929*2c2f96dcSApple OSS Distributions while (checking) {
930*2c2f96dcSApple OSS Distributions check_zmm(TRUE);
931*2c2f96dcSApple OSS Distributions }
932*2c2f96dcSApple OSS Distributions
933*2c2f96dcSApple OSS Distributions /* Check that the sig handler changed our AVX state */
934*2c2f96dcSApple OSS Distributions store_zmm(vec512array1);
935*2c2f96dcSApple OSS Distributions store_opmask(karray1);
936*2c2f96dcSApple OSS Distributions
937*2c2f96dcSApple OSS Distributions uint64_t *p = (uint64_t *) &vec512array1[7];
938*2c2f96dcSApple OSS Distributions if (p[0] != STOP_COOKIE_512 ||
939*2c2f96dcSApple OSS Distributions p[2] != STOP_COOKIE_512 ||
940*2c2f96dcSApple OSS Distributions p[4] != STOP_COOKIE_512 ||
941*2c2f96dcSApple OSS Distributions karray1[7] != STOP_COOKIE_512) {
942*2c2f96dcSApple OSS Distributions vec512_to_string(vec512array1, vec_str_buf);
943*2c2f96dcSApple OSS Distributions opmask_to_string(karray1, karray_str_buf);
944*2c2f96dcSApple OSS Distributions T_ASSERT_FAIL("sigreturn failed to stick");
945*2c2f96dcSApple OSS Distributions T_LOG("State:\n%s\n%s", vec_str_buf, karray_str_buf);
946*2c2f96dcSApple OSS Distributions }
947*2c2f96dcSApple OSS Distributions
948*2c2f96dcSApple OSS Distributions T_LOG("Ran for %ds", time);
949*2c2f96dcSApple OSS Distributions T_PASS("No zmm register corruption occurred");
950*2c2f96dcSApple OSS Distributions }
951*2c2f96dcSApple OSS Distributions
952*2c2f96dcSApple OSS Distributions void
zmm_zeroing_optimization_integrity(int time)953*2c2f96dcSApple OSS Distributions zmm_zeroing_optimization_integrity(int time)
954*2c2f96dcSApple OSS Distributions {
955*2c2f96dcSApple OSS Distributions /*
956*2c2f96dcSApple OSS Distributions * Check ZMM zero and OpMask zero
957*2c2f96dcSApple OSS Distributions */
958*2c2f96dcSApple OSS Distributions T_LOG("Checking ZMM zero and OpMask zero");
959*2c2f96dcSApple OSS Distributions checking = true;
960*2c2f96dcSApple OSS Distributions zero_zmm();
961*2c2f96dcSApple OSS Distributions zero_opmask();
962*2c2f96dcSApple OSS Distributions
963*2c2f96dcSApple OSS Distributions T_LOG("Running for %ds…", time);
964*2c2f96dcSApple OSS Distributions start_timer(time, zmm_sigalrm_handler_no_mod);
965*2c2f96dcSApple OSS Distributions
966*2c2f96dcSApple OSS Distributions /* re-populate because printing mucks up XMMs */
967*2c2f96dcSApple OSS Distributions zero_zmm();
968*2c2f96dcSApple OSS Distributions zero_opmask();
969*2c2f96dcSApple OSS Distributions
970*2c2f96dcSApple OSS Distributions /* Check state until timer fires */
971*2c2f96dcSApple OSS Distributions while (checking) {
972*2c2f96dcSApple OSS Distributions check_zmm(FALSE);
973*2c2f96dcSApple OSS Distributions }
974*2c2f96dcSApple OSS Distributions
975*2c2f96dcSApple OSS Distributions /* Check that sig handler did not changed our AVX state */
976*2c2f96dcSApple OSS Distributions store_zmm(vec512array2);
977*2c2f96dcSApple OSS Distributions store_opmask(karray2);
978*2c2f96dcSApple OSS Distributions
979*2c2f96dcSApple OSS Distributions assert_zmm_eq(vec512array0, vec512array2, sizeof(vec512array2));
980*2c2f96dcSApple OSS Distributions assert_opmask_eq(karray0, karray2);
981*2c2f96dcSApple OSS Distributions
982*2c2f96dcSApple OSS Distributions T_LOG("Ran for %ds", time);
983*2c2f96dcSApple OSS Distributions T_PASS("ZMM zero and OpMask zero");
984*2c2f96dcSApple OSS Distributions
985*2c2f96dcSApple OSS Distributions
986*2c2f96dcSApple OSS Distributions /*
987*2c2f96dcSApple OSS Distributions * Check ZMM zero and OpMask non-zero
988*2c2f96dcSApple OSS Distributions */
989*2c2f96dcSApple OSS Distributions T_LOG("Checking ZMM zero and OpMask non-zero");
990*2c2f96dcSApple OSS Distributions checking = true;
991*2c2f96dcSApple OSS Distributions zero_zmm();
992*2c2f96dcSApple OSS Distributions populate_opmask();
993*2c2f96dcSApple OSS Distributions
994*2c2f96dcSApple OSS Distributions T_LOG("Running for %ds…", time);
995*2c2f96dcSApple OSS Distributions start_timer(time, zmm_sigalrm_handler_no_mod);
996*2c2f96dcSApple OSS Distributions
997*2c2f96dcSApple OSS Distributions /* re-populate because printing mucks up XMMs */
998*2c2f96dcSApple OSS Distributions zero_zmm();
999*2c2f96dcSApple OSS Distributions populate_opmask();
1000*2c2f96dcSApple OSS Distributions
1001*2c2f96dcSApple OSS Distributions /* Check state until timer fires */
1002*2c2f96dcSApple OSS Distributions while (checking) {
1003*2c2f96dcSApple OSS Distributions check_zmm(FALSE);
1004*2c2f96dcSApple OSS Distributions }
1005*2c2f96dcSApple OSS Distributions
1006*2c2f96dcSApple OSS Distributions /* Check that sig handler did not changed our AVX state */
1007*2c2f96dcSApple OSS Distributions store_zmm(vec512array2);
1008*2c2f96dcSApple OSS Distributions store_opmask(karray2);
1009*2c2f96dcSApple OSS Distributions
1010*2c2f96dcSApple OSS Distributions assert_zmm_eq(vec512array0, vec512array2, sizeof(vec512array2));
1011*2c2f96dcSApple OSS Distributions assert_opmask_eq(karray0, karray2);
1012*2c2f96dcSApple OSS Distributions
1013*2c2f96dcSApple OSS Distributions T_LOG("Ran for %ds", time);
1014*2c2f96dcSApple OSS Distributions T_PASS("ZMM zero and OpMask non-zero");
1015*2c2f96dcSApple OSS Distributions
1016*2c2f96dcSApple OSS Distributions
1017*2c2f96dcSApple OSS Distributions /*
1018*2c2f96dcSApple OSS Distributions * Check ZMM non-zero and OpMask zero
1019*2c2f96dcSApple OSS Distributions */
1020*2c2f96dcSApple OSS Distributions T_LOG("Checking ZMM non-zero and OpMask zero");
1021*2c2f96dcSApple OSS Distributions checking = true;
1022*2c2f96dcSApple OSS Distributions populate_zmm();
1023*2c2f96dcSApple OSS Distributions zero_opmask();
1024*2c2f96dcSApple OSS Distributions
1025*2c2f96dcSApple OSS Distributions T_LOG("Running for %ds…", time);
1026*2c2f96dcSApple OSS Distributions start_timer(time, zmm_sigalrm_handler_no_mod);
1027*2c2f96dcSApple OSS Distributions
1028*2c2f96dcSApple OSS Distributions /* re-populate because printing mucks up XMMs */
1029*2c2f96dcSApple OSS Distributions populate_zmm();
1030*2c2f96dcSApple OSS Distributions zero_opmask();
1031*2c2f96dcSApple OSS Distributions
1032*2c2f96dcSApple OSS Distributions /* Check state until timer fires */
1033*2c2f96dcSApple OSS Distributions while (checking) {
1034*2c2f96dcSApple OSS Distributions check_zmm(FALSE);
1035*2c2f96dcSApple OSS Distributions }
1036*2c2f96dcSApple OSS Distributions
1037*2c2f96dcSApple OSS Distributions /* Check that sig handler did not changed our AVX state */
1038*2c2f96dcSApple OSS Distributions store_zmm(vec512array2);
1039*2c2f96dcSApple OSS Distributions store_opmask(karray2);
1040*2c2f96dcSApple OSS Distributions
1041*2c2f96dcSApple OSS Distributions assert_zmm_eq(vec512array0, vec512array2, sizeof(vec512array2));
1042*2c2f96dcSApple OSS Distributions assert_opmask_eq(karray0, karray2);
1043*2c2f96dcSApple OSS Distributions
1044*2c2f96dcSApple OSS Distributions T_LOG("Ran for %ds", time);
1045*2c2f96dcSApple OSS Distributions T_PASS("ZMM non-zero and OpMask zero");
1046*2c2f96dcSApple OSS Distributions
1047*2c2f96dcSApple OSS Distributions
1048*2c2f96dcSApple OSS Distributions /*
1049*2c2f96dcSApple OSS Distributions * Check ZMM non-zero and OpMask non-zero
1050*2c2f96dcSApple OSS Distributions */
1051*2c2f96dcSApple OSS Distributions T_LOG("Checking ZMM non-zero and OpMask non-zero");
1052*2c2f96dcSApple OSS Distributions checking = true;
1053*2c2f96dcSApple OSS Distributions populate_zmm();
1054*2c2f96dcSApple OSS Distributions populate_opmask();
1055*2c2f96dcSApple OSS Distributions
1056*2c2f96dcSApple OSS Distributions T_LOG("Running for %ds…", time);
1057*2c2f96dcSApple OSS Distributions start_timer(time, zmm_sigalrm_handler_no_mod);
1058*2c2f96dcSApple OSS Distributions
1059*2c2f96dcSApple OSS Distributions /* re-populate because printing mucks up XMMs */
1060*2c2f96dcSApple OSS Distributions populate_zmm();
1061*2c2f96dcSApple OSS Distributions populate_opmask();
1062*2c2f96dcSApple OSS Distributions
1063*2c2f96dcSApple OSS Distributions /* Check state until timer fires */
1064*2c2f96dcSApple OSS Distributions while (checking) {
1065*2c2f96dcSApple OSS Distributions check_zmm(FALSE);
1066*2c2f96dcSApple OSS Distributions }
1067*2c2f96dcSApple OSS Distributions
1068*2c2f96dcSApple OSS Distributions /* Check that sig handler did not changed our AVX state */
1069*2c2f96dcSApple OSS Distributions store_zmm(vec512array2);
1070*2c2f96dcSApple OSS Distributions store_opmask(karray2);
1071*2c2f96dcSApple OSS Distributions
1072*2c2f96dcSApple OSS Distributions assert_zmm_eq(vec512array0, vec512array2, sizeof(vec512array2));
1073*2c2f96dcSApple OSS Distributions assert_opmask_eq(karray0, karray2);
1074*2c2f96dcSApple OSS Distributions
1075*2c2f96dcSApple OSS Distributions T_LOG("Ran for %ds", time);
1076*2c2f96dcSApple OSS Distributions T_PASS("ZMM non-zero and OpMask non-zero");
1077*2c2f96dcSApple OSS Distributions }
1078*2c2f96dcSApple OSS Distributions
1079*2c2f96dcSApple OSS Distributions /*
1080*2c2f96dcSApple OSS Distributions * Main test declarations
1081*2c2f96dcSApple OSS Distributions */
1082*2c2f96dcSApple OSS Distributions T_DECL(ymm_integrity,
1083*2c2f96dcSApple OSS Distributions "Quick soak test to verify that AVX "
1084*2c2f96dcSApple OSS Distributions "register state is maintained correctly",
1085*2c2f96dcSApple OSS Distributions T_META_TIMEOUT(NORMAL_RUN_TIME + TIMEOUT_OVERHEAD)) {
1086*2c2f96dcSApple OSS Distributions require_avx();
1087*2c2f96dcSApple OSS Distributions ymm_integrity(NORMAL_RUN_TIME);
1088*2c2f96dcSApple OSS Distributions }
1089*2c2f96dcSApple OSS Distributions
1090*2c2f96dcSApple OSS Distributions T_DECL(ymm_integrity_stress,
1091*2c2f96dcSApple OSS Distributions "Extended soak test to verify that AVX "
1092*2c2f96dcSApple OSS Distributions "register state is maintained correctly",
1093*2c2f96dcSApple OSS Distributions T_META_TIMEOUT(LONG_RUN_TIME + TIMEOUT_OVERHEAD),
1094*2c2f96dcSApple OSS Distributions T_META_ENABLED(false)) {
1095*2c2f96dcSApple OSS Distributions require_avx();
1096*2c2f96dcSApple OSS Distributions ymm_integrity(LONG_RUN_TIME);
1097*2c2f96dcSApple OSS Distributions }
1098*2c2f96dcSApple OSS Distributions
1099*2c2f96dcSApple OSS Distributions T_DECL(zmm_integrity,
1100*2c2f96dcSApple OSS Distributions "Quick soak test to verify that AVX-512 "
1101*2c2f96dcSApple OSS Distributions "register state is maintained correctly",
1102*2c2f96dcSApple OSS Distributions T_META_TIMEOUT(NORMAL_RUN_TIME + TIMEOUT_OVERHEAD)) {
1103*2c2f96dcSApple OSS Distributions require_avx512();
1104*2c2f96dcSApple OSS Distributions zmm_integrity(NORMAL_RUN_TIME);
1105*2c2f96dcSApple OSS Distributions }
1106*2c2f96dcSApple OSS Distributions
1107*2c2f96dcSApple OSS Distributions T_DECL(zmm_integrity_stress,
1108*2c2f96dcSApple OSS Distributions "Extended soak test to verify that AVX-512 "
1109*2c2f96dcSApple OSS Distributions "register state is maintained correctly",
1110*2c2f96dcSApple OSS Distributions T_META_TIMEOUT(LONG_RUN_TIME + TIMEOUT_OVERHEAD),
1111*2c2f96dcSApple OSS Distributions T_META_ENABLED(false)) {
1112*2c2f96dcSApple OSS Distributions require_avx512();
1113*2c2f96dcSApple OSS Distributions zmm_integrity(LONG_RUN_TIME);
1114*2c2f96dcSApple OSS Distributions }
1115*2c2f96dcSApple OSS Distributions
1116*2c2f96dcSApple OSS Distributions T_DECL(zmm_zeroing_optimization_integrity,
1117*2c2f96dcSApple OSS Distributions "Quick soak test to verify AVX-512 "
1118*2c2f96dcSApple OSS Distributions "register state is maintained with "
1119*2c2f96dcSApple OSS Distributions "zeroing optimizations enabled",
1120*2c2f96dcSApple OSS Distributions T_META_TIMEOUT(QUICK_RUN_TIME + TIMEOUT_OVERHEAD)) {
1121*2c2f96dcSApple OSS Distributions require_avx512();
1122*2c2f96dcSApple OSS Distributions zmm_zeroing_optimization_integrity(QUICK_RUN_TIME);
1123*2c2f96dcSApple OSS Distributions }
1124