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