1#ifdef GET_SUPPORTED_EXTENSIONS
2#undef GET_SUPPORTED_EXTENSIONS
3
4static const RISCVSupportedExtension SupportedExtensions[] = {
5 {.Name: "a", .Version: {.Major: 2, .Minor: 1}},
6 {.Name: "b", .Version: {.Major: 1, .Minor: 0}},
7 {.Name: "c", .Version: {.Major: 2, .Minor: 0}},
8 {.Name: "d", .Version: {.Major: 2, .Minor: 2}},
9 {.Name: "e", .Version: {.Major: 2, .Minor: 0}},
10 {.Name: "f", .Version: {.Major: 2, .Minor: 2}},
11 {.Name: "h", .Version: {.Major: 1, .Minor: 0}},
12 {.Name: "i", .Version: {.Major: 2, .Minor: 1}},
13 {.Name: "m", .Version: {.Major: 2, .Minor: 0}},
14 {.Name: "q", .Version: {.Major: 2, .Minor: 2}},
15 {.Name: "sdext", .Version: {.Major: 1, .Minor: 0}},
16 {.Name: "sdtrig", .Version: {.Major: 1, .Minor: 0}},
17 {.Name: "sha", .Version: {.Major: 1, .Minor: 0}},
18 {.Name: "shcounterenw", .Version: {.Major: 1, .Minor: 0}},
19 {.Name: "shgatpa", .Version: {.Major: 1, .Minor: 0}},
20 {.Name: "shlcofideleg", .Version: {.Major: 1, .Minor: 0}},
21 {.Name: "shtvala", .Version: {.Major: 1, .Minor: 0}},
22 {.Name: "shvsatpa", .Version: {.Major: 1, .Minor: 0}},
23 {.Name: "shvstvala", .Version: {.Major: 1, .Minor: 0}},
24 {.Name: "shvstvecd", .Version: {.Major: 1, .Minor: 0}},
25 {.Name: "smaia", .Version: {.Major: 1, .Minor: 0}},
26 {.Name: "smcdeleg", .Version: {.Major: 1, .Minor: 0}},
27 {.Name: "smcntrpmf", .Version: {.Major: 1, .Minor: 0}},
28 {.Name: "smcsrind", .Version: {.Major: 1, .Minor: 0}},
29 {.Name: "smctr", .Version: {.Major: 1, .Minor: 0}},
30 {.Name: "smdbltrp", .Version: {.Major: 1, .Minor: 0}},
31 {.Name: "smepmp", .Version: {.Major: 1, .Minor: 0}},
32 {.Name: "smmpm", .Version: {.Major: 1, .Minor: 0}},
33 {.Name: "smnpm", .Version: {.Major: 1, .Minor: 0}},
34 {.Name: "smrnmi", .Version: {.Major: 1, .Minor: 0}},
35 {.Name: "smstateen", .Version: {.Major: 1, .Minor: 0}},
36 {.Name: "ssaia", .Version: {.Major: 1, .Minor: 0}},
37 {.Name: "ssccfg", .Version: {.Major: 1, .Minor: 0}},
38 {.Name: "ssccptr", .Version: {.Major: 1, .Minor: 0}},
39 {.Name: "sscofpmf", .Version: {.Major: 1, .Minor: 0}},
40 {.Name: "sscounterenw", .Version: {.Major: 1, .Minor: 0}},
41 {.Name: "sscsrind", .Version: {.Major: 1, .Minor: 0}},
42 {.Name: "ssctr", .Version: {.Major: 1, .Minor: 0}},
43 {.Name: "ssdbltrp", .Version: {.Major: 1, .Minor: 0}},
44 {.Name: "ssnpm", .Version: {.Major: 1, .Minor: 0}},
45 {.Name: "sspm", .Version: {.Major: 1, .Minor: 0}},
46 {.Name: "ssqosid", .Version: {.Major: 1, .Minor: 0}},
47 {.Name: "ssstateen", .Version: {.Major: 1, .Minor: 0}},
48 {.Name: "ssstrict", .Version: {.Major: 1, .Minor: 0}},
49 {.Name: "sstc", .Version: {.Major: 1, .Minor: 0}},
50 {.Name: "sstvala", .Version: {.Major: 1, .Minor: 0}},
51 {.Name: "sstvecd", .Version: {.Major: 1, .Minor: 0}},
52 {.Name: "ssu64xl", .Version: {.Major: 1, .Minor: 0}},
53 {.Name: "supm", .Version: {.Major: 1, .Minor: 0}},
54 {.Name: "svade", .Version: {.Major: 1, .Minor: 0}},
55 {.Name: "svadu", .Version: {.Major: 1, .Minor: 0}},
56 {.Name: "svbare", .Version: {.Major: 1, .Minor: 0}},
57 {.Name: "svinval", .Version: {.Major: 1, .Minor: 0}},
58 {.Name: "svnapot", .Version: {.Major: 1, .Minor: 0}},
59 {.Name: "svpbmt", .Version: {.Major: 1, .Minor: 0}},
60 {.Name: "svrsw60t59b", .Version: {.Major: 1, .Minor: 0}},
61 {.Name: "svvptc", .Version: {.Major: 1, .Minor: 0}},
62 {.Name: "v", .Version: {.Major: 1, .Minor: 0}},
63 {.Name: "xaifet", .Version: {.Major: 1, .Minor: 0}},
64 {.Name: "xandesbfhcvt", .Version: {.Major: 5, .Minor: 0}},
65 {.Name: "xandesperf", .Version: {.Major: 5, .Minor: 0}},
66 {.Name: "xandesvbfhcvt", .Version: {.Major: 5, .Minor: 0}},
67 {.Name: "xandesvdot", .Version: {.Major: 5, .Minor: 0}},
68 {.Name: "xandesvpackfph", .Version: {.Major: 5, .Minor: 0}},
69 {.Name: "xandesvsinth", .Version: {.Major: 5, .Minor: 0}},
70 {.Name: "xandesvsintload", .Version: {.Major: 5, .Minor: 0}},
71 {.Name: "xcvalu", .Version: {.Major: 1, .Minor: 0}},
72 {.Name: "xcvbi", .Version: {.Major: 1, .Minor: 0}},
73 {.Name: "xcvbitmanip", .Version: {.Major: 1, .Minor: 0}},
74 {.Name: "xcvelw", .Version: {.Major: 1, .Minor: 0}},
75 {.Name: "xcvmac", .Version: {.Major: 1, .Minor: 0}},
76 {.Name: "xcvmem", .Version: {.Major: 1, .Minor: 0}},
77 {.Name: "xcvsimd", .Version: {.Major: 1, .Minor: 0}},
78 {.Name: "xmipscbop", .Version: {.Major: 1, .Minor: 0}},
79 {.Name: "xmipscmov", .Version: {.Major: 1, .Minor: 0}},
80 {.Name: "xmipsexectl", .Version: {.Major: 1, .Minor: 0}},
81 {.Name: "xmipslsp", .Version: {.Major: 1, .Minor: 0}},
82 {.Name: "xqccmp", .Version: {.Major: 0, .Minor: 3}},
83 {.Name: "xqci", .Version: {.Major: 0, .Minor: 13}},
84 {.Name: "xqcia", .Version: {.Major: 0, .Minor: 7}},
85 {.Name: "xqciac", .Version: {.Major: 0, .Minor: 3}},
86 {.Name: "xqcibi", .Version: {.Major: 0, .Minor: 2}},
87 {.Name: "xqcibm", .Version: {.Major: 0, .Minor: 8}},
88 {.Name: "xqcicli", .Version: {.Major: 0, .Minor: 3}},
89 {.Name: "xqcicm", .Version: {.Major: 0, .Minor: 2}},
90 {.Name: "xqcics", .Version: {.Major: 0, .Minor: 2}},
91 {.Name: "xqcicsr", .Version: {.Major: 0, .Minor: 4}},
92 {.Name: "xqciint", .Version: {.Major: 0, .Minor: 10}},
93 {.Name: "xqciio", .Version: {.Major: 0, .Minor: 1}},
94 {.Name: "xqcilb", .Version: {.Major: 0, .Minor: 2}},
95 {.Name: "xqcili", .Version: {.Major: 0, .Minor: 2}},
96 {.Name: "xqcilia", .Version: {.Major: 0, .Minor: 2}},
97 {.Name: "xqcilo", .Version: {.Major: 0, .Minor: 3}},
98 {.Name: "xqcilsm", .Version: {.Major: 0, .Minor: 6}},
99 {.Name: "xqcisim", .Version: {.Major: 0, .Minor: 2}},
100 {.Name: "xqcisls", .Version: {.Major: 0, .Minor: 2}},
101 {.Name: "xqcisync", .Version: {.Major: 0, .Minor: 3}},
102 {.Name: "xsfcease", .Version: {.Major: 1, .Minor: 0}},
103 {.Name: "xsfmm128t", .Version: {.Major: 0, .Minor: 6}},
104 {.Name: "xsfmm16t", .Version: {.Major: 0, .Minor: 6}},
105 {.Name: "xsfmm32a16f", .Version: {.Major: 0, .Minor: 6}},
106 {.Name: "xsfmm32a32f", .Version: {.Major: 0, .Minor: 6}},
107 {.Name: "xsfmm32a8f", .Version: {.Major: 0, .Minor: 6}},
108 {.Name: "xsfmm32a8i", .Version: {.Major: 0, .Minor: 6}},
109 {.Name: "xsfmm32t", .Version: {.Major: 0, .Minor: 6}},
110 {.Name: "xsfmm64a64f", .Version: {.Major: 0, .Minor: 6}},
111 {.Name: "xsfmm64t", .Version: {.Major: 0, .Minor: 6}},
112 {.Name: "xsfmmbase", .Version: {.Major: 0, .Minor: 6}},
113 {.Name: "xsfvcp", .Version: {.Major: 1, .Minor: 0}},
114 {.Name: "xsfvfbfexp16e", .Version: {.Major: 0, .Minor: 5}},
115 {.Name: "xsfvfexp16e", .Version: {.Major: 0, .Minor: 5}},
116 {.Name: "xsfvfexp32e", .Version: {.Major: 0, .Minor: 5}},
117 {.Name: "xsfvfexpa", .Version: {.Major: 0, .Minor: 2}},
118 {.Name: "xsfvfexpa64e", .Version: {.Major: 0, .Minor: 2}},
119 {.Name: "xsfvfnrclipxfqf", .Version: {.Major: 1, .Minor: 0}},
120 {.Name: "xsfvfwmaccqqq", .Version: {.Major: 1, .Minor: 0}},
121 {.Name: "xsfvqmaccdod", .Version: {.Major: 1, .Minor: 0}},
122 {.Name: "xsfvqmaccqoq", .Version: {.Major: 1, .Minor: 0}},
123 {.Name: "xsifivecdiscarddlone", .Version: {.Major: 1, .Minor: 0}},
124 {.Name: "xsifivecflushdlone", .Version: {.Major: 1, .Minor: 0}},
125 {.Name: "xsmtvdot", .Version: {.Major: 1, .Minor: 0}},
126 {.Name: "xtheadba", .Version: {.Major: 1, .Minor: 0}},
127 {.Name: "xtheadbb", .Version: {.Major: 1, .Minor: 0}},
128 {.Name: "xtheadbs", .Version: {.Major: 1, .Minor: 0}},
129 {.Name: "xtheadcmo", .Version: {.Major: 1, .Minor: 0}},
130 {.Name: "xtheadcondmov", .Version: {.Major: 1, .Minor: 0}},
131 {.Name: "xtheadfmemidx", .Version: {.Major: 1, .Minor: 0}},
132 {.Name: "xtheadmac", .Version: {.Major: 1, .Minor: 0}},
133 {.Name: "xtheadmemidx", .Version: {.Major: 1, .Minor: 0}},
134 {.Name: "xtheadmempair", .Version: {.Major: 1, .Minor: 0}},
135 {.Name: "xtheadsync", .Version: {.Major: 1, .Minor: 0}},
136 {.Name: "xtheadvdot", .Version: {.Major: 1, .Minor: 0}},
137 {.Name: "xventanacondops", .Version: {.Major: 1, .Minor: 0}},
138 {.Name: "xwchc", .Version: {.Major: 2, .Minor: 2}},
139 {.Name: "za128rs", .Version: {.Major: 1, .Minor: 0}},
140 {.Name: "za64rs", .Version: {.Major: 1, .Minor: 0}},
141 {.Name: "zaamo", .Version: {.Major: 1, .Minor: 0}},
142 {.Name: "zabha", .Version: {.Major: 1, .Minor: 0}},
143 {.Name: "zacas", .Version: {.Major: 1, .Minor: 0}},
144 {.Name: "zalasr", .Version: {.Major: 1, .Minor: 0}},
145 {.Name: "zalrsc", .Version: {.Major: 1, .Minor: 0}},
146 {.Name: "zama16b", .Version: {.Major: 1, .Minor: 0}},
147 {.Name: "zawrs", .Version: {.Major: 1, .Minor: 0}},
148 {.Name: "zba", .Version: {.Major: 1, .Minor: 0}},
149 {.Name: "zbb", .Version: {.Major: 1, .Minor: 0}},
150 {.Name: "zbc", .Version: {.Major: 1, .Minor: 0}},
151 {.Name: "zbkb", .Version: {.Major: 1, .Minor: 0}},
152 {.Name: "zbkc", .Version: {.Major: 1, .Minor: 0}},
153 {.Name: "zbkx", .Version: {.Major: 1, .Minor: 0}},
154 {.Name: "zbs", .Version: {.Major: 1, .Minor: 0}},
155 {.Name: "zca", .Version: {.Major: 1, .Minor: 0}},
156 {.Name: "zcb", .Version: {.Major: 1, .Minor: 0}},
157 {.Name: "zcd", .Version: {.Major: 1, .Minor: 0}},
158 {.Name: "zce", .Version: {.Major: 1, .Minor: 0}},
159 {.Name: "zcf", .Version: {.Major: 1, .Minor: 0}},
160 {.Name: "zclsd", .Version: {.Major: 1, .Minor: 0}},
161 {.Name: "zcmop", .Version: {.Major: 1, .Minor: 0}},
162 {.Name: "zcmp", .Version: {.Major: 1, .Minor: 0}},
163 {.Name: "zcmt", .Version: {.Major: 1, .Minor: 0}},
164 {.Name: "zdinx", .Version: {.Major: 1, .Minor: 0}},
165 {.Name: "zfa", .Version: {.Major: 1, .Minor: 0}},
166 {.Name: "zfbfmin", .Version: {.Major: 1, .Minor: 0}},
167 {.Name: "zfh", .Version: {.Major: 1, .Minor: 0}},
168 {.Name: "zfhmin", .Version: {.Major: 1, .Minor: 0}},
169 {.Name: "zfinx", .Version: {.Major: 1, .Minor: 0}},
170 {.Name: "zhinx", .Version: {.Major: 1, .Minor: 0}},
171 {.Name: "zhinxmin", .Version: {.Major: 1, .Minor: 0}},
172 {.Name: "zic64b", .Version: {.Major: 1, .Minor: 0}},
173 {.Name: "zicbom", .Version: {.Major: 1, .Minor: 0}},
174 {.Name: "zicbop", .Version: {.Major: 1, .Minor: 0}},
175 {.Name: "zicboz", .Version: {.Major: 1, .Minor: 0}},
176 {.Name: "ziccamoa", .Version: {.Major: 1, .Minor: 0}},
177 {.Name: "ziccamoc", .Version: {.Major: 1, .Minor: 0}},
178 {.Name: "ziccif", .Version: {.Major: 1, .Minor: 0}},
179 {.Name: "zicclsm", .Version: {.Major: 1, .Minor: 0}},
180 {.Name: "ziccrse", .Version: {.Major: 1, .Minor: 0}},
181 {.Name: "zicntr", .Version: {.Major: 2, .Minor: 0}},
182 {.Name: "zicond", .Version: {.Major: 1, .Minor: 0}},
183 {.Name: "zicsr", .Version: {.Major: 2, .Minor: 0}},
184 {.Name: "zifencei", .Version: {.Major: 2, .Minor: 0}},
185 {.Name: "zihintntl", .Version: {.Major: 1, .Minor: 0}},
186 {.Name: "zihintpause", .Version: {.Major: 2, .Minor: 0}},
187 {.Name: "zihpm", .Version: {.Major: 2, .Minor: 0}},
188 {.Name: "zilsd", .Version: {.Major: 1, .Minor: 0}},
189 {.Name: "zimop", .Version: {.Major: 1, .Minor: 0}},
190 {.Name: "zk", .Version: {.Major: 1, .Minor: 0}},
191 {.Name: "zkn", .Version: {.Major: 1, .Minor: 0}},
192 {.Name: "zknd", .Version: {.Major: 1, .Minor: 0}},
193 {.Name: "zkne", .Version: {.Major: 1, .Minor: 0}},
194 {.Name: "zknh", .Version: {.Major: 1, .Minor: 0}},
195 {.Name: "zkr", .Version: {.Major: 1, .Minor: 0}},
196 {.Name: "zks", .Version: {.Major: 1, .Minor: 0}},
197 {.Name: "zksed", .Version: {.Major: 1, .Minor: 0}},
198 {.Name: "zksh", .Version: {.Major: 1, .Minor: 0}},
199 {.Name: "zkt", .Version: {.Major: 1, .Minor: 0}},
200 {.Name: "zmmul", .Version: {.Major: 1, .Minor: 0}},
201 {.Name: "ztso", .Version: {.Major: 1, .Minor: 0}},
202 {.Name: "zvbb", .Version: {.Major: 1, .Minor: 0}},
203 {.Name: "zvbc", .Version: {.Major: 1, .Minor: 0}},
204 {.Name: "zve32f", .Version: {.Major: 1, .Minor: 0}},
205 {.Name: "zve32x", .Version: {.Major: 1, .Minor: 0}},
206 {.Name: "zve64d", .Version: {.Major: 1, .Minor: 0}},
207 {.Name: "zve64f", .Version: {.Major: 1, .Minor: 0}},
208 {.Name: "zve64x", .Version: {.Major: 1, .Minor: 0}},
209 {.Name: "zvfbfmin", .Version: {.Major: 1, .Minor: 0}},
210 {.Name: "zvfbfwma", .Version: {.Major: 1, .Minor: 0}},
211 {.Name: "zvfh", .Version: {.Major: 1, .Minor: 0}},
212 {.Name: "zvfhmin", .Version: {.Major: 1, .Minor: 0}},
213 {.Name: "zvkb", .Version: {.Major: 1, .Minor: 0}},
214 {.Name: "zvkg", .Version: {.Major: 1, .Minor: 0}},
215 {.Name: "zvkn", .Version: {.Major: 1, .Minor: 0}},
216 {.Name: "zvknc", .Version: {.Major: 1, .Minor: 0}},
217 {.Name: "zvkned", .Version: {.Major: 1, .Minor: 0}},
218 {.Name: "zvkng", .Version: {.Major: 1, .Minor: 0}},
219 {.Name: "zvknha", .Version: {.Major: 1, .Minor: 0}},
220 {.Name: "zvknhb", .Version: {.Major: 1, .Minor: 0}},
221 {.Name: "zvks", .Version: {.Major: 1, .Minor: 0}},
222 {.Name: "zvksc", .Version: {.Major: 1, .Minor: 0}},
223 {.Name: "zvksed", .Version: {.Major: 1, .Minor: 0}},
224 {.Name: "zvksg", .Version: {.Major: 1, .Minor: 0}},
225 {.Name: "zvksh", .Version: {.Major: 1, .Minor: 0}},
226 {.Name: "zvkt", .Version: {.Major: 1, .Minor: 0}},
227 {.Name: "zvl1024b", .Version: {.Major: 1, .Minor: 0}},
228 {.Name: "zvl128b", .Version: {.Major: 1, .Minor: 0}},
229 {.Name: "zvl16384b", .Version: {.Major: 1, .Minor: 0}},
230 {.Name: "zvl2048b", .Version: {.Major: 1, .Minor: 0}},
231 {.Name: "zvl256b", .Version: {.Major: 1, .Minor: 0}},
232 {.Name: "zvl32768b", .Version: {.Major: 1, .Minor: 0}},
233 {.Name: "zvl32b", .Version: {.Major: 1, .Minor: 0}},
234 {.Name: "zvl4096b", .Version: {.Major: 1, .Minor: 0}},
235 {.Name: "zvl512b", .Version: {.Major: 1, .Minor: 0}},
236 {.Name: "zvl64b", .Version: {.Major: 1, .Minor: 0}},
237 {.Name: "zvl65536b", .Version: {.Major: 1, .Minor: 0}},
238 {.Name: "zvl8192b", .Version: {.Major: 1, .Minor: 0}},
239};
240
241static const RISCVSupportedExtension SupportedExperimentalExtensions[] = {
242 {.Name: "p", .Version: {.Major: 0, .Minor: 19}},
243 {.Name: "smpmpmt", .Version: {.Major: 0, .Minor: 6}},
244 {.Name: "svukte", .Version: {.Major: 0, .Minor: 3}},
245 {.Name: "xrivosvisni", .Version: {.Major: 0, .Minor: 1}},
246 {.Name: "xrivosvizip", .Version: {.Major: 0, .Minor: 1}},
247 {.Name: "xsfmclic", .Version: {.Major: 0, .Minor: 1}},
248 {.Name: "xsfsclic", .Version: {.Major: 0, .Minor: 1}},
249 {.Name: "y", .Version: {.Major: 0, .Minor: 96}},
250 {.Name: "zibi", .Version: {.Major: 0, .Minor: 1}},
251 {.Name: "zicfilp", .Version: {.Major: 1, .Minor: 0}},
252 {.Name: "zicfiss", .Version: {.Major: 1, .Minor: 0}},
253 {.Name: "zvbc32e", .Version: {.Major: 0, .Minor: 7}},
254 {.Name: "zvfbfa", .Version: {.Major: 0, .Minor: 1}},
255 {.Name: "zvfofp8min", .Version: {.Major: 0, .Minor: 2}},
256 {.Name: "zvkgs", .Version: {.Major: 0, .Minor: 7}},
257 {.Name: "zvqdotq", .Version: {.Major: 0, .Minor: 0}},
258};
259
260#endif // GET_SUPPORTED_EXTENSIONS
261
262#ifdef GET_IMPLIED_EXTENSIONS
263#undef GET_IMPLIED_EXTENSIONS
264
265
266static constexpr ImpliedExtsEntry ImpliedExts[] = {
267 { {"a"}, "zaamo"},
268 { {"a"}, "zalrsc"},
269 { {"b"}, "zba"},
270 { {"b"}, "zbb"},
271 { {"b"}, "zbs"},
272 { {"c"}, "zca"},
273 { {"d"}, "f"},
274 { {"f"}, "zicsr"},
275 { {"m"}, "zmmul"},
276 { {"q"}, "d"},
277 { {"sha"}, "h"},
278 { {"sha"}, "ssstateen"},
279 { {"sha"}, "shcounterenw"},
280 { {"sha"}, "shvstvala"},
281 { {"sha"}, "shtvala"},
282 { {"sha"}, "shvstvecd"},
283 { {"sha"}, "shvsatpa"},
284 { {"sha"}, "shgatpa"},
285 { {"smctr"}, "sscsrind"},
286 { {"smdbltrp"}, "zicsr"},
287 { {"ssctr"}, "sscsrind"},
288 { {"ssdbltrp"}, "zicsr"},
289 { {"v"}, "zvl128b"},
290 { {"v"}, "zve64d"},
291 { {"xaifet"}, "f"},
292 { {"xandesbfhcvt"}, "f"},
293 { {"xandesvbfhcvt"}, "zve32f"},
294 { {"xandesvdot"}, "zve32x"},
295 { {"xandesvpackfph"}, "f"},
296 { {"xandesvsinth"}, "zve32x"},
297 { {"xandesvsintload"}, "zve32x"},
298 { {"xqccmp"}, "zca"},
299 { {"xqci"}, "xqcia"},
300 { {"xqci"}, "xqciac"},
301 { {"xqci"}, "xqcibi"},
302 { {"xqci"}, "xqcibm"},
303 { {"xqci"}, "xqcicli"},
304 { {"xqci"}, "xqcicm"},
305 { {"xqci"}, "xqcics"},
306 { {"xqci"}, "xqcicsr"},
307 { {"xqci"}, "xqciint"},
308 { {"xqci"}, "xqciio"},
309 { {"xqci"}, "xqcilb"},
310 { {"xqci"}, "xqcili"},
311 { {"xqci"}, "xqcilia"},
312 { {"xqci"}, "xqcilo"},
313 { {"xqci"}, "xqcilsm"},
314 { {"xqci"}, "xqcisim"},
315 { {"xqci"}, "xqcisls"},
316 { {"xqci"}, "xqcisync"},
317 { {"xqciac"}, "zca"},
318 { {"xqcibi"}, "zca"},
319 { {"xqcibm"}, "zca"},
320 { {"xqcicm"}, "zca"},
321 { {"xqciint"}, "zca"},
322 { {"xqcilb"}, "zca"},
323 { {"xqcili"}, "zca"},
324 { {"xqcilia"}, "zca"},
325 { {"xqcilo"}, "zca"},
326 { {"xqcisim"}, "zca"},
327 { {"xqcisync"}, "zca"},
328 { {"xsfmm128t"}, "xsfmmbase"},
329 { {"xsfmm128t"}, "zvl512b"},
330 { {"xsfmm16t"}, "xsfmmbase"},
331 { {"xsfmm16t"}, "zvl64b"},
332 { {"xsfmm32a16f"}, "xsfmmbase"},
333 { {"xsfmm32a16f"}, "zve32f"},
334 { {"xsfmm32a32f"}, "xsfmmbase"},
335 { {"xsfmm32a32f"}, "zve32f"},
336 { {"xsfmm32a8f"}, "xsfmmbase"},
337 { {"xsfmm32a8f"}, "zve32f"},
338 { {"xsfmm32a8i"}, "xsfmmbase"},
339 { {"xsfmm32t"}, "xsfmmbase"},
340 { {"xsfmm32t"}, "zvl128b"},
341 { {"xsfmm64a64f"}, "xsfmmbase"},
342 { {"xsfmm64a64f"}, "zve64d"},
343 { {"xsfmm64t"}, "xsfmmbase"},
344 { {"xsfmm64t"}, "zvl256b"},
345 { {"xsfmmbase"}, "zve32x"},
346 { {"xsfvcp"}, "zve32x"},
347 { {"xsfvfexp16e"}, "zvfh"},
348 { {"xsfvfexp32e"}, "zve32f"},
349 { {"xsfvfexpa"}, "zve32f"},
350 { {"xsfvfexpa64e"}, "xsfvfexpa"},
351 { {"xsfvfexpa64e"}, "zve64d"},
352 { {"xsfvfnrclipxfqf"}, "zve32f"},
353 { {"xsfvfwmaccqqq"}, "zvfbfmin"},
354 { {"xsfvfwmaccqqq"}, "zvl128b"},
355 { {"xsfvqmaccdod"}, "zve32x"},
356 { {"xsfvqmaccdod"}, "zvl128b"},
357 { {"xsfvqmaccqoq"}, "zve32x"},
358 { {"xsfvqmaccqoq"}, "zvl256b"},
359 { {"xsmtvdot"}, "zve32f"},
360 { {"xtheadvdot"}, "v"},
361 { {"xwchc"}, "zca"},
362 { {"zabha"}, "zaamo"},
363 { {"zacas"}, "zaamo"},
364 { {"zcb"}, "zca"},
365 { {"zcd"}, "d"},
366 { {"zcd"}, "zca"},
367 { {"zce"}, "zca"},
368 { {"zce"}, "zcb"},
369 { {"zce"}, "zcmp"},
370 { {"zce"}, "zcmt"},
371 { {"zcf"}, "f"},
372 { {"zcf"}, "zca"},
373 { {"zclsd"}, "zilsd"},
374 { {"zclsd"}, "zca"},
375 { {"zcmop"}, "zca"},
376 { {"zcmp"}, "zca"},
377 { {"zcmt"}, "zca"},
378 { {"zcmt"}, "zicsr"},
379 { {"zdinx"}, "zfinx"},
380 { {"zfa"}, "f"},
381 { {"zfbfmin"}, "f"},
382 { {"zfh"}, "zfhmin"},
383 { {"zfhmin"}, "f"},
384 { {"zfinx"}, "zicsr"},
385 { {"zhinx"}, "zhinxmin"},
386 { {"zhinxmin"}, "zfinx"},
387 { {"zicfilp"}, "zicsr"},
388 { {"zicfiss"}, "zicsr"},
389 { {"zicfiss"}, "zimop"},
390 { {"zicntr"}, "zicsr"},
391 { {"zihpm"}, "zicsr"},
392 { {"zk"}, "zkn"},
393 { {"zk"}, "zkr"},
394 { {"zk"}, "zkt"},
395 { {"zkn"}, "zbkb"},
396 { {"zkn"}, "zbkc"},
397 { {"zkn"}, "zbkx"},
398 { {"zkn"}, "zkne"},
399 { {"zkn"}, "zknd"},
400 { {"zkn"}, "zknh"},
401 { {"zks"}, "zbkb"},
402 { {"zks"}, "zbkc"},
403 { {"zks"}, "zbkx"},
404 { {"zks"}, "zksed"},
405 { {"zks"}, "zksh"},
406 { {"zvbb"}, "zvkb"},
407 { {"zvbc"}, "zve64x"},
408 { {"zvbc32e"}, "zve32x"},
409 { {"zve32f"}, "zve32x"},
410 { {"zve32f"}, "f"},
411 { {"zve32x"}, "zicsr"},
412 { {"zve32x"}, "zvl32b"},
413 { {"zve64d"}, "zve64f"},
414 { {"zve64d"}, "d"},
415 { {"zve64f"}, "zve32f"},
416 { {"zve64f"}, "zve64x"},
417 { {"zve64x"}, "zve32x"},
418 { {"zve64x"}, "zvl64b"},
419 { {"zvfbfa"}, "zve32f"},
420 { {"zvfbfa"}, "zfbfmin"},
421 { {"zvfbfmin"}, "zve32f"},
422 { {"zvfbfwma"}, "zvfbfmin"},
423 { {"zvfbfwma"}, "zfbfmin"},
424 { {"zvfh"}, "zvfhmin"},
425 { {"zvfh"}, "zfhmin"},
426 { {"zvfhmin"}, "zve32f"},
427 { {"zvfofp8min"}, "zve32f"},
428 { {"zvkb"}, "zve32x"},
429 { {"zvkg"}, "zve32x"},
430 { {"zvkgs"}, "zvkg"},
431 { {"zvkn"}, "zvkned"},
432 { {"zvkn"}, "zvknhb"},
433 { {"zvkn"}, "zvkb"},
434 { {"zvkn"}, "zvkt"},
435 { {"zvknc"}, "zvkn"},
436 { {"zvknc"}, "zvbc"},
437 { {"zvkned"}, "zve32x"},
438 { {"zvkng"}, "zvkn"},
439 { {"zvkng"}, "zvkg"},
440 { {"zvknha"}, "zve32x"},
441 { {"zvknhb"}, "zve64x"},
442 { {"zvks"}, "zvksed"},
443 { {"zvks"}, "zvksh"},
444 { {"zvks"}, "zvkb"},
445 { {"zvks"}, "zvkt"},
446 { {"zvksc"}, "zvks"},
447 { {"zvksc"}, "zvbc"},
448 { {"zvksed"}, "zve32x"},
449 { {"zvksg"}, "zvks"},
450 { {"zvksg"}, "zvkg"},
451 { {"zvksh"}, "zve32x"},
452 { {"zvl1024b"}, "zvl512b"},
453 { {"zvl128b"}, "zvl64b"},
454 { {"zvl16384b"}, "zvl8192b"},
455 { {"zvl2048b"}, "zvl1024b"},
456 { {"zvl256b"}, "zvl128b"},
457 { {"zvl32768b"}, "zvl16384b"},
458 { {"zvl4096b"}, "zvl2048b"},
459 { {"zvl512b"}, "zvl256b"},
460 { {"zvl64b"}, "zvl32b"},
461 { {"zvl65536b"}, "zvl32768b"},
462 { {"zvl8192b"}, "zvl4096b"},
463 { {"zvqdotq"}, "zve32x"},
464};
465
466#endif // GET_IMPLIED_EXTENSIONS
467
468#ifdef GET_SUPPORTED_PROFILES
469#undef GET_SUPPORTED_PROFILES
470
471static constexpr RISCVProfile SupportedProfiles[] = {
472 {"rva20s64","rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_ziccamoa1p0_ziccif1p0_zicclsm1p0_ziccrse1p0_zicntr2p0_zicsr2p0_zifencei2p0_za128rs1p0_ssccptr1p0_sstvala1p0_sstvecd1p0_svade1p0_svbare1p0"},
473 {"rva20u64","rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_ziccamoa1p0_ziccif1p0_zicclsm1p0_ziccrse1p0_zicntr2p0_zicsr2p0_za128rs1p0"},
474 {"rva22s64","rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_b1p0_zic64b1p0_zicbom1p0_zicbop1p0_zicboz1p0_ziccamoa1p0_ziccif1p0_zicclsm1p0_ziccrse1p0_zicntr2p0_zicsr2p0_zifencei2p0_zihintpause2p0_zihpm2p0_za64rs1p0_zfhmin1p0_zkt1p0_ssccptr1p0_sscounterenw1p0_sstvala1p0_sstvecd1p0_svade1p0_svbare1p0_svinval1p0_svpbmt1p0"},
475 {"rva22u64","rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_b1p0_zic64b1p0_zicbom1p0_zicbop1p0_zicboz1p0_ziccamoa1p0_ziccif1p0_zicclsm1p0_ziccrse1p0_zicntr2p0_zicsr2p0_zihintpause2p0_zihpm2p0_za64rs1p0_zfhmin1p0_zkt1p0"},
476 {"rva23s64","rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_b1p0_v1p0_zic64b1p0_zicbom1p0_zicbop1p0_zicboz1p0_ziccamoa1p0_ziccif1p0_zicclsm1p0_ziccrse1p0_zicntr2p0_zicond1p0_zicsr2p0_zifencei2p0_zihintntl1p0_zihintpause2p0_zihpm2p0_zimop1p0_za64rs1p0_zawrs1p0_zfa1p0_zfhmin1p0_zcb1p0_zcmop1p0_zkt1p0_zvbb1p0_zvfhmin1p0_zvkt1p0_sha1p0_ssccptr1p0_sscofpmf1p0_sscounterenw1p0_ssnpm1p0_sstc1p0_sstvala1p0_sstvecd1p0_ssu64xl1p0_supm1p0_svade1p0_svbare1p0_svinval1p0_svnapot1p0_svpbmt1p0"},
477 {"rva23u64","rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_b1p0_v1p0_zic64b1p0_zicbom1p0_zicbop1p0_zicboz1p0_ziccamoa1p0_ziccif1p0_zicclsm1p0_ziccrse1p0_zicntr2p0_zicond1p0_zicsr2p0_zihintntl1p0_zihintpause2p0_zihpm2p0_zimop1p0_za64rs1p0_zawrs1p0_zfa1p0_zfhmin1p0_zcb1p0_zcmop1p0_zkt1p0_zvbb1p0_zvfhmin1p0_zvkt1p0_supm1p0"},
478 {"rvb23s64","rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_b1p0_zic64b1p0_zicbom1p0_zicbop1p0_zicboz1p0_ziccamoa1p0_ziccif1p0_zicclsm1p0_ziccrse1p0_zicntr2p0_zicond1p0_zicsr2p0_zifencei2p0_zihintntl1p0_zihintpause2p0_zihpm2p0_zimop1p0_za64rs1p0_zawrs1p0_zfa1p0_zcb1p0_zcmop1p0_zkt1p0_ssccptr1p0_sscofpmf1p0_sscounterenw1p0_sstc1p0_sstvala1p0_sstvecd1p0_ssu64xl1p0_svade1p0_svbare1p0_svinval1p0_svnapot1p0_svpbmt1p0"},
479 {"rvb23u64","rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_b1p0_zic64b1p0_zicbom1p0_zicbop1p0_zicboz1p0_ziccamoa1p0_ziccif1p0_zicclsm1p0_ziccrse1p0_zicntr2p0_zicond1p0_zicsr2p0_zihintntl1p0_zihintpause2p0_zihpm2p0_zimop1p0_za64rs1p0_zawrs1p0_zfa1p0_zcb1p0_zcmop1p0_zkt1p0"},
480 {"rvi20u32","rv32i2p1"},
481 {"rvi20u64","rv64i2p1"},
482};
483
484static constexpr RISCVProfile SupportedExperimentalProfiles[] = {
485 {"rvm23u32","rv32i2p1_m2p0_b1p0_zicbop1p0_zicond1p0_zihintntl1p0_zihintpause2p0_zimop1p0_zce1p0_zcmop1p0"},
486};
487
488#endif // GET_SUPPORTED_PROFILES
489
490#ifndef PROC
491#define PROC(ENUM, NAME, DEFAULT_MARCH, FAST_SCALAR_UNALIGN, FAST_VECTOR_UNALIGN, MVENDORID, MARCHID, MIMPID)
492#endif
493
494PROC(AINEKKO_ERBIUM, {"an-erbium"}, {"rv64m2p0_f2p2_c2p0_xaifet1p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
495PROC(ANDES_A25, {"andes-a25"}, {"rv32i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0_xandesperf5p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
496PROC(ANDES_A45, {"andes-a45"}, {"rv32i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0_xandesperf5p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
497PROC(ANDES_AX25, {"andes-ax25"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0_xandesperf5p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
498PROC(ANDES_AX45, {"andes-ax45"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0_xandesperf5p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
499PROC(ANDES_AX45MPV, {"andes-ax45mpv"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_v1p0_zicsr2p0_zifencei2p0_xandesperf5p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
500PROC(ANDES_N45, {"andes-n45"}, {"rv32i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0_xandesperf5p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
501PROC(ANDES_NX45, {"andes-nx45"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0_xandesperf5p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
502PROC(ESPERANTO_SOC1, {"et-soc1"}, {"rv64m2p0_f2p2_c2p0_xaifet1p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
503PROC(GENERIC_RV32, {"generic-rv32"}, {"rv32i2p1"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
504PROC(GENERIC_RV64, {"generic-rv64"}, {"rv64i2p1"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
505PROC(MIPS_P8700, {"mips-p8700"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0_zba1p0_zbb1p0_xmipscbop1p0_xmipscmov1p0_xmipsexectl1p0_xmipslsp1p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
506PROC(ROCKET_RV32, {"rocket-rv32"}, {"rv32i2p1_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
507PROC(ROCKET_RV64, {"rocket-rv64"}, {"rv64i2p1_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
508PROC(RP2350_HAZARD3, {"rp2350-hazard3"}, {"rv32i2p1_m2p0_a2p1_c2p0_zicsr2p0_zifencei2p0_zcb1p0_zcmp1p0_zba1p0_zbb1p0_zbkb1p0_zbs1p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
509PROC(SIFIVE_E20, {"sifive-e20"}, {"rv32i2p1_m2p0_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
510PROC(SIFIVE_E21, {"sifive-e21"}, {"rv32i2p1_m2p0_a2p1_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
511PROC(SIFIVE_E24, {"sifive-e24"}, {"rv32i2p1_m2p0_a2p1_f2p2_c2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
512PROC(SIFIVE_E31, {"sifive-e31"}, {"rv32i2p1_m2p0_a2p1_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
513PROC(SIFIVE_E34, {"sifive-e34"}, {"rv32i2p1_m2p0_a2p1_f2p2_c2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
514PROC(SIFIVE_E76, {"sifive-e76"}, {"rv32i2p1_m2p0_a2p1_f2p2_c2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
515PROC(SIFIVE_P450, {"sifive-p450"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_b1p0_zic64b1p0_zicbom1p0_zicbop1p0_zicboz1p0_ziccamoa1p0_ziccif1p0_zicclsm1p0_ziccrse1p0_zicsr2p0_zifencei2p0_zihintntl1p0_zihintpause2p0_zihpm2p0_za64rs1p0_zfhmin1p0_zkt1p0"}, 1, 1, 0x00000000, 0x0000000000000000, 0x0000000000000000)
516PROC(SIFIVE_P470, {"sifive-p470"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_b1p0_v1p0_zic64b1p0_zicbom1p0_zicbop1p0_zicboz1p0_ziccamoa1p0_ziccif1p0_zicclsm1p0_ziccrse1p0_zicsr2p0_zifencei2p0_zihintntl1p0_zihintpause2p0_zihpm2p0_za64rs1p0_zfhmin1p0_zkt1p0_zvbb1p0_zvknc1p0_zvkng1p0_zvksc1p0_zvksg1p0_zvl128b1p0_xsifivecdiscarddlone1p0_xsifivecflushdlone1p0"}, 1, 1, 0x00000000, 0x0000000000000000, 0x0000000000000000)
517PROC(SIFIVE_P550, {"sifive-p550"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zifencei2p0_zba1p0_zbb1p0"}, 0, 0, 0x00000489, 0x8000000000000008, 0x0000000006220425)
518PROC(SIFIVE_P670, {"sifive-p670"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_b1p0_v1p0_zic64b1p0_zicbom1p0_zicbop1p0_zicboz1p0_ziccamoa1p0_ziccif1p0_zicclsm1p0_ziccrse1p0_zicsr2p0_zifencei2p0_zihintntl1p0_zihintpause2p0_zihpm2p0_za64rs1p0_zfhmin1p0_zkt1p0_zvbb1p0_zvknc1p0_zvkng1p0_zvksc1p0_zvksg1p0_zvl128b1p0"}, 1, 1, 0x00000000, 0x0000000000000000, 0x0000000000000000)
519PROC(SIFIVE_P870, {"sifive-p870"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_b1p0_v1p0_zic64b1p0_zicbom1p0_zicbop1p0_zicboz1p0_ziccamoa1p0_ziccif1p0_zicclsm1p0_ziccrse1p0_zicntr2p0_zicond1p0_zicsr2p0_zifencei2p0_zihintntl1p0_zihintpause2p0_zihpm2p0_zimop1p0_za64rs1p0_zama16b1p0_zawrs1p0_zfa1p0_zfh1p0_zfhmin1p0_zcb1p0_zcmop1p0_zkr1p0_zkt1p0_zvbb1p0_zvfbfmin1p0_zvfbfwma1p0_zvfh1p0_zvfhmin1p0_zvknc1p0_zvkng1p0_zvksc1p0_zvksg1p0_zvkt1p0_zvl128b1p0_supm1p0"}, 1, 1, 0x00000000, 0x0000000000000000, 0x0000000000000000)
520PROC(SIFIVE_S21, {"sifive-s21"}, {"rv64i2p1_m2p0_a2p1_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
521PROC(SIFIVE_S51, {"sifive-s51"}, {"rv64i2p1_m2p0_a2p1_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
522PROC(SIFIVE_S54, {"sifive-s54"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
523PROC(SIFIVE_S76, {"sifive-s76"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zifencei2p0_zihintpause2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
524PROC(SIFIVE_U54, {"sifive-u54"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
525PROC(SIFIVE_U74, {"sifive-u74"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
526PROC(SIFIVE_X280, {"sifive-x280"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_v1p0_zifencei2p0_zfh1p0_zba1p0_zbb1p0_zvfh1p0_zvl512b1p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
527PROC(SIFIVE_X390, {"sifive-x390"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_b1p0_v1p0_zic64b1p0_zicbom1p0_zicbop1p0_zicboz1p0_ziccamoa1p0_ziccif1p0_ziccrse1p0_zicfilp1p0_zicfiss1p0_zicntr2p0_zicond1p0_zifencei2p0_zihintntl1p0_zihintpause2p0_zihpm2p0_zimop1p0_za64rs1p0_zawrs1p0_zfa1p0_zfh1p0_zcb1p0_zcmop1p0_zkr1p0_zkt1p0_zvbb1p0_zvfbfmin1p0_zvfbfwma1p0_zvfh1p0_zvkt1p0_zvl1024b1p0_xsifivecdiscarddlone1p0_xsifivecflushdlone1p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
528PROC(SPACEMIT_X60, {"spacemit-x60"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_b1p0_v1p0_zic64b1p0_zicbom1p0_zicbop1p0_zicboz1p0_ziccamoa1p0_ziccif1p0_zicclsm1p0_ziccrse1p0_zicntr2p0_zicond1p0_zicsr2p0_zifencei2p0_zihintpause2p0_zihpm2p0_za64rs1p0_zfh1p0_zfhmin1p0_zbc1p0_zbkc1p0_zkt1p0_zvfh1p0_zvkt1p0_zvl256b1p0_ssccptr1p0_sscofpmf1p0_sscounterenw1p0_sstc1p0_sstvala1p0_sstvecd1p0_svade1p0_svbare1p0_svinval1p0_svnapot1p0_svpbmt1p0_xsmtvdot1p0"}, 1, 0, 0x00000710, 0x8000000058000001, 0x1000000049772200)
529PROC(SPACEMIT_X100, {"spacemit-x100"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_b1p0_v1p0_zic64b1p0_zicbom1p0_zicbop1p0_zicboz1p0_ziccamoa1p0_ziccif1p0_zicclsm1p0_ziccrse1p0_zicntr2p0_zicond1p0_zicsr2p0_zihintntl1p0_zihintpause2p0_zihpm2p0_zimop1p0_za64rs1p0_zawrs1p0_zfa1p0_zfbfmin1p0_zfh1p0_zfhmin1p0_zcb1p0_zcmop1p0_zbc1p0_zbkc1p0_zkt1p0_zvbb1p0_zvbc1p0_zvfbfwma1p0_zvfh1p0_zvfhmin1p0_zvkng1p0_zvknha1p0_zvksc1p0_zvksg1p0_zvkt1p0_zvl256b1p0_supm1p0_xsmtvdot1p0"}, 1, 0, 0x00000710, 0x8000000058000002, 0x0000000033d8a600)
530PROC(SYNTACORE_SCR1_BASE, {"syntacore-scr1-base"}, {"rv32i2p1_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
531PROC(SYNTACORE_SCR1_MAX, {"syntacore-scr1-max"}, {"rv32i2p1_m2p0_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
532PROC(SYNTACORE_SCR3_RV32, {"syntacore-scr3-rv32"}, {"rv32i2p1_m2p0_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
533PROC(SYNTACORE_SCR3_RV64, {"syntacore-scr3-rv64"}, {"rv64i2p1_m2p0_a2p1_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
534PROC(SYNTACORE_SCR4_RV32, {"syntacore-scr4-rv32"}, {"rv32i2p1_m2p0_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
535PROC(SYNTACORE_SCR4_RV64, {"syntacore-scr4-rv64"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
536PROC(SYNTACORE_SCR5_RV32, {"syntacore-scr5-rv32"}, {"rv32i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
537PROC(SYNTACORE_SCR5_RV64, {"syntacore-scr5-rv64"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
538PROC(SYNTACORE_SCR7, {"syntacore-scr7"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_v1p0_zicsr2p0_zifencei2p0_zba1p0_zbb1p0_zbc1p0_zbs1p0_zkn1p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
539PROC(TENSTORRENT_ASCALON_X, {"tt-ascalon-x"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_b1p0_v1p0_zic64b1p0_zicbom1p0_zicbop1p0_zicboz1p0_ziccamoa1p0_ziccif1p0_zicclsm1p0_ziccrse1p0_zicntr2p0_zicond1p0_zicsr2p0_zifencei2p0_zihintntl1p0_zihintpause2p0_zihpm2p0_zimop1p0_za64rs1p0_zawrs1p0_zfa1p0_zfbfmin1p0_zfh1p0_zfhmin1p0_zcb1p0_zcmop1p0_zkr1p0_zkt1p0_zvbb1p0_zvbc1p0_zvfbfmin1p0_zvfbfwma1p0_zvfh1p0_zvfhmin1p0_zvkng1p0_zvkt1p0_zvl256b1p0_sha1p0_smaia1p0_smmpm1p0_smnpm1p0_smrnmi1p0_smstateen1p0_ssaia1p0_ssccptr1p0_sscofpmf1p0_sscounterenw1p0_ssnpm1p0_ssstrict1p0_sstc1p0_sstvala1p0_sstvecd1p0_ssu64xl1p0_supm1p0_svade1p0_svbare1p0_svinval1p0_svnapot1p0_svpbmt1p0"}, 1, 1, 0x00000000, 0x0000000000000000, 0x0000000000000000)
540PROC(VENTANA_VEYRON_V1, {"veyron-v1"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicbom1p0_zicbop1p0_zicboz1p0_zicntr2p0_zicsr2p0_zifencei2p0_zihintpause2p0_zihpm2p0_zba1p0_zbb1p0_zbc1p0_zbs1p0_xventanacondops1p0"}, 0, 0, 0x0000061f, 0x8000000000010000, 0x0000000000000111)
541PROC(XIANGSHAN_KUNMINGHU, {"xiangshan-kunminghu"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_b1p0_v1p0_zic64b1p0_zicbom1p0_zicbop1p0_zicboz1p0_ziccamoa1p0_ziccif1p0_zicclsm1p0_ziccrse1p0_zicntr2p0_zicond1p0_zicsr2p0_zifencei2p0_zihintntl1p0_zihintpause2p0_zihpm2p0_zimop1p0_za64rs1p0_zacas1p0_zawrs1p0_zfa1p0_zfh1p0_zfhmin1p0_zcb1p0_zcmop1p0_zbc1p0_zkn1p0_zks1p0_zkt1p0_zvbb1p0_zvfh1p0_zvfhmin1p0_zvkt1p0_zvl128b1p0_sha1p0_smaia1p0_smcsrind1p0_smdbltrp1p0_smmpm1p0_smnpm1p0_smrnmi1p0_smstateen1p0_ssaia1p0_ssccptr1p0_sscofpmf1p0_sscounterenw1p0_sscsrind1p0_ssdbltrp1p0_ssnpm1p0_sspm1p0_ssstrict1p0_sstc1p0_sstvala1p0_sstvecd1p0_ssu64xl1p0_supm1p0_svade1p0_svbare1p0_svinval1p0_svnapot1p0_svpbmt1p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
542PROC(XIANGSHAN_NANHU, {"xiangshan-nanhu"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicbom1p0_zicboz1p0_zicsr2p0_zifencei2p0_zba1p0_zbb1p0_zbc1p0_zbs1p0_zkn1p0_zksed1p0_zksh1p0_svinval1p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
543
544#undef PROC
545
546#ifndef TUNE_PROC
547#define TUNE_PROC(ENUM, NAME)
548#endif
549
550TUNE_PROC(ANDES_45, "andes-45-series")
551TUNE_PROC(GENERIC, "generic")
552TUNE_PROC(GENERIC_OOO, "generic-ooo")
553TUNE_PROC(ROCKET, "rocket")
554TUNE_PROC(SIFIVE_7, "sifive-7-series")
555
556#undef TUNE_PROC
557#ifdef GET_RISCVExtensionBitmaskTable_IMPL
558static const RISCVExtensionBitmask ExtensionBitmask[]={
559 {"a", 0, 0ULL},
560 {"b", 0, 1ULL},
561 {"c", 0, 2ULL},
562 {"d", 0, 3ULL},
563 {"e", 0, 4ULL},
564 {"f", 0, 5ULL},
565 {"h", 0, 7ULL},
566 {"i", 0, 8ULL},
567 {"m", 0, 12ULL},
568 {"q", 0, 16ULL},
569 {"v", 0, 21ULL},
570 {"zacas", 0, 26ULL},
571 {"zba", 0, 27ULL},
572 {"zbb", 0, 28ULL},
573 {"zbc", 0, 29ULL},
574 {"zbkb", 0, 30ULL},
575 {"zbkc", 0, 31ULL},
576 {"zbkx", 0, 32ULL},
577 {"zbs", 0, 33ULL},
578 {"zfa", 0, 34ULL},
579 {"zfh", 0, 35ULL},
580 {"zfhmin", 0, 36ULL},
581 {"zicboz", 0, 37ULL},
582 {"zicond", 0, 38ULL},
583 {"zihintntl", 0, 39ULL},
584 {"zihintpause", 0, 40ULL},
585 {"zknd", 0, 41ULL},
586 {"zkne", 0, 42ULL},
587 {"zknh", 0, 43ULL},
588 {"zksed", 0, 44ULL},
589 {"zksh", 0, 45ULL},
590 {"zkt", 0, 46ULL},
591 {"ztso", 0, 47ULL},
592 {"zvbb", 0, 48ULL},
593 {"zvbc", 0, 49ULL},
594 {"zvfh", 0, 50ULL},
595 {"zvfhmin", 0, 51ULL},
596 {"zvkb", 0, 52ULL},
597 {"zvkg", 0, 53ULL},
598 {"zvkned", 0, 54ULL},
599 {"zvknha", 0, 55ULL},
600 {"zvknhb", 0, 56ULL},
601 {"zvksed", 0, 57ULL},
602 {"zvksh", 0, 58ULL},
603 {"zvkt", 0, 59ULL},
604 {"zve32x", 0, 60ULL},
605 {"zve32f", 0, 61ULL},
606 {"zve64x", 0, 62ULL},
607 {"zve64f", 0, 63ULL},
608 {"zve64d", 1, 0ULL},
609 {"zimop", 1, 1ULL},
610 {"zca", 1, 2ULL},
611 {"zcb", 1, 3ULL},
612 {"zcd", 1, 4ULL},
613 {"zcf", 1, 5ULL},
614 {"zcmop", 1, 6ULL},
615 {"zawrs", 1, 7ULL},
616 {"zilsd", 1, 8ULL},
617 {"zclsd", 1, 9ULL},
618 {"zcmp", 1, 10ULL},
619};
620#endif
621