1 | //===-- CodeViewRegisters.def - CodeView registers --------------*- C++ -*-===// |
2 | // |
3 | // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
4 | // See https://llvm.org/LICENSE.txt for license information. |
5 | // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
6 | // |
7 | //===----------------------------------------------------------------------===// |
8 | // |
9 | // See CV_HREG_e in cvconst.h. This should match the constants there. |
10 | // |
11 | //===----------------------------------------------------------------------===// |
12 | |
13 | #ifndef CV_REGISTER |
14 | #define CV_REGISTER(name, value) |
15 | #endif |
16 | |
17 | #if !defined(CV_REGISTERS_ALL) && !defined(CV_REGISTERS_X86) && \ |
18 | !defined(CV_REGISTERS_ARM) && \ |
19 | !defined(CV_REGISTERS_ARM64) && \ |
20 | !defined(CV_REGISTERS_MIPS) |
21 | #error Need include at least one register set. |
22 | #endif |
23 | |
24 | // This currently only contains the "register subset shared by all processor |
25 | // types" (ERR etc.) and the x86/arm64 registers. |
26 | |
27 | #if defined(CV_REGISTERS_ALL) || defined(CV_REGISTERS_X86) |
28 | |
29 | // Some system headers define macros that conflict with our enums. Every |
30 | // compiler supported by LLVM has the push_macro and pop_macro pragmas, so use |
31 | // them to avoid the conflict. |
32 | #pragma push_macro("CR0") |
33 | #pragma push_macro("CR1") |
34 | #pragma push_macro("CR2") |
35 | #pragma push_macro("CR3") |
36 | #pragma push_macro("CR4") |
37 | |
38 | CV_REGISTER(ERR, 30000) |
39 | CV_REGISTER(TEB, 30001) |
40 | CV_REGISTER(TIMER, 30002) |
41 | CV_REGISTER(EFAD1, 30003) |
42 | CV_REGISTER(EFAD2, 30004) |
43 | CV_REGISTER(EFAD3, 30005) |
44 | CV_REGISTER(VFRAME, 30006) |
45 | CV_REGISTER(HANDLE, 30007) |
46 | CV_REGISTER(PARAMS, 30008) |
47 | CV_REGISTER(LOCALS, 30009) |
48 | CV_REGISTER(TID, 30010) |
49 | CV_REGISTER(ENV, 30011) |
50 | CV_REGISTER(CMDLN, 30012) |
51 | |
52 | CV_REGISTER(NONE, 0) |
53 | CV_REGISTER(AL, 1) |
54 | CV_REGISTER(CL, 2) |
55 | CV_REGISTER(DL, 3) |
56 | CV_REGISTER(BL, 4) |
57 | CV_REGISTER(AH, 5) |
58 | CV_REGISTER(CH, 6) |
59 | CV_REGISTER(DH, 7) |
60 | CV_REGISTER(BH, 8) |
61 | CV_REGISTER(AX, 9) |
62 | CV_REGISTER(CX, 10) |
63 | CV_REGISTER(DX, 11) |
64 | CV_REGISTER(BX, 12) |
65 | CV_REGISTER(SP, 13) |
66 | CV_REGISTER(BP, 14) |
67 | CV_REGISTER(SI, 15) |
68 | CV_REGISTER(DI, 16) |
69 | CV_REGISTER(EAX, 17) |
70 | CV_REGISTER(ECX, 18) |
71 | CV_REGISTER(EDX, 19) |
72 | CV_REGISTER(EBX, 20) |
73 | CV_REGISTER(ESP, 21) |
74 | CV_REGISTER(EBP, 22) |
75 | CV_REGISTER(ESI, 23) |
76 | CV_REGISTER(EDI, 24) |
77 | CV_REGISTER(ES, 25) |
78 | CV_REGISTER(CS, 26) |
79 | CV_REGISTER(SS, 27) |
80 | CV_REGISTER(DS, 28) |
81 | CV_REGISTER(FS, 29) |
82 | CV_REGISTER(GS, 30) |
83 | CV_REGISTER(IP, 31) |
84 | CV_REGISTER(FLAGS, 32) |
85 | CV_REGISTER(EIP, 33) |
86 | CV_REGISTER(EFLAGS, 34) |
87 | CV_REGISTER(TEMP, 40) |
88 | CV_REGISTER(TEMPH, 41) |
89 | CV_REGISTER(QUOTE, 42) |
90 | CV_REGISTER(PCDR3, 43) |
91 | CV_REGISTER(PCDR4, 44) |
92 | CV_REGISTER(PCDR5, 45) |
93 | CV_REGISTER(PCDR6, 46) |
94 | CV_REGISTER(PCDR7, 47) |
95 | CV_REGISTER(CR0, 80) |
96 | CV_REGISTER(CR1, 81) |
97 | CV_REGISTER(CR2, 82) |
98 | CV_REGISTER(CR3, 83) |
99 | CV_REGISTER(CR4, 84) |
100 | CV_REGISTER(DR0, 90) |
101 | CV_REGISTER(DR1, 91) |
102 | CV_REGISTER(DR2, 92) |
103 | CV_REGISTER(DR3, 93) |
104 | CV_REGISTER(DR4, 94) |
105 | CV_REGISTER(DR5, 95) |
106 | CV_REGISTER(DR6, 96) |
107 | CV_REGISTER(DR7, 97) |
108 | CV_REGISTER(GDTR, 110) |
109 | CV_REGISTER(GDTL, 111) |
110 | CV_REGISTER(IDTR, 112) |
111 | CV_REGISTER(IDTL, 113) |
112 | CV_REGISTER(LDTR, 114) |
113 | CV_REGISTER(TR, 115) |
114 | |
115 | CV_REGISTER(PSEUDO1, 116) |
116 | CV_REGISTER(PSEUDO2, 117) |
117 | CV_REGISTER(PSEUDO3, 118) |
118 | CV_REGISTER(PSEUDO4, 119) |
119 | CV_REGISTER(PSEUDO5, 120) |
120 | CV_REGISTER(PSEUDO6, 121) |
121 | CV_REGISTER(PSEUDO7, 122) |
122 | CV_REGISTER(PSEUDO8, 123) |
123 | CV_REGISTER(PSEUDO9, 124) |
124 | |
125 | CV_REGISTER(ST0, 128) |
126 | CV_REGISTER(ST1, 129) |
127 | CV_REGISTER(ST2, 130) |
128 | CV_REGISTER(ST3, 131) |
129 | CV_REGISTER(ST4, 132) |
130 | CV_REGISTER(ST5, 133) |
131 | CV_REGISTER(ST6, 134) |
132 | CV_REGISTER(ST7, 135) |
133 | CV_REGISTER(CTRL, 136) |
134 | CV_REGISTER(STAT, 137) |
135 | CV_REGISTER(TAG, 138) |
136 | CV_REGISTER(FPIP, 139) |
137 | CV_REGISTER(FPCS, 140) |
138 | CV_REGISTER(FPDO, 141) |
139 | CV_REGISTER(FPDS, 142) |
140 | CV_REGISTER(ISEM, 143) |
141 | CV_REGISTER(FPEIP, 144) |
142 | CV_REGISTER(FPEDO, 145) |
143 | |
144 | CV_REGISTER(MM0, 146) |
145 | CV_REGISTER(MM1, 147) |
146 | CV_REGISTER(MM2, 148) |
147 | CV_REGISTER(MM3, 149) |
148 | CV_REGISTER(MM4, 150) |
149 | CV_REGISTER(MM5, 151) |
150 | CV_REGISTER(MM6, 152) |
151 | CV_REGISTER(MM7, 153) |
152 | |
153 | CV_REGISTER(XMM0, 154) |
154 | CV_REGISTER(XMM1, 155) |
155 | CV_REGISTER(XMM2, 156) |
156 | CV_REGISTER(XMM3, 157) |
157 | CV_REGISTER(XMM4, 158) |
158 | CV_REGISTER(XMM5, 159) |
159 | CV_REGISTER(XMM6, 160) |
160 | CV_REGISTER(XMM7, 161) |
161 | |
162 | CV_REGISTER(MXCSR, 211) |
163 | |
164 | CV_REGISTER(EDXEAX, 212) |
165 | |
166 | CV_REGISTER(EMM0L, 220) |
167 | CV_REGISTER(EMM1L, 221) |
168 | CV_REGISTER(EMM2L, 222) |
169 | CV_REGISTER(EMM3L, 223) |
170 | CV_REGISTER(EMM4L, 224) |
171 | CV_REGISTER(EMM5L, 225) |
172 | CV_REGISTER(EMM6L, 226) |
173 | CV_REGISTER(EMM7L, 227) |
174 | |
175 | CV_REGISTER(EMM0H, 228) |
176 | CV_REGISTER(EMM1H, 229) |
177 | CV_REGISTER(EMM2H, 230) |
178 | CV_REGISTER(EMM3H, 231) |
179 | CV_REGISTER(EMM4H, 232) |
180 | CV_REGISTER(EMM5H, 233) |
181 | CV_REGISTER(EMM6H, 234) |
182 | CV_REGISTER(EMM7H, 235) |
183 | |
184 | CV_REGISTER(MM00, 236) |
185 | CV_REGISTER(MM01, 237) |
186 | CV_REGISTER(MM10, 238) |
187 | CV_REGISTER(MM11, 239) |
188 | CV_REGISTER(MM20, 240) |
189 | CV_REGISTER(MM21, 241) |
190 | CV_REGISTER(MM30, 242) |
191 | CV_REGISTER(MM31, 243) |
192 | CV_REGISTER(MM40, 244) |
193 | CV_REGISTER(MM41, 245) |
194 | CV_REGISTER(MM50, 246) |
195 | CV_REGISTER(MM51, 247) |
196 | CV_REGISTER(MM60, 248) |
197 | CV_REGISTER(MM61, 249) |
198 | CV_REGISTER(MM70, 250) |
199 | CV_REGISTER(MM71, 251) |
200 | |
201 | CV_REGISTER(BND0, 396) |
202 | CV_REGISTER(BND1, 397) |
203 | CV_REGISTER(BND2, 398) |
204 | |
205 | |
206 | CV_REGISTER(XMM8, 252) |
207 | CV_REGISTER(XMM9, 253) |
208 | CV_REGISTER(XMM10, 254) |
209 | CV_REGISTER(XMM11, 255) |
210 | CV_REGISTER(XMM12, 256) |
211 | CV_REGISTER(XMM13, 257) |
212 | CV_REGISTER(XMM14, 258) |
213 | CV_REGISTER(XMM15, 259) |
214 | |
215 | |
216 | CV_REGISTER(SIL, 324) |
217 | CV_REGISTER(DIL, 325) |
218 | CV_REGISTER(BPL, 326) |
219 | CV_REGISTER(SPL, 327) |
220 | |
221 | CV_REGISTER(RAX, 328) |
222 | CV_REGISTER(RBX, 329) |
223 | CV_REGISTER(RCX, 330) |
224 | CV_REGISTER(RDX, 331) |
225 | CV_REGISTER(RSI, 332) |
226 | CV_REGISTER(RDI, 333) |
227 | CV_REGISTER(RBP, 334) |
228 | CV_REGISTER(RSP, 335) |
229 | |
230 | CV_REGISTER(R8, 336) |
231 | CV_REGISTER(R9, 337) |
232 | CV_REGISTER(R10, 338) |
233 | CV_REGISTER(R11, 339) |
234 | CV_REGISTER(R12, 340) |
235 | CV_REGISTER(R13, 341) |
236 | CV_REGISTER(R14, 342) |
237 | CV_REGISTER(R15, 343) |
238 | |
239 | CV_REGISTER(R8B, 344) |
240 | CV_REGISTER(R9B, 345) |
241 | CV_REGISTER(R10B, 346) |
242 | CV_REGISTER(R11B, 347) |
243 | CV_REGISTER(R12B, 348) |
244 | CV_REGISTER(R13B, 349) |
245 | CV_REGISTER(R14B, 350) |
246 | CV_REGISTER(R15B, 351) |
247 | |
248 | CV_REGISTER(R8W, 352) |
249 | CV_REGISTER(R9W, 353) |
250 | CV_REGISTER(R10W, 354) |
251 | CV_REGISTER(R11W, 355) |
252 | CV_REGISTER(R12W, 356) |
253 | CV_REGISTER(R13W, 357) |
254 | CV_REGISTER(R14W, 358) |
255 | CV_REGISTER(R15W, 359) |
256 | |
257 | CV_REGISTER(R8D, 360) |
258 | CV_REGISTER(R9D, 361) |
259 | CV_REGISTER(R10D, 362) |
260 | CV_REGISTER(R11D, 363) |
261 | CV_REGISTER(R12D, 364) |
262 | CV_REGISTER(R13D, 365) |
263 | CV_REGISTER(R14D, 366) |
264 | CV_REGISTER(R15D, 367) |
265 | |
266 | |
267 | // cvconst.h defines both CV_REG_YMM0 (252) and CV_AMD64_YMM0 (368). Keep the |
268 | // original prefix to distinguish them. |
269 | |
270 | CV_REGISTER(AMD64_YMM0, 368) |
271 | CV_REGISTER(AMD64_YMM1, 369) |
272 | CV_REGISTER(AMD64_YMM2, 370) |
273 | CV_REGISTER(AMD64_YMM3, 371) |
274 | CV_REGISTER(AMD64_YMM4, 372) |
275 | CV_REGISTER(AMD64_YMM5, 373) |
276 | CV_REGISTER(AMD64_YMM6, 374) |
277 | CV_REGISTER(AMD64_YMM7, 375) |
278 | CV_REGISTER(AMD64_YMM8, 376) |
279 | CV_REGISTER(AMD64_YMM9, 377) |
280 | CV_REGISTER(AMD64_YMM10, 378) |
281 | CV_REGISTER(AMD64_YMM11, 379) |
282 | CV_REGISTER(AMD64_YMM12, 380) |
283 | CV_REGISTER(AMD64_YMM13, 381) |
284 | CV_REGISTER(AMD64_YMM14, 382) |
285 | CV_REGISTER(AMD64_YMM15, 383) |
286 | |
287 | CV_REGISTER(AMD64_XMM16, 694) |
288 | CV_REGISTER(AMD64_XMM17, 695) |
289 | CV_REGISTER(AMD64_XMM18, 696) |
290 | CV_REGISTER(AMD64_XMM19, 697) |
291 | CV_REGISTER(AMD64_XMM20, 698) |
292 | CV_REGISTER(AMD64_XMM21, 699) |
293 | CV_REGISTER(AMD64_XMM22, 700) |
294 | CV_REGISTER(AMD64_XMM23, 701) |
295 | CV_REGISTER(AMD64_XMM24, 702) |
296 | CV_REGISTER(AMD64_XMM25, 703) |
297 | CV_REGISTER(AMD64_XMM26, 704) |
298 | CV_REGISTER(AMD64_XMM27, 705) |
299 | CV_REGISTER(AMD64_XMM28, 706) |
300 | CV_REGISTER(AMD64_XMM29, 707) |
301 | CV_REGISTER(AMD64_XMM30, 708) |
302 | CV_REGISTER(AMD64_XMM31, 709) |
303 | |
304 | CV_REGISTER(AMD64_YMM16, 710) |
305 | CV_REGISTER(AMD64_YMM17, 711) |
306 | CV_REGISTER(AMD64_YMM18, 712) |
307 | CV_REGISTER(AMD64_YMM19, 713) |
308 | CV_REGISTER(AMD64_YMM20, 714) |
309 | CV_REGISTER(AMD64_YMM21, 715) |
310 | CV_REGISTER(AMD64_YMM22, 716) |
311 | CV_REGISTER(AMD64_YMM23, 717) |
312 | CV_REGISTER(AMD64_YMM24, 718) |
313 | CV_REGISTER(AMD64_YMM25, 719) |
314 | CV_REGISTER(AMD64_YMM26, 720) |
315 | CV_REGISTER(AMD64_YMM27, 721) |
316 | CV_REGISTER(AMD64_YMM28, 722) |
317 | CV_REGISTER(AMD64_YMM29, 723) |
318 | CV_REGISTER(AMD64_YMM30, 724) |
319 | CV_REGISTER(AMD64_YMM31, 725) |
320 | |
321 | CV_REGISTER(AMD64_ZMM0, 726) |
322 | CV_REGISTER(AMD64_ZMM1, 727) |
323 | CV_REGISTER(AMD64_ZMM2, 728) |
324 | CV_REGISTER(AMD64_ZMM3, 729) |
325 | CV_REGISTER(AMD64_ZMM4, 730) |
326 | CV_REGISTER(AMD64_ZMM5, 731) |
327 | CV_REGISTER(AMD64_ZMM6, 732) |
328 | CV_REGISTER(AMD64_ZMM7, 733) |
329 | CV_REGISTER(AMD64_ZMM8, 734) |
330 | CV_REGISTER(AMD64_ZMM9, 735) |
331 | CV_REGISTER(AMD64_ZMM10, 736) |
332 | CV_REGISTER(AMD64_ZMM11, 737) |
333 | CV_REGISTER(AMD64_ZMM12, 738) |
334 | CV_REGISTER(AMD64_ZMM13, 739) |
335 | CV_REGISTER(AMD64_ZMM14, 740) |
336 | CV_REGISTER(AMD64_ZMM15, 741) |
337 | CV_REGISTER(AMD64_ZMM16, 742) |
338 | CV_REGISTER(AMD64_ZMM17, 743) |
339 | CV_REGISTER(AMD64_ZMM18, 744) |
340 | CV_REGISTER(AMD64_ZMM19, 745) |
341 | CV_REGISTER(AMD64_ZMM20, 746) |
342 | CV_REGISTER(AMD64_ZMM21, 747) |
343 | CV_REGISTER(AMD64_ZMM22, 748) |
344 | CV_REGISTER(AMD64_ZMM23, 749) |
345 | CV_REGISTER(AMD64_ZMM24, 750) |
346 | CV_REGISTER(AMD64_ZMM25, 751) |
347 | CV_REGISTER(AMD64_ZMM26, 752) |
348 | CV_REGISTER(AMD64_ZMM27, 753) |
349 | CV_REGISTER(AMD64_ZMM28, 754) |
350 | CV_REGISTER(AMD64_ZMM29, 755) |
351 | CV_REGISTER(AMD64_ZMM30, 756) |
352 | CV_REGISTER(AMD64_ZMM31, 757) |
353 | |
354 | CV_REGISTER(AMD64_K0, 758) |
355 | CV_REGISTER(AMD64_K1, 759) |
356 | CV_REGISTER(AMD64_K2, 760) |
357 | CV_REGISTER(AMD64_K3, 761) |
358 | CV_REGISTER(AMD64_K4, 762) |
359 | CV_REGISTER(AMD64_K5, 763) |
360 | CV_REGISTER(AMD64_K6, 764) |
361 | CV_REGISTER(AMD64_K7, 765) |
362 | |
363 | #pragma pop_macro("CR0") |
364 | #pragma pop_macro("CR1") |
365 | #pragma pop_macro("CR2") |
366 | #pragma pop_macro("CR3") |
367 | #pragma pop_macro("CR4") |
368 | |
369 | #endif // defined(CV_REGISTERS_ALL) || defined(CV_REGISTERS_X86) |
370 | |
371 | #if defined(CV_REGISTERS_ALL) || defined(CV_REGISTERS_ARM) |
372 | |
373 | // ARM registers |
374 | |
375 | CV_REGISTER(ARM_NOREG, 0) |
376 | |
377 | // General purpose 32-bit integer registers |
378 | |
379 | CV_REGISTER(ARM_R0, 10) |
380 | CV_REGISTER(ARM_R1, 11) |
381 | CV_REGISTER(ARM_R2, 12) |
382 | CV_REGISTER(ARM_R3, 13) |
383 | CV_REGISTER(ARM_R4, 14) |
384 | CV_REGISTER(ARM_R5, 15) |
385 | CV_REGISTER(ARM_R6, 16) |
386 | CV_REGISTER(ARM_R7, 17) |
387 | CV_REGISTER(ARM_R8, 18) |
388 | CV_REGISTER(ARM_R9, 19) |
389 | CV_REGISTER(ARM_R10, 20) |
390 | CV_REGISTER(ARM_R11, 21) |
391 | CV_REGISTER(ARM_R12, 22) |
392 | CV_REGISTER(ARM_SP, 23) |
393 | CV_REGISTER(ARM_LR, 24) |
394 | CV_REGISTER(ARM_PC, 25) |
395 | |
396 | // Status register |
397 | |
398 | CV_REGISTER(ARM_CPSR, 26) |
399 | |
400 | // ARM VFPv1 registers |
401 | |
402 | CV_REGISTER(ARM_FPSCR, 40) |
403 | CV_REGISTER(ARM_FPEXC, 41) |
404 | |
405 | CV_REGISTER(ARM_FS0, 50) |
406 | CV_REGISTER(ARM_FS1, 51) |
407 | CV_REGISTER(ARM_FS2, 52) |
408 | CV_REGISTER(ARM_FS3, 53) |
409 | CV_REGISTER(ARM_FS4, 54) |
410 | CV_REGISTER(ARM_FS5, 55) |
411 | CV_REGISTER(ARM_FS6, 56) |
412 | CV_REGISTER(ARM_FS7, 57) |
413 | CV_REGISTER(ARM_FS8, 58) |
414 | CV_REGISTER(ARM_FS9, 59) |
415 | CV_REGISTER(ARM_FS10, 60) |
416 | CV_REGISTER(ARM_FS11, 61) |
417 | CV_REGISTER(ARM_FS12, 62) |
418 | CV_REGISTER(ARM_FS13, 63) |
419 | CV_REGISTER(ARM_FS14, 64) |
420 | CV_REGISTER(ARM_FS15, 65) |
421 | CV_REGISTER(ARM_FS16, 66) |
422 | CV_REGISTER(ARM_FS17, 67) |
423 | CV_REGISTER(ARM_FS18, 68) |
424 | CV_REGISTER(ARM_FS19, 69) |
425 | CV_REGISTER(ARM_FS20, 70) |
426 | CV_REGISTER(ARM_FS21, 71) |
427 | CV_REGISTER(ARM_FS22, 72) |
428 | CV_REGISTER(ARM_FS23, 73) |
429 | CV_REGISTER(ARM_FS24, 74) |
430 | CV_REGISTER(ARM_FS25, 75) |
431 | CV_REGISTER(ARM_FS26, 76) |
432 | CV_REGISTER(ARM_FS27, 77) |
433 | CV_REGISTER(ARM_FS28, 78) |
434 | CV_REGISTER(ARM_FS29, 79) |
435 | CV_REGISTER(ARM_FS30, 80) |
436 | CV_REGISTER(ARM_FS31, 81) |
437 | |
438 | // ARM VFPv3/NEON registers |
439 | |
440 | CV_REGISTER(ARM_FS32, 200) |
441 | CV_REGISTER(ARM_FS33, 201) |
442 | CV_REGISTER(ARM_FS34, 202) |
443 | CV_REGISTER(ARM_FS35, 203) |
444 | CV_REGISTER(ARM_FS36, 204) |
445 | CV_REGISTER(ARM_FS37, 205) |
446 | CV_REGISTER(ARM_FS38, 206) |
447 | CV_REGISTER(ARM_FS39, 207) |
448 | CV_REGISTER(ARM_FS40, 208) |
449 | CV_REGISTER(ARM_FS41, 209) |
450 | CV_REGISTER(ARM_FS42, 210) |
451 | CV_REGISTER(ARM_FS43, 211) |
452 | CV_REGISTER(ARM_FS44, 212) |
453 | CV_REGISTER(ARM_FS45, 213) |
454 | CV_REGISTER(ARM_FS46, 214) |
455 | CV_REGISTER(ARM_FS47, 215) |
456 | CV_REGISTER(ARM_FS48, 216) |
457 | CV_REGISTER(ARM_FS49, 217) |
458 | CV_REGISTER(ARM_FS50, 218) |
459 | CV_REGISTER(ARM_FS51, 219) |
460 | CV_REGISTER(ARM_FS52, 220) |
461 | CV_REGISTER(ARM_FS53, 221) |
462 | CV_REGISTER(ARM_FS54, 222) |
463 | CV_REGISTER(ARM_FS55, 223) |
464 | CV_REGISTER(ARM_FS56, 224) |
465 | CV_REGISTER(ARM_FS57, 225) |
466 | CV_REGISTER(ARM_FS58, 226) |
467 | CV_REGISTER(ARM_FS59, 227) |
468 | CV_REGISTER(ARM_FS60, 228) |
469 | CV_REGISTER(ARM_FS61, 229) |
470 | CV_REGISTER(ARM_FS62, 230) |
471 | CV_REGISTER(ARM_FS63, 231) |
472 | |
473 | CV_REGISTER(ARM_ND0, 300) |
474 | CV_REGISTER(ARM_ND1, 301) |
475 | CV_REGISTER(ARM_ND2, 302) |
476 | CV_REGISTER(ARM_ND3, 303) |
477 | CV_REGISTER(ARM_ND4, 304) |
478 | CV_REGISTER(ARM_ND5, 305) |
479 | CV_REGISTER(ARM_ND6, 306) |
480 | CV_REGISTER(ARM_ND7, 307) |
481 | CV_REGISTER(ARM_ND8, 308) |
482 | CV_REGISTER(ARM_ND9, 309) |
483 | CV_REGISTER(ARM_ND10, 310) |
484 | CV_REGISTER(ARM_ND11, 311) |
485 | CV_REGISTER(ARM_ND12, 312) |
486 | CV_REGISTER(ARM_ND13, 313) |
487 | CV_REGISTER(ARM_ND14, 314) |
488 | CV_REGISTER(ARM_ND15, 315) |
489 | CV_REGISTER(ARM_ND16, 316) |
490 | CV_REGISTER(ARM_ND17, 317) |
491 | CV_REGISTER(ARM_ND18, 318) |
492 | CV_REGISTER(ARM_ND19, 319) |
493 | CV_REGISTER(ARM_ND20, 320) |
494 | CV_REGISTER(ARM_ND21, 321) |
495 | CV_REGISTER(ARM_ND22, 322) |
496 | CV_REGISTER(ARM_ND23, 323) |
497 | CV_REGISTER(ARM_ND24, 324) |
498 | CV_REGISTER(ARM_ND25, 325) |
499 | CV_REGISTER(ARM_ND26, 326) |
500 | CV_REGISTER(ARM_ND27, 327) |
501 | CV_REGISTER(ARM_ND28, 328) |
502 | CV_REGISTER(ARM_ND29, 329) |
503 | CV_REGISTER(ARM_ND30, 330) |
504 | CV_REGISTER(ARM_ND31, 331) |
505 | |
506 | CV_REGISTER(ARM_NQ0, 400) |
507 | CV_REGISTER(ARM_NQ1, 401) |
508 | CV_REGISTER(ARM_NQ2, 402) |
509 | CV_REGISTER(ARM_NQ3, 403) |
510 | CV_REGISTER(ARM_NQ4, 404) |
511 | CV_REGISTER(ARM_NQ5, 405) |
512 | CV_REGISTER(ARM_NQ6, 406) |
513 | CV_REGISTER(ARM_NQ7, 407) |
514 | CV_REGISTER(ARM_NQ8, 408) |
515 | CV_REGISTER(ARM_NQ9, 409) |
516 | CV_REGISTER(ARM_NQ10, 410) |
517 | CV_REGISTER(ARM_NQ11, 411) |
518 | CV_REGISTER(ARM_NQ12, 412) |
519 | CV_REGISTER(ARM_NQ13, 413) |
520 | CV_REGISTER(ARM_NQ14, 414) |
521 | CV_REGISTER(ARM_NQ15, 415) |
522 | |
523 | #endif // defined(CV_REGISTERS_ALL) || defined(CV_REGISTERS_ARM) |
524 | |
525 | #if defined(CV_REGISTERS_ALL) || defined(CV_REGISTERS_ARM64) |
526 | |
527 | // arm64intr.h from MSVC defines ARM64_FPSR and ARM64_FPCR, which conflicts with |
528 | // these declarations. |
529 | #pragma push_macro("ARM64_FPSR") |
530 | #pragma push_macro("ARM64_FPCR") |
531 | #undef ARM64_FPSR |
532 | #undef ARM64_FPCR |
533 | |
534 | // ARM64 registers |
535 | |
536 | CV_REGISTER(ARM64_NOREG, 0) |
537 | |
538 | // General purpose 32-bit integer registers |
539 | |
540 | CV_REGISTER(ARM64_W0, 10) |
541 | CV_REGISTER(ARM64_W1, 11) |
542 | CV_REGISTER(ARM64_W2, 12) |
543 | CV_REGISTER(ARM64_W3, 13) |
544 | CV_REGISTER(ARM64_W4, 14) |
545 | CV_REGISTER(ARM64_W5, 15) |
546 | CV_REGISTER(ARM64_W6, 16) |
547 | CV_REGISTER(ARM64_W7, 17) |
548 | CV_REGISTER(ARM64_W8, 18) |
549 | CV_REGISTER(ARM64_W9, 19) |
550 | CV_REGISTER(ARM64_W10, 20) |
551 | CV_REGISTER(ARM64_W11, 21) |
552 | CV_REGISTER(ARM64_W12, 22) |
553 | CV_REGISTER(ARM64_W13, 23) |
554 | CV_REGISTER(ARM64_W14, 24) |
555 | CV_REGISTER(ARM64_W15, 25) |
556 | CV_REGISTER(ARM64_W16, 26) |
557 | CV_REGISTER(ARM64_W17, 27) |
558 | CV_REGISTER(ARM64_W18, 28) |
559 | CV_REGISTER(ARM64_W19, 29) |
560 | CV_REGISTER(ARM64_W20, 30) |
561 | CV_REGISTER(ARM64_W21, 31) |
562 | CV_REGISTER(ARM64_W22, 32) |
563 | CV_REGISTER(ARM64_W23, 33) |
564 | CV_REGISTER(ARM64_W24, 34) |
565 | CV_REGISTER(ARM64_W25, 35) |
566 | CV_REGISTER(ARM64_W26, 36) |
567 | CV_REGISTER(ARM64_W27, 37) |
568 | CV_REGISTER(ARM64_W28, 38) |
569 | CV_REGISTER(ARM64_W29, 39) |
570 | CV_REGISTER(ARM64_W30, 40) |
571 | CV_REGISTER(ARM64_WZR, 41) |
572 | |
573 | // General purpose 64-bit integer registers |
574 | |
575 | CV_REGISTER(ARM64_X0, 50) |
576 | CV_REGISTER(ARM64_X1, 51) |
577 | CV_REGISTER(ARM64_X2, 52) |
578 | CV_REGISTER(ARM64_X3, 53) |
579 | CV_REGISTER(ARM64_X4, 54) |
580 | CV_REGISTER(ARM64_X5, 55) |
581 | CV_REGISTER(ARM64_X6, 56) |
582 | CV_REGISTER(ARM64_X7, 57) |
583 | CV_REGISTER(ARM64_X8, 58) |
584 | CV_REGISTER(ARM64_X9, 59) |
585 | CV_REGISTER(ARM64_X10, 60) |
586 | CV_REGISTER(ARM64_X11, 61) |
587 | CV_REGISTER(ARM64_X12, 62) |
588 | CV_REGISTER(ARM64_X13, 63) |
589 | CV_REGISTER(ARM64_X14, 64) |
590 | CV_REGISTER(ARM64_X15, 65) |
591 | CV_REGISTER(ARM64_X16, 66) |
592 | CV_REGISTER(ARM64_X17, 67) |
593 | CV_REGISTER(ARM64_X18, 68) |
594 | CV_REGISTER(ARM64_X19, 69) |
595 | CV_REGISTER(ARM64_X20, 70) |
596 | CV_REGISTER(ARM64_X21, 71) |
597 | CV_REGISTER(ARM64_X22, 72) |
598 | CV_REGISTER(ARM64_X23, 73) |
599 | CV_REGISTER(ARM64_X24, 74) |
600 | CV_REGISTER(ARM64_X25, 75) |
601 | CV_REGISTER(ARM64_X26, 76) |
602 | CV_REGISTER(ARM64_X27, 77) |
603 | CV_REGISTER(ARM64_X28, 78) |
604 | CV_REGISTER(ARM64_FP, 79) |
605 | CV_REGISTER(ARM64_LR, 80) |
606 | CV_REGISTER(ARM64_SP, 81) |
607 | CV_REGISTER(ARM64_ZR, 82) |
608 | |
609 | // status register |
610 | |
611 | CV_REGISTER(ARM64_NZCV, 90) |
612 | |
613 | // 32-bit floating point registers |
614 | |
615 | CV_REGISTER(ARM64_S0, 100) |
616 | CV_REGISTER(ARM64_S1, 101) |
617 | CV_REGISTER(ARM64_S2, 102) |
618 | CV_REGISTER(ARM64_S3, 103) |
619 | CV_REGISTER(ARM64_S4, 104) |
620 | CV_REGISTER(ARM64_S5, 105) |
621 | CV_REGISTER(ARM64_S6, 106) |
622 | CV_REGISTER(ARM64_S7, 107) |
623 | CV_REGISTER(ARM64_S8, 108) |
624 | CV_REGISTER(ARM64_S9, 109) |
625 | CV_REGISTER(ARM64_S10, 110) |
626 | CV_REGISTER(ARM64_S11, 111) |
627 | CV_REGISTER(ARM64_S12, 112) |
628 | CV_REGISTER(ARM64_S13, 113) |
629 | CV_REGISTER(ARM64_S14, 114) |
630 | CV_REGISTER(ARM64_S15, 115) |
631 | CV_REGISTER(ARM64_S16, 116) |
632 | CV_REGISTER(ARM64_S17, 117) |
633 | CV_REGISTER(ARM64_S18, 118) |
634 | CV_REGISTER(ARM64_S19, 119) |
635 | CV_REGISTER(ARM64_S20, 120) |
636 | CV_REGISTER(ARM64_S21, 121) |
637 | CV_REGISTER(ARM64_S22, 122) |
638 | CV_REGISTER(ARM64_S23, 123) |
639 | CV_REGISTER(ARM64_S24, 124) |
640 | CV_REGISTER(ARM64_S25, 125) |
641 | CV_REGISTER(ARM64_S26, 126) |
642 | CV_REGISTER(ARM64_S27, 127) |
643 | CV_REGISTER(ARM64_S28, 128) |
644 | CV_REGISTER(ARM64_S29, 129) |
645 | CV_REGISTER(ARM64_S30, 130) |
646 | CV_REGISTER(ARM64_S31, 131) |
647 | |
648 | // 64-bit floating point registers |
649 | |
650 | CV_REGISTER(ARM64_D0, 140) |
651 | CV_REGISTER(ARM64_D1, 141) |
652 | CV_REGISTER(ARM64_D2, 142) |
653 | CV_REGISTER(ARM64_D3, 143) |
654 | CV_REGISTER(ARM64_D4, 144) |
655 | CV_REGISTER(ARM64_D5, 145) |
656 | CV_REGISTER(ARM64_D6, 146) |
657 | CV_REGISTER(ARM64_D7, 147) |
658 | CV_REGISTER(ARM64_D8, 148) |
659 | CV_REGISTER(ARM64_D9, 149) |
660 | CV_REGISTER(ARM64_D10, 150) |
661 | CV_REGISTER(ARM64_D11, 151) |
662 | CV_REGISTER(ARM64_D12, 152) |
663 | CV_REGISTER(ARM64_D13, 153) |
664 | CV_REGISTER(ARM64_D14, 154) |
665 | CV_REGISTER(ARM64_D15, 155) |
666 | CV_REGISTER(ARM64_D16, 156) |
667 | CV_REGISTER(ARM64_D17, 157) |
668 | CV_REGISTER(ARM64_D18, 158) |
669 | CV_REGISTER(ARM64_D19, 159) |
670 | CV_REGISTER(ARM64_D20, 160) |
671 | CV_REGISTER(ARM64_D21, 161) |
672 | CV_REGISTER(ARM64_D22, 162) |
673 | CV_REGISTER(ARM64_D23, 163) |
674 | CV_REGISTER(ARM64_D24, 164) |
675 | CV_REGISTER(ARM64_D25, 165) |
676 | CV_REGISTER(ARM64_D26, 166) |
677 | CV_REGISTER(ARM64_D27, 167) |
678 | CV_REGISTER(ARM64_D28, 168) |
679 | CV_REGISTER(ARM64_D29, 169) |
680 | CV_REGISTER(ARM64_D30, 170) |
681 | CV_REGISTER(ARM64_D31, 171) |
682 | |
683 | // 128-bit SIMD registers |
684 | |
685 | CV_REGISTER(ARM64_Q0, 180) |
686 | CV_REGISTER(ARM64_Q1, 181) |
687 | CV_REGISTER(ARM64_Q2, 182) |
688 | CV_REGISTER(ARM64_Q3, 183) |
689 | CV_REGISTER(ARM64_Q4, 184) |
690 | CV_REGISTER(ARM64_Q5, 185) |
691 | CV_REGISTER(ARM64_Q6, 186) |
692 | CV_REGISTER(ARM64_Q7, 187) |
693 | CV_REGISTER(ARM64_Q8, 188) |
694 | CV_REGISTER(ARM64_Q9, 189) |
695 | CV_REGISTER(ARM64_Q10, 190) |
696 | CV_REGISTER(ARM64_Q11, 191) |
697 | CV_REGISTER(ARM64_Q12, 192) |
698 | CV_REGISTER(ARM64_Q13, 193) |
699 | CV_REGISTER(ARM64_Q14, 194) |
700 | CV_REGISTER(ARM64_Q15, 195) |
701 | CV_REGISTER(ARM64_Q16, 196) |
702 | CV_REGISTER(ARM64_Q17, 197) |
703 | CV_REGISTER(ARM64_Q18, 198) |
704 | CV_REGISTER(ARM64_Q19, 199) |
705 | CV_REGISTER(ARM64_Q20, 200) |
706 | CV_REGISTER(ARM64_Q21, 201) |
707 | CV_REGISTER(ARM64_Q22, 202) |
708 | CV_REGISTER(ARM64_Q23, 203) |
709 | CV_REGISTER(ARM64_Q24, 204) |
710 | CV_REGISTER(ARM64_Q25, 205) |
711 | CV_REGISTER(ARM64_Q26, 206) |
712 | CV_REGISTER(ARM64_Q27, 207) |
713 | CV_REGISTER(ARM64_Q28, 208) |
714 | CV_REGISTER(ARM64_Q29, 209) |
715 | CV_REGISTER(ARM64_Q30, 210) |
716 | CV_REGISTER(ARM64_Q31, 211) |
717 | |
718 | // Floating point status register |
719 | |
720 | CV_REGISTER(ARM64_FPSR, 220) |
721 | CV_REGISTER(ARM64_FPCR, 221) |
722 | |
723 | // 8 bit floating point registers |
724 | |
725 | CV_REGISTER(ARM64_B0, 230) |
726 | CV_REGISTER(ARM64_B1, 231) |
727 | CV_REGISTER(ARM64_B2, 232) |
728 | CV_REGISTER(ARM64_B3, 233) |
729 | CV_REGISTER(ARM64_B4, 234) |
730 | CV_REGISTER(ARM64_B5, 235) |
731 | CV_REGISTER(ARM64_B6, 236) |
732 | CV_REGISTER(ARM64_B7, 237) |
733 | CV_REGISTER(ARM64_B8, 238) |
734 | CV_REGISTER(ARM64_B9, 239) |
735 | CV_REGISTER(ARM64_B10, 240) |
736 | CV_REGISTER(ARM64_B11, 241) |
737 | CV_REGISTER(ARM64_B12, 242) |
738 | CV_REGISTER(ARM64_B13, 243) |
739 | CV_REGISTER(ARM64_B14, 244) |
740 | CV_REGISTER(ARM64_B15, 245) |
741 | CV_REGISTER(ARM64_B16, 246) |
742 | CV_REGISTER(ARM64_B17, 247) |
743 | CV_REGISTER(ARM64_B18, 248) |
744 | CV_REGISTER(ARM64_B19, 249) |
745 | CV_REGISTER(ARM64_B20, 250) |
746 | CV_REGISTER(ARM64_B21, 251) |
747 | CV_REGISTER(ARM64_B22, 252) |
748 | CV_REGISTER(ARM64_B23, 253) |
749 | CV_REGISTER(ARM64_B24, 254) |
750 | CV_REGISTER(ARM64_B25, 255) |
751 | CV_REGISTER(ARM64_B26, 256) |
752 | CV_REGISTER(ARM64_B27, 257) |
753 | CV_REGISTER(ARM64_B28, 258) |
754 | CV_REGISTER(ARM64_B29, 259) |
755 | CV_REGISTER(ARM64_B30, 260) |
756 | CV_REGISTER(ARM64_B31, 261) |
757 | |
758 | // 16 bit floating point registers |
759 | |
760 | CV_REGISTER(ARM64_H0, 270) |
761 | CV_REGISTER(ARM64_H1, 271) |
762 | CV_REGISTER(ARM64_H2, 272) |
763 | CV_REGISTER(ARM64_H3, 273) |
764 | CV_REGISTER(ARM64_H4, 274) |
765 | CV_REGISTER(ARM64_H5, 275) |
766 | CV_REGISTER(ARM64_H6, 276) |
767 | CV_REGISTER(ARM64_H7, 277) |
768 | CV_REGISTER(ARM64_H8, 278) |
769 | CV_REGISTER(ARM64_H9, 279) |
770 | CV_REGISTER(ARM64_H10, 280) |
771 | CV_REGISTER(ARM64_H11, 281) |
772 | CV_REGISTER(ARM64_H12, 282) |
773 | CV_REGISTER(ARM64_H13, 283) |
774 | CV_REGISTER(ARM64_H14, 284) |
775 | CV_REGISTER(ARM64_H15, 285) |
776 | CV_REGISTER(ARM64_H16, 286) |
777 | CV_REGISTER(ARM64_H17, 287) |
778 | CV_REGISTER(ARM64_H18, 288) |
779 | CV_REGISTER(ARM64_H19, 289) |
780 | CV_REGISTER(ARM64_H20, 290) |
781 | CV_REGISTER(ARM64_H21, 291) |
782 | CV_REGISTER(ARM64_H22, 292) |
783 | CV_REGISTER(ARM64_H23, 293) |
784 | CV_REGISTER(ARM64_H24, 294) |
785 | CV_REGISTER(ARM64_H25, 295) |
786 | CV_REGISTER(ARM64_H26, 296) |
787 | CV_REGISTER(ARM64_H27, 297) |
788 | CV_REGISTER(ARM64_H28, 298) |
789 | CV_REGISTER(ARM64_H29, 299) |
790 | CV_REGISTER(ARM64_H30, 300) |
791 | CV_REGISTER(ARM64_H31, 301) |
792 | |
793 | #pragma pop_macro("ARM64_FPSR") |
794 | #pragma pop_macro("ARM64_FPCR") |
795 | |
796 | #endif // defined(CV_REGISTERS_ALL) || defined(CV_REGISTERS_ARM64) |
797 | |
798 | #if defined(CV_REGISTERS_ALL) || defined(CV_REGISTERS_MIPS) |
799 | |
800 | // MIPS registers |
801 | CV_REGISTER(MIPS_NOREG, 0) |
802 | |
803 | // General purpose integer registers |
804 | |
805 | CV_REGISTER(MIPS_ZERO, 10) |
806 | CV_REGISTER(MIPS_AT, 11) |
807 | CV_REGISTER(MIPS_V0, 12) |
808 | CV_REGISTER(MIPS_V1, 13) |
809 | CV_REGISTER(MIPS_A0, 14) |
810 | CV_REGISTER(MIPS_A1, 15) |
811 | CV_REGISTER(MIPS_A2, 16) |
812 | CV_REGISTER(MIPS_A3, 17) |
813 | CV_REGISTER(MIPS_T0, 18) |
814 | CV_REGISTER(MIPS_T1, 19) |
815 | CV_REGISTER(MIPS_T2, 20) |
816 | CV_REGISTER(MIPS_T3, 21) |
817 | CV_REGISTER(MIPS_T4, 22) |
818 | CV_REGISTER(MIPS_T5, 23) |
819 | CV_REGISTER(MIPS_T6, 24) |
820 | CV_REGISTER(MIPS_T7, 25) |
821 | CV_REGISTER(MIPS_S0, 26) |
822 | CV_REGISTER(MIPS_S1, 27) |
823 | CV_REGISTER(MIPS_S2, 28) |
824 | CV_REGISTER(MIPS_S3, 29) |
825 | CV_REGISTER(MIPS_S4, 30) |
826 | CV_REGISTER(MIPS_S5, 31) |
827 | CV_REGISTER(MIPS_S6, 32) |
828 | CV_REGISTER(MIPS_S7, 33) |
829 | CV_REGISTER(MIPS_T8, 34) |
830 | CV_REGISTER(MIPS_T9, 35) |
831 | CV_REGISTER(MIPS_K0, 36) |
832 | CV_REGISTER(MIPS_K1, 37) |
833 | CV_REGISTER(MIPS_GP, 38) |
834 | CV_REGISTER(MIPS_SP, 39) |
835 | CV_REGISTER(MIPS_S8, 40) |
836 | CV_REGISTER(MIPS_RA, 41) |
837 | CV_REGISTER(MIPS_LO, 42) |
838 | CV_REGISTER(MIPS_HI, 43) |
839 | |
840 | // Status registers |
841 | |
842 | CV_REGISTER(MIPS_Fir, 50) |
843 | CV_REGISTER(MIPS_Psr, 51) |
844 | |
845 | // Floating-point registers |
846 | |
847 | CV_REGISTER(MIPS_F0, 60) |
848 | CV_REGISTER(MIPS_F1, 61) |
849 | CV_REGISTER(MIPS_F2, 62) |
850 | CV_REGISTER(MIPS_F3, 63) |
851 | CV_REGISTER(MIPS_F4, 64) |
852 | CV_REGISTER(MIPS_F5, 65) |
853 | CV_REGISTER(MIPS_F6, 66) |
854 | CV_REGISTER(MIPS_F7, 67) |
855 | CV_REGISTER(MIPS_F8, 68) |
856 | CV_REGISTER(MIPS_F9, 69) |
857 | CV_REGISTER(MIPS_F10, 70) |
858 | CV_REGISTER(MIPS_F11, 71) |
859 | CV_REGISTER(MIPS_F12, 72) |
860 | CV_REGISTER(MIPS_F13, 73) |
861 | CV_REGISTER(MIPS_F14, 74) |
862 | CV_REGISTER(MIPS_F15, 75) |
863 | CV_REGISTER(MIPS_F16, 76) |
864 | CV_REGISTER(MIPS_F17, 77) |
865 | CV_REGISTER(MIPS_F18, 78) |
866 | CV_REGISTER(MIPS_F19, 79) |
867 | CV_REGISTER(MIPS_F20, 80) |
868 | CV_REGISTER(MIPS_F21, 81) |
869 | CV_REGISTER(MIPS_F22, 82) |
870 | CV_REGISTER(MIPS_F23, 83) |
871 | CV_REGISTER(MIPS_F24, 84) |
872 | CV_REGISTER(MIPS_F25, 85) |
873 | CV_REGISTER(MIPS_F26, 86) |
874 | CV_REGISTER(MIPS_F27, 87) |
875 | CV_REGISTER(MIPS_F28, 88) |
876 | CV_REGISTER(MIPS_F29, 89) |
877 | CV_REGISTER(MIPS_F30, 90) |
878 | CV_REGISTER(MIPS_F31, 91) |
879 | CV_REGISTER(MIPS_Fsr, 92) |
880 | |
881 | #endif // defined(CV_REGISTERS_ALL) || defined(CV_REGISTERS_MIPS) |
882 | |