1/*===- TableGen'erated file -------------------------------------*- C++ -*-===*\
2|* *|
3|* Assembly Writer Source Fragment *|
4|* *|
5|* Automatically generated file, do not edit! *|
6|* From: XCore.td *|
7|* *|
8\*===----------------------------------------------------------------------===*/
9
10/// getMnemonic - This method is automatically generated by tablegen
11/// from the instruction set description.
12std::pair<const char *, uint64_t>
13XCoreInstPrinter::getMnemonic(const MCInst &MI) const {
14
15#ifdef __GNUC__
16#pragma GCC diagnostic push
17#pragma GCC diagnostic ignored "-Woverlength-strings"
18#endif
19 static const char AsmStrs[] = {
20 /* 0 */ "ldap r11, \000"
21 /* 11 */ "getsr r11, \000"
22 /* 23 */ "set cp, \000"
23 /* 32 */ "set dp, \000"
24 /* 41 */ "set sp, \000"
25 /* 50 */ "crc32 \000"
26 /* 57 */ "lda16 \000"
27 /* 64 */ "st16 \000"
28 /* 70 */ "crc8 \000"
29 /* 76 */ "st8 \000"
30 /* 81 */ "# LDAWFI \000"
31 /* 91 */ "# LDWFI \000"
32 /* 100 */ "# STWFI \000"
33 /* 109 */ "# EH_RETURN \000"
34 /* 122 */ "# ADJCALLSTACKDOWN \000"
35 /* 142 */ "# ADJCALLSTACKUP \000"
36 /* 160 */ "# FRAME_TO_ARGS_OFFSET \000"
37 /* 184 */ "bla \000"
38 /* 189 */ "lsub \000"
39 /* 195 */ "ldc \000"
40 /* 200 */ "ladd \000"
41 /* 206 */ "and \000"
42 /* 211 */ "getd \000"
43 /* 217 */ "bf \000"
44 /* 221 */ "eef \000"
45 /* 226 */ "waitef \000"
46 /* 234 */ "ecallf \000"
47 /* 242 */ "neg \000"
48 /* 247 */ "dgetreg \000"
49 /* 256 */ "peek \000"
50 /* 262 */ "mkmsk \000"
51 /* 269 */ "bl \000"
52 /* 273 */ "testlcl \000"
53 /* 282 */ "shl \000"
54 /* 287 */ "kcall \000"
55 /* 294 */ "lmul \000"
56 /* 300 */ "endin \000"
57 /* 307 */ "getn \000"
58 /* 313 */ "extdp \000"
59 /* 320 */ "retsp \000"
60 /* 327 */ "kentsp \000"
61 /* 335 */ "krestsp \000"
62 /* 344 */ "extsp \000"
63 /* 351 */ "eq \000"
64 /* 355 */ "ashr \000"
65 /* 361 */ "inshr \000"
66 /* 368 */ "xor \000"
67 /* 373 */ "clrsr \000"
68 /* 380 */ "setsr \000"
69 /* 387 */ "getr \000"
70 /* 393 */ "ld16s \000"
71 /* 400 */ "maccs \000"
72 /* 407 */ "rems \000"
73 /* 413 */ "lss \000"
74 /* 418 */ "getts \000"
75 /* 425 */ "divs \000"
76 /* 431 */ "blat \000"
77 /* 437 */ "bt \000"
78 /* 441 */ "inct \000"
79 /* 447 */ "testct \000"
80 /* 455 */ "testwct \000"
81 /* 464 */ "eet \000"
82 /* 469 */ "get \000"
83 /* 474 */ "waitet \000"
84 /* 482 */ "ecallt \000"
85 /* 490 */ "int \000"
86 /* 495 */ "andnot \000"
87 /* 503 */ "getst \000"
88 /* 510 */ "sext \000"
89 /* 516 */ "zext \000"
90 /* 522 */ "ld8u \000"
91 /* 528 */ "bau \000"
92 /* 533 */ "bu \000"
93 /* 537 */ "maccu \000"
94 /* 544 */ "remu \000"
95 /* 550 */ "bru \000"
96 /* 555 */ "lsu \000"
97 /* 560 */ "ldivu \000"
98 /* 567 */ "byterev \000"
99 /* 576 */ "bitrev \000"
100 /* 584 */ "ldaw \000"
101 /* 590 */ "ldw \000"
102 /* 595 */ "inpw \000"
103 /* 601 */ "stw \000"
104 /* 606 */ "clz \000"
105 /* 611 */ "# SELECT_CC PSEUDO!\000"
106 /* 631 */ "# XRay Function Patchable RET.\000"
107 /* 662 */ "# XRay Typed Event Log.\000"
108 /* 686 */ "# XRay Custom Event Log.\000"
109 /* 711 */ "# XRay Function Enter.\000"
110 /* 734 */ "# XRay Tail Call Exit.\000"
111 /* 757 */ "# XRay Function Exit.\000"
112 /* 779 */ "set kep, r11\000"
113 /* 792 */ "LIFETIME_END\000"
114 /* 805 */ "PSEUDO_PROBE\000"
115 /* 818 */ "BUNDLE\000"
116 /* 825 */ "FAKE_USE\000"
117 /* 834 */ "DBG_VALUE\000"
118 /* 844 */ "DBG_INSTR_REF\000"
119 /* 858 */ "DBG_PHI\000"
120 /* 866 */ "DBG_LABEL\000"
121 /* 876 */ "LIFETIME_START\000"
122 /* 891 */ "DBG_VALUE_LIST\000"
123 /* 906 */ "ldaw r11, cp[\000"
124 /* 920 */ "ldw r11, cp[\000"
125 /* 933 */ "bla cp[\000"
126 /* 941 */ "msync res[\000"
127 /* 952 */ "setpsc res[\000"
128 /* 964 */ "setc res[\000"
129 /* 974 */ "setd res[\000"
130 /* 984 */ "setclk res[\000"
131 /* 996 */ "mjoin res[\000"
132 /* 1007 */ "setn res[\000"
133 /* 1017 */ "syncr res[\000"
134 /* 1028 */ "freer res[\000"
135 /* 1039 */ "outshr res[\000"
136 /* 1051 */ "chkct res[\000"
137 /* 1062 */ "outct res[\000"
138 /* 1073 */ "clrpt res[\000"
139 /* 1084 */ "setpt res[\000"
140 /* 1095 */ "outt res[\000"
141 /* 1105 */ "out res[\000"
142 /* 1114 */ "edu res[\000"
143 /* 1123 */ "eeu res[\000"
144 /* 1132 */ "setev res[\000"
145 /* 1143 */ "setv res[\000"
146 /* 1153 */ "outpw res[\000"
147 /* 1164 */ "settw res[\000"
148 /* 1175 */ "setrdy res[\000"
149 /* 1187 */ "set ps[\000"
150 /* 1195 */ "set t[\000"
151 /* 1202 */ "init t[\000"
152 /* 1210 */ "start t[\000"
153 /* 1219 */ "ldw spc, sp[1]\000"
154 /* 1234 */ "stw spc, sp[1]\000"
155 /* 1249 */ "ldw ssr, sp[2]\000"
156 /* 1264 */ "stw ssr, sp[2]\000"
157 /* 1279 */ "ldw sed, sp[3]\000"
158 /* 1294 */ "stw sed, sp[3]\000"
159 /* 1309 */ "ldw et, sp[4]\000"
160 /* 1323 */ "stw et, sp[4]\000"
161 /* 1337 */ "ssync\000"
162 /* 1343 */ "get r11, ed\000"
163 /* 1355 */ "get r11, id\000"
164 /* 1367 */ "clre\000"
165 /* 1372 */ "# FEntry call\000"
166 /* 1386 */ "dcall\000"
167 /* 1392 */ "get r11, kep\000"
168 /* 1405 */ "get r11, ksp\000"
169 /* 1418 */ "dentsp\000"
170 /* 1425 */ "drestsp\000"
171 /* 1433 */ "tsetmr r\000"
172 /* 1442 */ "get r11, et\000"
173 /* 1454 */ "freet\000"
174 /* 1460 */ "dret\000"
175 /* 1465 */ "kret\000"
176 /* 1470 */ "waiteu\000"
177};
178#ifdef __GNUC__
179#pragma GCC diagnostic pop
180#endif
181
182 static const uint32_t OpInfo0[] = {
183 0U, // PHI
184 0U, // INLINEASM
185 0U, // INLINEASM_BR
186 0U, // CFI_INSTRUCTION
187 0U, // EH_LABEL
188 0U, // GC_LABEL
189 0U, // ANNOTATION_LABEL
190 0U, // KILL
191 0U, // EXTRACT_SUBREG
192 0U, // INSERT_SUBREG
193 0U, // IMPLICIT_DEF
194 0U, // INIT_UNDEF
195 0U, // SUBREG_TO_REG
196 0U, // COPY_TO_REGCLASS
197 835U, // DBG_VALUE
198 892U, // DBG_VALUE_LIST
199 845U, // DBG_INSTR_REF
200 859U, // DBG_PHI
201 867U, // DBG_LABEL
202 0U, // REG_SEQUENCE
203 0U, // COPY
204 0U, // COPY_LANEMASK
205 819U, // BUNDLE
206 877U, // LIFETIME_START
207 793U, // LIFETIME_END
208 806U, // PSEUDO_PROBE
209 0U, // ARITH_FENCE
210 0U, // STACKMAP
211 1373U, // FENTRY_CALL
212 0U, // PATCHPOINT
213 0U, // LOAD_STACK_GUARD
214 0U, // PREALLOCATED_SETUP
215 0U, // PREALLOCATED_ARG
216 0U, // STATEPOINT
217 0U, // LOCAL_ESCAPE
218 0U, // FAULTING_OP
219 0U, // PATCHABLE_OP
220 712U, // PATCHABLE_FUNCTION_ENTER
221 632U, // PATCHABLE_RET
222 758U, // PATCHABLE_FUNCTION_EXIT
223 735U, // PATCHABLE_TAIL_CALL
224 687U, // PATCHABLE_EVENT_CALL
225 663U, // PATCHABLE_TYPED_EVENT_CALL
226 0U, // ICALL_BRANCH_FUNNEL
227 826U, // FAKE_USE
228 0U, // MEMBARRIER
229 0U, // JUMP_TABLE_DEBUG_INFO
230 0U, // RELOC_NONE
231 0U, // CONVERGENCECTRL_ENTRY
232 0U, // CONVERGENCECTRL_ANCHOR
233 0U, // CONVERGENCECTRL_LOOP
234 0U, // CONVERGENCECTRL_GLUE
235 0U, // G_ASSERT_SEXT
236 0U, // G_ASSERT_ZEXT
237 0U, // G_ASSERT_ALIGN
238 0U, // G_ADD
239 0U, // G_SUB
240 0U, // G_MUL
241 0U, // G_SDIV
242 0U, // G_UDIV
243 0U, // G_SREM
244 0U, // G_UREM
245 0U, // G_SDIVREM
246 0U, // G_UDIVREM
247 0U, // G_AND
248 0U, // G_OR
249 0U, // G_XOR
250 0U, // G_ABDS
251 0U, // G_ABDU
252 0U, // G_UAVGFLOOR
253 0U, // G_UAVGCEIL
254 0U, // G_SAVGFLOOR
255 0U, // G_SAVGCEIL
256 0U, // G_IMPLICIT_DEF
257 0U, // G_PHI
258 0U, // G_FRAME_INDEX
259 0U, // G_GLOBAL_VALUE
260 0U, // G_PTRAUTH_GLOBAL_VALUE
261 0U, // G_CONSTANT_POOL
262 0U, // G_EXTRACT
263 0U, // G_UNMERGE_VALUES
264 0U, // G_INSERT
265 0U, // G_MERGE_VALUES
266 0U, // G_BUILD_VECTOR
267 0U, // G_BUILD_VECTOR_TRUNC
268 0U, // G_CONCAT_VECTORS
269 0U, // G_PTRTOINT
270 0U, // G_INTTOPTR
271 0U, // G_BITCAST
272 0U, // G_FREEZE
273 0U, // G_CONSTANT_FOLD_BARRIER
274 0U, // G_INTRINSIC_FPTRUNC_ROUND
275 0U, // G_INTRINSIC_TRUNC
276 0U, // G_INTRINSIC_ROUND
277 0U, // G_INTRINSIC_LRINT
278 0U, // G_INTRINSIC_LLRINT
279 0U, // G_INTRINSIC_ROUNDEVEN
280 0U, // G_READCYCLECOUNTER
281 0U, // G_READSTEADYCOUNTER
282 0U, // G_LOAD
283 0U, // G_SEXTLOAD
284 0U, // G_ZEXTLOAD
285 0U, // G_FPEXTLOAD
286 0U, // G_INDEXED_LOAD
287 0U, // G_INDEXED_SEXTLOAD
288 0U, // G_INDEXED_ZEXTLOAD
289 0U, // G_STORE
290 0U, // G_FPTRUNCSTORE
291 0U, // G_INDEXED_STORE
292 0U, // G_ATOMIC_CMPXCHG_WITH_SUCCESS
293 0U, // G_ATOMIC_CMPXCHG
294 0U, // G_ATOMICRMW_XCHG
295 0U, // G_ATOMICRMW_ADD
296 0U, // G_ATOMICRMW_SUB
297 0U, // G_ATOMICRMW_AND
298 0U, // G_ATOMICRMW_NAND
299 0U, // G_ATOMICRMW_OR
300 0U, // G_ATOMICRMW_XOR
301 0U, // G_ATOMICRMW_MAX
302 0U, // G_ATOMICRMW_MIN
303 0U, // G_ATOMICRMW_UMAX
304 0U, // G_ATOMICRMW_UMIN
305 0U, // G_ATOMICRMW_FADD
306 0U, // G_ATOMICRMW_FSUB
307 0U, // G_ATOMICRMW_FMAX
308 0U, // G_ATOMICRMW_FMIN
309 0U, // G_ATOMICRMW_FMAXIMUM
310 0U, // G_ATOMICRMW_FMINIMUM
311 0U, // G_ATOMICRMW_FMAXIMUMNUM
312 0U, // G_ATOMICRMW_FMINIMUMNUM
313 0U, // G_ATOMICRMW_UINC_WRAP
314 0U, // G_ATOMICRMW_UDEC_WRAP
315 0U, // G_ATOMICRMW_USUB_COND
316 0U, // G_ATOMICRMW_USUB_SAT
317 0U, // G_FENCE
318 0U, // G_PREFETCH
319 0U, // G_BRCOND
320 0U, // G_BRINDIRECT
321 0U, // G_INVOKE_REGION_START
322 0U, // G_INTRINSIC
323 0U, // G_INTRINSIC_W_SIDE_EFFECTS
324 0U, // G_INTRINSIC_CONVERGENT
325 0U, // G_INTRINSIC_CONVERGENT_W_SIDE_EFFECTS
326 0U, // G_ANYEXT
327 0U, // G_TRUNC
328 0U, // G_TRUNC_SSAT_S
329 0U, // G_TRUNC_SSAT_U
330 0U, // G_TRUNC_USAT_U
331 0U, // G_CONSTANT
332 0U, // G_FCONSTANT
333 0U, // G_VASTART
334 0U, // G_VAARG
335 0U, // G_SEXT
336 0U, // G_SEXT_INREG
337 0U, // G_ZEXT
338 0U, // G_SHL
339 0U, // G_LSHR
340 0U, // G_ASHR
341 0U, // G_FSHL
342 0U, // G_FSHR
343 0U, // G_ROTR
344 0U, // G_ROTL
345 0U, // G_ICMP
346 0U, // G_FCMP
347 0U, // G_SCMP
348 0U, // G_UCMP
349 0U, // G_SELECT
350 0U, // G_UADDO
351 0U, // G_UADDE
352 0U, // G_USUBO
353 0U, // G_USUBE
354 0U, // G_SADDO
355 0U, // G_SADDE
356 0U, // G_SSUBO
357 0U, // G_SSUBE
358 0U, // G_UMULO
359 0U, // G_SMULO
360 0U, // G_UMULH
361 0U, // G_SMULH
362 0U, // G_UADDSAT
363 0U, // G_SADDSAT
364 0U, // G_USUBSAT
365 0U, // G_SSUBSAT
366 0U, // G_USHLSAT
367 0U, // G_SSHLSAT
368 0U, // G_SMULFIX
369 0U, // G_UMULFIX
370 0U, // G_SMULFIXSAT
371 0U, // G_UMULFIXSAT
372 0U, // G_SDIVFIX
373 0U, // G_UDIVFIX
374 0U, // G_SDIVFIXSAT
375 0U, // G_UDIVFIXSAT
376 0U, // G_FADD
377 0U, // G_FSUB
378 0U, // G_FMUL
379 0U, // G_FMA
380 0U, // G_FMAD
381 0U, // G_FDIV
382 0U, // G_FREM
383 0U, // G_FMODF
384 0U, // G_FPOW
385 0U, // G_FPOWI
386 0U, // G_FEXP
387 0U, // G_FEXP2
388 0U, // G_FEXP10
389 0U, // G_FLOG
390 0U, // G_FLOG2
391 0U, // G_FLOG10
392 0U, // G_FLDEXP
393 0U, // G_FFREXP
394 0U, // G_FNEG
395 0U, // G_FPEXT
396 0U, // G_FPTRUNC
397 0U, // G_FPTOSI
398 0U, // G_FPTOUI
399 0U, // G_SITOFP
400 0U, // G_UITOFP
401 0U, // G_FPTOSI_SAT
402 0U, // G_FPTOUI_SAT
403 0U, // G_FABS
404 0U, // G_FCOPYSIGN
405 0U, // G_IS_FPCLASS
406 0U, // G_FCANONICALIZE
407 0U, // G_FMINNUM
408 0U, // G_FMAXNUM
409 0U, // G_FMINNUM_IEEE
410 0U, // G_FMAXNUM_IEEE
411 0U, // G_FMINIMUM
412 0U, // G_FMAXIMUM
413 0U, // G_FMINIMUMNUM
414 0U, // G_FMAXIMUMNUM
415 0U, // G_GET_FPENV
416 0U, // G_SET_FPENV
417 0U, // G_RESET_FPENV
418 0U, // G_GET_FPMODE
419 0U, // G_SET_FPMODE
420 0U, // G_RESET_FPMODE
421 0U, // G_GET_ROUNDING
422 0U, // G_SET_ROUNDING
423 0U, // G_PTR_ADD
424 0U, // G_PTRMASK
425 0U, // G_SMIN
426 0U, // G_SMAX
427 0U, // G_UMIN
428 0U, // G_UMAX
429 0U, // G_ABS
430 0U, // G_LROUND
431 0U, // G_LLROUND
432 0U, // G_BR
433 0U, // G_BRJT
434 0U, // G_VSCALE
435 0U, // G_INSERT_SUBVECTOR
436 0U, // G_EXTRACT_SUBVECTOR
437 0U, // G_INSERT_VECTOR_ELT
438 0U, // G_EXTRACT_VECTOR_ELT
439 0U, // G_SHUFFLE_VECTOR
440 0U, // G_SPLAT_VECTOR
441 0U, // G_STEP_VECTOR
442 0U, // G_VECTOR_COMPRESS
443 0U, // G_CTTZ
444 0U, // G_CTTZ_ZERO_POISON
445 0U, // G_CTLZ
446 0U, // G_CTLZ_ZERO_POISON
447 0U, // G_CTLS
448 0U, // G_CTPOP
449 0U, // G_BSWAP
450 0U, // G_BITREVERSE
451 0U, // G_CLMUL
452 0U, // G_FCEIL
453 0U, // G_FCOS
454 0U, // G_FSIN
455 0U, // G_FSINCOS
456 0U, // G_FTAN
457 0U, // G_FACOS
458 0U, // G_FASIN
459 0U, // G_FATAN
460 0U, // G_FATAN2
461 0U, // G_FCOSH
462 0U, // G_FSINH
463 0U, // G_FTANH
464 0U, // G_FSQRT
465 0U, // G_FFLOOR
466 0U, // G_FRINT
467 0U, // G_FNEARBYINT
468 0U, // G_ADDRSPACE_CAST
469 0U, // G_BLOCK_ADDR
470 0U, // G_JUMP_TABLE
471 0U, // G_DYN_STACKALLOC
472 0U, // G_STACKSAVE
473 0U, // G_STACKRESTORE
474 0U, // G_STRICT_FADD
475 0U, // G_STRICT_FSUB
476 0U, // G_STRICT_FMUL
477 0U, // G_STRICT_FDIV
478 0U, // G_STRICT_FREM
479 0U, // G_STRICT_FMA
480 0U, // G_STRICT_FSQRT
481 0U, // G_STRICT_FLDEXP
482 0U, // G_STRICT_FCMP
483 0U, // G_STRICT_FCMPS
484 0U, // G_READ_REGISTER
485 0U, // G_WRITE_REGISTER
486 0U, // G_MEMCPY
487 0U, // G_MEMCPY_INLINE
488 0U, // G_MEMMOVE
489 0U, // G_MEMSET
490 0U, // G_BZERO
491 0U, // G_MEMSET_INLINE
492 0U, // G_TRAP
493 0U, // G_DEBUGTRAP
494 0U, // G_UBSANTRAP
495 0U, // G_VECREDUCE_SEQ_FADD
496 0U, // G_VECREDUCE_SEQ_FMUL
497 0U, // G_VECREDUCE_FADD
498 0U, // G_VECREDUCE_FMUL
499 0U, // G_VECREDUCE_FMAX
500 0U, // G_VECREDUCE_FMIN
501 0U, // G_VECREDUCE_FMAXIMUM
502 0U, // G_VECREDUCE_FMINIMUM
503 0U, // G_VECREDUCE_ADD
504 0U, // G_VECREDUCE_MUL
505 0U, // G_VECREDUCE_AND
506 0U, // G_VECREDUCE_OR
507 0U, // G_VECREDUCE_XOR
508 0U, // G_VECREDUCE_SMAX
509 0U, // G_VECREDUCE_SMIN
510 0U, // G_VECREDUCE_UMAX
511 0U, // G_VECREDUCE_UMIN
512 0U, // G_SBFX
513 0U, // G_UBFX
514 2171U, // ADJCALLSTACKDOWN
515 10383U, // ADJCALLSTACKUP
516 283175U, // BR_JT
517 545319U, // BR_JT32
518 2158U, // EH_RETURN
519 10401U, // FRAME_TO_ARGS_OFFSET
520 2130U, // LDAWFI
521 2140U, // LDWFI
522 612U, // SELECT_CC
523 2149U, // STWFI
524 2099402U, // ADD_2rus
525 2099402U, // ADD_3r
526 788976U, // ANDNOT_2r
527 2099407U, // AND_3r
528 2099556U, // ASHR_l2rus
529 2099556U, // ASHR_l3r
530 10769U, // BAU_1r
531 2625U, // BITREV_l2r
532 27558U, // BLACP_lu10
533 27558U, // BLACP_u10
534 10672U, // BLAT_lu6
535 10672U, // BLAT_u6
536 10425U, // BLA_1r
537 10510U, // BLRB_lu10
538 10510U, // BLRB_u10
539 10510U, // BLRF_lu10
540 10510U, // BLRF_u10
541 2266U, // BRBF_lru6
542 2266U, // BRBF_ru6
543 2486U, // BRBT_lru6
544 2486U, // BRBT_ru6
545 10774U, // BRBU_lu6
546 10774U, // BRBU_u6
547 2266U, // BRFF_lru6
548 2266U, // BRFF_ru6
549 2486U, // BRFT_lru6
550 2486U, // BRFT_ru6
551 10774U, // BRFU_lu6
552 10774U, // BRFU_u6
553 10791U, // BRU_1r
554 2616U, // BYTEREV_l2r
555 35868U, // CHKCT_2r
556 35868U, // CHKCT_rus
557 1368U, // CLRE_0R
558 27698U, // CLRPT_1R
559 10614U, // CLRSR_branch_lu6
560 10614U, // CLRSR_branch_u6
561 10614U, // CLRSR_lu6
562 10614U, // CLRSR_u6
563 2655U, // CLZ_l2r
564 5247047U, // CRC8_l4r
565 19662899U, // CRC_l3r
566 1387U, // DCALL_0R
567 1419U, // DENTSP_0R
568 10488U, // DGETREG_1r
569 2099626U, // DIVS_l3r
570 2099762U, // DIVU_l3r
571 1426U, // DRESTSP_0R
572 1461U, // DRET_0R
573 10475U, // ECALLF_1r
574 10723U, // ECALLT_1r
575 27739U, // EDU_1r
576 6334686U, // EEF_2r
577 6334929U, // EET_2r
578 27748U, // EEU_1r
579 6334765U, // ENDIN_2r
580 10569U, // ENTSP_lu6
581 10569U, // ENTSP_u6
582 2099552U, // EQ_2rus
583 2099552U, // EQ_3r
584 10554U, // EXTDP_lu6
585 10554U, // EXTDP_u6
586 10585U, // EXTSP_lu6
587 10585U, // EXTSP_u6
588 27653U, // FREER_1r
589 1455U, // FREET_0R
590 6334676U, // GETD_l2r
591 1344U, // GETED_0R
592 1443U, // GETET_0R
593 1356U, // GETID_0R
594 1393U, // GETKEP_0R
595 1406U, // GETKSP_0R
596 6334772U, // GETN_l2r
597 51670U, // GETPS_l2r
598 2436U, // GETR_rus
599 10252U, // GETSR_lu6
600 10252U, // GETSR_u6
601 6334968U, // GETST_2r
602 6334883U, // GETTS_2r
603 6334906U, // INCT_2r
604 62643U, // INITCP_2r
605 70835U, // INITDP_2r
606 79027U, // INITLR_l2r
607 87219U, // INITPC_2r
608 95411U, // INITSP_2r
609 8432212U, // INPW_l2rus
610 7121258U, // INSHR_2r
611 6334955U, // INT_2r
612 6334768U, // IN_2r
613 10528U, // KCALL_1r
614 10528U, // KCALL_lu6
615 10528U, // KCALL_u6
616 10568U, // KENTSP_lu6
617 10568U, // KENTSP_u6
618 10576U, // KRESTSP_lu6
619 10576U, // KRESTSP_u6
620 1466U, // KRET_0R
621 45093065U, // LADD_l5r
622 12585354U, // LD16S_3r
623 12585483U, // LD8U_3r
624 14682170U, // LDA16B_l3r
625 12585018U, // LDA16F_l3r
626 10241U, // LDAPB_lu10
627 10241U, // LDAPB_u10
628 10241U, // LDAPF_lu10
629 10241U, // LDAPF_lu10_ba
630 10241U, // LDAPF_u10
631 14682697U, // LDAWB_l2rus
632 14682697U, // LDAWB_l3r
633 27531U, // LDAWCP_lu6
634 27531U, // LDAWCP_u6
635 100937U, // LDAWDP_lru6
636 100937U, // LDAWDP_ru6
637 12585545U, // LDAWF_l2rus
638 12585545U, // LDAWF_l3r
639 109129U, // LDAWSP_lru6
640 109129U, // LDAWSP_ru6
641 2244U, // LDC_lru6
642 2244U, // LDC_ru6
643 1310U, // LDET_0R
644 186649137U, // LDIVU_l5r
645 1280U, // LDSED_0R
646 1220U, // LDSPC_0R
647 1250U, // LDSSR_0R
648 117327U, // LDWCP_lru6
649 27545U, // LDWCP_lu10
650 117327U, // LDWCP_ru6
651 27545U, // LDWCP_u10
652 100943U, // LDWDP_lru6
653 100943U, // LDWDP_ru6
654 109135U, // LDWSP_lru6
655 109135U, // LDWSP_ru6
656 12585551U, // LDW_2rus
657 12585551U, // LDW_3r
658 270534951U, // LMUL_l6r
659 2099614U, // LSS_3r
660 45093054U, // LSUB_l5r
661 2099756U, // LSU_3r
662 455084433U, // MACCS_l4r
663 455084570U, // MACCU_l4r
664 27621U, // MJOIN_1r
665 2311U, // MKMSK_2r
666 2311U, // MKMSK_rus
667 27566U, // MSYNC_1r
668 2099496U, // MUL_l3r
669 2291U, // NEG
670 2547U, // NOT
671 2099570U, // OR_3r
672 35879U, // OUTCT_2r
673 35879U, // OUTCT_rus
674 78681218U, // OUTPW_l2rus
675 39952U, // OUTSHR_2r
676 35912U, // OUTT_2r
677 35922U, // OUT_2r
678 6334721U, // PEEK_2r
679 2099608U, // REMS_l3r
680 2099745U, // REMU_l3r
681 10561U, // RETSP_lu6
682 10561U, // RETSP_u6
683 35801U, // SETCLK_l2r
684 10264U, // SETCP_1r
685 35781U, // SETC_l2r
686 35781U, // SETC_lru6
687 35781U, // SETC_ru6
688 10273U, // SETDP_1r
689 35791U, // SETD_2r
690 126061U, // SETEV_1r
691 780U, // SETKEP_0R
692 35824U, // SETN_l2r
693 35769U, // SETPSC_2r
694 36004U, // SETPS_l2r
695 35901U, // SETPT_2r
696 35992U, // SETRDY_l2r
697 10282U, // SETSP_1r
698 10621U, // SETSR_branch_lu6
699 10621U, // SETSR_branch_u6
700 10621U, // SETSR_lu6
701 10621U, // SETSR_u6
702 35981U, // SETTW_l2r
703 126072U, // SETV_1r
704 788991U, // SEXT_2r
705 788991U, // SEXT_rus
706 2099483U, // SHL_2rus
707 2099483U, // SHL_3r
708 2099557U, // SHR_2rus
709 2099557U, // SHR_3r
710 1338U, // SSYNC_0r
711 12585025U, // ST16_l3r
712 12585037U, // ST8_l3r
713 1324U, // STET_0R
714 1295U, // STSED_0R
715 1235U, // STSPC_0R
716 1265U, // STSSR_0R
717 100954U, // STWDP_lru6
718 100954U, // STWDP_ru6
719 109146U, // STWSP_lru6
720 109146U, // STWSP_ru6
721 12585562U, // STW_2rus
722 12585562U, // STW_l3r
723 2099391U, // SUB_2rus
724 2099391U, // SUB_3r
725 27642U, // SYNCR_1r
726 6334912U, // TESTCT_2r
727 6334738U, // TESTLCL_l2r
728 6334920U, // TESTWCT_2r
729 3482U, // TSETMR_2r
730 138412U, // TSETR_3r
731 27835U, // TSTART_1R
732 10467U, // WAITEF_1R
733 10715U, // WAITET_1R
734 1471U, // WAITEU_0R
735 2099569U, // XOR_l3r
736 788997U, // ZEXT_2r
737 788997U, // ZEXT_rus
738 };
739
740 // Emit the opcode for the instruction.
741 uint32_t Bits = 0;
742 Bits |= OpInfo0[MI.getOpcode()] << 0;
743 if (Bits == 0)
744 return {nullptr, Bits};
745 return {AsmStrs+(Bits & 2047)-1, Bits};
746
747}
748/// printInstruction - This method is automatically generated by tablegen
749/// from the instruction set description.
750LLVM_NO_PROFILE_INSTRUMENT_FUNCTION
751void XCoreInstPrinter::printInstruction(const MCInst *MI, uint64_t Address, raw_ostream &O) {
752 O << "\t";
753
754 auto MnemonicInfo = getMnemonic(MI: *MI);
755
756 O << MnemonicInfo.first;
757
758 uint32_t Bits = MnemonicInfo.second;
759 assert(Bits != 0 && "Cannot print this instruction.");
760
761 // Fragment 0 encoded into 2 bits for 4 unique commands.
762 switch ((Bits >> 11) & 3) {
763 default: llvm_unreachable("Invalid command number.");
764 case 0:
765 // DBG_VALUE, DBG_VALUE_LIST, DBG_INSTR_REF, DBG_PHI, DBG_LABEL, BUNDLE, ...
766 return;
767 break;
768 case 1:
769 // ADJCALLSTACKDOWN, ADJCALLSTACKUP, EH_RETURN, FRAME_TO_ARGS_OFFSET, LDA...
770 printOperand(MI, OpNo: 0, O);
771 break;
772 case 2:
773 // BR_JT, BR_JT32, CRC8_l4r, INITCP_2r, INITDP_2r, INITLR_l2r, INITPC_2r,...
774 printOperand(MI, OpNo: 1, O);
775 break;
776 case 3:
777 // OUTSHR_2r, TSETR_3r
778 printOperand(MI, OpNo: 2, O);
779 break;
780 }
781
782
783 // Fragment 1 encoded into 5 bits for 17 unique commands.
784 switch ((Bits >> 13) & 31) {
785 default: llvm_unreachable("Invalid command number.");
786 case 0:
787 // ADJCALLSTACKDOWN, EH_RETURN, LDAWFI, LDWFI, STWFI, ADD_2rus, ADD_3r, A...
788 O << ", ";
789 break;
790 case 1:
791 // ADJCALLSTACKUP, FRAME_TO_ARGS_OFFSET, BAU_1r, BLAT_lu6, BLAT_u6, BLA_1...
792 return;
793 break;
794 case 2:
795 // BR_JT, BR_JT32
796 O << "\n";
797 break;
798 case 3:
799 // BLACP_lu10, BLACP_u10, CLRPT_1R, EDU_1r, EEU_1r, FREER_1r, LDAWCP_lu6,...
800 O << ']';
801 return;
802 break;
803 case 4:
804 // CHKCT_2r, CHKCT_rus, OUTCT_2r, OUTCT_rus, OUTPW_l2rus, OUTSHR_2r, OUTT...
805 O << "], ";
806 break;
807 case 5:
808 // EEF_2r, EET_2r, ENDIN_2r, GETD_l2r, GETN_l2r, GETST_2r, GETTS_2r, INCT...
809 O << ", res[";
810 break;
811 case 6:
812 // GETPS_l2r
813 O << ", ps[";
814 printOperand(MI, OpNo: 1, O);
815 O << ']';
816 return;
817 break;
818 case 7:
819 // INITCP_2r
820 O << "]:cp, ";
821 printOperand(MI, OpNo: 0, O);
822 return;
823 break;
824 case 8:
825 // INITDP_2r
826 O << "]:dp, ";
827 printOperand(MI, OpNo: 0, O);
828 return;
829 break;
830 case 9:
831 // INITLR_l2r
832 O << "]:lr, ";
833 printOperand(MI, OpNo: 0, O);
834 return;
835 break;
836 case 10:
837 // INITPC_2r
838 O << "]:pc, ";
839 printOperand(MI, OpNo: 0, O);
840 return;
841 break;
842 case 11:
843 // INITSP_2r
844 O << "]:sp, ";
845 printOperand(MI, OpNo: 0, O);
846 return;
847 break;
848 case 12:
849 // LDAWDP_lru6, LDAWDP_ru6, LDWDP_lru6, LDWDP_ru6, STWDP_lru6, STWDP_ru6
850 O << ", dp[";
851 printOperand(MI, OpNo: 1, O);
852 O << ']';
853 return;
854 break;
855 case 13:
856 // LDAWSP_lru6, LDAWSP_ru6, LDWSP_lru6, LDWSP_ru6, STWSP_lru6, STWSP_ru6
857 O << ", sp[";
858 printOperand(MI, OpNo: 1, O);
859 O << ']';
860 return;
861 break;
862 case 14:
863 // LDWCP_lru6, LDWCP_ru6
864 O << ", cp[";
865 printOperand(MI, OpNo: 1, O);
866 O << ']';
867 return;
868 break;
869 case 15:
870 // SETEV_1r, SETV_1r
871 O << "], r11";
872 return;
873 break;
874 case 16:
875 // TSETR_3r
876 O << "]:r";
877 printOperand(MI, OpNo: 0, O);
878 O << ", ";
879 printOperand(MI, OpNo: 1, O);
880 return;
881 break;
882 }
883
884
885 // Fragment 2 encoded into 3 bits for 5 unique commands.
886 switch ((Bits >> 18) & 7) {
887 default: llvm_unreachable("Invalid command number.");
888 case 0:
889 // ADJCALLSTACKDOWN, EH_RETURN, LDAWFI, LDWFI, STWFI, ADD_2rus, ADD_3r, A...
890 printOperand(MI, OpNo: 1, O);
891 break;
892 case 1:
893 // BR_JT
894 printInlineJT(MI, opNum: 0, O);
895 return;
896 break;
897 case 2:
898 // BR_JT32
899 printInlineJT32(MI, opNum: 0, O);
900 return;
901 break;
902 case 3:
903 // ANDNOT_2r, CRC_l3r, INSHR_2r, SEXT_2r, SEXT_rus, ZEXT_2r, ZEXT_rus
904 printOperand(MI, OpNo: 2, O);
905 break;
906 case 4:
907 // CRC8_l4r, LADD_l5r, LSUB_l5r, OUTPW_l2rus
908 printOperand(MI, OpNo: 0, O);
909 O << ", ";
910 break;
911 }
912
913
914 // Fragment 3 encoded into 3 bits for 8 unique commands.
915 switch ((Bits >> 21) & 7) {
916 default: llvm_unreachable("Invalid command number.");
917 case 0:
918 // ADJCALLSTACKDOWN, EH_RETURN, LDAWFI, LDWFI, STWFI, ANDNOT_2r, BITREV_l...
919 return;
920 break;
921 case 1:
922 // ADD_2rus, ADD_3r, AND_3r, ASHR_l2rus, ASHR_l3r, CRC_l3r, DIVS_l3r, DIV...
923 O << ", ";
924 break;
925 case 2:
926 // CRC8_l4r
927 printOperand(MI, OpNo: 3, O);
928 O << ", ";
929 printOperand(MI, OpNo: 4, O);
930 return;
931 break;
932 case 3:
933 // EEF_2r, EET_2r, ENDIN_2r, GETD_l2r, GETN_l2r, GETST_2r, GETTS_2r, INCT...
934 O << ']';
935 return;
936 break;
937 case 4:
938 // INPW_l2rus
939 O << "], ";
940 printOperand(MI, OpNo: 2, O);
941 return;
942 break;
943 case 5:
944 // LADD_l5r, LSUB_l5r, OUTPW_l2rus
945 printOperand(MI, OpNo: 2, O);
946 break;
947 case 6:
948 // LD16S_3r, LD8U_3r, LDA16F_l3r, LDAWF_l2rus, LDAWF_l3r, LDW_2rus, LDW_3...
949 O << '[';
950 printOperand(MI, OpNo: 2, O);
951 O << ']';
952 return;
953 break;
954 case 7:
955 // LDA16B_l3r, LDAWB_l2rus, LDAWB_l3r
956 O << "[-";
957 printOperand(MI, OpNo: 2, O);
958 O << ']';
959 return;
960 break;
961 }
962
963
964 // Fragment 4 encoded into 3 bits for 5 unique commands.
965 switch ((Bits >> 24) & 7) {
966 default: llvm_unreachable("Invalid command number.");
967 case 0:
968 // ADD_2rus, ADD_3r, AND_3r, ASHR_l2rus, ASHR_l3r, DIVS_l3r, DIVU_l3r, EQ...
969 printOperand(MI, OpNo: 2, O);
970 break;
971 case 1:
972 // CRC_l3r
973 printOperand(MI, OpNo: 3, O);
974 return;
975 break;
976 case 2:
977 // LADD_l5r, LSUB_l5r
978 O << ", ";
979 printOperand(MI, OpNo: 3, O);
980 O << ", ";
981 printOperand(MI, OpNo: 4, O);
982 return;
983 break;
984 case 3:
985 // LDIVU_l5r, MACCS_l4r, MACCU_l4r
986 printOperand(MI, OpNo: 4, O);
987 O << ", ";
988 break;
989 case 4:
990 // OUTPW_l2rus
991 return;
992 break;
993 }
994
995
996 // Fragment 5 encoded into 2 bits for 4 unique commands.
997 switch ((Bits >> 27) & 3) {
998 default: llvm_unreachable("Invalid command number.");
999 case 0:
1000 // ADD_2rus, ADD_3r, AND_3r, ASHR_l2rus, ASHR_l3r, DIVS_l3r, DIVU_l3r, EQ...
1001 return;
1002 break;
1003 case 1:
1004 // LDIVU_l5r
1005 printOperand(MI, OpNo: 2, O);
1006 O << ", ";
1007 printOperand(MI, OpNo: 3, O);
1008 return;
1009 break;
1010 case 2:
1011 // LMUL_l6r
1012 O << ", ";
1013 printOperand(MI, OpNo: 3, O);
1014 O << ", ";
1015 printOperand(MI, OpNo: 4, O);
1016 O << ", ";
1017 printOperand(MI, OpNo: 5, O);
1018 return;
1019 break;
1020 case 3:
1021 // MACCS_l4r, MACCU_l4r
1022 printOperand(MI, OpNo: 5, O);
1023 return;
1024 break;
1025 }
1026
1027}
1028
1029
1030/// getRegisterName - This method is automatically generated by tblgen
1031/// from the register set description. This returns the assembler name
1032/// for the specified register.
1033const char *XCoreInstPrinter::getRegisterName(MCRegister Reg) {
1034 unsigned RegNo = Reg.id();
1035 assert(RegNo && RegNo < 17 && "Invalid register number!");
1036
1037
1038#ifdef __GNUC__
1039#pragma GCC diagnostic push
1040#pragma GCC diagnostic ignored "-Woverlength-strings"
1041#endif
1042 static const char AsmStrs[] = {
1043 /* 0 */ "r10\000"
1044 /* 4 */ "r0\000"
1045 /* 7 */ "r11\000"
1046 /* 11 */ "r1\000"
1047 /* 14 */ "r2\000"
1048 /* 17 */ "r3\000"
1049 /* 20 */ "r4\000"
1050 /* 23 */ "r5\000"
1051 /* 26 */ "r6\000"
1052 /* 29 */ "r7\000"
1053 /* 32 */ "r8\000"
1054 /* 35 */ "r9\000"
1055 /* 38 */ "cp\000"
1056 /* 41 */ "dp\000"
1057 /* 44 */ "sp\000"
1058 /* 47 */ "lr\000"
1059};
1060#ifdef __GNUC__
1061#pragma GCC diagnostic pop
1062#endif
1063
1064 static const uint8_t RegAsmOffset[] = {
1065 38, 41, 47, 44, 4, 11, 14, 17, 20, 23, 26, 29, 32, 35,
1066 0, 7,
1067 };
1068
1069 assert (*(AsmStrs+RegAsmOffset[RegNo-1]) &&
1070 "Invalid alt name index for register!");
1071 return AsmStrs+RegAsmOffset[RegNo-1];
1072}
1073
1074#ifdef PRINT_ALIAS_INSTR
1075#undef PRINT_ALIAS_INSTR
1076
1077bool XCoreInstPrinter::printAliasInstr(const MCInst *MI, uint64_t Address, raw_ostream &OS) {
1078 return false;
1079}
1080
1081#endif // PRINT_ALIAS_INSTR
1082