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