capstone/arch/ARM/ARMGenSubtargetInfo.inc
2013-12-01 22:19:27 +08:00

130 lines
8.2 KiB
C++

/*===- TableGen'erated file -------------------------------------*- C++ -*-===*\
|* *|
|*Subtarget Enumeration Source Fragment *|
|* *|
|* Automatically generated file, do not edit! *|
|* *|
\*===----------------------------------------------------------------------===*/
/* Capstone Disassembler Engine */
/* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013> */
#ifdef GET_SUBTARGETINFO_ENUM
#undef GET_SUBTARGETINFO_ENUM
#define ARM_FeatureAClass 1ULL << 0
#define ARM_FeatureAvoidMOVsShOp 1ULL << 1
#define ARM_FeatureAvoidPartialCPSR 1ULL << 2
#define ARM_FeatureCRC 1ULL << 3
#define ARM_FeatureCrypto 1ULL << 4
#define ARM_FeatureD16 1ULL << 5
#define ARM_FeatureDB 1ULL << 6
#define ARM_FeatureDSPThumb2 1ULL << 7
#define ARM_FeatureFP16 1ULL << 8
#define ARM_FeatureFPARMv8 1ULL << 9
#define ARM_FeatureHWDiv 1ULL << 10
#define ARM_FeatureHWDivARM 1ULL << 11
#define ARM_FeatureHasRAS 1ULL << 12
#define ARM_FeatureHasSlowFPVMLx 1ULL << 13
#define ARM_FeatureMClass 1ULL << 14
#define ARM_FeatureMP 1ULL << 15
#define ARM_FeatureNEON 1ULL << 16
#define ARM_FeatureNEONForFP 1ULL << 17
#define ARM_FeatureNaClTrap 1ULL << 18
#define ARM_FeatureNoARM 1ULL << 19
#define ARM_FeaturePerfMon 1ULL << 20
#define ARM_FeaturePref32BitThumb 1ULL << 21
#define ARM_FeatureRClass 1ULL << 22
#define ARM_FeatureSlowFPBrcc 1ULL << 23
#define ARM_FeatureT2XtPk 1ULL << 24
#define ARM_FeatureThumb2 1ULL << 25
#define ARM_FeatureTrustZone 1ULL << 26
#define ARM_FeatureVFP2 1ULL << 27
#define ARM_FeatureVFP3 1ULL << 28
#define ARM_FeatureVFP4 1ULL << 29
#define ARM_FeatureVFPOnlySP 1ULL << 30
#define ARM_FeatureVMLxForwarding 1ULL << 31
#define ARM_FeatureVirtualization 1ULL << 32
#define ARM_HasV4TOps 1ULL << 33
#define ARM_HasV5TEOps 1ULL << 34
#define ARM_HasV5TOps 1ULL << 35
#define ARM_HasV6MOps 1ULL << 36
#define ARM_HasV6Ops 1ULL << 37
#define ARM_HasV6T2Ops 1ULL << 38
#define ARM_HasV7Ops 1ULL << 39
#define ARM_HasV8Ops 1ULL << 40
#define ARM_ModeThumb 1ULL << 41
#define ARM_ProcA5 1ULL << 42
#define ARM_ProcA7 1ULL << 43
#define ARM_ProcA8 1ULL << 44
#define ARM_ProcA9 1ULL << 45
#define ARM_ProcA12 1ULL << 46
#define ARM_ProcA15 1ULL << 47
#define ARM_ProcA53 1ULL << 48
#define ARM_ProcA57 1ULL << 49
#define ARM_ProcR5 1ULL << 50
#define ARM_ProcSwift 1ULL << 51
#endif // GET_SUBTARGETINFO_ENUM
#ifdef GET_SUBTARGETINFO_MC_DESC
#undef GET_SUBTARGETINFO_MC_DESC
// Sorted (by key) array of values for CPU features.
static SubtargetFeatureKV ARMFeatureKV[] = {
{ "32bit", "Prefer 32-bit Thumb instrs", ARM_FeaturePref32BitThumb, 0ULL },
{ "a12", "Cortex-A12 ARM processors", ARM_ProcA12, ARM_FeatureVMLxForwarding | ARM_FeatureT2XtPk | ARM_FeatureVFP4 | ARM_FeatureHWDiv | ARM_FeatureHWDivARM | ARM_FeatureAvoidPartialCPSR | ARM_FeatureVirtualization | ARM_FeatureTrustZone },
{ "a15", "Cortex-A15 ARM processors", ARM_ProcA15, ARM_FeatureT2XtPk | ARM_FeatureVFP4 | ARM_FeatureMP | ARM_FeatureHWDiv | ARM_FeatureHWDivARM | ARM_FeatureAvoidPartialCPSR | ARM_FeatureTrustZone | ARM_FeatureVirtualization },
{ "a5", "Cortex-A5 ARM processors", ARM_ProcA5, ARM_FeatureSlowFPBrcc | ARM_FeatureHasSlowFPVMLx | ARM_FeatureVMLxForwarding | ARM_FeatureT2XtPk | ARM_FeatureTrustZone | ARM_FeatureMP },
{ "a53", "Cortex-A53 ARM processors", ARM_ProcA53, ARM_FeatureHWDiv | ARM_FeatureHWDivARM | ARM_FeatureTrustZone | ARM_FeatureT2XtPk | ARM_FeatureCrypto | ARM_FeatureCRC },
{ "a57", "Cortex-A57 ARM processors", ARM_ProcA57, ARM_FeatureHWDiv | ARM_FeatureHWDivARM | ARM_FeatureTrustZone | ARM_FeatureT2XtPk | ARM_FeatureCrypto | ARM_FeatureCRC },
{ "a7", "Cortex-A7 ARM processors", ARM_ProcA7, ARM_FeatureSlowFPBrcc | ARM_FeatureHasSlowFPVMLx | ARM_FeatureVMLxForwarding | ARM_FeatureT2XtPk | ARM_FeatureVFP4 | ARM_FeatureMP | ARM_FeatureHWDiv | ARM_FeatureHWDivARM | ARM_FeatureTrustZone | ARM_FeatureVirtualization },
{ "a8", "Cortex-A8 ARM processors", ARM_ProcA8, ARM_FeatureSlowFPBrcc | ARM_FeatureHasSlowFPVMLx | ARM_FeatureVMLxForwarding | ARM_FeatureT2XtPk | ARM_FeatureTrustZone },
{ "a9", "Cortex-A9 ARM processors", ARM_ProcA9, ARM_FeatureVMLxForwarding | ARM_FeatureT2XtPk | ARM_FeatureFP16 | ARM_FeatureAvoidPartialCPSR | ARM_FeatureTrustZone },
{ "aclass", "Is application profile ('A' series)", ARM_FeatureAClass, 0ULL },
{ "avoid-movs-shop", "Avoid movs instructions with shifter operand", ARM_FeatureAvoidMOVsShOp, 0ULL },
{ "avoid-partial-cpsr", "Avoid CPSR partial update for OOO execution", ARM_FeatureAvoidPartialCPSR, 0ULL },
{ "crc", "Enable support for CRC instructions", ARM_FeatureCRC, 0ULL },
{ "crypto", "Enable support for Cryptography extensions", ARM_FeatureCrypto, ARM_FeatureNEON },
{ "d16", "Restrict VFP3 to 16 double registers", ARM_FeatureD16, 0ULL },
{ "db", "Has data barrier (dmb / dsb) instructions", ARM_FeatureDB, 0ULL },
{ "fp-armv8", "Enable ARMv8 FP", ARM_FeatureFPARMv8, ARM_FeatureVFP4 },
{ "fp-only-sp", "Floating point unit supports single precision only", ARM_FeatureVFPOnlySP, 0ULL },
{ "fp16", "Enable half-precision floating point", ARM_FeatureFP16, 0ULL },
{ "hwdiv", "Enable divide instructions", ARM_FeatureHWDiv, 0ULL },
{ "hwdiv-arm", "Enable divide instructions in ARM mode", ARM_FeatureHWDivARM, 0ULL },
{ "mclass", "Is microcontroller profile ('M' series)", ARM_FeatureMClass, 0ULL },
{ "mp", "Supports Multiprocessing extension", ARM_FeatureMP, 0ULL },
{ "nacl-trap", "NaCl trap", ARM_FeatureNaClTrap, 0ULL },
{ "neon", "Enable NEON instructions", ARM_FeatureNEON, ARM_FeatureVFP3 },
{ "neonfp", "Use NEON for single precision FP", ARM_FeatureNEONForFP, 0ULL },
{ "noarm", "Does not support ARM mode execution", ARM_FeatureNoARM, ARM_ModeThumb },
{ "perfmon", "Enable support for Performance Monitor extensions", ARM_FeaturePerfMon, 0ULL },
{ "r5", "Cortex-R5 ARM processors", ARM_ProcR5, ARM_FeatureSlowFPBrcc | ARM_FeatureHWDiv | ARM_FeatureHWDivARM | ARM_FeatureHasSlowFPVMLx | ARM_FeatureAvoidPartialCPSR | ARM_FeatureT2XtPk },
{ "ras", "Has return address stack", ARM_FeatureHasRAS, 0ULL },
{ "rclass", "Is realtime profile ('R' series)", ARM_FeatureRClass, 0ULL },
{ "slow-fp-brcc", "FP compare + branch is slow", ARM_FeatureSlowFPBrcc, 0ULL },
{ "slowfpvmlx", "Disable VFP / NEON MAC instructions", ARM_FeatureHasSlowFPVMLx, 0ULL },
{ "swift", "Swift ARM processors", ARM_ProcSwift, ARM_FeatureNEONForFP | ARM_FeatureT2XtPk | ARM_FeatureVFP4 | ARM_FeatureMP | ARM_FeatureHWDiv | ARM_FeatureHWDivARM | ARM_FeatureAvoidPartialCPSR | ARM_FeatureAvoidMOVsShOp | ARM_FeatureHasSlowFPVMLx | ARM_FeatureTrustZone },
{ "t2dsp", "Supports v7 DSP instructions in Thumb2", ARM_FeatureDSPThumb2, 0ULL },
{ "t2xtpk", "Enable Thumb2 extract and pack instructions", ARM_FeatureT2XtPk, 0ULL },
{ "thumb-mode", "Thumb mode", ARM_ModeThumb, 0ULL },
{ "thumb2", "Enable Thumb2 instructions", ARM_FeatureThumb2, 0ULL },
{ "trustzone", "Enable support for TrustZone security extensions", ARM_FeatureTrustZone, 0ULL },
{ "v4t", "Support ARM v4T instructions", ARM_HasV4TOps, 0ULL },
{ "v5t", "Support ARM v5T instructions", ARM_HasV5TOps, ARM_HasV4TOps },
{ "v5te", "Support ARM v5TE, v5TEj, and v5TExp instructions", ARM_HasV5TEOps, ARM_HasV5TOps },
{ "v6", "Support ARM v6 instructions", ARM_HasV6Ops, ARM_HasV5TEOps },
{ "v6m", "Support ARM v6M instructions", ARM_HasV6MOps, ARM_HasV6Ops },
{ "v6t2", "Support ARM v6t2 instructions", ARM_HasV6T2Ops, ARM_HasV6MOps | ARM_FeatureThumb2 },
{ "v7", "Support ARM v7 instructions", ARM_HasV7Ops, ARM_HasV6T2Ops | ARM_FeaturePerfMon },
{ "v8", "Support ARM v8 instructions", ARM_HasV8Ops, ARM_HasV7Ops | ARM_FeatureVirtualization | ARM_FeatureMP },
{ "vfp2", "Enable VFP2 instructions", ARM_FeatureVFP2, 0ULL },
{ "vfp3", "Enable VFP3 instructions", ARM_FeatureVFP3, ARM_FeatureVFP2 },
{ "vfp4", "Enable VFP4 instructions", ARM_FeatureVFP4, ARM_FeatureVFP3 | ARM_FeatureFP16 },
{ "virtualization", "Supports Virtualization extension", ARM_FeatureVirtualization, ARM_FeatureHWDiv | ARM_FeatureHWDivARM },
{ "vmlx-forwarding", "Has multiplier accumulator forwarding", ARM_FeatureVMLxForwarding, 0ULL }
};
#endif // GET_SUBTARGETINFO_MC_DESC