+typedef struct initializer
+{
+ const char *name;
+ const char *init;
+} initializer;
+
+static initializer cpu_flag_init[] =
+{
+ { "CPU_UNKNOWN_FLAGS",
+ "~(CpuL1OM|CpuK1OM)" },
+ { "CPU_GENERIC32_FLAGS",
+ "Cpu186|Cpu286|Cpu386" },
+ { "CPU_GENERIC64_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|Cpu686|CpuClflush|Cpu387|Cpu687|CpuNop|CpuMMX|CpuSSE|CpuSSE2|CpuLM" },
+ { "CPU_NONE_FLAGS",
+ "0" },
+ { "CPU_I186_FLAGS",
+ "Cpu186" },
+ { "CPU_I286_FLAGS",
+ "Cpu186|Cpu286" },
+ { "CPU_I386_FLAGS",
+ "Cpu186|Cpu286|Cpu386" },
+ { "CPU_I486_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486" },
+ { "CPU_I586_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|Cpu387" },
+ { "CPU_I686_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|Cpu686|Cpu387|Cpu687" },
+ { "CPU_PENTIUMPRO_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|Cpu686|Cpu387|Cpu687|CpuNop" },
+ { "CPU_P2_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|Cpu686|Cpu387|Cpu687|CpuNop|CpuMMX" },
+ { "CPU_P3_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|Cpu686|Cpu387|Cpu687|CpuNop|CpuMMX|CpuSSE" },
+ { "CPU_P4_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|Cpu686|CpuClflush|Cpu387|Cpu687|CpuNop|CpuMMX|CpuSSE|CpuSSE2" },
+ { "CPU_NOCONA_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|Cpu686|CpuClflush|Cpu387|Cpu687|CpuFISTTP|CpuNop|CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuLM|CpuCX16" },
+ { "CPU_CORE_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|Cpu686|CpuClflush|Cpu387|Cpu687|CpuFISTTP|CpuNop|CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuCX16" },
+ { "CPU_CORE2_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|Cpu686|CpuClflush|Cpu387|Cpu687|CpuFISTTP|CpuNop|CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSSE3|CpuLM|CpuCX16" },
+ { "CPU_COREI7_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|Cpu686|CpuClflush|Cpu387|Cpu687|CpuFISTTP|CpuNop|CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSSE3|CpuSSE4_1|CpuSSE4_2|CpuRdtscp|CpuLM|CpuCX16" },
+ { "CPU_K6_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|CpuSYSCALL|Cpu387|CpuMMX" },
+ { "CPU_K6_2_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|CpuSYSCALL|Cpu387|CpuNop|CpuMMX|Cpu3dnow" },
+ { "CPU_ATHLON_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|Cpu686|CpuSYSCALL|Cpu387|Cpu687|CpuNop|CpuMMX|Cpu3dnow|Cpu3dnowA" },
+ { "CPU_K8_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|Cpu686|CpuSYSCALL|CpuRdtscp|Cpu387|Cpu687|CpuNop|CpuMMX|Cpu3dnow|Cpu3dnowA|CpuSSE|CpuSSE2|CpuLM" },
+ { "CPU_AMDFAM10_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|Cpu686|CpuSYSCALL|CpuRdtscp|Cpu387|Cpu687|CpuFISTTP|CpuNop|CpuMMX|Cpu3dnow|Cpu3dnowA|CpuSSE|CpuSSE2|CpuSSE3|CpuSSE4a|CpuABM|CpuLM" },
+ { "CPU_BDVER1_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|Cpu686|CpuSYSCALL|CpuRdtscp|Cpu387|Cpu687|CpuFISTTP|CpuNop|CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSE4a|CpuABM|CpuLM|CpuFMA4|CpuXOP|CpuLWP|CpuCX16|CpuClflush|CpuSSSE3|CpuSVME|CpuSSE4_1|CpuSSE4_2|CpuXsave|CpuAES|CpuAVX|CpuPCLMUL|CpuLZCNT|CpuPRFCHW" },
+ { "CPU_BDVER2_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|Cpu686|CpuSYSCALL|CpuRdtscp|Cpu387|Cpu687|CpuFISTTP|CpuNop|CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSE4a|CpuABM|CpuLM|CpuFMA|CpuFMA4|CpuXOP|CpuLWP|CpuBMI|CpuTBM|CpuF16C|CpuCX16|CpuClflush|CpuSSSE3|CpuSVME|CpuSSE4_1|CpuSSE4_2|CpuXsave|CpuAES|CpuAVX|CpuPCLMUL|CpuLZCNT|CpuPRFCHW" },
+ { "CPU_BDVER3_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|Cpu686|CpuSYSCALL|CpuRdtscp|Cpu387|Cpu687|CpuFISTTP|CpuNop|CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSE4a|CpuABM|CpuLM|CpuFMA|CpuFMA4|CpuXOP|CpuLWP|CpuBMI|CpuTBM|CpuF16C|CpuCX16|CpuClflush|CpuSSSE3|CpuSVME|CpuSSE4_1|CpuSSE4_2|CpuAES|CpuAVX|CpuPCLMUL|CpuLZCNT|CpuPRFCHW|CpuXsave|CpuXsaveopt|CpuFSGSBase" },
+ { "CPU_BTVER1_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|Cpu686|CpuSYSCALL|CpuRdtscp|Cpu387|Cpu687|CpuNop|CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSSE3|CpuSSE4a|CpuABM|CpuLM|CpuPRFCHW|CpuCX16|CpuClflush|CpuFISTTP|CpuSVME|CpuLZCNT" },
+ { "CPU_BTVER2_FLAGS",
+ "Cpu186|Cpu286|Cpu386|Cpu486|Cpu586|Cpu686|CpuSYSCALL|CpuRdtscp|Cpu387|Cpu687|CpuNop|CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSSE3|CpuSSE4a|CpuSSE4_1|CpuSSE4_2|CpuABM|CpuLM|CpuBMI|CpuF16C|CpuAES|CpuPCLMUL|CpuAVX|CpuMovbe|CpuXsave|CpuXsaveopt|CpuPRFCHW|CpuCX16|CpuClflush|CpuFISTTP|CpuSVME|CpuLZCNT" },
+ { "CPU_8087_FLAGS",
+ "Cpu8087" },
+ { "CPU_287_FLAGS",
+ "Cpu287" },
+ { "CPU_387_FLAGS",
+ "Cpu387" },
+ { "CPU_ANY87_FLAGS",
+ "Cpu8087|Cpu287|Cpu387|Cpu687|CpuFISTTP" },
+ { "CPU_CLFLUSH_FLAGS",
+ "CpuClflush" },
+ { "CPU_NOP_FLAGS",
+ "CpuNop" },
+ { "CPU_SYSCALL_FLAGS",
+ "CpuSYSCALL" },
+ { "CPU_MMX_FLAGS",
+ "CpuMMX" },
+ { "CPU_SSE_FLAGS",
+ "CpuMMX|CpuSSE" },
+ { "CPU_SSE2_FLAGS",
+ "CpuMMX|CpuSSE|CpuSSE2" },
+ { "CPU_SSE3_FLAGS",
+ "CpuMMX|CpuSSE|CpuSSE2|CpuSSE3" },
+ { "CPU_SSSE3_FLAGS",
+ "CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSSE3" },
+ { "CPU_SSE4_1_FLAGS",
+ "CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSSE3|CpuSSE4_1" },
+ { "CPU_SSE4_2_FLAGS",
+ "CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSSE3|CpuSSE4_1|CpuSSE4_2" },
+ { "CPU_ANY_SSE_FLAGS",
+ "CpuSSE|CpuSSE2|CpuSSE3|CpuSSSE3|CpuSSE4_1|CpuSSE4_2|CpuSSE4a|CpuAVX|CpuAVX2|CpuAVX512F|CpuAVX512CD|CpuAVX512ER|CpuAVX512PF" },
+ { "CPU_VMX_FLAGS",
+ "CpuVMX" },
+ { "CPU_SMX_FLAGS",
+ "CpuSMX" },
+ { "CPU_XSAVE_FLAGS",
+ "CpuXsave" },
+ { "CPU_XSAVEOPT_FLAGS",
+ "CpuXsaveopt" },
+ { "CPU_AES_FLAGS",
+ "CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSSE3|CpuSSE4_1|CpuSSE4_2|CpuAES" },
+ { "CPU_PCLMUL_FLAGS",
+ "CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSSE3|CpuSSE4_1|CpuSSE4_2|CpuPCLMUL" },
+ { "CPU_FMA_FLAGS",
+ "CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSSE3|CpuSSE4_1|CpuSSE4_2|CpuAVX|CpuFMA" },
+ { "CPU_FMA4_FLAGS",
+ "CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSSE3|CpuSSE4_1|CpuSSE4_2|CpuAVX|CpuFMA4" },
+ { "CPU_XOP_FLAGS",
+ "CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSSE3|CpuSSE4_1|CpuSSE4_2|CpuSSE4a|CpuABM|CpuAVX|CpuFMA4|CpuXOP" },
+ { "CPU_LWP_FLAGS",
+ "CpuLWP" },
+ { "CPU_BMI_FLAGS",
+ "CpuBMI" },
+ { "CPU_TBM_FLAGS",
+ "CpuTBM" },
+ { "CPU_MOVBE_FLAGS",
+ "CpuMovbe" },
+ { "CPU_CX16_FLAGS",
+ "CpuCX16" },
+ { "CPU_RDTSCP_FLAGS",
+ "CpuRdtscp" },
+ { "CPU_EPT_FLAGS",
+ "CpuEPT" },
+ { "CPU_FSGSBASE_FLAGS",
+ "CpuFSGSBase" },
+ { "CPU_RDRND_FLAGS",
+ "CpuRdRnd" },
+ { "CPU_F16C_FLAGS",
+ "CpuF16C" },
+ { "CPU_BMI2_FLAGS",
+ "CpuBMI2" },
+ { "CPU_LZCNT_FLAGS",
+ "CpuLZCNT" },
+ { "CPU_HLE_FLAGS",
+ "CpuHLE" },
+ { "CPU_RTM_FLAGS",
+ "CpuRTM" },
+ { "CPU_INVPCID_FLAGS",
+ "CpuINVPCID" },
+ { "CPU_VMFUNC_FLAGS",
+ "CpuVMFUNC" },
+ { "CPU_3DNOW_FLAGS",
+ "CpuMMX|Cpu3dnow" },
+ { "CPU_3DNOWA_FLAGS",
+ "CpuMMX|Cpu3dnow|Cpu3dnowA" },
+ { "CPU_PADLOCK_FLAGS",
+ "CpuPadLock" },
+ { "CPU_SVME_FLAGS",
+ "CpuSVME" },
+ { "CPU_SSE4A_FLAGS",
+ "CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSE4a" },
+ { "CPU_ABM_FLAGS",
+ "CpuABM" },
+ { "CPU_AVX_FLAGS",
+ "CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSSE3|CpuSSE4_1|CpuSSE4_2|CpuAVX" },
+ { "CPU_AVX2_FLAGS",
+ "CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSSE3|CpuSSE4_1|CpuSSE4_2|CpuAVX|CpuAVX2" },
+ { "CPU_AVX512F_FLAGS",
+ "CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSSE3|CpuSSE4_1|CpuSSE4_2|CpuAVX|CpuAVX2|CpuAVX512F" },
+ { "CPU_AVX512CD_FLAGS",
+ "CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSSE3|CpuSSE4_1|CpuSSE4_2|CpuAVX|CpuAVX2|CpuAVX512F|CpuAVX512CD" },
+ { "CPU_AVX512ER_FLAGS",
+ "CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSSE3|CpuSSE4_1|CpuSSE4_2|CpuAVX|CpuAVX2|CpuAVX512F|CpuAVX512ER" },
+ { "CPU_AVX512PF_FLAGS",
+ "CpuMMX|CpuSSE|CpuSSE2|CpuSSE3|CpuSSSE3|CpuSSE4_1|CpuSSE4_2|CpuAVX|CpuAVX2|CpuAVX512F|CpuAVX512PF" },
+ { "CPU_ANY_AVX_FLAGS",
+ "CpuAVX|CpuAVX2|CpuAVX512F|CpuAVX512CD|CpuAVX512ER|CpuAVX512PF" },
+ { "CPU_L1OM_FLAGS",
+ "unknown" },
+ { "CPU_K1OM_FLAGS",
+ "unknown" },
+ { "CPU_ADX_FLAGS",
+ "CpuADX" },
+ { "CPU_RDSEED_FLAGS",
+ "CpuRdSeed" },
+ { "CPU_PRFCHW_FLAGS",
+ "CpuPRFCHW" },
+ { "CPU_SMAP_FLAGS",
+ "CpuSMAP" },
+ { "CPU_MPX_FLAGS",
+ "CpuMPX" },
+ { "CPU_SHA_FLAGS",
+ "CpuSHA" },
+};
+
+static initializer operand_type_init[] =
+{
+ { "OPERAND_TYPE_NONE",
+ "0" },
+ { "OPERAND_TYPE_REG8",
+ "Reg8" },
+ { "OPERAND_TYPE_REG16",
+ "Reg16" },
+ { "OPERAND_TYPE_REG32",
+ "Reg32" },
+ { "OPERAND_TYPE_REG64",
+ "Reg64" },
+ { "OPERAND_TYPE_IMM1",
+ "Imm1" },
+ { "OPERAND_TYPE_IMM8",
+ "Imm8" },
+ { "OPERAND_TYPE_IMM8S",
+ "Imm8S" },
+ { "OPERAND_TYPE_IMM16",
+ "Imm16" },
+ { "OPERAND_TYPE_IMM32",
+ "Imm32" },
+ { "OPERAND_TYPE_IMM32S",
+ "Imm32S" },
+ { "OPERAND_TYPE_IMM64",
+ "Imm64" },
+ { "OPERAND_TYPE_BASEINDEX",
+ "BaseIndex" },
+ { "OPERAND_TYPE_DISP8",
+ "Disp8" },
+ { "OPERAND_TYPE_DISP16",
+ "Disp16" },
+ { "OPERAND_TYPE_DISP32",
+ "Disp32" },
+ { "OPERAND_TYPE_DISP32S",
+ "Disp32S" },
+ { "OPERAND_TYPE_DISP64",
+ "Disp64" },
+ { "OPERAND_TYPE_INOUTPORTREG",
+ "InOutPortReg" },
+ { "OPERAND_TYPE_SHIFTCOUNT",
+ "ShiftCount" },
+ { "OPERAND_TYPE_CONTROL",
+ "Control" },
+ { "OPERAND_TYPE_TEST",
+ "Test" },
+ { "OPERAND_TYPE_DEBUG",
+ "FloatReg" },
+ { "OPERAND_TYPE_FLOATREG",
+ "FloatReg" },
+ { "OPERAND_TYPE_FLOATACC",
+ "FloatAcc" },
+ { "OPERAND_TYPE_SREG2",
+ "SReg2" },
+ { "OPERAND_TYPE_SREG3",
+ "SReg3" },
+ { "OPERAND_TYPE_ACC",
+ "Acc" },
+ { "OPERAND_TYPE_JUMPABSOLUTE",
+ "JumpAbsolute" },
+ { "OPERAND_TYPE_REGMMX",
+ "RegMMX" },
+ { "OPERAND_TYPE_REGXMM",
+ "RegXMM" },
+ { "OPERAND_TYPE_REGYMM",
+ "RegYMM" },
+ { "OPERAND_TYPE_REGZMM",
+ "RegZMM" },
+ { "OPERAND_TYPE_REGMASK",
+ "RegMask" },
+ { "OPERAND_TYPE_ESSEG",
+ "EsSeg" },
+ { "OPERAND_TYPE_ACC32",
+ "Reg32|Acc|Dword" },
+ { "OPERAND_TYPE_ACC64",
+ "Reg64|Acc|Qword" },
+ { "OPERAND_TYPE_INOUTPORTREG",
+ "InOutPortReg" },
+ { "OPERAND_TYPE_REG16_INOUTPORTREG",
+ "Reg16|InOutPortReg" },
+ { "OPERAND_TYPE_DISP16_32",
+ "Disp16|Disp32" },
+ { "OPERAND_TYPE_ANYDISP",
+ "Disp8|Disp16|Disp32|Disp32S|Disp64" },
+ { "OPERAND_TYPE_IMM16_32",
+ "Imm16|Imm32" },
+ { "OPERAND_TYPE_IMM16_32S",
+ "Imm16|Imm32S" },
+ { "OPERAND_TYPE_IMM16_32_32S",
+ "Imm16|Imm32|Imm32S" },
+ { "OPERAND_TYPE_IMM32_64",
+ "Imm32|Imm64" },
+ { "OPERAND_TYPE_IMM32_32S_DISP32",
+ "Imm32|Imm32S|Disp32" },
+ { "OPERAND_TYPE_IMM64_DISP64",
+ "Imm64|Disp64" },
+ { "OPERAND_TYPE_IMM32_32S_64_DISP32",
+ "Imm32|Imm32S|Imm64|Disp32" },
+ { "OPERAND_TYPE_IMM32_32S_64_DISP32_64",
+ "Imm32|Imm32S|Imm64|Disp32|Disp64" },
+ { "OPERAND_TYPE_VEC_IMM4",
+ "Vec_Imm4" },
+ { "OPERAND_TYPE_REGBND",
+ "RegBND" },
+ { "OPERAND_TYPE_VEC_DISP8",
+ "Vec_Disp8" },
+};
+
+typedef struct bitfield
+{
+ int position;
+ int value;
+ const char *name;
+} bitfield;
+
+#define BITFIELD(n) { n, 0, #n }
+
+static bitfield cpu_flags[] =
+{
+ BITFIELD (Cpu186),
+ BITFIELD (Cpu286),
+ BITFIELD (Cpu386),
+ BITFIELD (Cpu486),
+ BITFIELD (Cpu586),
+ BITFIELD (Cpu686),
+ BITFIELD (CpuClflush),
+ BITFIELD (CpuNop),
+ BITFIELD (CpuSYSCALL),
+ BITFIELD (Cpu8087),
+ BITFIELD (Cpu287),
+ BITFIELD (Cpu387),
+ BITFIELD (Cpu687),
+ BITFIELD (CpuFISTTP),
+ BITFIELD (CpuMMX),
+ BITFIELD (CpuSSE),
+ BITFIELD (CpuSSE2),
+ BITFIELD (CpuSSE3),
+ BITFIELD (CpuSSSE3),
+ BITFIELD (CpuSSE4_1),
+ BITFIELD (CpuSSE4_2),
+ BITFIELD (CpuAVX),
+ BITFIELD (CpuAVX2),
+ BITFIELD (CpuAVX512F),
+ BITFIELD (CpuAVX512CD),
+ BITFIELD (CpuAVX512ER),
+ BITFIELD (CpuAVX512PF),
+ BITFIELD (CpuL1OM),
+ BITFIELD (CpuK1OM),
+ BITFIELD (CpuSSE4a),
+ BITFIELD (Cpu3dnow),
+ BITFIELD (Cpu3dnowA),
+ BITFIELD (CpuPadLock),
+ BITFIELD (CpuSVME),
+ BITFIELD (CpuVMX),
+ BITFIELD (CpuSMX),
+ BITFIELD (CpuABM),
+ BITFIELD (CpuXsave),
+ BITFIELD (CpuXsaveopt),
+ BITFIELD (CpuAES),
+ BITFIELD (CpuPCLMUL),
+ BITFIELD (CpuFMA),
+ BITFIELD (CpuFMA4),
+ BITFIELD (CpuXOP),
+ BITFIELD (CpuLWP),
+ BITFIELD (CpuBMI),
+ BITFIELD (CpuTBM),
+ BITFIELD (CpuLM),
+ BITFIELD (CpuMovbe),
+ BITFIELD (CpuCX16),
+ BITFIELD (CpuEPT),
+ BITFIELD (CpuRdtscp),
+ BITFIELD (CpuFSGSBase),
+ BITFIELD (CpuRdRnd),
+ BITFIELD (CpuF16C),
+ BITFIELD (CpuBMI2),
+ BITFIELD (CpuLZCNT),
+ BITFIELD (CpuHLE),
+ BITFIELD (CpuRTM),
+ BITFIELD (CpuINVPCID),
+ BITFIELD (CpuVMFUNC),
+ BITFIELD (CpuRDSEED),
+ BITFIELD (CpuADX),
+ BITFIELD (CpuPRFCHW),
+ BITFIELD (CpuSMAP),
+ BITFIELD (CpuSHA),
+ BITFIELD (CpuVREX),
+ BITFIELD (Cpu64),
+ BITFIELD (CpuNo64),
+ BITFIELD (CpuMPX),
+#ifdef CpuUnused
+ BITFIELD (CpuUnused),
+#endif
+};
+
+static bitfield opcode_modifiers[] =
+{
+ BITFIELD (D),
+ BITFIELD (W),
+ BITFIELD (S),
+ BITFIELD (Modrm),
+ BITFIELD (ShortForm),
+ BITFIELD (Jump),
+ BITFIELD (JumpDword),
+ BITFIELD (JumpByte),
+ BITFIELD (JumpInterSegment),
+ BITFIELD (FloatMF),
+ BITFIELD (FloatR),
+ BITFIELD (FloatD),
+ BITFIELD (Size16),
+ BITFIELD (Size32),
+ BITFIELD (Size64),
+ BITFIELD (CheckRegSize),
+ BITFIELD (IgnoreSize),
+ BITFIELD (DefaultSize),
+ BITFIELD (No_bSuf),
+ BITFIELD (No_wSuf),
+ BITFIELD (No_lSuf),
+ BITFIELD (No_sSuf),
+ BITFIELD (No_qSuf),
+ BITFIELD (No_ldSuf),
+ BITFIELD (FWait),
+ BITFIELD (IsString),
+ BITFIELD (BNDPrefixOk),
+ BITFIELD (IsLockable),
+ BITFIELD (RegKludge),
+ BITFIELD (FirstXmm0),
+ BITFIELD (Implicit1stXmm0),
+ BITFIELD (RepPrefixOk),
+ BITFIELD (HLEPrefixOk),
+ BITFIELD (ToDword),
+ BITFIELD (ToQword),
+ BITFIELD (AddrPrefixOp0),
+ BITFIELD (IsPrefix),
+ BITFIELD (ImmExt),
+ BITFIELD (NoRex64),
+ BITFIELD (Rex64),
+ BITFIELD (Ugh),
+ BITFIELD (Vex),
+ BITFIELD (VexVVVV),
+ BITFIELD (VexW),
+ BITFIELD (VexOpcode),
+ BITFIELD (VexSources),
+ BITFIELD (VexImmExt),
+ BITFIELD (VecSIB),
+ BITFIELD (SSE2AVX),
+ BITFIELD (NoAVX),
+ BITFIELD (EVex),
+ BITFIELD (Masking),
+ BITFIELD (VecESize),
+ BITFIELD (Broadcast),
+ BITFIELD (StaticRounding),
+ BITFIELD (SAE),
+ BITFIELD (Disp8MemShift),
+ BITFIELD (NoDefMask),
+ BITFIELD (OldGcc),
+ BITFIELD (ATTMnemonic),
+ BITFIELD (ATTSyntax),
+ BITFIELD (IntelSyntax),
+};
+
+static bitfield operand_types[] =
+{
+ BITFIELD (Reg8),
+ BITFIELD (Reg16),
+ BITFIELD (Reg32),
+ BITFIELD (Reg64),
+ BITFIELD (FloatReg),
+ BITFIELD (RegMMX),
+ BITFIELD (RegXMM),
+ BITFIELD (RegYMM),
+ BITFIELD (RegZMM),
+ BITFIELD (RegMask),
+ BITFIELD (Imm1),
+ BITFIELD (Imm8),
+ BITFIELD (Imm8S),
+ BITFIELD (Imm16),
+ BITFIELD (Imm32),
+ BITFIELD (Imm32S),
+ BITFIELD (Imm64),
+ BITFIELD (BaseIndex),
+ BITFIELD (Disp8),
+ BITFIELD (Disp16),
+ BITFIELD (Disp32),
+ BITFIELD (Disp32S),
+ BITFIELD (Disp64),
+ BITFIELD (InOutPortReg),
+ BITFIELD (ShiftCount),
+ BITFIELD (Control),
+ BITFIELD (Debug),
+ BITFIELD (Test),
+ BITFIELD (SReg2),
+ BITFIELD (SReg3),
+ BITFIELD (Acc),
+ BITFIELD (FloatAcc),
+ BITFIELD (JumpAbsolute),
+ BITFIELD (EsSeg),
+ BITFIELD (RegMem),
+ BITFIELD (Mem),
+ BITFIELD (Byte),
+ BITFIELD (Word),
+ BITFIELD (Dword),
+ BITFIELD (Fword),
+ BITFIELD (Qword),
+ BITFIELD (Tbyte),
+ BITFIELD (Xmmword),
+ BITFIELD (Ymmword),
+ BITFIELD (Zmmword),
+ BITFIELD (Unspecified),
+ BITFIELD (Anysize),
+ BITFIELD (Vec_Imm4),
+ BITFIELD (RegBND),
+ BITFIELD (Vec_Disp8),
+#ifdef OTUnused
+ BITFIELD (OTUnused),
+#endif
+};
+
+static const char *filename;
+
+static int
+compare (const void *x, const void *y)
+{
+ const bitfield *xp = (const bitfield *) x;
+ const bitfield *yp = (const bitfield *) y;
+ return xp->position - yp->position;
+}
+