1#ifdef GET_SysRegsList_DECL 2const SysReg *lookupSysRegByEncoding(uint16_t Encoding); 3const SysReg *lookupSysRegByName(StringRef Name); 4#endif 5 6#ifdef GET_SysRegsList_IMPL 7constexpr SysReg SysRegsList[] = { 8 { "ustatus", 0x0, {} , false }, // 0 9 { "fflags", 0x1, {} , false }, // 1 10 { "frm", 0x2, {} , false }, // 2 11 { "fcsr", 0x3, {} , false }, // 3 12 { "uie", 0x4, {} , false }, // 4 13 { "utvec", 0x5, {} , false }, // 5 14 { "uscratch", 0x40, {} , false }, // 6 15 { "uepc", 0x41, {} , false }, // 7 16 { "ucause", 0x42, {} , false }, // 8 17 { "utval", 0x43, {} , false }, // 9 18 { "uip", 0x44, {} , false }, // 10 19 { "sstatus", 0x100, {} , false }, // 11 20 { "sedeleg", 0x102, {} , false }, // 12 21 { "sideleg", 0x103, {} , false }, // 13 22 { "sie", 0x104, {} , false }, // 14 23 { "stvec", 0x105, {} , false }, // 15 24 { "scounteren", 0x106, {} , false }, // 16 25 { "sscratch", 0x140, {} , false }, // 17 26 { "sepc", 0x141, {} , false }, // 18 27 { "scause", 0x142, {} , false }, // 19 28 { "stval", 0x143, {} , false }, // 20 29 { "sip", 0x144, {} , false }, // 21 30 { "satp", 0x180, {} , false }, // 22 31 { "mstatus", 0x300, {} , false }, // 23 32 { "misa", 0x301, {} , false }, // 24 33 { "medeleg", 0x302, {} , false }, // 25 34 { "mideleg", 0x303, {} , false }, // 26 35 { "mie", 0x304, {} , false }, // 27 36 { "mtvec", 0x305, {} , false }, // 28 37 { "mcounteren", 0x306, {} , false }, // 29 38 { "mhpmevent3", 0x323, {} , false }, // 30 39 { "mhpmevent4", 0x324, {} , false }, // 31 40 { "mhpmevent5", 0x325, {} , false }, // 32 41 { "mhpmevent6", 0x326, {} , false }, // 33 42 { "mhpmevent7", 0x327, {} , false }, // 34 43 { "mhpmevent8", 0x328, {} , false }, // 35 44 { "mhpmevent9", 0x329, {} , false }, // 36 45 { "mhpmevent10", 0x32A, {} , false }, // 37 46 { "mhpmevent11", 0x32B, {} , false }, // 38 47 { "mhpmevent12", 0x32C, {} , false }, // 39 48 { "mhpmevent13", 0x32D, {} , false }, // 40 49 { "mhpmevent14", 0x32E, {} , false }, // 41 50 { "mhpmevent15", 0x32F, {} , false }, // 42 51 { "mhpmevent16", 0x330, {} , false }, // 43 52 { "mhpmevent17", 0x331, {} , false }, // 44 53 { "mhpmevent18", 0x332, {} , false }, // 45 54 { "mhpmevent19", 0x333, {} , false }, // 46 55 { "mhpmevent20", 0x334, {} , false }, // 47 56 { "mhpmevent21", 0x335, {} , false }, // 48 57 { "mhpmevent22", 0x336, {} , false }, // 49 58 { "mhpmevent23", 0x337, {} , false }, // 50 59 { "mhpmevent24", 0x338, {} , false }, // 51 60 { "mhpmevent25", 0x339, {} , false }, // 52 61 { "mhpmevent26", 0x33A, {} , false }, // 53 62 { "mhpmevent27", 0x33B, {} , false }, // 54 63 { "mhpmevent28", 0x33C, {} , false }, // 55 64 { "mhpmevent29", 0x33D, {} , false }, // 56 65 { "mhpmevent30", 0x33E, {} , false }, // 57 66 { "mhpmevent31", 0x33F, {} , false }, // 58 67 { "mscratch", 0x340, {} , false }, // 59 68 { "mepc", 0x341, {} , false }, // 60 69 { "mcause", 0x342, {} , false }, // 61 70 { "mtval", 0x343, {} , false }, // 62 71 { "mip", 0x344, {} , false }, // 63 72 { "pmpcfg0", 0x3A0, {} , false }, // 64 73 { "pmpcfg1", 0x3A1, {} , true }, // 65 74 { "pmpcfg2", 0x3A2, {} , false }, // 66 75 { "pmpcfg3", 0x3A3, {} , true }, // 67 76 { "pmpaddr0", 0x3B0, {} , false }, // 68 77 { "pmpaddr1", 0x3B1, {} , false }, // 69 78 { "pmpaddr2", 0x3B2, {} , false }, // 70 79 { "pmpaddr3", 0x3B3, {} , false }, // 71 80 { "pmpaddr4", 0x3B4, {} , false }, // 72 81 { "pmpaddr5", 0x3B5, {} , false }, // 73 82 { "pmpaddr6", 0x3B6, {} , false }, // 74 83 { "pmpaddr7", 0x3B7, {} , false }, // 75 84 { "pmpaddr8", 0x3B8, {} , false }, // 76 85 { "pmpaddr9", 0x3B9, {} , false }, // 77 86 { "pmpaddr10", 0x3BA, {} , false }, // 78 87 { "pmpaddr11", 0x3BB, {} , false }, // 79 88 { "pmpaddr12", 0x3BC, {} , false }, // 80 89 { "pmpaddr13", 0x3BD, {} , false }, // 81 90 { "pmpaddr14", 0x3BE, {} , false }, // 82 91 { "pmpaddr15", 0x3BF, {} , false }, // 83 92 { "tselect", 0x7A0, {} , false }, // 84 93 { "tdata1", 0x7A1, {} , false }, // 85 94 { "tdata2", 0x7A2, {} , false }, // 86 95 { "tdata3", 0x7A3, {} , false }, // 87 96 { "dcsr", 0x7B0, {} , false }, // 88 97 { "dpc", 0x7B1, {} , false }, // 89 98 { "dscratch", 0x7B2, {} , false }, // 90 99 { "mcycle", 0xB00, {} , false }, // 91 100 { "minstret", 0xB02, {} , false }, // 92 101 { "mhpmcounter3", 0xB03, {} , false }, // 93 102 { "mhpmcounter4", 0xB04, {} , false }, // 94 103 { "mhpmcounter5", 0xB05, {} , false }, // 95 104 { "mhpmcounter6", 0xB06, {} , false }, // 96 105 { "mhpmcounter7", 0xB07, {} , false }, // 97 106 { "mhpmcounter8", 0xB08, {} , false }, // 98 107 { "mhpmcounter9", 0xB09, {} , false }, // 99 108 { "mhpmcounter10", 0xB0A, {} , false }, // 100 109 { "mhpmcounter11", 0xB0B, {} , false }, // 101 110 { "mhpmcounter12", 0xB0C, {} , false }, // 102 111 { "mhpmcounter13", 0xB0D, {} , false }, // 103 112 { "mhpmcounter14", 0xB0E, {} , false }, // 104 113 { "mhpmcounter15", 0xB0F, {} , false }, // 105 114 { "mhpmcounter16", 0xB10, {} , false }, // 106 115 { "mhpmcounter17", 0xB11, {} , false }, // 107 116 { "mhpmcounter18", 0xB12, {} , false }, // 108 117 { "mhpmcounter19", 0xB13, {} , false }, // 109 118 { "mhpmcounter20", 0xB14, {} , false }, // 110 119 { "mhpmcounter21", 0xB15, {} , false }, // 111 120 { "mhpmcounter22", 0xB16, {} , false }, // 112 121 { "mhpmcounter23", 0xB17, {} , false }, // 113 122 { "mhpmcounter24", 0xB18, {} , false }, // 114 123 { "mhpmcounter25", 0xB19, {} , false }, // 115 124 { "mhpmcounter26", 0xB1A, {} , false }, // 116 125 { "mhpmcounter27", 0xB1B, {} , false }, // 117 126 { "mhpmcounter28", 0xB1C, {} , false }, // 118 127 { "mhpmcounter29", 0xB1D, {} , false }, // 119 128 { "mhpmcounter30", 0xB1E, {} , false }, // 120 129 { "mhpmcounter31", 0xB1F, {} , false }, // 121 130 { "mcycleh", 0xB80, {} , true }, // 122 131 { "minstreth", 0xB82, {} , true }, // 123 132 { "mhpmcounter3h", 0xB83, {} , true }, // 124 133 { "mhpmcounter4h", 0xB84, {} , true }, // 125 134 { "mhpmcounter5h", 0xB85, {} , true }, // 126 135 { "mhpmcounter6h", 0xB86, {} , true }, // 127 136 { "mhpmcounter7h", 0xB87, {} , true }, // 128 137 { "mhpmcounter8h", 0xB88, {} , true }, // 129 138 { "mhpmcounter9h", 0xB89, {} , true }, // 130 139 { "mhpmcounter10h", 0xB8A, {} , true }, // 131 140 { "mhpmcounter11h", 0xB8B, {} , true }, // 132 141 { "mhpmcounter12h", 0xB8C, {} , true }, // 133 142 { "mhpmcounter13h", 0xB8D, {} , true }, // 134 143 { "mhpmcounter14h", 0xB8E, {} , true }, // 135 144 { "mhpmcounter15h", 0xB8F, {} , true }, // 136 145 { "mhpmcounter16h", 0xB90, {} , true }, // 137 146 { "mhpmcounter17h", 0xB91, {} , true }, // 138 147 { "mhpmcounter18h", 0xB92, {} , true }, // 139 148 { "mhpmcounter19h", 0xB93, {} , true }, // 140 149 { "mhpmcounter20h", 0xB94, {} , true }, // 141 150 { "mhpmcounter21h", 0xB95, {} , true }, // 142 151 { "mhpmcounter22h", 0xB96, {} , true }, // 143 152 { "mhpmcounter23h", 0xB97, {} , true }, // 144 153 { "mhpmcounter24h", 0xB98, {} , true }, // 145 154 { "mhpmcounter25h", 0xB99, {} , true }, // 146 155 { "mhpmcounter26h", 0xB9A, {} , true }, // 147 156 { "mhpmcounter27h", 0xB9B, {} , true }, // 148 157 { "mhpmcounter28h", 0xB9C, {} , true }, // 149 158 { "mhpmcounter29h", 0xB9D, {} , true }, // 150 159 { "mhpmcounter30h", 0xB9E, {} , true }, // 151 160 { "mhpmcounter31h", 0xB9F, {} , true }, // 152 161 { "cycle", 0xC00, {} , false }, // 153 162 { "time", 0xC01, {} , false }, // 154 163 { "instret", 0xC02, {} , false }, // 155 164 { "hpmcounter3", 0xC03, {} , false }, // 156 165 { "hpmcounter4", 0xC04, {} , false }, // 157 166 { "hpmcounter5", 0xC05, {} , false }, // 158 167 { "hpmcounter6", 0xC06, {} , false }, // 159 168 { "hpmcounter7", 0xC07, {} , false }, // 160 169 { "hpmcounter8", 0xC08, {} , false }, // 161 170 { "hpmcounter9", 0xC09, {} , false }, // 162 171 { "hpmcounter10", 0xC0A, {} , false }, // 163 172 { "hpmcounter11", 0xC0B, {} , false }, // 164 173 { "hpmcounter12", 0xC0C, {} , false }, // 165 174 { "hpmcounter13", 0xC0D, {} , false }, // 166 175 { "hpmcounter14", 0xC0E, {} , false }, // 167 176 { "hpmcounter15", 0xC0F, {} , false }, // 168 177 { "hpmcounter16", 0xC10, {} , false }, // 169 178 { "hpmcounter17", 0xC11, {} , false }, // 170 179 { "hpmcounter18", 0xC12, {} , false }, // 171 180 { "hpmcounter19", 0xC13, {} , false }, // 172 181 { "hpmcounter20", 0xC14, {} , false }, // 173 182 { "hpmcounter21", 0xC15, {} , false }, // 174 183 { "hpmcounter22", 0xC16, {} , false }, // 175 184 { "hpmcounter23", 0xC17, {} , false }, // 176 185 { "hpmcounter24", 0xC18, {} , false }, // 177 186 { "hpmcounter25", 0xC19, {} , false }, // 178 187 { "hpmcounter26", 0xC1A, {} , false }, // 179 188 { "hpmcounter27", 0xC1B, {} , false }, // 180 189 { "hpmcounter28", 0xC1C, {} , false }, // 181 190 { "hpmcounter29", 0xC1D, {} , false }, // 182 191 { "hpmcounter30", 0xC1E, {} , false }, // 183 192 { "hpmcounter31", 0xC1F, {} , false }, // 184 193 { "cycleh", 0xC80, {} , true }, // 185 194 { "timeh", 0xC81, {} , true }, // 186 195 { "instreth", 0xC82, {} , true }, // 187 196 { "hpmcounter3h", 0xC83, {} , true }, // 188 197 { "hpmcounter4h", 0xC84, {} , true }, // 189 198 { "hpmcounter5h", 0xC85, {} , true }, // 190 199 { "hpmcounter6h", 0xC86, {} , true }, // 191 200 { "hpmcounter7h", 0xC87, {} , true }, // 192 201 { "hpmcounter8h", 0xC88, {} , true }, // 193 202 { "hpmcounter9h", 0xC89, {} , true }, // 194 203 { "hpmcounter10h", 0xC8A, {} , true }, // 195 204 { "hpmcounter11h", 0xC8B, {} , true }, // 196 205 { "hpmcounter12h", 0xC8C, {} , true }, // 197 206 { "hpmcounter13h", 0xC8D, {} , true }, // 198 207 { "hpmcounter14h", 0xC8E, {} , true }, // 199 208 { "hpmcounter15h", 0xC8F, {} , true }, // 200 209 { "hpmcounter16h", 0xC90, {} , true }, // 201 210 { "hpmcounter17h", 0xC91, {} , true }, // 202 211 { "hpmcounter18h", 0xC92, {} , true }, // 203 212 { "hpmcounter19h", 0xC93, {} , true }, // 204 213 { "hpmcounter20h", 0xC94, {} , true }, // 205 214 { "hpmcounter21h", 0xC95, {} , true }, // 206 215 { "hpmcounter22h", 0xC96, {} , true }, // 207 216 { "hpmcounter23h", 0xC97, {} , true }, // 208 217 { "hpmcounter24h", 0xC98, {} , true }, // 209 218 { "hpmcounter25h", 0xC99, {} , true }, // 210 219 { "hpmcounter26h", 0xC9A, {} , true }, // 211 220 { "hpmcounter27h", 0xC9B, {} , true }, // 212 221 { "hpmcounter28h", 0xC9C, {} , true }, // 213 222 { "hpmcounter29h", 0xC9D, {} , true }, // 214 223 { "hpmcounter30h", 0xC9E, {} , true }, // 215 224 { "hpmcounter31h", 0xC9F, {} , true }, // 216 225 { "mvendorid", 0xF11, {} , false }, // 217 226 { "marchid", 0xF12, {} , false }, // 218 227 { "mimpid", 0xF13, {} , false }, // 219 228 { "mhartid", 0xF14, {} , false }, // 220 229 }; 230 231const SysReg *lookupSysRegByEncoding(uint16_t Encoding) { 232 struct KeyType { 233 uint16_t Encoding; 234 }; 235 KeyType Key = { Encoding }; 236 auto Table = makeArrayRef(SysRegsList); 237 auto Idx = std::lower_bound(Table.begin(), Table.end(), Key, 238 [](const SysReg &LHS, const KeyType &RHS) { 239 if (LHS.Encoding < RHS.Encoding) 240 return true; 241 if (LHS.Encoding > RHS.Encoding) 242 return false; 243 return false; 244 }); 245 246 if (Idx == Table.end() || 247 Key.Encoding != Idx->Encoding) 248 return nullptr; 249 return &*Idx; 250} 251 252const SysReg *lookupSysRegByName(StringRef Name) { 253 struct IndexType { 254 const char * Name; 255 unsigned _index; 256 }; 257 static const struct IndexType Index[] = { 258 { "CYCLE", 153 }, 259 { "CYCLEH", 185 }, 260 { "DCSR", 88 }, 261 { "DPC", 89 }, 262 { "DSCRATCH", 90 }, 263 { "FCSR", 3 }, 264 { "FFLAGS", 1 }, 265 { "FRM", 2 }, 266 { "HPMCOUNTER10", 163 }, 267 { "HPMCOUNTER10H", 195 }, 268 { "HPMCOUNTER11", 164 }, 269 { "HPMCOUNTER11H", 196 }, 270 { "HPMCOUNTER12", 165 }, 271 { "HPMCOUNTER12H", 197 }, 272 { "HPMCOUNTER13", 166 }, 273 { "HPMCOUNTER13H", 198 }, 274 { "HPMCOUNTER14", 167 }, 275 { "HPMCOUNTER14H", 199 }, 276 { "HPMCOUNTER15", 168 }, 277 { "HPMCOUNTER15H", 200 }, 278 { "HPMCOUNTER16", 169 }, 279 { "HPMCOUNTER16H", 201 }, 280 { "HPMCOUNTER17", 170 }, 281 { "HPMCOUNTER17H", 202 }, 282 { "HPMCOUNTER18", 171 }, 283 { "HPMCOUNTER18H", 203 }, 284 { "HPMCOUNTER19", 172 }, 285 { "HPMCOUNTER19H", 204 }, 286 { "HPMCOUNTER20", 173 }, 287 { "HPMCOUNTER20H", 205 }, 288 { "HPMCOUNTER21", 174 }, 289 { "HPMCOUNTER21H", 206 }, 290 { "HPMCOUNTER22", 175 }, 291 { "HPMCOUNTER22H", 207 }, 292 { "HPMCOUNTER23", 176 }, 293 { "HPMCOUNTER23H", 208 }, 294 { "HPMCOUNTER24", 177 }, 295 { "HPMCOUNTER24H", 209 }, 296 { "HPMCOUNTER25", 178 }, 297 { "HPMCOUNTER25H", 210 }, 298 { "HPMCOUNTER26", 179 }, 299 { "HPMCOUNTER26H", 211 }, 300 { "HPMCOUNTER27", 180 }, 301 { "HPMCOUNTER27H", 212 }, 302 { "HPMCOUNTER28", 181 }, 303 { "HPMCOUNTER28H", 213 }, 304 { "HPMCOUNTER29", 182 }, 305 { "HPMCOUNTER29H", 214 }, 306 { "HPMCOUNTER3", 156 }, 307 { "HPMCOUNTER30", 183 }, 308 { "HPMCOUNTER30H", 215 }, 309 { "HPMCOUNTER31", 184 }, 310 { "HPMCOUNTER31H", 216 }, 311 { "HPMCOUNTER3H", 188 }, 312 { "HPMCOUNTER4", 157 }, 313 { "HPMCOUNTER4H", 189 }, 314 { "HPMCOUNTER5", 158 }, 315 { "HPMCOUNTER5H", 190 }, 316 { "HPMCOUNTER6", 159 }, 317 { "HPMCOUNTER6H", 191 }, 318 { "HPMCOUNTER7", 160 }, 319 { "HPMCOUNTER7H", 192 }, 320 { "HPMCOUNTER8", 161 }, 321 { "HPMCOUNTER8H", 193 }, 322 { "HPMCOUNTER9", 162 }, 323 { "HPMCOUNTER9H", 194 }, 324 { "INSTRET", 155 }, 325 { "INSTRETH", 187 }, 326 { "MARCHID", 218 }, 327 { "MCAUSE", 61 }, 328 { "MCOUNTEREN", 29 }, 329 { "MCYCLE", 91 }, 330 { "MCYCLEH", 122 }, 331 { "MEDELEG", 25 }, 332 { "MEPC", 60 }, 333 { "MHARTID", 220 }, 334 { "MHPMCOUNTER10", 100 }, 335 { "MHPMCOUNTER10H", 131 }, 336 { "MHPMCOUNTER11", 101 }, 337 { "MHPMCOUNTER11H", 132 }, 338 { "MHPMCOUNTER12", 102 }, 339 { "MHPMCOUNTER12H", 133 }, 340 { "MHPMCOUNTER13", 103 }, 341 { "MHPMCOUNTER13H", 134 }, 342 { "MHPMCOUNTER14", 104 }, 343 { "MHPMCOUNTER14H", 135 }, 344 { "MHPMCOUNTER15", 105 }, 345 { "MHPMCOUNTER15H", 136 }, 346 { "MHPMCOUNTER16", 106 }, 347 { "MHPMCOUNTER16H", 137 }, 348 { "MHPMCOUNTER17", 107 }, 349 { "MHPMCOUNTER17H", 138 }, 350 { "MHPMCOUNTER18", 108 }, 351 { "MHPMCOUNTER18H", 139 }, 352 { "MHPMCOUNTER19", 109 }, 353 { "MHPMCOUNTER19H", 140 }, 354 { "MHPMCOUNTER20", 110 }, 355 { "MHPMCOUNTER20H", 141 }, 356 { "MHPMCOUNTER21", 111 }, 357 { "MHPMCOUNTER21H", 142 }, 358 { "MHPMCOUNTER22", 112 }, 359 { "MHPMCOUNTER22H", 143 }, 360 { "MHPMCOUNTER23", 113 }, 361 { "MHPMCOUNTER23H", 144 }, 362 { "MHPMCOUNTER24", 114 }, 363 { "MHPMCOUNTER24H", 145 }, 364 { "MHPMCOUNTER25", 115 }, 365 { "MHPMCOUNTER25H", 146 }, 366 { "MHPMCOUNTER26", 116 }, 367 { "MHPMCOUNTER26H", 147 }, 368 { "MHPMCOUNTER27", 117 }, 369 { "MHPMCOUNTER27H", 148 }, 370 { "MHPMCOUNTER28", 118 }, 371 { "MHPMCOUNTER28H", 149 }, 372 { "MHPMCOUNTER29", 119 }, 373 { "MHPMCOUNTER29H", 150 }, 374 { "MHPMCOUNTER3", 93 }, 375 { "MHPMCOUNTER30", 120 }, 376 { "MHPMCOUNTER30H", 151 }, 377 { "MHPMCOUNTER31", 121 }, 378 { "MHPMCOUNTER31H", 152 }, 379 { "MHPMCOUNTER3H", 124 }, 380 { "MHPMCOUNTER4", 94 }, 381 { "MHPMCOUNTER4H", 125 }, 382 { "MHPMCOUNTER5", 95 }, 383 { "MHPMCOUNTER5H", 126 }, 384 { "MHPMCOUNTER6", 96 }, 385 { "MHPMCOUNTER6H", 127 }, 386 { "MHPMCOUNTER7", 97 }, 387 { "MHPMCOUNTER7H", 128 }, 388 { "MHPMCOUNTER8", 98 }, 389 { "MHPMCOUNTER8H", 129 }, 390 { "MHPMCOUNTER9", 99 }, 391 { "MHPMCOUNTER9H", 130 }, 392 { "MHPMEVENT10", 37 }, 393 { "MHPMEVENT11", 38 }, 394 { "MHPMEVENT12", 39 }, 395 { "MHPMEVENT13", 40 }, 396 { "MHPMEVENT14", 41 }, 397 { "MHPMEVENT15", 42 }, 398 { "MHPMEVENT16", 43 }, 399 { "MHPMEVENT17", 44 }, 400 { "MHPMEVENT18", 45 }, 401 { "MHPMEVENT19", 46 }, 402 { "MHPMEVENT20", 47 }, 403 { "MHPMEVENT21", 48 }, 404 { "MHPMEVENT22", 49 }, 405 { "MHPMEVENT23", 50 }, 406 { "MHPMEVENT24", 51 }, 407 { "MHPMEVENT25", 52 }, 408 { "MHPMEVENT26", 53 }, 409 { "MHPMEVENT27", 54 }, 410 { "MHPMEVENT28", 55 }, 411 { "MHPMEVENT29", 56 }, 412 { "MHPMEVENT3", 30 }, 413 { "MHPMEVENT30", 57 }, 414 { "MHPMEVENT31", 58 }, 415 { "MHPMEVENT4", 31 }, 416 { "MHPMEVENT5", 32 }, 417 { "MHPMEVENT6", 33 }, 418 { "MHPMEVENT7", 34 }, 419 { "MHPMEVENT8", 35 }, 420 { "MHPMEVENT9", 36 }, 421 { "MIDELEG", 26 }, 422 { "MIE", 27 }, 423 { "MIMPID", 219 }, 424 { "MINSTRET", 92 }, 425 { "MINSTRETH", 123 }, 426 { "MIP", 63 }, 427 { "MISA", 24 }, 428 { "MSCRATCH", 59 }, 429 { "MSTATUS", 23 }, 430 { "MTVAL", 62 }, 431 { "MTVEC", 28 }, 432 { "MVENDORID", 217 }, 433 { "PMPADDR0", 68 }, 434 { "PMPADDR1", 69 }, 435 { "PMPADDR10", 78 }, 436 { "PMPADDR11", 79 }, 437 { "PMPADDR12", 80 }, 438 { "PMPADDR13", 81 }, 439 { "PMPADDR14", 82 }, 440 { "PMPADDR15", 83 }, 441 { "PMPADDR2", 70 }, 442 { "PMPADDR3", 71 }, 443 { "PMPADDR4", 72 }, 444 { "PMPADDR5", 73 }, 445 { "PMPADDR6", 74 }, 446 { "PMPADDR7", 75 }, 447 { "PMPADDR8", 76 }, 448 { "PMPADDR9", 77 }, 449 { "PMPCFG0", 64 }, 450 { "PMPCFG1", 65 }, 451 { "PMPCFG2", 66 }, 452 { "PMPCFG3", 67 }, 453 { "SATP", 22 }, 454 { "SCAUSE", 19 }, 455 { "SCOUNTEREN", 16 }, 456 { "SEDELEG", 12 }, 457 { "SEPC", 18 }, 458 { "SIDELEG", 13 }, 459 { "SIE", 14 }, 460 { "SIP", 21 }, 461 { "SSCRATCH", 17 }, 462 { "SSTATUS", 11 }, 463 { "STVAL", 20 }, 464 { "STVEC", 15 }, 465 { "TDATA1", 85 }, 466 { "TDATA2", 86 }, 467 { "TDATA3", 87 }, 468 { "TIME", 154 }, 469 { "TIMEH", 186 }, 470 { "TSELECT", 84 }, 471 { "UCAUSE", 8 }, 472 { "UEPC", 7 }, 473 { "UIE", 4 }, 474 { "UIP", 10 }, 475 { "USCRATCH", 6 }, 476 { "USTATUS", 0 }, 477 { "UTVAL", 9 }, 478 { "UTVEC", 5 }, 479 }; 480 481 struct KeyType { 482 std::string Name; 483 }; 484 KeyType Key = { Name.upper() }; 485 auto Table = makeArrayRef(Index); 486 auto Idx = std::lower_bound(Table.begin(), Table.end(), Key, 487 [](const IndexType &LHS, const KeyType &RHS) { 488 int CmpName = StringRef(LHS.Name).compare(RHS.Name); 489 if (CmpName < 0) return true; 490 if (CmpName > 0) return false; 491 return false; 492 }); 493 494 if (Idx == Table.end() || 495 Key.Name != Idx->Name) 496 return nullptr; 497 return &SysRegsList[Idx->_index]; 498} 499#endif 500 501#undef GET_SysRegsList_DECL 502#undef GET_SysRegsList_IMPL 503