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