Coverage Report

Created: 2025-11-11 06:33

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/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