[SDK] One step further towards ReactOS source code tree restructure: the sdk folder...
[reactos.git] / reactos / sdk / include / psdk / cvconst.h
1 /*
2 * File cvconst.h - MS debug information
3 *
4 * Copyright (C) 2004, Eric Pouech
5 * Copyright (C) 2012, André Hentschel
6 *
7 * This library is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation; either
10 * version 2.1 of the License, or (at your option) any later version.
11 *
12 * This library is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
16 *
17 * You should have received a copy of the GNU Lesser General Public
18 * License along with this library; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
20 */
21
22 /* information in this file is highly derived from MSDN DIA information pages */
23
24 /* symbols & types enumeration */
25 enum SymTagEnum
26 {
27 SymTagNull,
28 SymTagExe,
29 SymTagCompiland,
30 SymTagCompilandDetails,
31 SymTagCompilandEnv,
32 SymTagFunction,
33 SymTagBlock,
34 SymTagData,
35 SymTagAnnotation,
36 SymTagLabel,
37 SymTagPublicSymbol,
38 SymTagUDT,
39 SymTagEnum,
40 SymTagFunctionType,
41 SymTagPointerType,
42 SymTagArrayType,
43 SymTagBaseType,
44 SymTagTypedef,
45 SymTagBaseClass,
46 SymTagFriend,
47 SymTagFunctionArgType,
48 SymTagFuncDebugStart,
49 SymTagFuncDebugEnd,
50 SymTagUsingNamespace,
51 SymTagVTableShape,
52 SymTagVTable,
53 SymTagCustom,
54 SymTagThunk,
55 SymTagCustomType,
56 SymTagManagedType,
57 SymTagDimension,
58 SymTagMax
59 };
60
61 enum BasicType
62 {
63 btNoType = 0,
64 btVoid = 1,
65 btChar = 2,
66 btWChar = 3,
67 btInt = 6,
68 btUInt = 7,
69 btFloat = 8,
70 btBCD = 9,
71 btBool = 10,
72 btLong = 13,
73 btULong = 14,
74 btCurrency = 25,
75 btDate = 26,
76 btVariant = 27,
77 btComplex = 28,
78 btBit = 29,
79 btBSTR = 30,
80 btHresult = 31,
81 };
82
83 /* kind of UDT */
84 enum UdtKind
85 {
86 UdtStruct,
87 UdtClass,
88 UdtUnion
89 };
90
91 /* where a SymTagData is */
92 enum LocationType
93 {
94 LocIsNull,
95 LocIsStatic,
96 LocIsTLS,
97 LocIsRegRel,
98 LocIsThisRel,
99 LocIsEnregistered,
100 LocIsBitField,
101 LocIsSlot,
102 LocIsIlRel,
103 LocInMetaData,
104 LocIsConstant
105 };
106
107 /* kind of SymTagData */
108 enum DataKind
109 {
110 DataIsUnknown,
111 DataIsLocal,
112 DataIsStaticLocal,
113 DataIsParam,
114 DataIsObjectPtr,
115 DataIsFileStatic,
116 DataIsGlobal,
117 DataIsMember,
118 DataIsStaticMember,
119 DataIsConstant
120 };
121
122 /* values for registers (on different CPUs) */
123 enum CV_HREG_e
124 {
125 /* those values are common to all supported CPUs (and CPU independent) */
126 CV_ALLREG_ERR = 30000,
127 CV_ALLREG_TEB = 30001,
128 CV_ALLREG_TIMER = 30002,
129 CV_ALLREG_EFAD1 = 30003,
130 CV_ALLREG_EFAD2 = 30004,
131 CV_ALLREG_EFAD3 = 30005,
132 CV_ALLREG_VFRAME = 30006,
133 CV_ALLREG_HANDLE = 30007,
134 CV_ALLREG_PARAMS = 30008,
135 CV_ALLREG_LOCALS = 30009,
136 CV_ALLREG_TID = 30010,
137 CV_ALLREG_ENV = 30011,
138 CV_ALLREG_CMDLN = 30012,
139
140 /* Intel x86 CPU */
141 CV_REG_NONE = 0,
142 CV_REG_AL = 1,
143 CV_REG_CL = 2,
144 CV_REG_DL = 3,
145 CV_REG_BL = 4,
146 CV_REG_AH = 5,
147 CV_REG_CH = 6,
148 CV_REG_DH = 7,
149 CV_REG_BH = 8,
150 CV_REG_AX = 9,
151 CV_REG_CX = 10,
152 CV_REG_DX = 11,
153 CV_REG_BX = 12,
154 CV_REG_SP = 13,
155 CV_REG_BP = 14,
156 CV_REG_SI = 15,
157 CV_REG_DI = 16,
158 CV_REG_EAX = 17,
159 CV_REG_ECX = 18,
160 CV_REG_EDX = 19,
161 CV_REG_EBX = 20,
162 CV_REG_ESP = 21,
163 CV_REG_EBP = 22,
164 CV_REG_ESI = 23,
165 CV_REG_EDI = 24,
166 CV_REG_ES = 25,
167 CV_REG_CS = 26,
168 CV_REG_SS = 27,
169 CV_REG_DS = 28,
170 CV_REG_FS = 29,
171 CV_REG_GS = 30,
172 CV_REG_IP = 31,
173 CV_REG_FLAGS = 32,
174 CV_REG_EIP = 33,
175 CV_REG_EFLAGS = 34,
176
177 /* <pcode> */
178 CV_REG_TEMP = 40,
179 CV_REG_TEMPH = 41,
180 CV_REG_QUOTE = 42,
181 CV_REG_PCDR3 = 43, /* this includes PCDR4 to PCDR7 */
182 CV_REG_CR0 = 80, /* this includes CR1 to CR4 */
183 CV_REG_DR0 = 90, /* this includes DR1 to DR7 */
184 /* </pcode> */
185
186 CV_REG_GDTR = 110,
187 CV_REG_GDTL = 111,
188 CV_REG_IDTR = 112,
189 CV_REG_IDTL = 113,
190 CV_REG_LDTR = 114,
191 CV_REG_TR = 115,
192
193 CV_REG_PSEUDO1 = 116, /* this includes Pseudo02 to Pseudo09 */
194 CV_REG_ST0 = 128, /* this includes ST1 to ST7 */
195 CV_REG_CTRL = 136,
196 CV_REG_STAT = 137,
197 CV_REG_TAG = 138,
198 CV_REG_FPIP = 139,
199 CV_REG_FPCS = 140,
200 CV_REG_FPDO = 141,
201 CV_REG_FPDS = 142,
202 CV_REG_ISEM = 143,
203 CV_REG_FPEIP = 144,
204 CV_REG_FPEDO = 145,
205 CV_REG_MM0 = 146, /* this includes MM1 to MM7 */
206 CV_REG_XMM0 = 154, /* this includes XMM1 to XMM7 */
207 CV_REG_XMM00 = 162,
208 CV_REG_XMM0L = 194, /* this includes XMM1L to XMM7L */
209 CV_REG_XMM0H = 202, /* this includes XMM1H to XMM7H */
210 CV_REG_MXCSR = 211,
211 CV_REG_EDXEAX = 212,
212 CV_REG_EMM0L = 220,
213 CV_REG_EMM0H = 228,
214 CV_REG_MM00 = 236,
215 CV_REG_MM01 = 237,
216 CV_REG_MM10 = 238,
217 CV_REG_MM11 = 239,
218 CV_REG_MM20 = 240,
219 CV_REG_MM21 = 241,
220 CV_REG_MM30 = 242,
221 CV_REG_MM31 = 243,
222 CV_REG_MM40 = 244,
223 CV_REG_MM41 = 245,
224 CV_REG_MM50 = 246,
225 CV_REG_MM51 = 247,
226 CV_REG_MM60 = 248,
227 CV_REG_MM61 = 249,
228 CV_REG_MM70 = 250,
229 CV_REG_MM71 = 251,
230
231 CV_REG_YMM0 = 252, /* this includes YMM1 to YMM7 */
232 CV_REG_YMM0H = 260, /* this includes YMM1H to YMM7H */
233 CV_REG_YMM0I0 = 268, /* this includes YMM0I1 to YMM0I3 */
234 CV_REG_YMM1I0 = 272, /* this includes YMM1I1 to YMM1I3 */
235 CV_REG_YMM2I0 = 276, /* this includes YMM2I1 to YMM2I3 */
236 CV_REG_YMM3I0 = 280, /* this includes YMM3I1 to YMM3I3 */
237 CV_REG_YMM4I0 = 284, /* this includes YMM4I1 to YMM4I3 */
238 CV_REG_YMM5I0 = 288, /* this includes YMM5I1 to YMM5I3 */
239 CV_REG_YMM6I0 = 292, /* this includes YMM6I1 to YMM6I3 */
240 CV_REG_YMM7I0 = 296, /* this includes YMM7I1 to YMM7I3 */
241 CV_REG_YMM0F0 = 300, /* this includes YMM0F1 to YMM0F7 */
242 CV_REG_YMM1F0 = 308, /* this includes YMM1F1 to YMM1F7 */
243 CV_REG_YMM2F0 = 316, /* this includes YMM2F1 to YMM2F7 */
244 CV_REG_YMM3F0 = 324, /* this includes YMM3F1 to YMM3F7 */
245 CV_REG_YMM4F0 = 332, /* this includes YMM4F1 to YMM4F7 */
246 CV_REG_YMM5F0 = 340, /* this includes YMM5F1 to YMM5F7 */
247 CV_REG_YMM6F0 = 348, /* this includes YMM6F1 to YMM6F7 */
248 CV_REG_YMM7F0 = 356, /* this includes YMM7F1 to YMM7F7 */
249 CV_REG_YMM0D0 = 364, /* this includes YMM0D1 to YMM0D3 */
250 CV_REG_YMM1D0 = 368, /* this includes YMM1D1 to YMM1D3 */
251 CV_REG_YMM2D0 = 372, /* this includes YMM2D1 to YMM2D3 */
252 CV_REG_YMM3D0 = 376, /* this includes YMM3D1 to YMM3D3 */
253 CV_REG_YMM4D0 = 380, /* this includes YMM4D1 to YMM4D3 */
254 CV_REG_YMM5D0 = 384, /* this includes YMM5D1 to YMM5D3 */
255 CV_REG_YMM6D0 = 388, /* this includes YMM6D1 to YMM6D3 */
256 CV_REG_YMM7D0 = 392, /* this includes YMM7D1 to YMM7D3 */
257
258 /* Motorola 68K CPU */
259 CV_R68_D0 = 0, /* this includes D1 to D7 too */
260 CV_R68_A0 = 8, /* this includes A1 to A7 too */
261 CV_R68_CCR = 16,
262 CV_R68_SR = 17,
263 CV_R68_USP = 18,
264 CV_R68_MSP = 19,
265 CV_R68_SFC = 20,
266 CV_R68_DFC = 21,
267 CV_R68_CACR = 22,
268 CV_R68_VBR = 23,
269 CV_R68_CAAR = 24,
270 CV_R68_ISP = 25,
271 CV_R68_PC = 26,
272 CV_R68_FPCR = 28,
273 CV_R68_FPSR = 29,
274 CV_R68_FPIAR = 30,
275 CV_R68_FP0 = 32, /* this includes FP1 to FP7 */
276 CV_R68_MMUSR030 = 41,
277 CV_R68_MMUSR = 42,
278 CV_R68_URP = 43,
279 CV_R68_DTT0 = 44,
280 CV_R68_DTT1 = 45,
281 CV_R68_ITT0 = 46,
282 CV_R68_ITT1 = 47,
283 CV_R68_PSR = 51,
284 CV_R68_PCSR = 52,
285 CV_R68_VAL = 53,
286 CV_R68_CRP = 54,
287 CV_R68_SRP = 55,
288 CV_R68_DRP = 56,
289 CV_R68_TC = 57,
290 CV_R68_AC = 58,
291 CV_R68_SCC = 59,
292 CV_R68_CAL = 60,
293 CV_R68_TT0 = 61,
294 CV_R68_TT1 = 62,
295 CV_R68_BAD0 = 64, /* this includes BAD1 to BAD7 */
296 CV_R68_BAC0 = 72, /* this includes BAC1 to BAC7 */
297
298 /* MIPS 4000 CPU */
299 CV_M4_NOREG = CV_REG_NONE,
300 CV_M4_IntZERO = 10,
301 CV_M4_IntAT = 11,
302 CV_M4_IntV0 = 12,
303 CV_M4_IntV1 = 13,
304 CV_M4_IntA0 = 14, /* this includes IntA1 to IntA3 */
305 CV_M4_IntT0 = 18, /* this includes IntT1 to IntT7 */
306 CV_M4_IntS0 = 26, /* this includes IntS1 to IntS7 */
307 CV_M4_IntT8 = 34,
308 CV_M4_IntT9 = 35,
309 CV_M4_IntKT0 = 36,
310 CV_M4_IntKT1 = 37,
311 CV_M4_IntGP = 38,
312 CV_M4_IntSP = 39,
313 CV_M4_IntS8 = 40,
314 CV_M4_IntRA = 41,
315 CV_M4_IntLO = 42,
316 CV_M4_IntHI = 43,
317 CV_M4_Fir = 50,
318 CV_M4_Psr = 51,
319 CV_M4_FltF0 = 60, /* this includes FltF1 to Flt31 */
320 CV_M4_FltFsr = 92,
321
322 /* Alpha AXP CPU */
323 CV_ALPHA_NOREG = CV_REG_NONE,
324 CV_ALPHA_FltF0 = 10, /* this includes FltF1 to FltF31 */
325 CV_ALPHA_IntV0 = 42,
326 CV_ALPHA_IntT0 = 43, /* this includes T1 to T7 */
327 CV_ALPHA_IntS0 = 51, /* this includes S1 to S5 */
328 CV_ALPHA_IntFP = 57,
329 CV_ALPHA_IntA0 = 58, /* this includes A1 to A5 */
330 CV_ALPHA_IntT8 = 64,
331 CV_ALPHA_IntT9 = 65,
332 CV_ALPHA_IntT10 = 66,
333 CV_ALPHA_IntT11 = 67,
334 CV_ALPHA_IntRA = 68,
335 CV_ALPHA_IntT12 = 69,
336 CV_ALPHA_IntAT = 70,
337 CV_ALPHA_IntGP = 71,
338 CV_ALPHA_IntSP = 72,
339 CV_ALPHA_IntZERO = 73,
340 CV_ALPHA_Fpcr = 74,
341 CV_ALPHA_Fir = 75,
342 CV_ALPHA_Psr = 76,
343 CV_ALPHA_FltFsr = 77,
344 CV_ALPHA_SoftFpcr = 78,
345
346 /* Motorola & IBM PowerPC CPU */
347 CV_PPC_GPR0 = 1, /* this includes GPR1 to GPR31 */
348 CV_PPC_CR = 33,
349 CV_PPC_CR0 = 34, /* this includes CR1 to CR7 */
350 CV_PPC_FPR0 = 42, /* this includes FPR1 to FPR31 */
351
352 CV_PPC_FPSCR = 74,
353 CV_PPC_MSR = 75,
354 CV_PPC_SR0 = 76, /* this includes SR1 to SR15 */
355 CV_PPC_PC = 99,
356 CV_PPC_MQ = 100,
357 CV_PPC_XER = 101,
358 CV_PPC_RTCU = 104,
359 CV_PPC_RTCL = 105,
360 CV_PPC_LR = 108,
361 CV_PPC_CTR = 109,
362 CV_PPC_COMPARE = 110,
363 CV_PPC_COUNT = 111,
364 CV_PPC_DSISR = 118,
365 CV_PPC_DAR = 119,
366 CV_PPC_DEC = 122,
367 CV_PPC_SDR1 = 125,
368 CV_PPC_SRR0 = 126,
369 CV_PPC_SRR1 = 127,
370 CV_PPC_SPRG0 = 372, /* this includes SPRG1 to SPRG3 */
371 CV_PPC_ASR = 280,
372 CV_PPC_EAR = 382,
373 CV_PPC_PVR = 287,
374 CV_PPC_BAT0U = 628,
375 CV_PPC_BAT0L = 629,
376 CV_PPC_BAT1U = 630,
377 CV_PPC_BAT1L = 631,
378 CV_PPC_BAT2U = 632,
379 CV_PPC_BAT2L = 633,
380 CV_PPC_BAT3U = 634,
381 CV_PPC_BAT3L = 635,
382 CV_PPC_DBAT0U = 636,
383 CV_PPC_DBAT0L = 637,
384 CV_PPC_DBAT1U = 638,
385 CV_PPC_DBAT1L = 639,
386 CV_PPC_DBAT2U = 640,
387 CV_PPC_DBAT2L = 641,
388 CV_PPC_DBAT3U = 642,
389 CV_PPC_DBAT3L = 643,
390 CV_PPC_PMR0 = 1044, /* this includes PMR1 to PMR15 */
391 CV_PPC_DMISS = 1076,
392 CV_PPC_DCMP = 1077,
393 CV_PPC_HASH1 = 1078,
394 CV_PPC_HASH2 = 1079,
395 CV_PPC_IMISS = 1080,
396 CV_PPC_ICMP = 1081,
397 CV_PPC_RPA = 1082,
398 CV_PPC_HID0 = 1108, /* this includes HID1 to HID15 */
399
400 /* Java */
401 CV_JAVA_PC = 1,
402
403 /* Hitachi SH3 CPU */
404 CV_SH3_NOREG = CV_REG_NONE,
405 CV_SH3_IntR0 = 10, /* this include R1 to R13 */
406 CV_SH3_IntFp = 24,
407 CV_SH3_IntSp = 25,
408 CV_SH3_Gbr = 38,
409 CV_SH3_Pr = 39,
410 CV_SH3_Mach = 40,
411 CV_SH3_Macl = 41,
412 CV_SH3_Pc = 50,
413 CV_SH3_Sr = 51,
414 CV_SH3_BarA = 60,
415 CV_SH3_BasrA = 61,
416 CV_SH3_BamrA = 62,
417 CV_SH3_BbrA = 63,
418 CV_SH3_BarB = 64,
419 CV_SH3_BasrB = 65,
420 CV_SH3_BamrB = 66,
421 CV_SH3_BbrB = 67,
422 CV_SH3_BdrB = 68,
423 CV_SH3_BdmrB = 69,
424 CV_SH3_Brcr = 70,
425 CV_SH_Fpscr = 75,
426 CV_SH_Fpul = 76,
427 CV_SH_FpR0 = 80, /* this includes FpR1 to FpR15 */
428 CV_SH_XFpR0 = 96, /* this includes XFpR1 to XXFpR15 */
429
430 /* ARM CPU */
431 CV_ARM_NOREG = CV_REG_NONE,
432 CV_ARM_R0 = 10, /* this includes R1 to R12 */
433 CV_ARM_SP = 23,
434 CV_ARM_LR = 24,
435 CV_ARM_PC = 25,
436 CV_ARM_CPSR = 26,
437 CV_ARM_ACC0 = 27,
438 CV_ARM_FPSCR = 40,
439 CV_ARM_FPEXC = 41,
440 CV_ARM_FS0 = 50, /* this includes FS1 to FS31 */
441 CV_ARM_FPEXTRA0 = 90, /* this includes FPEXTRA1 to FPEXTRA7 */
442 CV_ARM_WR0 = 128, /* this includes WR1 to WR15 */
443 CV_ARM_WCID = 144,
444 CV_ARM_WCON = 145,
445 CV_ARM_WCSSF = 146,
446 CV_ARM_WCASF = 147,
447 CV_ARM_WC4 = 148,
448 CV_ARM_WC5 = 149,
449 CV_ARM_WC6 = 150,
450 CV_ARM_WC7 = 151,
451 CV_ARM_WCGR0 = 152, /* this includes WCGR1 to WCGR3 */
452 CV_ARM_WC12 = 156,
453 CV_ARM_WC13 = 157,
454 CV_ARM_WC14 = 158,
455 CV_ARM_WC15 = 159,
456 CV_ARM_FS32 = 200, /* this includes FS33 to FS63 */
457 CV_ARM_ND0 = 300, /* this includes ND1 to ND31 */
458 CV_ARM_NQ0 = 400, /* this includes NQ1 to NQ15 */
459
460 /* ARM64 CPU */
461 CV_ARM64_NOREG = CV_REG_NONE,
462 CV_ARM64_W0 = 10, /* this includes W0 to W30 */
463 CV_ARM64_WZR = 41,
464 CV_ARM64_PC = 42, /* Wine extension */
465 CV_ARM64_PSTATE = 43, /* Wine extension */
466 CV_ARM64_X0 = 50, /* this includes X0 to X28 */
467 CV_ARM64_IP0 = 66, /* Same as X16 */
468 CV_ARM64_IP1 = 67, /* Same as X17 */
469 CV_ARM64_FP = 79,
470 CV_ARM64_LR = 80,
471 CV_ARM64_SP = 81,
472 CV_ARM64_ZR = 82,
473 CV_ARM64_NZCV = 90,
474 CV_ARM64_S0 = 100, /* this includes S0 to S31 */
475 CV_ARM64_D0 = 140, /* this includes D0 to D31 */
476 CV_ARM64_Q0 = 180, /* this includes Q0 to Q31 */
477 CV_ARM64_FPSR = 220,
478
479 /* Intel IA64 CPU */
480 CV_IA64_NOREG = CV_REG_NONE,
481 CV_IA64_Br0 = 512, /* this includes Br1 to Br7 */
482 CV_IA64_P0 = 704, /* this includes P1 to P63 */
483 CV_IA64_Preds = 768,
484 CV_IA64_IntH0 = 832, /* this includes H1 to H15 */
485 CV_IA64_Ip = 1016,
486 CV_IA64_Umask = 1017,
487 CV_IA64_Cfm = 1018,
488 CV_IA64_Psr = 1019,
489 CV_IA64_Nats = 1020,
490 CV_IA64_Nats2 = 1021,
491 CV_IA64_Nats3 = 1022,
492 CV_IA64_IntR0 = 1024, /* this includes R1 to R127 */
493 CV_IA64_FltF0 = 2048, /* this includes FltF1 to FltF127 */
494 /* some IA64 registers missing */
495
496 /* TriCore CPU */
497 CV_TRI_NOREG = CV_REG_NONE,
498 CV_TRI_D0 = 10, /* includes D1 to D15 */
499 CV_TRI_A0 = 26, /* includes A1 to A15 */
500 CV_TRI_E0 = 42,
501 CV_TRI_E2 = 43,
502 CV_TRI_E4 = 44,
503 CV_TRI_E6 = 45,
504 CV_TRI_E8 = 46,
505 CV_TRI_E10 = 47,
506 CV_TRI_E12 = 48,
507 CV_TRI_E14 = 49,
508 CV_TRI_EA0 = 50,
509 CV_TRI_EA2 = 51,
510 CV_TRI_EA4 = 52,
511 CV_TRI_EA6 = 53,
512 CV_TRI_EA8 = 54,
513 CV_TRI_EA10 = 55,
514 CV_TRI_EA12 = 56,
515 CV_TRI_EA14 = 57,
516 CV_TRI_PSW = 58,
517 CV_TRI_PCXI = 59,
518 CV_TRI_PC = 60,
519 CV_TRI_FCX = 61,
520 CV_TRI_LCX = 62,
521 CV_TRI_ISP = 63,
522 CV_TRI_ICR = 64,
523 CV_TRI_BIV = 65,
524 CV_TRI_BTV = 66,
525 CV_TRI_SYSCON = 67,
526 CV_TRI_DPRx_0 = 68, /* includes DPRx_1 to DPRx_3 */
527 CV_TRI_CPRx_0 = 68, /* includes CPRx_1 to CPRx_3 */
528 CV_TRI_DPMx_0 = 68, /* includes DPMx_1 to DPMx_3 */
529 CV_TRI_CPMx_0 = 68, /* includes CPMx_1 to CPMx_3 */
530 CV_TRI_DBGSSR = 72,
531 CV_TRI_EXEVT = 73,
532 CV_TRI_SWEVT = 74,
533 CV_TRI_CREVT = 75,
534 CV_TRI_TRnEVT = 76,
535 CV_TRI_MMUCON = 77,
536 CV_TRI_ASI = 78,
537 CV_TRI_TVA = 79,
538 CV_TRI_TPA = 80,
539 CV_TRI_TPX = 81,
540 CV_TRI_TFA = 82,
541
542 /* AM33 (and the likes) CPU */
543 CV_AM33_NOREG = CV_REG_NONE,
544 CV_AM33_E0 = 10, /* this includes E1 to E7 */
545 CV_AM33_A0 = 20, /* this includes A1 to A3 */
546 CV_AM33_D0 = 30, /* this includes D1 to D3 */
547 CV_AM33_FS0 = 40, /* this includes FS1 to FS31 */
548 CV_AM33_SP = 80,
549 CV_AM33_PC = 81,
550 CV_AM33_MDR = 82,
551 CV_AM33_MDRQ = 83,
552 CV_AM33_MCRH = 84,
553 CV_AM33_MCRL = 85,
554 CV_AM33_MCVF = 86,
555 CV_AM33_EPSW = 87,
556 CV_AM33_FPCR = 88,
557 CV_AM33_LIR = 89,
558 CV_AM33_LAR = 90,
559
560 /* Mitsubishi M32R CPU */
561 CV_M32R_NOREG = CV_REG_NONE,
562 CV_M32R_R0 = 10, /* this includes R1 to R11 */
563 CV_M32R_R12 = 22,
564 CV_M32R_R13 = 23,
565 CV_M32R_R14 = 24,
566 CV_M32R_R15 = 25,
567 CV_M32R_PSW = 26,
568 CV_M32R_CBR = 27,
569 CV_M32R_SPI = 28,
570 CV_M32R_SPU = 29,
571 CV_M32R_SPO = 30,
572 CV_M32R_BPC = 31,
573 CV_M32R_ACHI = 32,
574 CV_M32R_ACLO = 33,
575 CV_M32R_PC = 34,
576
577 /* AMD/Intel x86_64 CPU */
578 CV_AMD64_NONE = CV_REG_NONE,
579 CV_AMD64_AL = CV_REG_AL,
580 CV_AMD64_CL = CV_REG_CL,
581 CV_AMD64_DL = CV_REG_DL,
582 CV_AMD64_BL = CV_REG_BL,
583 CV_AMD64_AH = CV_REG_AH,
584 CV_AMD64_CH = CV_REG_CH,
585 CV_AMD64_DH = CV_REG_DH,
586 CV_AMD64_BH = CV_REG_BH,
587 CV_AMD64_AX = CV_REG_AX,
588 CV_AMD64_CX = CV_REG_CX,
589 CV_AMD64_DX = CV_REG_DX,
590 CV_AMD64_BX = CV_REG_BX,
591 CV_AMD64_SP = CV_REG_SP,
592 CV_AMD64_BP = CV_REG_BP,
593 CV_AMD64_SI = CV_REG_SI,
594 CV_AMD64_DI = CV_REG_DI,
595 CV_AMD64_EAX = CV_REG_EAX,
596 CV_AMD64_ECX = CV_REG_ECX,
597 CV_AMD64_EDX = CV_REG_EDX,
598 CV_AMD64_EBX = CV_REG_EBX,
599 CV_AMD64_ESP = CV_REG_ESP,
600 CV_AMD64_EBP = CV_REG_EBP,
601 CV_AMD64_ESI = CV_REG_ESI,
602 CV_AMD64_EDI = CV_REG_EDI,
603 CV_AMD64_ES = CV_REG_ES,
604 CV_AMD64_CS = CV_REG_CS,
605 CV_AMD64_SS = CV_REG_SS,
606 CV_AMD64_DS = CV_REG_DS,
607 CV_AMD64_FS = CV_REG_FS,
608 CV_AMD64_GS = CV_REG_GS,
609 CV_AMD64_FLAGS = CV_REG_FLAGS,
610 CV_AMD64_RIP = CV_REG_EIP,
611 CV_AMD64_EFLAGS = CV_REG_EFLAGS,
612
613 /* <pcode> */
614 CV_AMD64_TEMP = CV_REG_TEMP,
615 CV_AMD64_TEMPH = CV_REG_TEMPH,
616 CV_AMD64_QUOTE = CV_REG_QUOTE,
617 CV_AMD64_PCDR3 = CV_REG_PCDR3, /* this includes PCDR4 to PCDR7 */
618 CV_AMD64_CR0 = CV_REG_CR0, /* this includes CR1 to CR4 */
619 CV_AMD64_DR0 = CV_REG_DR0, /* this includes DR1 to DR7 */
620 /* </pcode> */
621
622 CV_AMD64_GDTR = CV_REG_GDTR,
623 CV_AMD64_GDTL = CV_REG_GDTL,
624 CV_AMD64_IDTR = CV_REG_IDTR,
625 CV_AMD64_IDTL = CV_REG_IDTL,
626 CV_AMD64_LDTR = CV_REG_LDTR,
627 CV_AMD64_TR = CV_REG_TR,
628
629 CV_AMD64_PSEUDO1 = CV_REG_PSEUDO1, /* this includes Pseudo02 to Pseudo09 */
630 CV_AMD64_ST0 = CV_REG_ST0, /* this includes ST1 to ST7 */
631 CV_AMD64_CTRL = CV_REG_CTRL,
632 CV_AMD64_STAT = CV_REG_STAT,
633 CV_AMD64_TAG = CV_REG_TAG,
634 CV_AMD64_FPIP = CV_REG_FPIP,
635 CV_AMD64_FPCS = CV_REG_FPCS,
636 CV_AMD64_FPDO = CV_REG_FPDO,
637 CV_AMD64_FPDS = CV_REG_FPDS,
638 CV_AMD64_ISEM = CV_REG_ISEM,
639 CV_AMD64_FPEIP = CV_REG_FPEIP,
640 CV_AMD64_FPEDO = CV_REG_FPEDO,
641 CV_AMD64_MM0 = CV_REG_MM0, /* this includes MM1 to MM7 */
642 CV_AMD64_XMM0 = CV_REG_XMM0, /* this includes XMM1 to XMM7 */
643 CV_AMD64_XMM00 = CV_REG_XMM00,
644 CV_AMD64_XMM0L = CV_REG_XMM0L, /* this includes XMM1L to XMM7L */
645 CV_AMD64_XMM0H = CV_REG_XMM0H, /* this includes XMM1H to XMM7H */
646 CV_AMD64_MXCSR = CV_REG_MXCSR,
647 CV_AMD64_EDXEAX = CV_REG_EDXEAX,
648 CV_AMD64_EMM0L = CV_REG_EMM0L,
649 CV_AMD64_EMM0H = CV_REG_EMM0H,
650 CV_AMD64_MM00 = CV_REG_MM00,
651 CV_AMD64_MM01 = CV_REG_MM01,
652 CV_AMD64_MM10 = CV_REG_MM10,
653 CV_AMD64_MM11 = CV_REG_MM11,
654 CV_AMD64_MM20 = CV_REG_MM20,
655 CV_AMD64_MM21 = CV_REG_MM21,
656 CV_AMD64_MM30 = CV_REG_MM30,
657 CV_AMD64_MM31 = CV_REG_MM31,
658 CV_AMD64_MM40 = CV_REG_MM40,
659 CV_AMD64_MM41 = CV_REG_MM41,
660 CV_AMD64_MM50 = CV_REG_MM50,
661 CV_AMD64_MM51 = CV_REG_MM51,
662 CV_AMD64_MM60 = CV_REG_MM60,
663 CV_AMD64_MM61 = CV_REG_MM61,
664 CV_AMD64_MM70 = CV_REG_MM70,
665 CV_AMD64_MM71 = CV_REG_MM71,
666
667 CV_AMD64_XMM8 = 252, /* this includes XMM9 to XMM15 */
668
669 CV_AMD64_RAX = 328,
670 CV_AMD64_RBX = 329,
671 CV_AMD64_RCX = 330,
672 CV_AMD64_RDX = 331,
673 CV_AMD64_RSI = 332,
674 CV_AMD64_RDI = 333,
675 CV_AMD64_RBP = 334,
676 CV_AMD64_RSP = 335,
677
678 CV_AMD64_R8 = 336,
679 CV_AMD64_R9 = 337,
680 CV_AMD64_R10 = 338,
681 CV_AMD64_R11 = 339,
682 CV_AMD64_R12 = 340,
683 CV_AMD64_R13 = 341,
684 CV_AMD64_R14 = 342,
685 CV_AMD64_R15 = 343,
686 };
687
688 typedef enum
689 {
690 THUNK_ORDINAL_NOTYPE,
691 THUNK_ORDINAL_ADJUSTOR,
692 THUNK_ORDINAL_VCALL,
693 THUNK_ORDINAL_PCODE,
694 THUNK_ORDINAL_LOAD
695 } THUNK_ORDINAL;
696
697 typedef enum CV_call_e
698 {
699 CV_CALL_NEAR_C,
700 CV_CALL_FAR_C,
701 CV_CALL_NEAR_PASCAL,
702 CV_CALL_FAR_PASCAL,
703 CV_CALL_NEAR_FAST,
704 CV_CALL_FAR_FAST,
705 CV_CALL_SKIPPED,
706 CV_CALL_NEAR_STD,
707 CV_CALL_FAR_STD,
708 CV_CALL_NEAR_SYS,
709 CV_CALL_FAR_SYS,
710 CV_CALL_THISCALL,
711 CV_CALL_MIPSCALL,
712 CV_CALL_GENERIC,
713 CV_CALL_ALPHACALL,
714 CV_CALL_PPCCALL,
715 CV_CALL_SHCALL,
716 CV_CALL_ARMCALL,
717 CV_CALL_AM33CALL,
718 CV_CALL_TRICALL,
719 CV_CALL_SH5CALL,
720 CV_CALL_M32RCALL,
721 CV_CALL_RESERVED,
722 } CV_call_e;