/src/capstonenext/arch/ARM/ARMGenSystemRegister.inc
Line | Count | Source |
1 | | /* Capstone Disassembly Engine, https://www.capstone-engine.org */ |
2 | | /* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2022, */ |
3 | | /* Rot127 <unisono@quyllur.org> 2022-2024 */ |
4 | | /* Automatically generated file by Capstone's LLVM TableGen Disassembler Backend. */ |
5 | | |
6 | | /* LLVM-commit: <commit> */ |
7 | | /* LLVM-tag: <tag> */ |
8 | | |
9 | | /* Do not edit. */ |
10 | | |
11 | | /* Capstone's LLVM TableGen Backends: */ |
12 | | /* https://github.com/capstone-engine/llvm-capstone */ |
13 | | |
14 | | #ifdef GET_BANKEDREG_DECL |
15 | | #endif |
16 | | |
17 | | #ifdef GET_MCLASSSYSREG_DECL |
18 | | #endif |
19 | | |
20 | | #ifdef GET_BANKEDREG_DECL |
21 | | const ARMBankedReg_BankedReg *ARMBankedReg_lookupBankedRegByName(const char * Name); |
22 | | const ARMBankedReg_BankedReg *ARMBankedReg_lookupBankedRegByEncoding(uint8_t Encoding); |
23 | | #endif |
24 | | |
25 | | #ifdef GET_MCLASSSYSREG_DECL |
26 | | const ARMSysReg_MClassSysReg *ARMSysReg_lookupMClassSysRegByName(const char * Name); |
27 | | const ARMSysReg_MClassSysReg *ARMSysReg_lookupMClassSysRegByM1Encoding12(uint16_t M1Encoding12); |
28 | | const ARMSysReg_MClassSysReg *ARMSysReg_lookupMClassSysRegByM2M3Encoding8(uint16_t M2M3Encoding8); |
29 | | const ARMSysReg_MClassSysReg *ARMSysReg_lookupMClassSysRegByEncoding(uint16_t Encoding); |
30 | | #endif |
31 | | |
32 | | #ifdef GET_BANKEDREG_IMPL |
33 | | static const ARMBankedReg_BankedReg BankedRegsList[] = { |
34 | | { "elr_hyp", { .raw_val = ARM_BANKEDREG_ELR_HYP }, 0x1E }, // 0 |
35 | | { "lr_abt", { .raw_val = ARM_BANKEDREG_LR_ABT }, 0x14 }, // 1 |
36 | | { "lr_fiq", { .raw_val = ARM_BANKEDREG_LR_FIQ }, 0xE }, // 2 |
37 | | { "lr_irq", { .raw_val = ARM_BANKEDREG_LR_IRQ }, 0x10 }, // 3 |
38 | | { "lr_mon", { .raw_val = ARM_BANKEDREG_LR_MON }, 0x1C }, // 4 |
39 | | { "lr_svc", { .raw_val = ARM_BANKEDREG_LR_SVC }, 0x12 }, // 5 |
40 | | { "lr_und", { .raw_val = ARM_BANKEDREG_LR_UND }, 0x16 }, // 6 |
41 | | { "lr_usr", { .raw_val = ARM_BANKEDREG_LR_USR }, 0x6 }, // 7 |
42 | | { "r10_fiq", { .raw_val = ARM_BANKEDREG_R10_FIQ }, 0xA }, // 8 |
43 | | { "r10_usr", { .raw_val = ARM_BANKEDREG_R10_USR }, 0x2 }, // 9 |
44 | | { "r11_fiq", { .raw_val = ARM_BANKEDREG_R11_FIQ }, 0xB }, // 10 |
45 | | { "r11_usr", { .raw_val = ARM_BANKEDREG_R11_USR }, 0x3 }, // 11 |
46 | | { "r12_fiq", { .raw_val = ARM_BANKEDREG_R12_FIQ }, 0xC }, // 12 |
47 | | { "r12_usr", { .raw_val = ARM_BANKEDREG_R12_USR }, 0x4 }, // 13 |
48 | | { "r8_fiq", { .raw_val = ARM_BANKEDREG_R8_FIQ }, 0x8 }, // 14 |
49 | | { "r8_usr", { .raw_val = ARM_BANKEDREG_R8_USR }, 0x0 }, // 15 |
50 | | { "r9_fiq", { .raw_val = ARM_BANKEDREG_R9_FIQ }, 0x9 }, // 16 |
51 | | { "r9_usr", { .raw_val = ARM_BANKEDREG_R9_USR }, 0x1 }, // 17 |
52 | | { "spsr_abt", { .raw_val = ARM_BANKEDREG_SPSR_ABT }, 0x34 }, // 18 |
53 | | { "spsr_fiq", { .raw_val = ARM_BANKEDREG_SPSR_FIQ }, 0x2E }, // 19 |
54 | | { "spsr_hyp", { .raw_val = ARM_BANKEDREG_SPSR_HYP }, 0x3E }, // 20 |
55 | | { "spsr_irq", { .raw_val = ARM_BANKEDREG_SPSR_IRQ }, 0x30 }, // 21 |
56 | | { "spsr_mon", { .raw_val = ARM_BANKEDREG_SPSR_MON }, 0x3C }, // 22 |
57 | | { "spsr_svc", { .raw_val = ARM_BANKEDREG_SPSR_SVC }, 0x32 }, // 23 |
58 | | { "spsr_und", { .raw_val = ARM_BANKEDREG_SPSR_UND }, 0x36 }, // 24 |
59 | | { "sp_abt", { .raw_val = ARM_BANKEDREG_SP_ABT }, 0x15 }, // 25 |
60 | | { "sp_fiq", { .raw_val = ARM_BANKEDREG_SP_FIQ }, 0xD }, // 26 |
61 | | { "sp_hyp", { .raw_val = ARM_BANKEDREG_SP_HYP }, 0x1F }, // 27 |
62 | | { "sp_irq", { .raw_val = ARM_BANKEDREG_SP_IRQ }, 0x11 }, // 28 |
63 | | { "sp_mon", { .raw_val = ARM_BANKEDREG_SP_MON }, 0x1D }, // 29 |
64 | | { "sp_svc", { .raw_val = ARM_BANKEDREG_SP_SVC }, 0x13 }, // 30 |
65 | | { "sp_und", { .raw_val = ARM_BANKEDREG_SP_UND }, 0x17 }, // 31 |
66 | | { "sp_usr", { .raw_val = ARM_BANKEDREG_SP_USR }, 0x5 }, // 32 |
67 | | }; |
68 | | |
69 | 0 | const ARMBankedReg_BankedReg *ARMBankedReg_lookupBankedRegByName(const char * Name) { |
70 | 0 | static const struct IndexTypeStr Index[] = { |
71 | 0 | { "ELR_HYP", 0 }, |
72 | 0 | { "LR_ABT", 1 }, |
73 | 0 | { "LR_FIQ", 2 }, |
74 | 0 | { "LR_IRQ", 3 }, |
75 | 0 | { "LR_MON", 4 }, |
76 | 0 | { "LR_SVC", 5 }, |
77 | 0 | { "LR_UND", 6 }, |
78 | 0 | { "LR_USR", 7 }, |
79 | 0 | { "R10_FIQ", 8 }, |
80 | 0 | { "R10_USR", 9 }, |
81 | 0 | { "R11_FIQ", 10 }, |
82 | 0 | { "R11_USR", 11 }, |
83 | 0 | { "R12_FIQ", 12 }, |
84 | 0 | { "R12_USR", 13 }, |
85 | 0 | { "R8_FIQ", 14 }, |
86 | 0 | { "R8_USR", 15 }, |
87 | 0 | { "R9_FIQ", 16 }, |
88 | 0 | { "R9_USR", 17 }, |
89 | 0 | { "SPSR_ABT", 18 }, |
90 | 0 | { "SPSR_FIQ", 19 }, |
91 | 0 | { "SPSR_HYP", 20 }, |
92 | 0 | { "SPSR_IRQ", 21 }, |
93 | 0 | { "SPSR_MON", 22 }, |
94 | 0 | { "SPSR_SVC", 23 }, |
95 | 0 | { "SPSR_UND", 24 }, |
96 | 0 | { "SP_ABT", 25 }, |
97 | 0 | { "SP_FIQ", 26 }, |
98 | 0 | { "SP_HYP", 27 }, |
99 | 0 | { "SP_IRQ", 28 }, |
100 | 0 | { "SP_MON", 29 }, |
101 | 0 | { "SP_SVC", 30 }, |
102 | 0 | { "SP_UND", 31 }, |
103 | 0 | { "SP_USR", 32 }, |
104 | 0 | }; |
105 | |
|
106 | 0 | unsigned i = binsearch_IndexTypeStrEncoding(Index, ARR_SIZE(Index), Name); |
107 | 0 | if (i == -1) |
108 | 0 | return NULL; |
109 | 0 | else |
110 | 0 | return &BankedRegsList[Index[i].index]; |
111 | 0 | } |
112 | | |
113 | 2.31k | const ARMBankedReg_BankedReg *ARMBankedReg_lookupBankedRegByEncoding(uint8_t Encoding) { |
114 | 2.31k | static const struct IndexType Index[] = { |
115 | 2.31k | { 0x0, 15 }, |
116 | 2.31k | { 0x1, 17 }, |
117 | 2.31k | { 0x2, 9 }, |
118 | 2.31k | { 0x3, 11 }, |
119 | 2.31k | { 0x4, 13 }, |
120 | 2.31k | { 0x5, 32 }, |
121 | 2.31k | { 0x6, 7 }, |
122 | 2.31k | { 0x8, 14 }, |
123 | 2.31k | { 0x9, 16 }, |
124 | 2.31k | { 0xA, 8 }, |
125 | 2.31k | { 0xB, 10 }, |
126 | 2.31k | { 0xC, 12 }, |
127 | 2.31k | { 0xD, 26 }, |
128 | 2.31k | { 0xE, 2 }, |
129 | 2.31k | { 0x10, 3 }, |
130 | 2.31k | { 0x11, 28 }, |
131 | 2.31k | { 0x12, 5 }, |
132 | 2.31k | { 0x13, 30 }, |
133 | 2.31k | { 0x14, 1 }, |
134 | 2.31k | { 0x15, 25 }, |
135 | 2.31k | { 0x16, 6 }, |
136 | 2.31k | { 0x17, 31 }, |
137 | 2.31k | { 0x1C, 4 }, |
138 | 2.31k | { 0x1D, 29 }, |
139 | 2.31k | { 0x1E, 0 }, |
140 | 2.31k | { 0x1F, 27 }, |
141 | 2.31k | { 0x2E, 19 }, |
142 | 2.31k | { 0x30, 21 }, |
143 | 2.31k | { 0x32, 23 }, |
144 | 2.31k | { 0x34, 18 }, |
145 | 2.31k | { 0x36, 24 }, |
146 | 2.31k | { 0x3C, 22 }, |
147 | 2.31k | { 0x3E, 20 }, |
148 | 2.31k | }; |
149 | | |
150 | 2.31k | unsigned i = binsearch_IndexTypeEncoding(Index, ARR_SIZE(Index), Encoding); |
151 | 2.31k | if (i == -1) |
152 | 4 | return NULL; |
153 | 2.30k | else |
154 | 2.30k | return &BankedRegsList[Index[i].index]; |
155 | 2.31k | } |
156 | | |
157 | | #endif |
158 | | |
159 | | #ifdef GET_MCLASSSYSREG_IMPL |
160 | | static const ARMSysReg_MClassSysReg MClassSysRegsList[] = { |
161 | | { "apsr", { .raw_val = ARM_MCLASSSYSREG_APSR }, 0x800, 0x100, 0x800, {0} }, // 0 |
162 | | { "apsr_g", { .raw_val = ARM_MCLASSSYSREG_APSR_G }, 0x400, 0x0, 0x400, {ARM_FeatureDSP} }, // 1 |
163 | | { "apsr_nzcvq", { .raw_val = ARM_MCLASSSYSREG_APSR_NZCVQ }, 0x1800, 0x200, 0x800, {0} }, // 2 |
164 | | { "apsr_nzcvqg", { .raw_val = ARM_MCLASSSYSREG_APSR_NZCVQG }, 0xC00, 0x300, 0xC00, {ARM_FeatureDSP} }, // 3 |
165 | | { "basepri", { .raw_val = ARM_MCLASSSYSREG_BASEPRI }, 0x811, 0x111, 0x811, {ARM_HasV7Ops} }, // 4 |
166 | | { "basepri_max", { .raw_val = ARM_MCLASSSYSREG_BASEPRI_MAX }, 0x812, 0x112, 0x812, {ARM_HasV7Ops} }, // 5 |
167 | | { "basepri_ns", { .raw_val = ARM_MCLASSSYSREG_BASEPRI_NS }, 0x891, 0x191, 0x891, {ARM_Feature8MSecExt, ARM_HasV7Ops} }, // 6 |
168 | | { "control", { .raw_val = ARM_MCLASSSYSREG_CONTROL }, 0x814, 0x114, 0x814, {0} }, // 7 |
169 | | { "control_ns", { .raw_val = ARM_MCLASSSYSREG_CONTROL_NS }, 0x894, 0x194, 0x894, {ARM_Feature8MSecExt} }, // 8 |
170 | | { "eapsr", { .raw_val = ARM_MCLASSSYSREG_EAPSR }, 0x802, 0x102, 0x802, {0} }, // 9 |
171 | | { "eapsr_g", { .raw_val = ARM_MCLASSSYSREG_EAPSR_G }, 0x402, 0x2, 0x402, {ARM_FeatureDSP} }, // 10 |
172 | | { "eapsr_nzcvq", { .raw_val = ARM_MCLASSSYSREG_EAPSR_NZCVQ }, 0x1802, 0x202, 0x802, {0} }, // 11 |
173 | | { "eapsr_nzcvqg", { .raw_val = ARM_MCLASSSYSREG_EAPSR_NZCVQG }, 0xC02, 0x302, 0xC02, {ARM_FeatureDSP} }, // 12 |
174 | | { "epsr", { .raw_val = ARM_MCLASSSYSREG_EPSR }, 0x806, 0x106, 0x806, {0} }, // 13 |
175 | | { "faultmask", { .raw_val = ARM_MCLASSSYSREG_FAULTMASK }, 0x813, 0x113, 0x813, {ARM_HasV7Ops} }, // 14 |
176 | | { "faultmask_ns", { .raw_val = ARM_MCLASSSYSREG_FAULTMASK_NS }, 0x893, 0x193, 0x893, {ARM_Feature8MSecExt, ARM_HasV7Ops} }, // 15 |
177 | | { "iapsr", { .raw_val = ARM_MCLASSSYSREG_IAPSR }, 0x801, 0x101, 0x801, {0} }, // 16 |
178 | | { "iapsr_g", { .raw_val = ARM_MCLASSSYSREG_IAPSR_G }, 0x401, 0x1, 0x401, {ARM_FeatureDSP} }, // 17 |
179 | | { "iapsr_nzcvq", { .raw_val = ARM_MCLASSSYSREG_IAPSR_NZCVQ }, 0x1801, 0x201, 0x801, {0} }, // 18 |
180 | | { "iapsr_nzcvqg", { .raw_val = ARM_MCLASSSYSREG_IAPSR_NZCVQG }, 0xC01, 0x301, 0xC01, {ARM_FeatureDSP} }, // 19 |
181 | | { "iepsr", { .raw_val = ARM_MCLASSSYSREG_IEPSR }, 0x807, 0x107, 0x807, {0} }, // 20 |
182 | | { "ipsr", { .raw_val = ARM_MCLASSSYSREG_IPSR }, 0x805, 0x105, 0x805, {0} }, // 21 |
183 | | { "msp", { .raw_val = ARM_MCLASSSYSREG_MSP }, 0x808, 0x108, 0x808, {0} }, // 22 |
184 | | { "msplim", { .raw_val = ARM_MCLASSSYSREG_MSPLIM }, 0x80A, 0x10A, 0x80A, {ARM_HasV8MBaselineOps} }, // 23 |
185 | | { "msplim_ns", { .raw_val = ARM_MCLASSSYSREG_MSPLIM_NS }, 0x88A, 0x18A, 0x88A, {ARM_Feature8MSecExt, ARM_HasV8MBaselineOps} }, // 24 |
186 | | { "msp_ns", { .raw_val = ARM_MCLASSSYSREG_MSP_NS }, 0x888, 0x188, 0x888, {ARM_Feature8MSecExt} }, // 25 |
187 | | { "pac_key_p_0", { .raw_val = ARM_MCLASSSYSREG_PAC_KEY_P_0 }, 0x820, 0x120, 0x820, {ARM_FeaturePACBTI} }, // 26 |
188 | | { "pac_key_p_0_ns", { .raw_val = ARM_MCLASSSYSREG_PAC_KEY_P_0_NS }, 0x8A0, 0x1A0, 0x8A0, {ARM_FeaturePACBTI} }, // 27 |
189 | | { "pac_key_p_1", { .raw_val = ARM_MCLASSSYSREG_PAC_KEY_P_1 }, 0x821, 0x121, 0x821, {ARM_FeaturePACBTI} }, // 28 |
190 | | { "pac_key_p_1_ns", { .raw_val = ARM_MCLASSSYSREG_PAC_KEY_P_1_NS }, 0x8A1, 0x1A1, 0x8A1, {ARM_FeaturePACBTI} }, // 29 |
191 | | { "pac_key_p_2", { .raw_val = ARM_MCLASSSYSREG_PAC_KEY_P_2 }, 0x822, 0x122, 0x822, {ARM_FeaturePACBTI} }, // 30 |
192 | | { "pac_key_p_2_ns", { .raw_val = ARM_MCLASSSYSREG_PAC_KEY_P_2_NS }, 0x8A2, 0x1A2, 0x8A2, {ARM_FeaturePACBTI} }, // 31 |
193 | | { "pac_key_p_3", { .raw_val = ARM_MCLASSSYSREG_PAC_KEY_P_3 }, 0x823, 0x123, 0x823, {ARM_FeaturePACBTI} }, // 32 |
194 | | { "pac_key_p_3_ns", { .raw_val = ARM_MCLASSSYSREG_PAC_KEY_P_3_NS }, 0x8A3, 0x1A3, 0x8A3, {ARM_FeaturePACBTI} }, // 33 |
195 | | { "pac_key_u_0", { .raw_val = ARM_MCLASSSYSREG_PAC_KEY_U_0 }, 0x824, 0x124, 0x824, {ARM_FeaturePACBTI} }, // 34 |
196 | | { "pac_key_u_0_ns", { .raw_val = ARM_MCLASSSYSREG_PAC_KEY_U_0_NS }, 0x8A4, 0x1A4, 0x8A4, {ARM_FeaturePACBTI} }, // 35 |
197 | | { "pac_key_u_1", { .raw_val = ARM_MCLASSSYSREG_PAC_KEY_U_1 }, 0x825, 0x125, 0x825, {ARM_FeaturePACBTI} }, // 36 |
198 | | { "pac_key_u_1_ns", { .raw_val = ARM_MCLASSSYSREG_PAC_KEY_U_1_NS }, 0x8A5, 0x1A5, 0x8A5, {ARM_FeaturePACBTI} }, // 37 |
199 | | { "pac_key_u_2", { .raw_val = ARM_MCLASSSYSREG_PAC_KEY_U_2 }, 0x826, 0x126, 0x826, {ARM_FeaturePACBTI} }, // 38 |
200 | | { "pac_key_u_2_ns", { .raw_val = ARM_MCLASSSYSREG_PAC_KEY_U_2_NS }, 0x8A6, 0x1A6, 0x8A6, {ARM_FeaturePACBTI} }, // 39 |
201 | | { "pac_key_u_3", { .raw_val = ARM_MCLASSSYSREG_PAC_KEY_U_3 }, 0x827, 0x127, 0x827, {ARM_FeaturePACBTI} }, // 40 |
202 | | { "pac_key_u_3_ns", { .raw_val = ARM_MCLASSSYSREG_PAC_KEY_U_3_NS }, 0x8A7, 0x1A7, 0x8A7, {ARM_FeaturePACBTI} }, // 41 |
203 | | { "primask", { .raw_val = ARM_MCLASSSYSREG_PRIMASK }, 0x810, 0x110, 0x810, {0} }, // 42 |
204 | | { "primask_ns", { .raw_val = ARM_MCLASSSYSREG_PRIMASK_NS }, 0x890, 0x190, 0x890, {0} }, // 43 |
205 | | { "psp", { .raw_val = ARM_MCLASSSYSREG_PSP }, 0x809, 0x109, 0x809, {0} }, // 44 |
206 | | { "psplim", { .raw_val = ARM_MCLASSSYSREG_PSPLIM }, 0x80B, 0x10B, 0x80B, {ARM_HasV8MBaselineOps} }, // 45 |
207 | | { "psplim_ns", { .raw_val = ARM_MCLASSSYSREG_PSPLIM_NS }, 0x88B, 0x18B, 0x88B, {ARM_Feature8MSecExt, ARM_HasV8MBaselineOps} }, // 46 |
208 | | { "psp_ns", { .raw_val = ARM_MCLASSSYSREG_PSP_NS }, 0x889, 0x189, 0x889, {ARM_Feature8MSecExt} }, // 47 |
209 | | { "sp_ns", { .raw_val = ARM_MCLASSSYSREG_SP_NS }, 0x898, 0x198, 0x898, {ARM_Feature8MSecExt} }, // 48 |
210 | | { "xpsr", { .raw_val = ARM_MCLASSSYSREG_XPSR }, 0x803, 0x103, 0x803, {0} }, // 49 |
211 | | { "xpsr_g", { .raw_val = ARM_MCLASSSYSREG_XPSR_G }, 0x403, 0x3, 0x403, {ARM_FeatureDSP} }, // 50 |
212 | | { "xpsr_nzcvq", { .raw_val = ARM_MCLASSSYSREG_XPSR_NZCVQ }, 0x1803, 0x203, 0x803, {0} }, // 51 |
213 | | { "xpsr_nzcvqg", { .raw_val = ARM_MCLASSSYSREG_XPSR_NZCVQG }, 0xC03, 0x303, 0xC03, {ARM_FeatureDSP} }, // 52 |
214 | | }; |
215 | | |
216 | 0 | const ARMSysReg_MClassSysReg *ARMSysReg_lookupMClassSysRegByName(const char * Name) { |
217 | 0 | static const struct IndexTypeStr Index[] = { |
218 | 0 | { "APSR", 0 }, |
219 | 0 | { "APSR_G", 1 }, |
220 | 0 | { "APSR_NZCVQ", 2 }, |
221 | 0 | { "APSR_NZCVQG", 3 }, |
222 | 0 | { "BASEPRI", 4 }, |
223 | 0 | { "BASEPRI_MAX", 5 }, |
224 | 0 | { "BASEPRI_NS", 6 }, |
225 | 0 | { "CONTROL", 7 }, |
226 | 0 | { "CONTROL_NS", 8 }, |
227 | 0 | { "EAPSR", 9 }, |
228 | 0 | { "EAPSR_G", 10 }, |
229 | 0 | { "EAPSR_NZCVQ", 11 }, |
230 | 0 | { "EAPSR_NZCVQG", 12 }, |
231 | 0 | { "EPSR", 13 }, |
232 | 0 | { "FAULTMASK", 14 }, |
233 | 0 | { "FAULTMASK_NS", 15 }, |
234 | 0 | { "IAPSR", 16 }, |
235 | 0 | { "IAPSR_G", 17 }, |
236 | 0 | { "IAPSR_NZCVQ", 18 }, |
237 | 0 | { "IAPSR_NZCVQG", 19 }, |
238 | 0 | { "IEPSR", 20 }, |
239 | 0 | { "IPSR", 21 }, |
240 | 0 | { "MSP", 22 }, |
241 | 0 | { "MSPLIM", 23 }, |
242 | 0 | { "MSPLIM_NS", 24 }, |
243 | 0 | { "MSP_NS", 25 }, |
244 | 0 | { "PAC_KEY_P_0", 26 }, |
245 | 0 | { "PAC_KEY_P_0_NS", 27 }, |
246 | 0 | { "PAC_KEY_P_1", 28 }, |
247 | 0 | { "PAC_KEY_P_1_NS", 29 }, |
248 | 0 | { "PAC_KEY_P_2", 30 }, |
249 | 0 | { "PAC_KEY_P_2_NS", 31 }, |
250 | 0 | { "PAC_KEY_P_3", 32 }, |
251 | 0 | { "PAC_KEY_P_3_NS", 33 }, |
252 | 0 | { "PAC_KEY_U_0", 34 }, |
253 | 0 | { "PAC_KEY_U_0_NS", 35 }, |
254 | 0 | { "PAC_KEY_U_1", 36 }, |
255 | 0 | { "PAC_KEY_U_1_NS", 37 }, |
256 | 0 | { "PAC_KEY_U_2", 38 }, |
257 | 0 | { "PAC_KEY_U_2_NS", 39 }, |
258 | 0 | { "PAC_KEY_U_3", 40 }, |
259 | 0 | { "PAC_KEY_U_3_NS", 41 }, |
260 | 0 | { "PRIMASK", 42 }, |
261 | 0 | { "PRIMASK_NS", 43 }, |
262 | 0 | { "PSP", 44 }, |
263 | 0 | { "PSPLIM", 45 }, |
264 | 0 | { "PSPLIM_NS", 46 }, |
265 | 0 | { "PSP_NS", 47 }, |
266 | 0 | { "SP_NS", 48 }, |
267 | 0 | { "XPSR", 49 }, |
268 | 0 | { "XPSR_G", 50 }, |
269 | 0 | { "XPSR_NZCVQ", 51 }, |
270 | 0 | { "XPSR_NZCVQG", 52 }, |
271 | 0 | }; |
272 | |
|
273 | 0 | unsigned i = binsearch_IndexTypeStrEncoding(Index, ARR_SIZE(Index), Name); |
274 | 0 | if (i == -1) |
275 | 0 | return NULL; |
276 | 0 | else |
277 | 0 | return &MClassSysRegsList[Index[i].index]; |
278 | 0 | } |
279 | | |
280 | 13.6k | const ARMSysReg_MClassSysReg *ARMSysReg_lookupMClassSysRegByM1Encoding12(uint16_t M1Encoding12) { |
281 | 13.6k | static const struct IndexType Index[] = { |
282 | 13.6k | { 0x400, 1 }, |
283 | 13.6k | { 0x401, 17 }, |
284 | 13.6k | { 0x402, 10 }, |
285 | 13.6k | { 0x403, 50 }, |
286 | 13.6k | { 0x800, 0 }, |
287 | 13.6k | { 0x801, 16 }, |
288 | 13.6k | { 0x802, 9 }, |
289 | 13.6k | { 0x803, 49 }, |
290 | 13.6k | { 0x805, 21 }, |
291 | 13.6k | { 0x806, 13 }, |
292 | 13.6k | { 0x807, 20 }, |
293 | 13.6k | { 0x808, 22 }, |
294 | 13.6k | { 0x809, 44 }, |
295 | 13.6k | { 0x80A, 23 }, |
296 | 13.6k | { 0x80B, 45 }, |
297 | 13.6k | { 0x810, 42 }, |
298 | 13.6k | { 0x811, 4 }, |
299 | 13.6k | { 0x812, 5 }, |
300 | 13.6k | { 0x813, 14 }, |
301 | 13.6k | { 0x814, 7 }, |
302 | 13.6k | { 0x820, 26 }, |
303 | 13.6k | { 0x821, 28 }, |
304 | 13.6k | { 0x822, 30 }, |
305 | 13.6k | { 0x823, 32 }, |
306 | 13.6k | { 0x824, 34 }, |
307 | 13.6k | { 0x825, 36 }, |
308 | 13.6k | { 0x826, 38 }, |
309 | 13.6k | { 0x827, 40 }, |
310 | 13.6k | { 0x888, 25 }, |
311 | 13.6k | { 0x889, 47 }, |
312 | 13.6k | { 0x88A, 24 }, |
313 | 13.6k | { 0x88B, 46 }, |
314 | 13.6k | { 0x890, 43 }, |
315 | 13.6k | { 0x891, 6 }, |
316 | 13.6k | { 0x893, 15 }, |
317 | 13.6k | { 0x894, 8 }, |
318 | 13.6k | { 0x898, 48 }, |
319 | 13.6k | { 0x8A0, 27 }, |
320 | 13.6k | { 0x8A1, 29 }, |
321 | 13.6k | { 0x8A2, 31 }, |
322 | 13.6k | { 0x8A3, 33 }, |
323 | 13.6k | { 0x8A4, 35 }, |
324 | 13.6k | { 0x8A5, 37 }, |
325 | 13.6k | { 0x8A6, 39 }, |
326 | 13.6k | { 0x8A7, 41 }, |
327 | 13.6k | { 0xC00, 3 }, |
328 | 13.6k | { 0xC01, 19 }, |
329 | 13.6k | { 0xC02, 12 }, |
330 | 13.6k | { 0xC03, 52 }, |
331 | 13.6k | { 0x1800, 2 }, |
332 | 13.6k | { 0x1801, 18 }, |
333 | 13.6k | { 0x1802, 11 }, |
334 | 13.6k | { 0x1803, 51 }, |
335 | 13.6k | }; |
336 | | |
337 | 13.6k | unsigned i = binsearch_IndexTypeEncoding(Index, ARR_SIZE(Index), M1Encoding12); |
338 | 13.6k | if (i == -1) |
339 | 9.21k | return NULL; |
340 | 4.45k | else |
341 | 4.45k | return &MClassSysRegsList[Index[i].index]; |
342 | 13.6k | } |
343 | | |
344 | 27.8k | const ARMSysReg_MClassSysReg *ARMSysReg_lookupMClassSysRegByM2M3Encoding8(uint16_t M2M3Encoding8) { |
345 | 27.8k | static const struct IndexType Index[] = { |
346 | 27.8k | { 0x0, 1 }, |
347 | 27.8k | { 0x1, 17 }, |
348 | 27.8k | { 0x2, 10 }, |
349 | 27.8k | { 0x3, 50 }, |
350 | 27.8k | { 0x100, 0 }, |
351 | 27.8k | { 0x101, 16 }, |
352 | 27.8k | { 0x102, 9 }, |
353 | 27.8k | { 0x103, 49 }, |
354 | 27.8k | { 0x105, 21 }, |
355 | 27.8k | { 0x106, 13 }, |
356 | 27.8k | { 0x107, 20 }, |
357 | 27.8k | { 0x108, 22 }, |
358 | 27.8k | { 0x109, 44 }, |
359 | 27.8k | { 0x10A, 23 }, |
360 | 27.8k | { 0x10B, 45 }, |
361 | 27.8k | { 0x110, 42 }, |
362 | 27.8k | { 0x111, 4 }, |
363 | 27.8k | { 0x112, 5 }, |
364 | 27.8k | { 0x113, 14 }, |
365 | 27.8k | { 0x114, 7 }, |
366 | 27.8k | { 0x120, 26 }, |
367 | 27.8k | { 0x121, 28 }, |
368 | 27.8k | { 0x122, 30 }, |
369 | 27.8k | { 0x123, 32 }, |
370 | 27.8k | { 0x124, 34 }, |
371 | 27.8k | { 0x125, 36 }, |
372 | 27.8k | { 0x126, 38 }, |
373 | 27.8k | { 0x127, 40 }, |
374 | 27.8k | { 0x188, 25 }, |
375 | 27.8k | { 0x189, 47 }, |
376 | 27.8k | { 0x18A, 24 }, |
377 | 27.8k | { 0x18B, 46 }, |
378 | 27.8k | { 0x190, 43 }, |
379 | 27.8k | { 0x191, 6 }, |
380 | 27.8k | { 0x193, 15 }, |
381 | 27.8k | { 0x194, 8 }, |
382 | 27.8k | { 0x198, 48 }, |
383 | 27.8k | { 0x1A0, 27 }, |
384 | 27.8k | { 0x1A1, 29 }, |
385 | 27.8k | { 0x1A2, 31 }, |
386 | 27.8k | { 0x1A3, 33 }, |
387 | 27.8k | { 0x1A4, 35 }, |
388 | 27.8k | { 0x1A5, 37 }, |
389 | 27.8k | { 0x1A6, 39 }, |
390 | 27.8k | { 0x1A7, 41 }, |
391 | 27.8k | { 0x200, 2 }, |
392 | 27.8k | { 0x201, 18 }, |
393 | 27.8k | { 0x202, 11 }, |
394 | 27.8k | { 0x203, 51 }, |
395 | 27.8k | { 0x300, 3 }, |
396 | 27.8k | { 0x301, 19 }, |
397 | 27.8k | { 0x302, 12 }, |
398 | 27.8k | { 0x303, 52 }, |
399 | 27.8k | }; |
400 | | |
401 | 27.8k | unsigned i = binsearch_IndexTypeEncoding(Index, ARR_SIZE(Index), M2M3Encoding8); |
402 | 27.8k | if (i == -1) |
403 | 14.6k | return NULL; |
404 | 13.1k | else |
405 | 13.1k | return &MClassSysRegsList[Index[i].index]; |
406 | 27.8k | } |
407 | | |
408 | 0 | const ARMSysReg_MClassSysReg *ARMSysReg_lookupMClassSysRegByEncoding(uint16_t Encoding) { |
409 | 0 | static const struct IndexType Index[] = { |
410 | 0 | { 0x400, 1 }, |
411 | 0 | { 0x401, 17 }, |
412 | 0 | { 0x402, 10 }, |
413 | 0 | { 0x403, 50 }, |
414 | 0 | { 0x800, 0 }, |
415 | 0 | { 0x800, 2 }, |
416 | 0 | { 0x801, 16 }, |
417 | 0 | { 0x801, 18 }, |
418 | 0 | { 0x802, 9 }, |
419 | 0 | { 0x802, 11 }, |
420 | 0 | { 0x803, 49 }, |
421 | 0 | { 0x803, 51 }, |
422 | 0 | { 0x805, 21 }, |
423 | 0 | { 0x806, 13 }, |
424 | 0 | { 0x807, 20 }, |
425 | 0 | { 0x808, 22 }, |
426 | 0 | { 0x809, 44 }, |
427 | 0 | { 0x80A, 23 }, |
428 | 0 | { 0x80B, 45 }, |
429 | 0 | { 0x810, 42 }, |
430 | 0 | { 0x811, 4 }, |
431 | 0 | { 0x812, 5 }, |
432 | 0 | { 0x813, 14 }, |
433 | 0 | { 0x814, 7 }, |
434 | 0 | { 0x820, 26 }, |
435 | 0 | { 0x821, 28 }, |
436 | 0 | { 0x822, 30 }, |
437 | 0 | { 0x823, 32 }, |
438 | 0 | { 0x824, 34 }, |
439 | 0 | { 0x825, 36 }, |
440 | 0 | { 0x826, 38 }, |
441 | 0 | { 0x827, 40 }, |
442 | 0 | { 0x888, 25 }, |
443 | 0 | { 0x889, 47 }, |
444 | 0 | { 0x88A, 24 }, |
445 | 0 | { 0x88B, 46 }, |
446 | 0 | { 0x890, 43 }, |
447 | 0 | { 0x891, 6 }, |
448 | 0 | { 0x893, 15 }, |
449 | 0 | { 0x894, 8 }, |
450 | 0 | { 0x898, 48 }, |
451 | 0 | { 0x8A0, 27 }, |
452 | 0 | { 0x8A1, 29 }, |
453 | 0 | { 0x8A2, 31 }, |
454 | 0 | { 0x8A3, 33 }, |
455 | 0 | { 0x8A4, 35 }, |
456 | 0 | { 0x8A5, 37 }, |
457 | 0 | { 0x8A6, 39 }, |
458 | 0 | { 0x8A7, 41 }, |
459 | 0 | { 0xC00, 3 }, |
460 | 0 | { 0xC01, 19 }, |
461 | 0 | { 0xC02, 12 }, |
462 | 0 | { 0xC03, 52 }, |
463 | 0 | }; |
464 | |
|
465 | 0 | unsigned i = binsearch_IndexTypeEncoding(Index, ARR_SIZE(Index), Encoding); |
466 | 0 | if (i == -1) |
467 | 0 | return NULL; |
468 | 0 | else |
469 | 0 | return &MClassSysRegsList[Index[i].index]; |
470 | 0 | } |
471 | | |
472 | | #endif |
473 | | |
474 | | #undef GET_BANKEDREG_DECL |
475 | | #undef GET_BANKEDREG_IMPL |
476 | | #undef GET_MCLASSSYSREG_DECL |
477 | | #undef GET_MCLASSSYSREG_IMPL |