msvcp90: Return last index in string::find_last_not_of_cstr_substr if input is empty.
[wine/multimedia.git] / include / cvconst.h
blob9ad6324eecdc9176e9571441e160339e306fbb12
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 SymTagMax
61 enum BasicType
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,
83 /* kind of UDT */
84 enum UdtKind
86 UdtStruct,
87 UdtClass,
88 UdtUnion
91 /* where a SymTagData is */
92 enum LocationType
94 LocIsNull,
95 LocIsStatic,
96 LocIsTLS,
97 LocIsRegRel,
98 LocIsThisRel,
99 LocIsEnregistered,
100 LocIsBitField,
101 LocIsSlot,
102 LocIsIlRel,
103 LocInMetaData,
104 LocIsConstant
107 /* kind of SymTagData */
108 enum DataKind
110 DataIsUnknown,
111 DataIsLocal,
112 DataIsStaticLocal,
113 DataIsParam,
114 DataIsObjectPtr,
115 DataIsFileStatic,
116 DataIsGlobal,
117 DataIsMember,
118 DataIsStaticMember,
119 DataIsConstant
122 /* values for registers (on different CPUs) */
123 enum CV_HREG_e
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,
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,
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> */
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,
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,
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 */
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 */
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,
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,
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 */
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 */
400 /* Java */
401 CV_JAVA_PC = 1,
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 */
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 */
460 /* Intel IA64 CPU */
461 CV_IA64_NOREG = CV_REG_NONE,
462 CV_IA64_Br0 = 512, /* this includes Br1 to Br7 */
463 CV_IA64_P0 = 704, /* this includes P1 to P63 */
464 CV_IA64_Preds = 768,
465 CV_IA64_IntH0 = 832, /* this includes H1 to H15 */
466 CV_IA64_Ip = 1016,
467 CV_IA64_Umask = 1017,
468 CV_IA64_Cfm = 1018,
469 CV_IA64_Psr = 1019,
470 CV_IA64_Nats = 1020,
471 CV_IA64_Nats2 = 1021,
472 CV_IA64_Nats3 = 1022,
473 CV_IA64_IntR0 = 1024, /* this includes R1 to R127 */
474 CV_IA64_FltF0 = 2048, /* this includes FltF1 to FltF127 */
475 /* some IA64 registers missing */
477 /* TriCore CPU */
478 CV_TRI_NOREG = CV_REG_NONE,
479 CV_TRI_D0 = 10, /* includes D1 to D15 */
480 CV_TRI_A0 = 26, /* includes A1 to A15 */
481 CV_TRI_E0 = 42,
482 CV_TRI_E2 = 43,
483 CV_TRI_E4 = 44,
484 CV_TRI_E6 = 45,
485 CV_TRI_E8 = 46,
486 CV_TRI_E10 = 47,
487 CV_TRI_E12 = 48,
488 CV_TRI_E14 = 49,
489 CV_TRI_EA0 = 50,
490 CV_TRI_EA2 = 51,
491 CV_TRI_EA4 = 52,
492 CV_TRI_EA6 = 53,
493 CV_TRI_EA8 = 54,
494 CV_TRI_EA10 = 55,
495 CV_TRI_EA12 = 56,
496 CV_TRI_EA14 = 57,
497 CV_TRI_PSW = 58,
498 CV_TRI_PCXI = 59,
499 CV_TRI_PC = 60,
500 CV_TRI_FCX = 61,
501 CV_TRI_LCX = 62,
502 CV_TRI_ISP = 63,
503 CV_TRI_ICR = 64,
504 CV_TRI_BIV = 65,
505 CV_TRI_BTV = 66,
506 CV_TRI_SYSCON = 67,
507 CV_TRI_DPRx_0 = 68, /* includes DPRx_1 to DPRx_3 */
508 CV_TRI_CPRx_0 = 68, /* includes CPRx_1 to CPRx_3 */
509 CV_TRI_DPMx_0 = 68, /* includes DPMx_1 to DPMx_3 */
510 CV_TRI_CPMx_0 = 68, /* includes CPMx_1 to CPMx_3 */
511 CV_TRI_DBGSSR = 72,
512 CV_TRI_EXEVT = 73,
513 CV_TRI_SWEVT = 74,
514 CV_TRI_CREVT = 75,
515 CV_TRI_TRnEVT = 76,
516 CV_TRI_MMUCON = 77,
517 CV_TRI_ASI = 78,
518 CV_TRI_TVA = 79,
519 CV_TRI_TPA = 80,
520 CV_TRI_TPX = 81,
521 CV_TRI_TFA = 82,
523 /* AM33 (and the likes) CPU */
524 CV_AM33_NOREG = CV_REG_NONE,
525 CV_AM33_E0 = 10, /* this includes E1 to E7 */
526 CV_AM33_A0 = 20, /* this includes A1 to A3 */
527 CV_AM33_D0 = 30, /* this includes D1 to D3 */
528 CV_AM33_FS0 = 40, /* this includes FS1 to FS31 */
529 CV_AM33_SP = 80,
530 CV_AM33_PC = 81,
531 CV_AM33_MDR = 82,
532 CV_AM33_MDRQ = 83,
533 CV_AM33_MCRH = 84,
534 CV_AM33_MCRL = 85,
535 CV_AM33_MCVF = 86,
536 CV_AM33_EPSW = 87,
537 CV_AM33_FPCR = 88,
538 CV_AM33_LIR = 89,
539 CV_AM33_LAR = 90,
541 /* Mitsubishi M32R CPU */
542 CV_M32R_NOREG = CV_REG_NONE,
543 CV_M32R_R0 = 10, /* this includes R1 to R11 */
544 CV_M32R_R12 = 22,
545 CV_M32R_R13 = 23,
546 CV_M32R_R14 = 24,
547 CV_M32R_R15 = 25,
548 CV_M32R_PSW = 26,
549 CV_M32R_CBR = 27,
550 CV_M32R_SPI = 28,
551 CV_M32R_SPU = 29,
552 CV_M32R_SPO = 30,
553 CV_M32R_BPC = 31,
554 CV_M32R_ACHI = 32,
555 CV_M32R_ACLO = 33,
556 CV_M32R_PC = 34,
558 /* AMD/Intel x86_64 CPU */
559 CV_AMD64_NONE = CV_REG_NONE,
560 CV_AMD64_AL = CV_REG_AL,
561 CV_AMD64_CL = CV_REG_CL,
562 CV_AMD64_DL = CV_REG_DL,
563 CV_AMD64_BL = CV_REG_BL,
564 CV_AMD64_AH = CV_REG_AH,
565 CV_AMD64_CH = CV_REG_CH,
566 CV_AMD64_DH = CV_REG_DH,
567 CV_AMD64_BH = CV_REG_BH,
568 CV_AMD64_AX = CV_REG_AX,
569 CV_AMD64_CX = CV_REG_CX,
570 CV_AMD64_DX = CV_REG_DX,
571 CV_AMD64_BX = CV_REG_BX,
572 CV_AMD64_SP = CV_REG_SP,
573 CV_AMD64_BP = CV_REG_BP,
574 CV_AMD64_SI = CV_REG_SI,
575 CV_AMD64_DI = CV_REG_DI,
576 CV_AMD64_EAX = CV_REG_EAX,
577 CV_AMD64_ECX = CV_REG_ECX,
578 CV_AMD64_EDX = CV_REG_EDX,
579 CV_AMD64_EBX = CV_REG_EBX,
580 CV_AMD64_ESP = CV_REG_ESP,
581 CV_AMD64_EBP = CV_REG_EBP,
582 CV_AMD64_ESI = CV_REG_ESI,
583 CV_AMD64_EDI = CV_REG_EDI,
584 CV_AMD64_ES = CV_REG_ES,
585 CV_AMD64_CS = CV_REG_CS,
586 CV_AMD64_SS = CV_REG_SS,
587 CV_AMD64_DS = CV_REG_DS,
588 CV_AMD64_FS = CV_REG_FS,
589 CV_AMD64_GS = CV_REG_GS,
590 CV_AMD64_FLAGS = CV_REG_FLAGS,
591 CV_AMD64_RIP = CV_REG_EIP,
592 CV_AMD64_EFLAGS = CV_REG_EFLAGS,
594 /* <pcode> */
595 CV_AMD64_TEMP = CV_REG_TEMP,
596 CV_AMD64_TEMPH = CV_REG_TEMPH,
597 CV_AMD64_QUOTE = CV_REG_QUOTE,
598 CV_AMD64_PCDR3 = CV_REG_PCDR3, /* this includes PCDR4 to PCDR7 */
599 CV_AMD64_CR0 = CV_REG_CR0, /* this includes CR1 to CR4 */
600 CV_AMD64_DR0 = CV_REG_DR0, /* this includes DR1 to DR7 */
601 /* </pcode> */
603 CV_AMD64_GDTR = CV_REG_GDTR,
604 CV_AMD64_GDTL = CV_REG_GDTL,
605 CV_AMD64_IDTR = CV_REG_IDTR,
606 CV_AMD64_IDTL = CV_REG_IDTL,
607 CV_AMD64_LDTR = CV_REG_LDTR,
608 CV_AMD64_TR = CV_REG_TR,
610 CV_AMD64_PSEUDO1 = CV_REG_PSEUDO1, /* this includes Pseudo02 to Pseudo09 */
611 CV_AMD64_ST0 = CV_REG_ST0, /* this includes ST1 to ST7 */
612 CV_AMD64_CTRL = CV_REG_CTRL,
613 CV_AMD64_STAT = CV_REG_STAT,
614 CV_AMD64_TAG = CV_REG_TAG,
615 CV_AMD64_FPIP = CV_REG_FPIP,
616 CV_AMD64_FPCS = CV_REG_FPCS,
617 CV_AMD64_FPDO = CV_REG_FPDO,
618 CV_AMD64_FPDS = CV_REG_FPDS,
619 CV_AMD64_ISEM = CV_REG_ISEM,
620 CV_AMD64_FPEIP = CV_REG_FPEIP,
621 CV_AMD64_FPEDO = CV_REG_FPEDO,
622 CV_AMD64_MM0 = CV_REG_MM0, /* this includes MM1 to MM7 */
623 CV_AMD64_XMM0 = CV_REG_XMM0, /* this includes XMM1 to XMM7 */
624 CV_AMD64_XMM00 = CV_REG_XMM00,
625 CV_AMD64_XMM0L = CV_REG_XMM0L, /* this includes XMM1L to XMM7L */
626 CV_AMD64_XMM0H = CV_REG_XMM0H, /* this includes XMM1H to XMM7H */
627 CV_AMD64_MXCSR = CV_REG_MXCSR,
628 CV_AMD64_EDXEAX = CV_REG_EDXEAX,
629 CV_AMD64_EMM0L = CV_REG_EMM0L,
630 CV_AMD64_EMM0H = CV_REG_EMM0H,
631 CV_AMD64_MM00 = CV_REG_MM00,
632 CV_AMD64_MM01 = CV_REG_MM01,
633 CV_AMD64_MM10 = CV_REG_MM10,
634 CV_AMD64_MM11 = CV_REG_MM11,
635 CV_AMD64_MM20 = CV_REG_MM20,
636 CV_AMD64_MM21 = CV_REG_MM21,
637 CV_AMD64_MM30 = CV_REG_MM30,
638 CV_AMD64_MM31 = CV_REG_MM31,
639 CV_AMD64_MM40 = CV_REG_MM40,
640 CV_AMD64_MM41 = CV_REG_MM41,
641 CV_AMD64_MM50 = CV_REG_MM50,
642 CV_AMD64_MM51 = CV_REG_MM51,
643 CV_AMD64_MM60 = CV_REG_MM60,
644 CV_AMD64_MM61 = CV_REG_MM61,
645 CV_AMD64_MM70 = CV_REG_MM70,
646 CV_AMD64_MM71 = CV_REG_MM71,
648 CV_AMD64_XMM8 = 252, /* this includes XMM9 to XMM15 */
650 CV_AMD64_RAX = 328,
651 CV_AMD64_RBX = 329,
652 CV_AMD64_RCX = 330,
653 CV_AMD64_RDX = 331,
654 CV_AMD64_RSI = 332,
655 CV_AMD64_RDI = 333,
656 CV_AMD64_RBP = 334,
657 CV_AMD64_RSP = 335,
659 CV_AMD64_R8 = 336,
660 CV_AMD64_R9 = 337,
661 CV_AMD64_R10 = 338,
662 CV_AMD64_R11 = 339,
663 CV_AMD64_R12 = 340,
664 CV_AMD64_R13 = 341,
665 CV_AMD64_R14 = 342,
666 CV_AMD64_R15 = 343,
668 /* Wine extension */
669 CV_ARM64_NOREG = CV_REG_NONE,
670 CV_ARM64_X0 = 10, /* this includes X0 to X30 */
671 CV_ARM64_SP = 41,
672 CV_ARM64_PC = 42,
673 CV_ARM64_PSTATE = 43,
676 typedef enum
678 THUNK_ORDINAL_NOTYPE,
679 THUNK_ORDINAL_ADJUSTOR,
680 THUNK_ORDINAL_VCALL,
681 THUNK_ORDINAL_PCODE,
682 THUNK_ORDINAL_LOAD
683 } THUNK_ORDINAL;
685 typedef enum CV_call_e
687 CV_CALL_NEAR_C,
688 CV_CALL_FAR_C,
689 CV_CALL_NEAR_PASCAL,
690 CV_CALL_FAR_PASCAL,
691 CV_CALL_NEAR_FAST,
692 CV_CALL_FAR_FAST,
693 CV_CALL_SKIPPED,
694 CV_CALL_NEAR_STD,
695 CV_CALL_FAR_STD,
696 CV_CALL_NEAR_SYS,
697 CV_CALL_FAR_SYS,
698 CV_CALL_THISCALL,
699 CV_CALL_MIPSCALL,
700 CV_CALL_GENERIC,
701 CV_CALL_ALPHACALL,
702 CV_CALL_PPCCALL,
703 CV_CALL_SHCALL,
704 CV_CALL_ARMCALL,
705 CV_CALL_AM33CALL,
706 CV_CALL_TRICALL,
707 CV_CALL_SH5CALL,
708 CV_CALL_M32RCALL,
709 CV_CALL_RESERVED,
710 } CV_call_e;