| /* Capstone Disassembly Engine, https://www.capstone-engine.org */ |
| /* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2022, */ |
| /* Rot127 <unisono@quyllur.org> 2022-2023 */ |
| /* Automatically generated file by Capstone's LLVM TableGen Disassembler Backend. */ |
| |
| /* LLVM-commit: 464bda7750a3ba9e23823fc707d7e7b6fc38438d */ |
| /* LLVM-tag: llvmorg-16.0.2-5-g464bda7750a3 */ |
| |
| /* Do not edit. */ |
| |
| /* Capstone's LLVM TableGen Backends: */ |
| /* https://github.com/capstone-engine/llvm-capstone */ |
| |
| #ifdef GET_BANKEDREG_DECL |
| #endif |
| |
| #ifdef GET_MCLASSSYSREG_DECL |
| #endif |
| |
| #ifdef GET_BANKEDREG_DECL |
| const ARMBankedReg_BankedReg * |
| ARMBankedReg_lookupBankedRegByName(const char *Name); |
| const ARMBankedReg_BankedReg * |
| ARMBankedReg_lookupBankedRegByEncoding(uint8_t Encoding); |
| #endif |
| |
| #ifdef GET_MCLASSSYSREG_DECL |
| const ARMSysReg_MClassSysReg * |
| ARMSysReg_lookupMClassSysRegByName(const char *Name); |
| const ARMSysReg_MClassSysReg * |
| ARMSysReg_lookupMClassSysRegByM1Encoding12(uint16_t M1Encoding12); |
| const ARMSysReg_MClassSysReg * |
| ARMSysReg_lookupMClassSysRegByM2M3Encoding8(uint16_t M2M3Encoding8); |
| const ARMSysReg_MClassSysReg * |
| ARMSysReg_lookupMClassSysRegByEncoding(uint16_t Encoding); |
| #endif |
| |
| #ifdef GET_BANKEDREG_IMPL |
| static const ARMBankedReg_BankedReg BankedRegsList[] = { |
| { "elr_hyp", { .bankedreg = ARM_BANKEDREG_ELR_HYP }, 0x1E }, // 0 |
| { "lr_abt", { .bankedreg = ARM_BANKEDREG_LR_ABT }, 0x14 }, // 1 |
| { "lr_fiq", { .bankedreg = ARM_BANKEDREG_LR_FIQ }, 0xE }, // 2 |
| { "lr_irq", { .bankedreg = ARM_BANKEDREG_LR_IRQ }, 0x10 }, // 3 |
| { "lr_mon", { .bankedreg = ARM_BANKEDREG_LR_MON }, 0x1C }, // 4 |
| { "lr_svc", { .bankedreg = ARM_BANKEDREG_LR_SVC }, 0x12 }, // 5 |
| { "lr_und", { .bankedreg = ARM_BANKEDREG_LR_UND }, 0x16 }, // 6 |
| { "lr_usr", { .bankedreg = ARM_BANKEDREG_LR_USR }, 0x6 }, // 7 |
| { "r10_fiq", { .bankedreg = ARM_BANKEDREG_R10_FIQ }, 0xA }, // 8 |
| { "r10_usr", { .bankedreg = ARM_BANKEDREG_R10_USR }, 0x2 }, // 9 |
| { "r11_fiq", { .bankedreg = ARM_BANKEDREG_R11_FIQ }, 0xB }, // 10 |
| { "r11_usr", { .bankedreg = ARM_BANKEDREG_R11_USR }, 0x3 }, // 11 |
| { "r12_fiq", { .bankedreg = ARM_BANKEDREG_R12_FIQ }, 0xC }, // 12 |
| { "r12_usr", { .bankedreg = ARM_BANKEDREG_R12_USR }, 0x4 }, // 13 |
| { "r8_fiq", { .bankedreg = ARM_BANKEDREG_R8_FIQ }, 0x8 }, // 14 |
| { "r8_usr", { .bankedreg = ARM_BANKEDREG_R8_USR }, 0x0 }, // 15 |
| { "r9_fiq", { .bankedreg = ARM_BANKEDREG_R9_FIQ }, 0x9 }, // 16 |
| { "r9_usr", { .bankedreg = ARM_BANKEDREG_R9_USR }, 0x1 }, // 17 |
| { "spsr_abt", { .bankedreg = ARM_BANKEDREG_SPSR_ABT }, 0x34 }, // 18 |
| { "spsr_fiq", { .bankedreg = ARM_BANKEDREG_SPSR_FIQ }, 0x2E }, // 19 |
| { "spsr_hyp", { .bankedreg = ARM_BANKEDREG_SPSR_HYP }, 0x3E }, // 20 |
| { "spsr_irq", { .bankedreg = ARM_BANKEDREG_SPSR_IRQ }, 0x30 }, // 21 |
| { "spsr_mon", { .bankedreg = ARM_BANKEDREG_SPSR_MON }, 0x3C }, // 22 |
| { "spsr_svc", { .bankedreg = ARM_BANKEDREG_SPSR_SVC }, 0x32 }, // 23 |
| { "spsr_und", { .bankedreg = ARM_BANKEDREG_SPSR_UND }, 0x36 }, // 24 |
| { "sp_abt", { .bankedreg = ARM_BANKEDREG_SP_ABT }, 0x15 }, // 25 |
| { "sp_fiq", { .bankedreg = ARM_BANKEDREG_SP_FIQ }, 0xD }, // 26 |
| { "sp_hyp", { .bankedreg = ARM_BANKEDREG_SP_HYP }, 0x1F }, // 27 |
| { "sp_irq", { .bankedreg = ARM_BANKEDREG_SP_IRQ }, 0x11 }, // 28 |
| { "sp_mon", { .bankedreg = ARM_BANKEDREG_SP_MON }, 0x1D }, // 29 |
| { "sp_svc", { .bankedreg = ARM_BANKEDREG_SP_SVC }, 0x13 }, // 30 |
| { "sp_und", { .bankedreg = ARM_BANKEDREG_SP_UND }, 0x17 }, // 31 |
| { "sp_usr", { .bankedreg = ARM_BANKEDREG_SP_USR }, 0x5 }, // 32 |
| }; |
| |
| const ARMBankedReg_BankedReg * |
| ARMBankedReg_lookupBankedRegByName(const char *Name) |
| { |
| static const struct IndexTypeStr Index[] = { |
| { "ELR_HYP", 0 }, { "LR_ABT", 1 }, { "LR_FIQ", 2 }, |
| { "LR_IRQ", 3 }, { "LR_MON", 4 }, { "LR_SVC", 5 }, |
| { "LR_UND", 6 }, { "LR_USR", 7 }, { "R10_FIQ", 8 }, |
| { "R10_USR", 9 }, { "R11_FIQ", 10 }, { "R11_USR", 11 }, |
| { "R12_FIQ", 12 }, { "R12_USR", 13 }, { "R8_FIQ", 14 }, |
| { "R8_USR", 15 }, { "R9_FIQ", 16 }, { "R9_USR", 17 }, |
| { "SPSR_ABT", 18 }, { "SPSR_FIQ", 19 }, { "SPSR_HYP", 20 }, |
| { "SPSR_IRQ", 21 }, { "SPSR_MON", 22 }, { "SPSR_SVC", 23 }, |
| { "SPSR_UND", 24 }, { "SP_ABT", 25 }, { "SP_FIQ", 26 }, |
| { "SP_HYP", 27 }, { "SP_IRQ", 28 }, { "SP_MON", 29 }, |
| { "SP_SVC", 30 }, { "SP_UND", 31 }, { "SP_USR", 32 }, |
| }; |
| |
| unsigned i = |
| binsearch_IndexTypeStrEncoding(Index, ARR_SIZE(Index), Name); |
| if (i == -1) |
| return NULL; |
| else |
| return &BankedRegsList[Index[i].index]; |
| } |
| |
| const ARMBankedReg_BankedReg * |
| ARMBankedReg_lookupBankedRegByEncoding(uint8_t Encoding) |
| { |
| static const struct IndexType Index[] = { |
| { 0x0, 15 }, { 0x1, 17 }, { 0x2, 9 }, { 0x3, 11 }, |
| { 0x4, 13 }, { 0x5, 32 }, { 0x6, 7 }, { 0x8, 14 }, |
| { 0x9, 16 }, { 0xA, 8 }, { 0xB, 10 }, { 0xC, 12 }, |
| { 0xD, 26 }, { 0xE, 2 }, { 0x10, 3 }, { 0x11, 28 }, |
| { 0x12, 5 }, { 0x13, 30 }, { 0x14, 1 }, { 0x15, 25 }, |
| { 0x16, 6 }, { 0x17, 31 }, { 0x1C, 4 }, { 0x1D, 29 }, |
| { 0x1E, 0 }, { 0x1F, 27 }, { 0x2E, 19 }, { 0x30, 21 }, |
| { 0x32, 23 }, { 0x34, 18 }, { 0x36, 24 }, { 0x3C, 22 }, |
| { 0x3E, 20 }, |
| }; |
| |
| unsigned i = |
| binsearch_IndexTypeEncoding(Index, ARR_SIZE(Index), Encoding); |
| if (i == -1) |
| return NULL; |
| else |
| return &BankedRegsList[Index[i].index]; |
| } |
| |
| #endif |
| |
| #ifdef GET_MCLASSSYSREG_IMPL |
| static const ARMSysReg_MClassSysReg MClassSysRegsList[] = { |
| { "apsr", |
| { .mclasssysreg = ARM_MCLASSSYSREG_APSR }, |
| 0x800, |
| 0x100, |
| 0x800, |
| { 0 } }, // 0 |
| { "apsr_g", |
| { .mclasssysreg = ARM_MCLASSSYSREG_APSR_G }, |
| 0x400, |
| 0x0, |
| 0x400, |
| { ARM_FeatureDSP } }, // 1 |
| { "apsr_nzcvq", |
| { .mclasssysreg = ARM_MCLASSSYSREG_APSR_NZCVQ }, |
| 0x1800, |
| 0x200, |
| 0x800, |
| { 0 } }, // 2 |
| { "apsr_nzcvqg", |
| { .mclasssysreg = ARM_MCLASSSYSREG_APSR_NZCVQG }, |
| 0xC00, |
| 0x300, |
| 0xC00, |
| { ARM_FeatureDSP } }, // 3 |
| { "basepri", |
| { .mclasssysreg = ARM_MCLASSSYSREG_BASEPRI }, |
| 0x811, |
| 0x111, |
| 0x811, |
| { ARM_HasV7Ops } }, // 4 |
| { "basepri_max", |
| { .mclasssysreg = ARM_MCLASSSYSREG_BASEPRI_MAX }, |
| 0x812, |
| 0x112, |
| 0x812, |
| { ARM_HasV7Ops } }, // 5 |
| { "basepri_ns", |
| { .mclasssysreg = ARM_MCLASSSYSREG_BASEPRI_NS }, |
| 0x891, |
| 0x191, |
| 0x891, |
| { ARM_Feature8MSecExt, ARM_HasV7Ops } }, // 6 |
| { "control", |
| { .mclasssysreg = ARM_MCLASSSYSREG_CONTROL }, |
| 0x814, |
| 0x114, |
| 0x814, |
| { 0 } }, // 7 |
| { "control_ns", |
| { .mclasssysreg = ARM_MCLASSSYSREG_CONTROL_NS }, |
| 0x894, |
| 0x194, |
| 0x894, |
| { ARM_Feature8MSecExt } }, // 8 |
| { "eapsr", |
| { .mclasssysreg = ARM_MCLASSSYSREG_EAPSR }, |
| 0x802, |
| 0x102, |
| 0x802, |
| { 0 } }, // 9 |
| { "eapsr_g", |
| { .mclasssysreg = ARM_MCLASSSYSREG_EAPSR_G }, |
| 0x402, |
| 0x2, |
| 0x402, |
| { ARM_FeatureDSP } }, // 10 |
| { "eapsr_nzcvq", |
| { .mclasssysreg = ARM_MCLASSSYSREG_EAPSR_NZCVQ }, |
| 0x1802, |
| 0x202, |
| 0x802, |
| { 0 } }, // 11 |
| { "eapsr_nzcvqg", |
| { .mclasssysreg = ARM_MCLASSSYSREG_EAPSR_NZCVQG }, |
| 0xC02, |
| 0x302, |
| 0xC02, |
| { ARM_FeatureDSP } }, // 12 |
| { "epsr", |
| { .mclasssysreg = ARM_MCLASSSYSREG_EPSR }, |
| 0x806, |
| 0x106, |
| 0x806, |
| { 0 } }, // 13 |
| { "faultmask", |
| { .mclasssysreg = ARM_MCLASSSYSREG_FAULTMASK }, |
| 0x813, |
| 0x113, |
| 0x813, |
| { ARM_HasV7Ops } }, // 14 |
| { "faultmask_ns", |
| { .mclasssysreg = ARM_MCLASSSYSREG_FAULTMASK_NS }, |
| 0x893, |
| 0x193, |
| 0x893, |
| { ARM_Feature8MSecExt, ARM_HasV7Ops } }, // 15 |
| { "iapsr", |
| { .mclasssysreg = ARM_MCLASSSYSREG_IAPSR }, |
| 0x801, |
| 0x101, |
| 0x801, |
| { 0 } }, // 16 |
| { "iapsr_g", |
| { .mclasssysreg = ARM_MCLASSSYSREG_IAPSR_G }, |
| 0x401, |
| 0x1, |
| 0x401, |
| { ARM_FeatureDSP } }, // 17 |
| { "iapsr_nzcvq", |
| { .mclasssysreg = ARM_MCLASSSYSREG_IAPSR_NZCVQ }, |
| 0x1801, |
| 0x201, |
| 0x801, |
| { 0 } }, // 18 |
| { "iapsr_nzcvqg", |
| { .mclasssysreg = ARM_MCLASSSYSREG_IAPSR_NZCVQG }, |
| 0xC01, |
| 0x301, |
| 0xC01, |
| { ARM_FeatureDSP } }, // 19 |
| { "iepsr", |
| { .mclasssysreg = ARM_MCLASSSYSREG_IEPSR }, |
| 0x807, |
| 0x107, |
| 0x807, |
| { 0 } }, // 20 |
| { "ipsr", |
| { .mclasssysreg = ARM_MCLASSSYSREG_IPSR }, |
| 0x805, |
| 0x105, |
| 0x805, |
| { 0 } }, // 21 |
| { "msp", |
| { .mclasssysreg = ARM_MCLASSSYSREG_MSP }, |
| 0x808, |
| 0x108, |
| 0x808, |
| { 0 } }, // 22 |
| { "msplim", |
| { .mclasssysreg = ARM_MCLASSSYSREG_MSPLIM }, |
| 0x80A, |
| 0x10A, |
| 0x80A, |
| { ARM_HasV8MBaselineOps } }, // 23 |
| { "msplim_ns", |
| { .mclasssysreg = ARM_MCLASSSYSREG_MSPLIM_NS }, |
| 0x88A, |
| 0x18A, |
| 0x88A, |
| { ARM_Feature8MSecExt, ARM_HasV8MBaselineOps } }, // 24 |
| { "msp_ns", |
| { .mclasssysreg = ARM_MCLASSSYSREG_MSP_NS }, |
| 0x888, |
| 0x188, |
| 0x888, |
| { ARM_Feature8MSecExt } }, // 25 |
| { "pac_key_p_0", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PAC_KEY_P_0 }, |
| 0x820, |
| 0x120, |
| 0x820, |
| { ARM_FeaturePACBTI } }, // 26 |
| { "pac_key_p_0_ns", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PAC_KEY_P_0_NS }, |
| 0x8A0, |
| 0x1A0, |
| 0x8A0, |
| { ARM_FeaturePACBTI } }, // 27 |
| { "pac_key_p_1", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PAC_KEY_P_1 }, |
| 0x821, |
| 0x121, |
| 0x821, |
| { ARM_FeaturePACBTI } }, // 28 |
| { "pac_key_p_1_ns", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PAC_KEY_P_1_NS }, |
| 0x8A1, |
| 0x1A1, |
| 0x8A1, |
| { ARM_FeaturePACBTI } }, // 29 |
| { "pac_key_p_2", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PAC_KEY_P_2 }, |
| 0x822, |
| 0x122, |
| 0x822, |
| { ARM_FeaturePACBTI } }, // 30 |
| { "pac_key_p_2_ns", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PAC_KEY_P_2_NS }, |
| 0x8A2, |
| 0x1A2, |
| 0x8A2, |
| { ARM_FeaturePACBTI } }, // 31 |
| { "pac_key_p_3", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PAC_KEY_P_3 }, |
| 0x823, |
| 0x123, |
| 0x823, |
| { ARM_FeaturePACBTI } }, // 32 |
| { "pac_key_p_3_ns", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PAC_KEY_P_3_NS }, |
| 0x8A3, |
| 0x1A3, |
| 0x8A3, |
| { ARM_FeaturePACBTI } }, // 33 |
| { "pac_key_u_0", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PAC_KEY_U_0 }, |
| 0x824, |
| 0x124, |
| 0x824, |
| { ARM_FeaturePACBTI } }, // 34 |
| { "pac_key_u_0_ns", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PAC_KEY_U_0_NS }, |
| 0x8A4, |
| 0x1A4, |
| 0x8A4, |
| { ARM_FeaturePACBTI } }, // 35 |
| { "pac_key_u_1", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PAC_KEY_U_1 }, |
| 0x825, |
| 0x125, |
| 0x825, |
| { ARM_FeaturePACBTI } }, // 36 |
| { "pac_key_u_1_ns", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PAC_KEY_U_1_NS }, |
| 0x8A5, |
| 0x1A5, |
| 0x8A5, |
| { ARM_FeaturePACBTI } }, // 37 |
| { "pac_key_u_2", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PAC_KEY_U_2 }, |
| 0x826, |
| 0x126, |
| 0x826, |
| { ARM_FeaturePACBTI } }, // 38 |
| { "pac_key_u_2_ns", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PAC_KEY_U_2_NS }, |
| 0x8A6, |
| 0x1A6, |
| 0x8A6, |
| { ARM_FeaturePACBTI } }, // 39 |
| { "pac_key_u_3", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PAC_KEY_U_3 }, |
| 0x827, |
| 0x127, |
| 0x827, |
| { ARM_FeaturePACBTI } }, // 40 |
| { "pac_key_u_3_ns", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PAC_KEY_U_3_NS }, |
| 0x8A7, |
| 0x1A7, |
| 0x8A7, |
| { ARM_FeaturePACBTI } }, // 41 |
| { "primask", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PRIMASK }, |
| 0x810, |
| 0x110, |
| 0x810, |
| { 0 } }, // 42 |
| { "primask_ns", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PRIMASK_NS }, |
| 0x890, |
| 0x190, |
| 0x890, |
| { 0 } }, // 43 |
| { "psp", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PSP }, |
| 0x809, |
| 0x109, |
| 0x809, |
| { 0 } }, // 44 |
| { "psplim", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PSPLIM }, |
| 0x80B, |
| 0x10B, |
| 0x80B, |
| { ARM_HasV8MBaselineOps } }, // 45 |
| { "psplim_ns", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PSPLIM_NS }, |
| 0x88B, |
| 0x18B, |
| 0x88B, |
| { ARM_Feature8MSecExt, ARM_HasV8MBaselineOps } }, // 46 |
| { "psp_ns", |
| { .mclasssysreg = ARM_MCLASSSYSREG_PSP_NS }, |
| 0x889, |
| 0x189, |
| 0x889, |
| { ARM_Feature8MSecExt } }, // 47 |
| { "sp_ns", |
| { .mclasssysreg = ARM_MCLASSSYSREG_SP_NS }, |
| 0x898, |
| 0x198, |
| 0x898, |
| { ARM_Feature8MSecExt } }, // 48 |
| { "xpsr", |
| { .mclasssysreg = ARM_MCLASSSYSREG_XPSR }, |
| 0x803, |
| 0x103, |
| 0x803, |
| { 0 } }, // 49 |
| { "xpsr_g", |
| { .mclasssysreg = ARM_MCLASSSYSREG_XPSR_G }, |
| 0x403, |
| 0x3, |
| 0x403, |
| { ARM_FeatureDSP } }, // 50 |
| { "xpsr_nzcvq", |
| { .mclasssysreg = ARM_MCLASSSYSREG_XPSR_NZCVQ }, |
| 0x1803, |
| 0x203, |
| 0x803, |
| { 0 } }, // 51 |
| { "xpsr_nzcvqg", |
| { .mclasssysreg = ARM_MCLASSSYSREG_XPSR_NZCVQG }, |
| 0xC03, |
| 0x303, |
| 0xC03, |
| { ARM_FeatureDSP } }, // 52 |
| }; |
| |
| const ARMSysReg_MClassSysReg * |
| ARMSysReg_lookupMClassSysRegByName(const char *Name) |
| { |
| static const struct IndexTypeStr Index[] = { |
| { "APSR", 0 }, { "APSR_G", 1 }, |
| { "APSR_NZCVQ", 2 }, { "APSR_NZCVQG", 3 }, |
| { "BASEPRI", 4 }, { "BASEPRI_MAX", 5 }, |
| { "BASEPRI_NS", 6 }, { "CONTROL", 7 }, |
| { "CONTROL_NS", 8 }, { "EAPSR", 9 }, |
| { "EAPSR_G", 10 }, { "EAPSR_NZCVQ", 11 }, |
| { "EAPSR_NZCVQG", 12 }, { "EPSR", 13 }, |
| { "FAULTMASK", 14 }, { "FAULTMASK_NS", 15 }, |
| { "IAPSR", 16 }, { "IAPSR_G", 17 }, |
| { "IAPSR_NZCVQ", 18 }, { "IAPSR_NZCVQG", 19 }, |
| { "IEPSR", 20 }, { "IPSR", 21 }, |
| { "MSP", 22 }, { "MSPLIM", 23 }, |
| { "MSPLIM_NS", 24 }, { "MSP_NS", 25 }, |
| { "PAC_KEY_P_0", 26 }, { "PAC_KEY_P_0_NS", 27 }, |
| { "PAC_KEY_P_1", 28 }, { "PAC_KEY_P_1_NS", 29 }, |
| { "PAC_KEY_P_2", 30 }, { "PAC_KEY_P_2_NS", 31 }, |
| { "PAC_KEY_P_3", 32 }, { "PAC_KEY_P_3_NS", 33 }, |
| { "PAC_KEY_U_0", 34 }, { "PAC_KEY_U_0_NS", 35 }, |
| { "PAC_KEY_U_1", 36 }, { "PAC_KEY_U_1_NS", 37 }, |
| { "PAC_KEY_U_2", 38 }, { "PAC_KEY_U_2_NS", 39 }, |
| { "PAC_KEY_U_3", 40 }, { "PAC_KEY_U_3_NS", 41 }, |
| { "PRIMASK", 42 }, { "PRIMASK_NS", 43 }, |
| { "PSP", 44 }, { "PSPLIM", 45 }, |
| { "PSPLIM_NS", 46 }, { "PSP_NS", 47 }, |
| { "SP_NS", 48 }, { "XPSR", 49 }, |
| { "XPSR_G", 50 }, { "XPSR_NZCVQ", 51 }, |
| { "XPSR_NZCVQG", 52 }, |
| }; |
| |
| unsigned i = |
| binsearch_IndexTypeStrEncoding(Index, ARR_SIZE(Index), Name); |
| if (i == -1) |
| return NULL; |
| else |
| return &MClassSysRegsList[Index[i].index]; |
| } |
| |
| const ARMSysReg_MClassSysReg * |
| ARMSysReg_lookupMClassSysRegByM1Encoding12(uint16_t M1Encoding12) |
| { |
| static const struct IndexType Index[] = { |
| { 0x400, 1 }, { 0x401, 17 }, { 0x402, 10 }, { 0x403, 50 }, |
| { 0x800, 0 }, { 0x801, 16 }, { 0x802, 9 }, { 0x803, 49 }, |
| { 0x805, 21 }, { 0x806, 13 }, { 0x807, 20 }, { 0x808, 22 }, |
| { 0x809, 44 }, { 0x80A, 23 }, { 0x80B, 45 }, { 0x810, 42 }, |
| { 0x811, 4 }, { 0x812, 5 }, { 0x813, 14 }, { 0x814, 7 }, |
| { 0x820, 26 }, { 0x821, 28 }, { 0x822, 30 }, { 0x823, 32 }, |
| { 0x824, 34 }, { 0x825, 36 }, { 0x826, 38 }, { 0x827, 40 }, |
| { 0x888, 25 }, { 0x889, 47 }, { 0x88A, 24 }, { 0x88B, 46 }, |
| { 0x890, 43 }, { 0x891, 6 }, { 0x893, 15 }, { 0x894, 8 }, |
| { 0x898, 48 }, { 0x8A0, 27 }, { 0x8A1, 29 }, { 0x8A2, 31 }, |
| { 0x8A3, 33 }, { 0x8A4, 35 }, { 0x8A5, 37 }, { 0x8A6, 39 }, |
| { 0x8A7, 41 }, { 0xC00, 3 }, { 0xC01, 19 }, { 0xC02, 12 }, |
| { 0xC03, 52 }, { 0x1800, 2 }, { 0x1801, 18 }, { 0x1802, 11 }, |
| { 0x1803, 51 }, |
| }; |
| |
| unsigned i = binsearch_IndexTypeEncoding(Index, ARR_SIZE(Index), |
| M1Encoding12); |
| if (i == -1) |
| return NULL; |
| else |
| return &MClassSysRegsList[Index[i].index]; |
| } |
| |
| const ARMSysReg_MClassSysReg * |
| ARMSysReg_lookupMClassSysRegByM2M3Encoding8(uint16_t M2M3Encoding8) |
| { |
| static const struct IndexType Index[] = { |
| { 0x0, 1 }, { 0x1, 17 }, { 0x2, 10 }, { 0x3, 50 }, |
| { 0x100, 0 }, { 0x101, 16 }, { 0x102, 9 }, { 0x103, 49 }, |
| { 0x105, 21 }, { 0x106, 13 }, { 0x107, 20 }, { 0x108, 22 }, |
| { 0x109, 44 }, { 0x10A, 23 }, { 0x10B, 45 }, { 0x110, 42 }, |
| { 0x111, 4 }, { 0x112, 5 }, { 0x113, 14 }, { 0x114, 7 }, |
| { 0x120, 26 }, { 0x121, 28 }, { 0x122, 30 }, { 0x123, 32 }, |
| { 0x124, 34 }, { 0x125, 36 }, { 0x126, 38 }, { 0x127, 40 }, |
| { 0x188, 25 }, { 0x189, 47 }, { 0x18A, 24 }, { 0x18B, 46 }, |
| { 0x190, 43 }, { 0x191, 6 }, { 0x193, 15 }, { 0x194, 8 }, |
| { 0x198, 48 }, { 0x1A0, 27 }, { 0x1A1, 29 }, { 0x1A2, 31 }, |
| { 0x1A3, 33 }, { 0x1A4, 35 }, { 0x1A5, 37 }, { 0x1A6, 39 }, |
| { 0x1A7, 41 }, { 0x200, 2 }, { 0x201, 18 }, { 0x202, 11 }, |
| { 0x203, 51 }, { 0x300, 3 }, { 0x301, 19 }, { 0x302, 12 }, |
| { 0x303, 52 }, |
| }; |
| |
| unsigned i = binsearch_IndexTypeEncoding(Index, ARR_SIZE(Index), |
| M2M3Encoding8); |
| if (i == -1) |
| return NULL; |
| else |
| return &MClassSysRegsList[Index[i].index]; |
| } |
| |
| const ARMSysReg_MClassSysReg * |
| ARMSysReg_lookupMClassSysRegByEncoding(uint16_t Encoding) |
| { |
| static const struct IndexType Index[] = { |
| { 0x400, 1 }, { 0x401, 17 }, { 0x402, 10 }, { 0x403, 50 }, |
| { 0x800, 0 }, { 0x800, 2 }, { 0x801, 16 }, { 0x801, 18 }, |
| { 0x802, 9 }, { 0x802, 11 }, { 0x803, 49 }, { 0x803, 51 }, |
| { 0x805, 21 }, { 0x806, 13 }, { 0x807, 20 }, { 0x808, 22 }, |
| { 0x809, 44 }, { 0x80A, 23 }, { 0x80B, 45 }, { 0x810, 42 }, |
| { 0x811, 4 }, { 0x812, 5 }, { 0x813, 14 }, { 0x814, 7 }, |
| { 0x820, 26 }, { 0x821, 28 }, { 0x822, 30 }, { 0x823, 32 }, |
| { 0x824, 34 }, { 0x825, 36 }, { 0x826, 38 }, { 0x827, 40 }, |
| { 0x888, 25 }, { 0x889, 47 }, { 0x88A, 24 }, { 0x88B, 46 }, |
| { 0x890, 43 }, { 0x891, 6 }, { 0x893, 15 }, { 0x894, 8 }, |
| { 0x898, 48 }, { 0x8A0, 27 }, { 0x8A1, 29 }, { 0x8A2, 31 }, |
| { 0x8A3, 33 }, { 0x8A4, 35 }, { 0x8A5, 37 }, { 0x8A6, 39 }, |
| { 0x8A7, 41 }, { 0xC00, 3 }, { 0xC01, 19 }, { 0xC02, 12 }, |
| { 0xC03, 52 }, |
| }; |
| |
| unsigned i = |
| binsearch_IndexTypeEncoding(Index, ARR_SIZE(Index), Encoding); |
| if (i == -1) |
| return NULL; |
| else |
| return &MClassSysRegsList[Index[i].index]; |
| } |
| |
| #endif |
| |
| #undef GET_BANKEDREG_DECL |
| #undef GET_MCLASSSYSREG_DECL |