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: "xsfmm32a", .Version: {.Major: 0, .Minor: 6}},
106 {.Name: "xsfmm32a16f", .Version: {.Major: 0, .Minor: 6}},
107 {.Name: "xsfmm32a32f", .Version: {.Major: 0, .Minor: 6}},
108 {.Name: "xsfmm32a8f", .Version: {.Major: 0, .Minor: 6}},
109 {.Name: "xsfmm32a8i", .Version: {.Major: 0, .Minor: 6}},
110 {.Name: "xsfmm32t", .Version: {.Major: 0, .Minor: 6}},
111 {.Name: "xsfmm64a64f", .Version: {.Major: 0, .Minor: 6}},
112 {.Name: "xsfmm64t", .Version: {.Major: 0, .Minor: 6}},
113 {.Name: "xsfmmbase", .Version: {.Major: 0, .Minor: 6}},
114 {.Name: "xsfvcp", .Version: {.Major: 1, .Minor: 0}},
115 {.Name: "xsfvfbfexp16e", .Version: {.Major: 0, .Minor: 5}},
116 {.Name: "xsfvfexp16e", .Version: {.Major: 0, .Minor: 5}},
117 {.Name: "xsfvfexp32e", .Version: {.Major: 0, .Minor: 5}},
118 {.Name: "xsfvfexpa", .Version: {.Major: 0, .Minor: 2}},
119 {.Name: "xsfvfexpa64e", .Version: {.Major: 0, .Minor: 2}},
120 {.Name: "xsfvfnrclipxfqf", .Version: {.Major: 1, .Minor: 0}},
121 {.Name: "xsfvfwmaccqqq", .Version: {.Major: 1, .Minor: 0}},
122 {.Name: "xsfvqmaccdod", .Version: {.Major: 1, .Minor: 0}},
123 {.Name: "xsfvqmaccqoq", .Version: {.Major: 1, .Minor: 0}},
124 {.Name: "xsifivecdiscarddlone", .Version: {.Major: 1, .Minor: 0}},
125 {.Name: "xsifivecflushdlone", .Version: {.Major: 1, .Minor: 0}},
126 {.Name: "xsmtvdot", .Version: {.Major: 1, .Minor: 0}},
127 {.Name: "xtheadba", .Version: {.Major: 1, .Minor: 0}},
128 {.Name: "xtheadbb", .Version: {.Major: 1, .Minor: 0}},
129 {.Name: "xtheadbs", .Version: {.Major: 1, .Minor: 0}},
130 {.Name: "xtheadcmo", .Version: {.Major: 1, .Minor: 0}},
131 {.Name: "xtheadcondmov", .Version: {.Major: 1, .Minor: 0}},
132 {.Name: "xtheadfmemidx", .Version: {.Major: 1, .Minor: 0}},
133 {.Name: "xtheadmac", .Version: {.Major: 1, .Minor: 0}},
134 {.Name: "xtheadmemidx", .Version: {.Major: 1, .Minor: 0}},
135 {.Name: "xtheadmempair", .Version: {.Major: 1, .Minor: 0}},
136 {.Name: "xtheadsync", .Version: {.Major: 1, .Minor: 0}},
137 {.Name: "xtheadvdot", .Version: {.Major: 1, .Minor: 0}},
138 {.Name: "xventanacondops", .Version: {.Major: 1, .Minor: 0}},
139 {.Name: "xwchc", .Version: {.Major: 2, .Minor: 2}},
140 {.Name: "za128rs", .Version: {.Major: 1, .Minor: 0}},
141 {.Name: "za64rs", .Version: {.Major: 1, .Minor: 0}},
142 {.Name: "zaamo", .Version: {.Major: 1, .Minor: 0}},
143 {.Name: "zabha", .Version: {.Major: 1, .Minor: 0}},
144 {.Name: "zacas", .Version: {.Major: 1, .Minor: 0}},
145 {.Name: "zalasr", .Version: {.Major: 1, .Minor: 0}},
146 {.Name: "zalrsc", .Version: {.Major: 1, .Minor: 0}},
147 {.Name: "zama16b", .Version: {.Major: 1, .Minor: 0}},
148 {.Name: "zawrs", .Version: {.Major: 1, .Minor: 0}},
149 {.Name: "zba", .Version: {.Major: 1, .Minor: 0}},
150 {.Name: "zbb", .Version: {.Major: 1, .Minor: 0}},
151 {.Name: "zbc", .Version: {.Major: 1, .Minor: 0}},
152 {.Name: "zbkb", .Version: {.Major: 1, .Minor: 0}},
153 {.Name: "zbkc", .Version: {.Major: 1, .Minor: 0}},
154 {.Name: "zbkx", .Version: {.Major: 1, .Minor: 0}},
155 {.Name: "zbs", .Version: {.Major: 1, .Minor: 0}},
156 {.Name: "zca", .Version: {.Major: 1, .Minor: 0}},
157 {.Name: "zcb", .Version: {.Major: 1, .Minor: 0}},
158 {.Name: "zcd", .Version: {.Major: 1, .Minor: 0}},
159 {.Name: "zce", .Version: {.Major: 1, .Minor: 0}},
160 {.Name: "zcf", .Version: {.Major: 1, .Minor: 0}},
161 {.Name: "zclsd", .Version: {.Major: 1, .Minor: 0}},
162 {.Name: "zcmop", .Version: {.Major: 1, .Minor: 0}},
163 {.Name: "zcmp", .Version: {.Major: 1, .Minor: 0}},
164 {.Name: "zcmt", .Version: {.Major: 1, .Minor: 0}},
165 {.Name: "zdinx", .Version: {.Major: 1, .Minor: 0}},
166 {.Name: "zfa", .Version: {.Major: 1, .Minor: 0}},
167 {.Name: "zfbfmin", .Version: {.Major: 1, .Minor: 0}},
168 {.Name: "zfh", .Version: {.Major: 1, .Minor: 0}},
169 {.Name: "zfhmin", .Version: {.Major: 1, .Minor: 0}},
170 {.Name: "zfinx", .Version: {.Major: 1, .Minor: 0}},
171 {.Name: "zhinx", .Version: {.Major: 1, .Minor: 0}},
172 {.Name: "zhinxmin", .Version: {.Major: 1, .Minor: 0}},
173 {.Name: "zic64b", .Version: {.Major: 1, .Minor: 0}},
174 {.Name: "zicbom", .Version: {.Major: 1, .Minor: 0}},
175 {.Name: "zicbop", .Version: {.Major: 1, .Minor: 0}},
176 {.Name: "zicboz", .Version: {.Major: 1, .Minor: 0}},
177 {.Name: "ziccamoa", .Version: {.Major: 1, .Minor: 0}},
178 {.Name: "ziccamoc", .Version: {.Major: 1, .Minor: 0}},
179 {.Name: "ziccif", .Version: {.Major: 1, .Minor: 0}},
180 {.Name: "zicclsm", .Version: {.Major: 1, .Minor: 0}},
181 {.Name: "ziccrse", .Version: {.Major: 1, .Minor: 0}},
182 {.Name: "zicntr", .Version: {.Major: 2, .Minor: 0}},
183 {.Name: "zicond", .Version: {.Major: 1, .Minor: 0}},
184 {.Name: "zicsr", .Version: {.Major: 2, .Minor: 0}},
185 {.Name: "zifencei", .Version: {.Major: 2, .Minor: 0}},
186 {.Name: "zihintntl", .Version: {.Major: 1, .Minor: 0}},
187 {.Name: "zihintpause", .Version: {.Major: 2, .Minor: 0}},
188 {.Name: "zihpm", .Version: {.Major: 2, .Minor: 0}},
189 {.Name: "zilsd", .Version: {.Major: 1, .Minor: 0}},
190 {.Name: "zimop", .Version: {.Major: 1, .Minor: 0}},
191 {.Name: "zk", .Version: {.Major: 1, .Minor: 0}},
192 {.Name: "zkn", .Version: {.Major: 1, .Minor: 0}},
193 {.Name: "zknd", .Version: {.Major: 1, .Minor: 0}},
194 {.Name: "zkne", .Version: {.Major: 1, .Minor: 0}},
195 {.Name: "zknh", .Version: {.Major: 1, .Minor: 0}},
196 {.Name: "zkr", .Version: {.Major: 1, .Minor: 0}},
197 {.Name: "zks", .Version: {.Major: 1, .Minor: 0}},
198 {.Name: "zksed", .Version: {.Major: 1, .Minor: 0}},
199 {.Name: "zksh", .Version: {.Major: 1, .Minor: 0}},
200 {.Name: "zkt", .Version: {.Major: 1, .Minor: 0}},
201 {.Name: "zmmul", .Version: {.Major: 1, .Minor: 0}},
202 {.Name: "ztso", .Version: {.Major: 1, .Minor: 0}},
203 {.Name: "zvbb", .Version: {.Major: 1, .Minor: 0}},
204 {.Name: "zvbc", .Version: {.Major: 1, .Minor: 0}},
205 {.Name: "zve32f", .Version: {.Major: 1, .Minor: 0}},
206 {.Name: "zve32x", .Version: {.Major: 1, .Minor: 0}},
207 {.Name: "zve64d", .Version: {.Major: 1, .Minor: 0}},
208 {.Name: "zve64f", .Version: {.Major: 1, .Minor: 0}},
209 {.Name: "zve64x", .Version: {.Major: 1, .Minor: 0}},
210 {.Name: "zvfbfmin", .Version: {.Major: 1, .Minor: 0}},
211 {.Name: "zvfbfwma", .Version: {.Major: 1, .Minor: 0}},
212 {.Name: "zvfh", .Version: {.Major: 1, .Minor: 0}},
213 {.Name: "zvfhmin", .Version: {.Major: 1, .Minor: 0}},
214 {.Name: "zvkb", .Version: {.Major: 1, .Minor: 0}},
215 {.Name: "zvkg", .Version: {.Major: 1, .Minor: 0}},
216 {.Name: "zvkn", .Version: {.Major: 1, .Minor: 0}},
217 {.Name: "zvknc", .Version: {.Major: 1, .Minor: 0}},
218 {.Name: "zvkned", .Version: {.Major: 1, .Minor: 0}},
219 {.Name: "zvkng", .Version: {.Major: 1, .Minor: 0}},
220 {.Name: "zvknha", .Version: {.Major: 1, .Minor: 0}},
221 {.Name: "zvknhb", .Version: {.Major: 1, .Minor: 0}},
222 {.Name: "zvks", .Version: {.Major: 1, .Minor: 0}},
223 {.Name: "zvksc", .Version: {.Major: 1, .Minor: 0}},
224 {.Name: "zvksed", .Version: {.Major: 1, .Minor: 0}},
225 {.Name: "zvksg", .Version: {.Major: 1, .Minor: 0}},
226 {.Name: "zvksh", .Version: {.Major: 1, .Minor: 0}},
227 {.Name: "zvkt", .Version: {.Major: 1, .Minor: 0}},
228 {.Name: "zvl1024b", .Version: {.Major: 1, .Minor: 0}},
229 {.Name: "zvl128b", .Version: {.Major: 1, .Minor: 0}},
230 {.Name: "zvl16384b", .Version: {.Major: 1, .Minor: 0}},
231 {.Name: "zvl2048b", .Version: {.Major: 1, .Minor: 0}},
232 {.Name: "zvl256b", .Version: {.Major: 1, .Minor: 0}},
233 {.Name: "zvl32768b", .Version: {.Major: 1, .Minor: 0}},
234 {.Name: "zvl32b", .Version: {.Major: 1, .Minor: 0}},
235 {.Name: "zvl4096b", .Version: {.Major: 1, .Minor: 0}},
236 {.Name: "zvl512b", .Version: {.Major: 1, .Minor: 0}},
237 {.Name: "zvl64b", .Version: {.Major: 1, .Minor: 0}},
238 {.Name: "zvl65536b", .Version: {.Major: 1, .Minor: 0}},
239 {.Name: "zvl8192b", .Version: {.Major: 1, .Minor: 0}},
240};
241
242static const RISCVSupportedExtension SupportedExperimentalExtensions[] = {
243 {.Name: "p", .Version: {.Major: 0, .Minor: 19}},
244 {.Name: "smpmpmt", .Version: {.Major: 0, .Minor: 6}},
245 {.Name: "svukte", .Version: {.Major: 0, .Minor: 3}},
246 {.Name: "xrivosvisni", .Version: {.Major: 0, .Minor: 1}},
247 {.Name: "xrivosvizip", .Version: {.Major: 0, .Minor: 1}},
248 {.Name: "xsfmclic", .Version: {.Major: 0, .Minor: 1}},
249 {.Name: "xsfsclic", .Version: {.Major: 0, .Minor: 1}},
250 {.Name: "y", .Version: {.Major: 0, .Minor: 96}},
251 {.Name: "zibi", .Version: {.Major: 0, .Minor: 1}},
252 {.Name: "zicfilp", .Version: {.Major: 1, .Minor: 0}},
253 {.Name: "zicfiss", .Version: {.Major: 1, .Minor: 0}},
254 {.Name: "zvabd", .Version: {.Major: 0, .Minor: 7}},
255 {.Name: "zvbc32e", .Version: {.Major: 0, .Minor: 7}},
256 {.Name: "zvdot4a8i", .Version: {.Major: 0, .Minor: 1}},
257 {.Name: "zvfbfa", .Version: {.Major: 0, .Minor: 1}},
258 {.Name: "zvfofp8min", .Version: {.Major: 0, .Minor: 2}},
259 {.Name: "zvkgs", .Version: {.Major: 0, .Minor: 7}},
260};
261
262#endif // GET_SUPPORTED_EXTENSIONS
263
264#ifdef GET_IMPLIED_EXTENSIONS
265#undef GET_IMPLIED_EXTENSIONS
266
267
268static constexpr ImpliedExtsEntry ImpliedExts[] = {
269 { {"a"}, "zaamo"},
270 { {"a"}, "zalrsc"},
271 { {"b"}, "zba"},
272 { {"b"}, "zbb"},
273 { {"b"}, "zbs"},
274 { {"c"}, "zca"},
275 { {"d"}, "f"},
276 { {"f"}, "zicsr"},
277 { {"m"}, "zmmul"},
278 { {"q"}, "d"},
279 { {"sha"}, "h"},
280 { {"sha"}, "ssstateen"},
281 { {"sha"}, "shcounterenw"},
282 { {"sha"}, "shvstvala"},
283 { {"sha"}, "shtvala"},
284 { {"sha"}, "shvstvecd"},
285 { {"sha"}, "shvsatpa"},
286 { {"sha"}, "shgatpa"},
287 { {"smctr"}, "sscsrind"},
288 { {"smdbltrp"}, "zicsr"},
289 { {"ssctr"}, "sscsrind"},
290 { {"ssdbltrp"}, "zicsr"},
291 { {"v"}, "zvl128b"},
292 { {"v"}, "zve64d"},
293 { {"xaifet"}, "f"},
294 { {"xandesbfhcvt"}, "f"},
295 { {"xandesvbfhcvt"}, "zve32f"},
296 { {"xandesvdot"}, "zve32x"},
297 { {"xandesvpackfph"}, "f"},
298 { {"xandesvsinth"}, "zve32x"},
299 { {"xandesvsintload"}, "zve32x"},
300 { {"xqccmp"}, "zca"},
301 { {"xqci"}, "xqcia"},
302 { {"xqci"}, "xqciac"},
303 { {"xqci"}, "xqcibi"},
304 { {"xqci"}, "xqcibm"},
305 { {"xqci"}, "xqcicli"},
306 { {"xqci"}, "xqcicm"},
307 { {"xqci"}, "xqcics"},
308 { {"xqci"}, "xqcicsr"},
309 { {"xqci"}, "xqciint"},
310 { {"xqci"}, "xqciio"},
311 { {"xqci"}, "xqcilb"},
312 { {"xqci"}, "xqcili"},
313 { {"xqci"}, "xqcilia"},
314 { {"xqci"}, "xqcilo"},
315 { {"xqci"}, "xqcilsm"},
316 { {"xqci"}, "xqcisim"},
317 { {"xqci"}, "xqcisls"},
318 { {"xqci"}, "xqcisync"},
319 { {"xqciac"}, "zca"},
320 { {"xqcibi"}, "zca"},
321 { {"xqcibm"}, "zca"},
322 { {"xqcicm"}, "zca"},
323 { {"xqciint"}, "zca"},
324 { {"xqcilb"}, "zca"},
325 { {"xqcili"}, "zca"},
326 { {"xqcilia"}, "zca"},
327 { {"xqcilo"}, "zca"},
328 { {"xqcisim"}, "zca"},
329 { {"xqcisync"}, "zca"},
330 { {"xsfmm128t"}, "xsfmmbase"},
331 { {"xsfmm128t"}, "zvl512b"},
332 { {"xsfmm16t"}, "xsfmmbase"},
333 { {"xsfmm16t"}, "zvl64b"},
334 { {"xsfmm32a"}, "xsfmm32a8i"},
335 { {"xsfmm32a"}, "xsfmm32a16f"},
336 { {"xsfmm32a"}, "xsfmm32a32f"},
337 { {"xsfmm32a16f"}, "xsfmmbase"},
338 { {"xsfmm32a16f"}, "zve32f"},
339 { {"xsfmm32a32f"}, "xsfmmbase"},
340 { {"xsfmm32a32f"}, "zve32f"},
341 { {"xsfmm32a8f"}, "xsfmmbase"},
342 { {"xsfmm32a8f"}, "zve32f"},
343 { {"xsfmm32a8i"}, "xsfmmbase"},
344 { {"xsfmm32t"}, "xsfmmbase"},
345 { {"xsfmm32t"}, "zvl128b"},
346 { {"xsfmm64a64f"}, "xsfmmbase"},
347 { {"xsfmm64a64f"}, "zve64d"},
348 { {"xsfmm64t"}, "xsfmmbase"},
349 { {"xsfmm64t"}, "zvl256b"},
350 { {"xsfmmbase"}, "zve32x"},
351 { {"xsfvcp"}, "zve32x"},
352 { {"xsfvfexp16e"}, "zvfh"},
353 { {"xsfvfexp32e"}, "zve32f"},
354 { {"xsfvfexpa"}, "zve32f"},
355 { {"xsfvfexpa64e"}, "xsfvfexpa"},
356 { {"xsfvfexpa64e"}, "zve64d"},
357 { {"xsfvfnrclipxfqf"}, "zve32f"},
358 { {"xsfvfwmaccqqq"}, "zvfbfmin"},
359 { {"xsfvfwmaccqqq"}, "zvl128b"},
360 { {"xsfvqmaccdod"}, "zve32x"},
361 { {"xsfvqmaccdod"}, "zvl128b"},
362 { {"xsfvqmaccqoq"}, "zve32x"},
363 { {"xsfvqmaccqoq"}, "zvl256b"},
364 { {"xsmtvdot"}, "zve32f"},
365 { {"xtheadvdot"}, "v"},
366 { {"xwchc"}, "zca"},
367 { {"zabha"}, "zaamo"},
368 { {"zacas"}, "zaamo"},
369 { {"zcb"}, "zca"},
370 { {"zcd"}, "d"},
371 { {"zcd"}, "zca"},
372 { {"zce"}, "zca"},
373 { {"zce"}, "zcb"},
374 { {"zce"}, "zcmp"},
375 { {"zce"}, "zcmt"},
376 { {"zcf"}, "f"},
377 { {"zcf"}, "zca"},
378 { {"zclsd"}, "zilsd"},
379 { {"zclsd"}, "zca"},
380 { {"zcmop"}, "zca"},
381 { {"zcmp"}, "zca"},
382 { {"zcmt"}, "zca"},
383 { {"zcmt"}, "zicsr"},
384 { {"zdinx"}, "zfinx"},
385 { {"zfa"}, "f"},
386 { {"zfbfmin"}, "f"},
387 { {"zfh"}, "zfhmin"},
388 { {"zfhmin"}, "f"},
389 { {"zfinx"}, "zicsr"},
390 { {"zhinx"}, "zhinxmin"},
391 { {"zhinxmin"}, "zfinx"},
392 { {"zicfilp"}, "zicsr"},
393 { {"zicfiss"}, "zicsr"},
394 { {"zicfiss"}, "zimop"},
395 { {"zicntr"}, "zicsr"},
396 { {"zihpm"}, "zicsr"},
397 { {"zk"}, "zkn"},
398 { {"zk"}, "zkr"},
399 { {"zk"}, "zkt"},
400 { {"zkn"}, "zbkb"},
401 { {"zkn"}, "zbkc"},
402 { {"zkn"}, "zbkx"},
403 { {"zkn"}, "zkne"},
404 { {"zkn"}, "zknd"},
405 { {"zkn"}, "zknh"},
406 { {"zks"}, "zbkb"},
407 { {"zks"}, "zbkc"},
408 { {"zks"}, "zbkx"},
409 { {"zks"}, "zksed"},
410 { {"zks"}, "zksh"},
411 { {"zvbb"}, "zvkb"},
412 { {"zvbc"}, "zve64x"},
413 { {"zvbc32e"}, "zve32x"},
414 { {"zvdot4a8i"}, "zve32x"},
415 { {"zve32f"}, "zve32x"},
416 { {"zve32f"}, "f"},
417 { {"zve32x"}, "zicsr"},
418 { {"zve32x"}, "zvl32b"},
419 { {"zve64d"}, "zve64f"},
420 { {"zve64d"}, "d"},
421 { {"zve64f"}, "zve32f"},
422 { {"zve64f"}, "zve64x"},
423 { {"zve64x"}, "zve32x"},
424 { {"zve64x"}, "zvl64b"},
425 { {"zvfbfa"}, "zve32f"},
426 { {"zvfbfa"}, "zfbfmin"},
427 { {"zvfbfmin"}, "zve32f"},
428 { {"zvfbfwma"}, "zvfbfmin"},
429 { {"zvfbfwma"}, "zfbfmin"},
430 { {"zvfh"}, "zvfhmin"},
431 { {"zvfh"}, "zfhmin"},
432 { {"zvfhmin"}, "zve32f"},
433 { {"zvfofp8min"}, "zve32f"},
434 { {"zvkb"}, "zve32x"},
435 { {"zvkg"}, "zve32x"},
436 { {"zvkgs"}, "zvkg"},
437 { {"zvkn"}, "zvkned"},
438 { {"zvkn"}, "zvknhb"},
439 { {"zvkn"}, "zvkb"},
440 { {"zvkn"}, "zvkt"},
441 { {"zvknc"}, "zvkn"},
442 { {"zvknc"}, "zvbc"},
443 { {"zvkned"}, "zve32x"},
444 { {"zvkng"}, "zvkn"},
445 { {"zvkng"}, "zvkg"},
446 { {"zvknha"}, "zve32x"},
447 { {"zvknhb"}, "zve64x"},
448 { {"zvks"}, "zvksed"},
449 { {"zvks"}, "zvksh"},
450 { {"zvks"}, "zvkb"},
451 { {"zvks"}, "zvkt"},
452 { {"zvksc"}, "zvks"},
453 { {"zvksc"}, "zvbc"},
454 { {"zvksed"}, "zve32x"},
455 { {"zvksg"}, "zvks"},
456 { {"zvksg"}, "zvkg"},
457 { {"zvksh"}, "zve32x"},
458 { {"zvl1024b"}, "zvl512b"},
459 { {"zvl128b"}, "zvl64b"},
460 { {"zvl16384b"}, "zvl8192b"},
461 { {"zvl2048b"}, "zvl1024b"},
462 { {"zvl256b"}, "zvl128b"},
463 { {"zvl32768b"}, "zvl16384b"},
464 { {"zvl4096b"}, "zvl2048b"},
465 { {"zvl512b"}, "zvl256b"},
466 { {"zvl64b"}, "zvl32b"},
467 { {"zvl65536b"}, "zvl32768b"},
468 { {"zvl8192b"}, "zvl4096b"},
469};
470
471#endif // GET_IMPLIED_EXTENSIONS
472
473#ifdef GET_SUPPORTED_PROFILES
474#undef GET_SUPPORTED_PROFILES
475
476static constexpr RISCVProfile SupportedProfiles[] = {
477 {"rva20s64","rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_ziccamoa1p0_ziccif1p0_zicclsm1p0_ziccrse1p0_zicntr2p0_zicsr2p0_zifencei2p0_za128rs1p0_ssccptr1p0_sstvala1p0_sstvecd1p0_svade1p0_svbare1p0"},
478 {"rva20u64","rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_ziccamoa1p0_ziccif1p0_zicclsm1p0_ziccrse1p0_zicntr2p0_zicsr2p0_za128rs1p0"},
479 {"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"},
480 {"rva22u64","rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_b1p0_zic64b1p0_zicbom1p0_zicbop1p0_zicboz1p0_ziccamoa1p0_ziccif1p0_zicclsm1p0_ziccrse1p0_zicntr2p0_zicsr2p0_zihintpause2p0_zihpm2p0_za64rs1p0_zfhmin1p0_zkt1p0"},
481 {"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"},
482 {"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"},
483 {"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"},
484 {"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"},
485 {"rvi20u32","rv32i2p1"},
486 {"rvi20u64","rv64i2p1"},
487};
488
489static constexpr RISCVProfile SupportedExperimentalProfiles[] = {
490 {"rvm23u32","rv32i2p1_m2p0_b1p0_zicbop1p0_zicond1p0_zihintntl1p0_zihintpause2p0_zimop1p0_zce1p0_zcmop1p0"},
491};
492
493#endif // GET_SUPPORTED_PROFILES
494
495#ifndef PROC
496#define PROC(ENUM, NAME, DEFAULT_MARCH, FAST_SCALAR_UNALIGN, FAST_VECTOR_UNALIGN, MVENDORID, MARCHID, MIMPID)
497#endif
498
499PROC(AINEKKO_ERBIUM, {"an-erbium"}, {"rv64m2p0_f2p2_c2p0_xaifet1p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
500PROC(ANDES_A25, {"andes-a25"}, {"rv32i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0_xandesperf5p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
501PROC(ANDES_A45, {"andes-a45"}, {"rv32i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0_xandesperf5p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
502PROC(ANDES_AX25, {"andes-ax25"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0_xandesperf5p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
503PROC(ANDES_AX45, {"andes-ax45"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0_xandesperf5p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
504PROC(ANDES_AX45MPV, {"andes-ax45mpv"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_v1p0_zicsr2p0_zifencei2p0_xandesperf5p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
505PROC(ANDES_N45, {"andes-n45"}, {"rv32i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0_xandesperf5p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
506PROC(ANDES_NX45, {"andes-nx45"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0_xandesperf5p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
507PROC(ESPERANTO_SOC1, {"et-soc1"}, {"rv64m2p0_f2p2_c2p0_xaifet1p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
508PROC(GENERIC_RV32, {"generic-rv32"}, {"rv32i2p1"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
509PROC(GENERIC_RV64, {"generic-rv64"}, {"rv64i2p1"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
510PROC(MIPS_P8700, {"mips-p8700"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0_zba1p0_zbb1p0_xmipscbop1p0_xmipscmov1p0_xmipsexectl1p0_xmipslsp1p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
511PROC(ROCKET_RV32, {"rocket-rv32"}, {"rv32i2p1_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
512PROC(ROCKET_RV64, {"rocket-rv64"}, {"rv64i2p1_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
513PROC(RP2350_HAZARD3, {"rp2350-hazard3"}, {"rv32i2p1_m2p0_a2p1_c2p0_zicsr2p0_zifencei2p0_zcb1p0_zcmp1p0_zba1p0_zbb1p0_zbkb1p0_zbs1p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
514PROC(SIFIVE_E20, {"sifive-e20"}, {"rv32i2p1_m2p0_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
515PROC(SIFIVE_E21, {"sifive-e21"}, {"rv32i2p1_m2p0_a2p1_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
516PROC(SIFIVE_E24, {"sifive-e24"}, {"rv32i2p1_m2p0_a2p1_f2p2_c2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
517PROC(SIFIVE_E31, {"sifive-e31"}, {"rv32i2p1_m2p0_a2p1_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
518PROC(SIFIVE_E34, {"sifive-e34"}, {"rv32i2p1_m2p0_a2p1_f2p2_c2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
519PROC(SIFIVE_E76, {"sifive-e76"}, {"rv32i2p1_m2p0_a2p1_f2p2_c2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
520PROC(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)
521PROC(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)
522PROC(SIFIVE_P550, {"sifive-p550"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zifencei2p0_zba1p0_zbb1p0"}, 0, 0, 0x00000489, 0x8000000000000008, 0x0000000006220425)
523PROC(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)
524PROC(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)
525PROC(SIFIVE_S21, {"sifive-s21"}, {"rv64i2p1_m2p0_a2p1_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
526PROC(SIFIVE_S51, {"sifive-s51"}, {"rv64i2p1_m2p0_a2p1_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
527PROC(SIFIVE_S54, {"sifive-s54"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
528PROC(SIFIVE_S76, {"sifive-s76"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zifencei2p0_zihintpause2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
529PROC(SIFIVE_U54, {"sifive-u54"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
530PROC(SIFIVE_U74, {"sifive-u74"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
531PROC(SIFIVE_X280, {"sifive-x280"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_v1p0_zifencei2p0_zfh1p0_zba1p0_zbb1p0_zvfh1p0_zvl512b1p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
532PROC(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)
533PROC(SPACEMIT_A100, {"spacemit-a100"}, {"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_zbc1p0_zbkc1p0_zkt1p0_zvbb1p0_zvbc1p0_zvfbfwma1p0_zvfh1p0_zvfhmin1p0_zvkng1p0_zvknha1p0_zvksc1p0_zvksg1p0_zvkt1p0_zvl1024b1p0_smepmp1p0_smnpm1p0_smstateen1p0_ssccptr1p0_sscofpmf1p0_sscounterenw1p0_ssnpm1p0_sspm1p0_sstc1p0_sstvala1p0_sstvecd1p0_ssu64xl1p0_supm1p0_svade1p0_svbare1p0_svinval1p0_svnapot1p0_svpbmt1p0"}, 1, 0, 0x00000710, 0x8000000041000002, 0x10000000d5686200)
534PROC(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)
535PROC(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)
536PROC(SYNTACORE_SCR1_BASE, {"syntacore-scr1-base"}, {"rv32i2p1_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
537PROC(SYNTACORE_SCR1_MAX, {"syntacore-scr1-max"}, {"rv32i2p1_m2p0_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
538PROC(SYNTACORE_SCR3_RV32, {"syntacore-scr3-rv32"}, {"rv32i2p1_m2p0_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
539PROC(SYNTACORE_SCR3_RV64, {"syntacore-scr3-rv64"}, {"rv64i2p1_m2p0_a2p1_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
540PROC(SYNTACORE_SCR4_RV32, {"syntacore-scr4-rv32"}, {"rv32i2p1_m2p0_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
541PROC(SYNTACORE_SCR4_RV64, {"syntacore-scr4-rv64"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
542PROC(SYNTACORE_SCR5_RV32, {"syntacore-scr5-rv32"}, {"rv32i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
543PROC(SYNTACORE_SCR5_RV64, {"syntacore-scr5-rv64"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_zicsr2p0_zifencei2p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
544PROC(SYNTACORE_SCR7, {"syntacore-scr7"}, {"rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_v1p0_zicsr2p0_zifencei2p0_zba1p0_zbb1p0_zbc1p0_zbs1p0_zkn1p0"}, 0, 0, 0x00000000, 0x0000000000000000, 0x0000000000000000)
545PROC(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)
546PROC(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)
547PROC(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)
548PROC(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)
549
550#undef PROC
551
552#ifndef TUNE_PROC
553#define TUNE_PROC(ENUM, NAME)
554#endif
555
556TUNE_PROC(ANDES_45, "andes-45-series")
557TUNE_PROC(GENERIC, "generic")
558TUNE_PROC(GENERIC_OOO, "generic-ooo")
559TUNE_PROC(ROCKET, "rocket")
560TUNE_PROC(SIFIVE_7, "sifive-7-series")
561
562#undef TUNE_PROC
563#ifdef GET_RISCVExtensionBitmaskTable_IMPL
564static const RISCVExtensionBitmask ExtensionBitmask[]={
565 {"a", 0, 0ULL},
566 {"b", 0, 1ULL},
567 {"c", 0, 2ULL},
568 {"d", 0, 3ULL},
569 {"e", 0, 4ULL},
570 {"f", 0, 5ULL},
571 {"h", 0, 7ULL},
572 {"i", 0, 8ULL},
573 {"m", 0, 12ULL},
574 {"q", 0, 16ULL},
575 {"v", 0, 21ULL},
576 {"zacas", 0, 26ULL},
577 {"zba", 0, 27ULL},
578 {"zbb", 0, 28ULL},
579 {"zbc", 0, 29ULL},
580 {"zbkb", 0, 30ULL},
581 {"zbkc", 0, 31ULL},
582 {"zbkx", 0, 32ULL},
583 {"zbs", 0, 33ULL},
584 {"zfa", 0, 34ULL},
585 {"zfh", 0, 35ULL},
586 {"zfhmin", 0, 36ULL},
587 {"zicboz", 0, 37ULL},
588 {"zicond", 0, 38ULL},
589 {"zihintntl", 0, 39ULL},
590 {"zihintpause", 0, 40ULL},
591 {"zknd", 0, 41ULL},
592 {"zkne", 0, 42ULL},
593 {"zknh", 0, 43ULL},
594 {"zksed", 0, 44ULL},
595 {"zksh", 0, 45ULL},
596 {"zkt", 0, 46ULL},
597 {"ztso", 0, 47ULL},
598 {"zvbb", 0, 48ULL},
599 {"zvbc", 0, 49ULL},
600 {"zvfh", 0, 50ULL},
601 {"zvfhmin", 0, 51ULL},
602 {"zvkb", 0, 52ULL},
603 {"zvkg", 0, 53ULL},
604 {"zvkned", 0, 54ULL},
605 {"zvknha", 0, 55ULL},
606 {"zvknhb", 0, 56ULL},
607 {"zvksed", 0, 57ULL},
608 {"zvksh", 0, 58ULL},
609 {"zvkt", 0, 59ULL},
610 {"zve32x", 0, 60ULL},
611 {"zve32f", 0, 61ULL},
612 {"zve64x", 0, 62ULL},
613 {"zve64f", 0, 63ULL},
614 {"zve64d", 1, 0ULL},
615 {"zimop", 1, 1ULL},
616 {"zca", 1, 2ULL},
617 {"zcb", 1, 3ULL},
618 {"zcd", 1, 4ULL},
619 {"zcf", 1, 5ULL},
620 {"zcmop", 1, 6ULL},
621 {"zawrs", 1, 7ULL},
622 {"zilsd", 1, 8ULL},
623 {"zclsd", 1, 9ULL},
624 {"zcmp", 1, 10ULL},
625};
626#endif
627
628#ifdef GET_TUNE_FEATURES
629#undef GET_TUNE_FEATURES
630
631
632#ifdef __GNUC__
633#pragma GCC diagnostic push
634#pragma GCC diagnostic ignored "-Woverlength-strings"
635#endif
636static constexpr char TuneFeatureStringsStorage[] =
637 "\0"
638 "conditional-cmv-fusion\0"
639 "no-conditional-cmv-fusion\0"
640 "disable-latency-sched-heuristic\0"
641 "enable-latency-sched-heuristic\0"
642 "disable-misched-load-clustering\0"
643 "enable-misched-load-clustering\0"
644 "disable-misched-store-clustering\0"
645 "enable-misched-store-clustering\0"
646 "disable-postmisched-load-clustering\0"
647 "enable-postmisched-load-clustering\0"
648 "disable-postmisched-store-clustering\0"
649 "enable-postmisched-store-clustering\0"
650 "single-element-vec-fp64\0"
651 "full-vec-fp64\0"
652 "no-default-unroll\0"
653 "enable-default-unroll\0"
654 "no-sink-splat-operands\0"
655 "sink-splat-operands\0"
656 "use-postra-scheduler\0"
657 "no-use-postra-scheduler\0"
658 "predictable-select-expensive\0"
659 "no-predictable-select-expensive\0"
660 "prefer-vsetvli-over-read-vlenb\0"
661 "no-prefer-vsetvli-over-read-vlenb\0"
662 "prefer-w-inst\0"
663 "no-prefer-w-inst\0"
664 "short-forward-branch-ialu\0"
665 "no-short-forward-branch-ialu\0"
666 "short-forward-branch-iload\0"
667 "no-short-forward-branch-iload\0"
668 "short-forward-branch-iminmax\0"
669 "no-short-forward-branch-iminmax\0"
670 "short-forward-branch-imul\0"
671 "no-short-forward-branch-imul\0"
672 "vl-dependent-latency\0"
673 "no-vl-dependent-latency\0"
674 "vxrm-pipeline-flush\0"
675 "no-vxrm-pipeline-flush\0"
676 ;
677#ifdef __GNUC__
678#pragma GCC diagnostic pop
679#endif
680
681static constexpr llvm::StringTable
682TuneFeatureStrings = TuneFeatureStringsStorage;
683
684static constexpr RISCVTuneFeature TuneFeatures[] = {
685 { 1, 24, 1 }, // 'conditional-cmv-fusion'
686 { 50, 82, 50 }, // 'disable-latency-sched-heuristic'
687 { 113, 145, 113 }, // 'disable-misched-load-clustering'
688 { 176, 209, 176 }, // 'disable-misched-store-clustering'
689 { 241, 277, 241 }, // 'disable-postmisched-load-clustering'
690 { 312, 349, 312 }, // 'disable-postmisched-store-clustering'
691 { 385, 409, 385 }, // 'single-element-vec-fp64'
692 { 423, 441, 423 }, // 'no-default-unroll'
693 { 463, 486, 463 }, // 'no-sink-splat-operands'
694 { 506, 527, 506 }, // 'use-postra-scheduler'
695 { 551, 580, 551 }, // 'predictable-select-expensive'
696 { 612, 643, 612 }, // 'prefer-vsetvli-over-read-vlenb'
697 { 677, 691, 677 }, // 'prefer-w-inst'
698 { 708, 734, 708 }, // 'short-forward-branch-ialu'
699 { 763, 790, 763 }, // 'short-forward-branch-iload'
700 { 820, 849, 820 }, // 'short-forward-branch-iminmax'
701 { 881, 907, 881 }, // 'short-forward-branch-imul'
702 { 936, 957, 936 }, // 'vl-dependent-latency'
703 { 981, 1001, 981 }, // 'vxrm-pipeline-flush'
704};
705
706static constexpr RISCVImpliedTuneFeature ImpliedTuneFeatures[] = {
707 { 763, 708 }, // 'short-forward-branch-iload' -> 'short-forward-branch-ialu'
708 { 820, 708 }, // 'short-forward-branch-iminmax' -> 'short-forward-branch-ialu'
709 { 881, 708 }, // 'short-forward-branch-imul' -> 'short-forward-branch-ialu'
710};
711
712#endif // GET_TUNE_FEATURES
713
714#ifdef GET_CONFIGURABLE_TUNE_FEATURES
715#undef GET_CONFIGURABLE_TUNE_FEATURES
716
717static constexpr RISCVConfigurableTuneFeatures ConfigurableTuneFeatures[] = {
718 { { "sifive-x280" }, 385 },
719 { { "sifive-x280" }, 409 },
720 { { "sifive-x390" }, 385 },
721 { { "sifive-x390" }, 409 },
722};
723
724#endif // GET_CONFIGURABLE_TUNE_FEATURES
725