[libc][NFC] Remove extra ; in exhaustive_test.h. (#124216)
[llvm-project.git] / lldb / test / Shell / Register / Core / Inputs / x86-core-dump.cpp
blobf6183a57bd5fec4837b072ff253113c2e1840f03
1 // This program is used to generate a core dump for testing register dumps.
2 // The exact set of registers dumped depends on the instruction sets enabled
3 // via compiler flags.
5 #include <cstdint>
7 struct alignas(64) zmm_t {
8 uint64_t a, b, c, d, e, f, g, h;
9 };
11 struct alignas(16) float80_raw {
12 uint64_t mantissa;
13 uint16_t sign_exp;
16 int main() {
17 // test data for xmm, ymm and zmm registers
18 constexpr zmm_t zmm[] = {
19 { 0x0706050403020100, 0x0F0E0D0C0B0A0908,
20 0x1716151413121110, 0x1F1E1D1C1B1A1918,
21 0x2726252423222120, 0x2F2E2D2C2B2A2928,
22 0x3736353433323130, 0x3F3E3D3C3B3A3938, },
23 { 0x0807060504030201, 0x100F0E0D0C0B0A09,
24 0x1817161514131211, 0x201F1E1D1C1B1A19,
25 0x2827262524232221, 0x302F2E2D2C2B2A29,
26 0x3837363534333231, 0x403F3E3D3C3B3A39, },
27 { 0x0908070605040302, 0x11100F0E0D0C0B0A,
28 0x1918171615141312, 0x21201F1E1D1C1B1A,
29 0x2928272625242322, 0x31302F2E2D2C2B2A,
30 0x3938373635343332, 0x41403F3E3D3C3B3A, },
31 { 0x0A09080706050403, 0x1211100F0E0D0C0B,
32 0x1A19181716151413, 0x2221201F1E1D1C1B,
33 0x2A29282726252423, 0x3231302F2E2D2C2B,
34 0x3A39383736353433, 0x4241403F3E3D3C3B, },
35 { 0x0B0A090807060504, 0x131211100F0E0D0C,
36 0x1B1A191817161514, 0x232221201F1E1D1C,
37 0x2B2A292827262524, 0x333231302F2E2D2C,
38 0x3B3A393837363534, 0x434241403F3E3D3C, },
39 { 0x0C0B0A0908070605, 0x14131211100F0E0D,
40 0x1C1B1A1918171615, 0x24232221201F1E1D,
41 0x2C2B2A2928272625, 0x34333231302F2E2D,
42 0x3C3B3A3938373635, 0x44434241403F3E3D, },
43 { 0x0D0C0B0A09080706, 0x1514131211100F0E,
44 0x1D1C1B1A19181716, 0x2524232221201F1E,
45 0x2D2C2B2A29282726, 0x3534333231302F2E,
46 0x3D3C3B3A39383736, 0x4544434241403F3E, },
47 { 0x0E0D0C0B0A090807, 0x161514131211100F,
48 0x1E1D1C1B1A191817, 0x262524232221201F,
49 0x2E2D2C2B2A292827, 0x363534333231302F,
50 0x3E3D3C3B3A393837, 0x464544434241403F, },
51 #if defined(__x86_64__) || defined(_M_X64)
52 { 0x0F0E0D0C0B0A0908, 0x1716151413121110,
53 0x1F1E1D1C1B1A1918, 0x2726252423222120,
54 0x2F2E2D2C2B2A2928, 0x3736353433323130,
55 0x3F3E3D3C3B3A3938, 0x4746454443424140, },
56 { 0x100F0E0D0C0B0A09, 0x1817161514131211,
57 0x201F1E1D1C1B1A19, 0x2827262524232221,
58 0x302F2E2D2C2B2A29, 0x3837363534333231,
59 0x403F3E3D3C3B3A39, 0x4847464544434241, },
60 { 0x11100F0E0D0C0B0A, 0x1918171615141312,
61 0x21201F1E1D1C1B1A, 0x2928272625242322,
62 0x31302F2E2D2C2B2A, 0x3938373635343332,
63 0x41403F3E3D3C3B3A, 0x4948474645444342, },
64 { 0x1211100F0E0D0C0B, 0x1A19181716151413,
65 0x2221201F1E1D1C1B, 0x2A29282726252423,
66 0x3231302F2E2D2C2B, 0x3A39383736353433,
67 0x4241403F3E3D3C3B, 0x4A49484746454443, },
68 { 0x131211100F0E0D0C, 0x1B1A191817161514,
69 0x232221201F1E1D1C, 0x2B2A292827262524,
70 0x333231302F2E2D2C, 0x3B3A393837363534,
71 0x434241403F3E3D3C, 0x4B4A494847464544, },
72 { 0x14131211100F0E0D, 0x1C1B1A1918171615,
73 0x24232221201F1E1D, 0x2C2B2A2928272625,
74 0x34333231302F2E2D, 0x3C3B3A3938373635,
75 0x44434241403F3E3D, 0x4C4B4A4948474645, },
76 { 0x1514131211100F0E, 0x1D1C1B1A19181716,
77 0x2524232221201F1E, 0x2D2C2B2A29282726,
78 0x3534333231302F2E, 0x3D3C3B3A39383736,
79 0x4544434241403F3E, 0x4D4C4B4A49484746, },
80 { 0x161514131211100F, 0x1E1D1C1B1A191817,
81 0x262524232221201F, 0x2E2D2C2B2A292827,
82 0x363534333231302F, 0x3E3D3C3B3A393837,
83 0x464544434241403F, 0x4E4D4C4B4A494847, },
84 { 0x1716151413121110, 0x1F1E1D1C1B1A1918,
85 0x2726252423222120, 0x2F2E2D2C2B2A2928,
86 0x3736353433323130, 0x3F3E3D3C3B3A3938,
87 0x4746454443424140, 0x4F4E4D4C4B4A4948, },
88 { 0x1817161514131211, 0x201F1E1D1C1B1A19,
89 0x2827262524232221, 0x302F2E2D2C2B2A29,
90 0x3837363534333231, 0x403F3E3D3C3B3A39,
91 0x4847464544434241, 0x504F4E4D4C4B4A49, },
92 { 0x1918171615141312, 0x21201F1E1D1C1B1A,
93 0x2928272625242322, 0x31302F2E2D2C2B2A,
94 0x3938373635343332, 0x41403F3E3D3C3B3A,
95 0x4948474645444342, 0x51504F4E4D4C4B4A, },
96 { 0x1A19181716151413, 0x2221201F1E1D1C1B,
97 0x2A29282726252423, 0x3231302F2E2D2C2B,
98 0x3A39383736353433, 0x4241403F3E3D3C3B,
99 0x4A49484746454443, 0x5251504F4E4D4C4B, },
100 { 0x1B1A191817161514, 0x232221201F1E1D1C,
101 0x2B2A292827262524, 0x333231302F2E2D2C,
102 0x3B3A393837363534, 0x434241403F3E3D3C,
103 0x4B4A494847464544, 0x535251504F4E4D4C, },
104 { 0x1C1B1A1918171615, 0x24232221201F1E1D,
105 0x2C2B2A2928272625, 0x34333231302F2E2D,
106 0x3C3B3A3938373635, 0x44434241403F3E3D,
107 0x4C4B4A4948474645, 0x54535251504F4E4D, },
108 { 0x1D1C1B1A19181716, 0x2524232221201F1E,
109 0x2D2C2B2A29282726, 0x3534333231302F2E,
110 0x3D3C3B3A39383736, 0x4544434241403F3E,
111 0x4D4C4B4A49484746, 0x5554535251504F4E, },
112 { 0x1E1D1C1B1A191817, 0x262524232221201F,
113 0x2E2D2C2B2A292827, 0x363534333231302F,
114 0x3E3D3C3B3A393837, 0x464544434241403F,
115 0x4E4D4C4B4A494847, 0x565554535251504F, },
116 { 0x1F1E1D1C1B1A1918, 0x2726252423222120,
117 0x2F2E2D2C2B2A2928, 0x3736353433323130,
118 0x3F3E3D3C3B3A3938, 0x4746454443424140,
119 0x4F4E4D4C4B4A4948, 0x5756555453525150, },
120 { 0x201F1E1D1C1B1A19, 0x2827262524232221,
121 0x302F2E2D2C2B2A29, 0x3837363534333231,
122 0x403F3E3D3C3B3A39, 0x4847464544434241,
123 0x504F4E4D4C4B4A49, 0x5857565554535251, },
124 { 0x21201F1E1D1C1B1A, 0x2928272625242322,
125 0x31302F2E2D2C2B2A, 0x3938373635343332,
126 0x41403F3E3D3C3B3A, 0x4948474645444342,
127 0x51504F4E4D4C4B4A, 0x5958575655545352, },
128 { 0x2221201F1E1D1C1B, 0x2A29282726252423,
129 0x3231302F2E2D2C2B, 0x3A39383736353433,
130 0x4241403F3E3D3C3B, 0x4A49484746454443,
131 0x5251504F4E4D4C4B, 0x5A59585756555453, },
132 { 0x232221201F1E1D1C, 0x2B2A292827262524,
133 0x333231302F2E2D2C, 0x3B3A393837363534,
134 0x434241403F3E3D3C, 0x4B4A494847464544,
135 0x535251504F4E4D4C, 0x5B5A595857565554, },
136 { 0x24232221201F1E1D, 0x2C2B2A2928272625,
137 0x34333231302F2E2D, 0x3C3B3A3938373635,
138 0x44434241403F3E3D, 0x4C4B4A4948474645,
139 0x54535251504F4E4D, 0x5C5B5A5958575655, },
140 { 0x2524232221201F1E, 0x2D2C2B2A29282726,
141 0x3534333231302F2E, 0x3D3C3B3A39383736,
142 0x4544434241403F3E, 0x4D4C4B4A49484746,
143 0x5554535251504F4E, 0x5D5C5B5A59585756, },
144 { 0x262524232221201F, 0x2E2D2C2B2A292827,
145 0x363534333231302F, 0x3E3D3C3B3A393837,
146 0x464544434241403F, 0x4E4D4C4B4A494847,
147 0x565554535251504F, 0x5E5D5C5B5A595857, },
148 #endif
151 // test data for FPU registers
152 float80_raw st[] = {
153 {0x8000000000000000, 0x4000}, // +2.0
154 {0x3f00000000000000, 0x0000}, // 1.654785e-4932 (denormal)
155 {0x0000000000000000, 0x0000}, // +0
156 {0x0000000000000000, 0x8000}, // -0
157 {0x8000000000000000, 0x7fff}, // +inf
158 {0x8000000000000000, 0xffff}, // -inf
159 {0xc000000000000000, 0xffff}, // nan
160 // st7 will be freed to test tag word better
161 {0x0000000000000000, 0x0000}, // +0
164 // unmask divide-by-zero exception
165 uint16_t cw = 0x037b;
166 // used as single-precision float
167 uint32_t zero = 0;
169 // test data for GP registers
170 const uint64_t gpr[] = {
171 0x2726252423222120,
172 0x2827262524232221,
173 0x2928272625242322,
174 0x2A29282726252423,
175 0x2B2A292827262524,
176 0x2C2B2A2928272625,
177 0x2D2C2B2A29282726,
178 0x2E2D2C2B2A292827,
179 0x2F2E2D2C2B2A2928,
180 0x302F2E2D2C2B2A29,
181 0x31302F2E2D2C2B2A,
182 0x3231302F2E2D2C2B,
183 0x333231302F2E2D2C,
184 0x34333231302F2E2D,
185 0x3534333231302F2E,
186 0x363534333231302F,
189 asm volatile(
190 // fill the highest register set supported -- ZMM, YMM or XMM
191 #if defined(__AVX512F__)
192 "vmovaps 0x000(%0), %%zmm0\n\t"
193 "vmovaps 0x040(%0), %%zmm1\n\t"
194 "vmovaps 0x080(%0), %%zmm2\n\t"
195 "vmovaps 0x0C0(%0), %%zmm3\n\t"
196 "vmovaps 0x100(%0), %%zmm4\n\t"
197 "vmovaps 0x140(%0), %%zmm5\n\t"
198 "vmovaps 0x180(%0), %%zmm6\n\t"
199 "vmovaps 0x1C0(%0), %%zmm7\n\t"
200 #if defined(__x86_64__) || defined(_M_X64)
201 "vmovaps 0x200(%0), %%zmm8\n\t"
202 "vmovaps 0x240(%0), %%zmm9\n\t"
203 "vmovaps 0x280(%0), %%zmm10\n\t"
204 "vmovaps 0x2C0(%0), %%zmm11\n\t"
205 "vmovaps 0x300(%0), %%zmm12\n\t"
206 "vmovaps 0x340(%0), %%zmm13\n\t"
207 "vmovaps 0x380(%0), %%zmm14\n\t"
208 "vmovaps 0x3C0(%0), %%zmm15\n\t"
209 "vmovaps 0x400(%0), %%zmm16\n\t"
210 "vmovaps 0x440(%0), %%zmm17\n\t"
211 "vmovaps 0x480(%0), %%zmm18\n\t"
212 "vmovaps 0x4C0(%0), %%zmm19\n\t"
213 "vmovaps 0x500(%0), %%zmm20\n\t"
214 "vmovaps 0x540(%0), %%zmm21\n\t"
215 "vmovaps 0x580(%0), %%zmm22\n\t"
216 "vmovaps 0x5C0(%0), %%zmm23\n\t"
217 "vmovaps 0x600(%0), %%zmm24\n\t"
218 "vmovaps 0x640(%0), %%zmm25\n\t"
219 "vmovaps 0x680(%0), %%zmm26\n\t"
220 "vmovaps 0x6C0(%0), %%zmm27\n\t"
221 "vmovaps 0x700(%0), %%zmm28\n\t"
222 "vmovaps 0x740(%0), %%zmm29\n\t"
223 "vmovaps 0x780(%0), %%zmm30\n\t"
224 "vmovaps 0x7C0(%0), %%zmm31\n\t"
225 #endif // defined(__x86_64__) || defined(_M_X64)
226 #elif defined(__AVX__)
227 "vmovaps 0x000(%0), %%ymm0\n\t"
228 "vmovaps 0x040(%0), %%ymm1\n\t"
229 "vmovaps 0x080(%0), %%ymm2\n\t"
230 "vmovaps 0x0C0(%0), %%ymm3\n\t"
231 "vmovaps 0x100(%0), %%ymm4\n\t"
232 "vmovaps 0x140(%0), %%ymm5\n\t"
233 "vmovaps 0x180(%0), %%ymm6\n\t"
234 "vmovaps 0x1C0(%0), %%ymm7\n\t"
235 #if defined(__x86_64__) || defined(_M_X64)
236 "vmovaps 0x200(%0), %%ymm8\n\t"
237 "vmovaps 0x240(%0), %%ymm9\n\t"
238 "vmovaps 0x280(%0), %%ymm10\n\t"
239 "vmovaps 0x2C0(%0), %%ymm11\n\t"
240 "vmovaps 0x300(%0), %%ymm12\n\t"
241 "vmovaps 0x340(%0), %%ymm13\n\t"
242 "vmovaps 0x380(%0), %%ymm14\n\t"
243 "vmovaps 0x3C0(%0), %%ymm15\n\t"
244 #endif // defined(__x86_64__) || defined(_M_X64)
245 #else // !defined(__AVX__)
246 "movaps 0x000(%0), %%xmm0\n\t"
247 "movaps 0x040(%0), %%xmm1\n\t"
248 "movaps 0x080(%0), %%xmm2\n\t"
249 "movaps 0x0C0(%0), %%xmm3\n\t"
250 "movaps 0x100(%0), %%xmm4\n\t"
251 "movaps 0x140(%0), %%xmm5\n\t"
252 "movaps 0x180(%0), %%xmm6\n\t"
253 "movaps 0x1C0(%0), %%xmm7\n\t"
254 #if defined(__x86_64__) || defined(_M_X64)
255 "movaps 0x200(%0), %%xmm8\n\t"
256 "movaps 0x240(%0), %%xmm9\n\t"
257 "movaps 0x280(%0), %%xmm10\n\t"
258 "movaps 0x2C0(%0), %%xmm11\n\t"
259 "movaps 0x300(%0), %%xmm12\n\t"
260 "movaps 0x340(%0), %%xmm13\n\t"
261 "movaps 0x380(%0), %%xmm14\n\t"
262 "movaps 0x3C0(%0), %%xmm15\n\t"
263 #endif // defined(__x86_64__) || defined(_M_X64)
264 #endif
265 "\n\t"
267 // fill FPU registers
268 "finit\n\t"
269 "fldcw %2\n\t"
270 // load on stack in reverse order to make the result easier to read
271 "fldt 0x70(%1)\n\t"
272 "fldt 0x60(%1)\n\t"
273 "fldt 0x50(%1)\n\t"
274 "fldt 0x40(%1)\n\t"
275 "fldt 0x30(%1)\n\t"
276 "fldt 0x20(%1)\n\t"
277 "fldt 0x10(%1)\n\t"
278 "fldt 0x00(%1)\n\t"
279 // free st7
280 "ffree %%st(7)\n\t"
281 // this should trigger a divide-by-zero
282 "fdivs (%3)\n\t"
283 "\n\t"
285 // fill GP registers
286 // note that this invalidates all parameters
287 #if defined(__x86_64__) || defined(_M_X64)
288 "movq 0x78(%4), %%r15\n\t"
289 "movq 0x70(%4), %%r14\n\t"
290 "movq 0x68(%4), %%r13\n\t"
291 "movq 0x60(%4), %%r12\n\t"
292 "movq 0x58(%4), %%r11\n\t"
293 "movq 0x50(%4), %%r10\n\t"
294 "movq 0x48(%4), %%r9\n\t"
295 "movq 0x40(%4), %%r8\n\t"
296 "movq 0x38(%4), %%rdi\n\t"
297 "movq 0x30(%4), %%rsi\n\t"
298 "movq 0x28(%4), %%rbp\n\t"
299 "movq 0x20(%4), %%rsp\n\t"
300 "movq 0x18(%4), %%rdx\n\t"
301 "movq 0x10(%4), %%rcx\n\t"
302 "movq 0x08(%4), %%rbx\n\t"
303 "movq 0x00(%4), %%rax\n\t"
304 #else // !(defined(__x86_64__) || defined(_M_X64))
305 "movl 0x38(%4), %%edi\n\t"
306 "movl 0x30(%4), %%esi\n\t"
307 "movl 0x28(%4), %%ebp\n\t"
308 "movl 0x20(%4), %%esp\n\t"
309 "movl 0x18(%4), %%edx\n\t"
310 "movl 0x10(%4), %%ecx\n\t"
311 "movl 0x08(%4), %%ebx\n\t"
312 "movl 0x00(%4), %%eax\n\t"
313 #endif
314 "\n\t"
316 // trigger SEGV
317 "movl %%eax, 0\n\t"
319 : "b"(zmm), "c"(st), "m"(cw), "d"(&zero), "a"(gpr)
320 : // clobbers do not really matter since we crash
323 return 0;