usp10: Explicitly check for zero-width control characters in ScriptShapeOpenType().
[wine.git] / include / cvconst.h
blob83b529d7f8275f68783949213303e0299ed3677d
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 /* 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,
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 */
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,
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,
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,
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,
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> */
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,
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,
667 CV_AMD64_XMM8 = 252, /* this includes XMM9 to XMM15 */
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,
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,
688 typedef enum
690 THUNK_ORDINAL_NOTYPE,
691 THUNK_ORDINAL_ADJUSTOR,
692 THUNK_ORDINAL_VCALL,
693 THUNK_ORDINAL_PCODE,
694 THUNK_ORDINAL_LOAD
695 } THUNK_ORDINAL;
697 typedef enum CV_call_e
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;