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_INDEXED_LOAD
286 0U, // G_INDEXED_SEXTLOAD
287 0U, // G_INDEXED_ZEXTLOAD
288 0U, // G_STORE
289 0U, // G_INDEXED_STORE
290 0U, // G_ATOMIC_CMPXCHG_WITH_SUCCESS
291 0U, // G_ATOMIC_CMPXCHG
292 0U, // G_ATOMICRMW_XCHG
293 0U, // G_ATOMICRMW_ADD
294 0U, // G_ATOMICRMW_SUB
295 0U, // G_ATOMICRMW_AND
296 0U, // G_ATOMICRMW_NAND
297 0U, // G_ATOMICRMW_OR
298 0U, // G_ATOMICRMW_XOR
299 0U, // G_ATOMICRMW_MAX
300 0U, // G_ATOMICRMW_MIN
301 0U, // G_ATOMICRMW_UMAX
302 0U, // G_ATOMICRMW_UMIN
303 0U, // G_ATOMICRMW_FADD
304 0U, // G_ATOMICRMW_FSUB
305 0U, // G_ATOMICRMW_FMAX
306 0U, // G_ATOMICRMW_FMIN
307 0U, // G_ATOMICRMW_FMAXIMUM
308 0U, // G_ATOMICRMW_FMINIMUM
309 0U, // G_ATOMICRMW_UINC_WRAP
310 0U, // G_ATOMICRMW_UDEC_WRAP
311 0U, // G_ATOMICRMW_USUB_COND
312 0U, // G_ATOMICRMW_USUB_SAT
313 0U, // G_FENCE
314 0U, // G_PREFETCH
315 0U, // G_BRCOND
316 0U, // G_BRINDIRECT
317 0U, // G_INVOKE_REGION_START
318 0U, // G_INTRINSIC
319 0U, // G_INTRINSIC_W_SIDE_EFFECTS
320 0U, // G_INTRINSIC_CONVERGENT
321 0U, // G_INTRINSIC_CONVERGENT_W_SIDE_EFFECTS
322 0U, // G_ANYEXT
323 0U, // G_TRUNC
324 0U, // G_TRUNC_SSAT_S
325 0U, // G_TRUNC_SSAT_U
326 0U, // G_TRUNC_USAT_U
327 0U, // G_CONSTANT
328 0U, // G_FCONSTANT
329 0U, // G_VASTART
330 0U, // G_VAARG
331 0U, // G_SEXT
332 0U, // G_SEXT_INREG
333 0U, // G_ZEXT
334 0U, // G_SHL
335 0U, // G_LSHR
336 0U, // G_ASHR
337 0U, // G_FSHL
338 0U, // G_FSHR
339 0U, // G_ROTR
340 0U, // G_ROTL
341 0U, // G_ICMP
342 0U, // G_FCMP
343 0U, // G_SCMP
344 0U, // G_UCMP
345 0U, // G_SELECT
346 0U, // G_UADDO
347 0U, // G_UADDE
348 0U, // G_USUBO
349 0U, // G_USUBE
350 0U, // G_SADDO
351 0U, // G_SADDE
352 0U, // G_SSUBO
353 0U, // G_SSUBE
354 0U, // G_UMULO
355 0U, // G_SMULO
356 0U, // G_UMULH
357 0U, // G_SMULH
358 0U, // G_UADDSAT
359 0U, // G_SADDSAT
360 0U, // G_USUBSAT
361 0U, // G_SSUBSAT
362 0U, // G_USHLSAT
363 0U, // G_SSHLSAT
364 0U, // G_SMULFIX
365 0U, // G_UMULFIX
366 0U, // G_SMULFIXSAT
367 0U, // G_UMULFIXSAT
368 0U, // G_SDIVFIX
369 0U, // G_UDIVFIX
370 0U, // G_SDIVFIXSAT
371 0U, // G_UDIVFIXSAT
372 0U, // G_FADD
373 0U, // G_FSUB
374 0U, // G_FMUL
375 0U, // G_FMA
376 0U, // G_FMAD
377 0U, // G_FDIV
378 0U, // G_FREM
379 0U, // G_FMODF
380 0U, // G_FPOW
381 0U, // G_FPOWI
382 0U, // G_FEXP
383 0U, // G_FEXP2
384 0U, // G_FEXP10
385 0U, // G_FLOG
386 0U, // G_FLOG2
387 0U, // G_FLOG10
388 0U, // G_FLDEXP
389 0U, // G_FFREXP
390 0U, // G_FNEG
391 0U, // G_FPEXT
392 0U, // G_FPTRUNC
393 0U, // G_FPTOSI
394 0U, // G_FPTOUI
395 0U, // G_SITOFP
396 0U, // G_UITOFP
397 0U, // G_FPTOSI_SAT
398 0U, // G_FPTOUI_SAT
399 0U, // G_FABS
400 0U, // G_FCOPYSIGN
401 0U, // G_IS_FPCLASS
402 0U, // G_FCANONICALIZE
403 0U, // G_FMINNUM
404 0U, // G_FMAXNUM
405 0U, // G_FMINNUM_IEEE
406 0U, // G_FMAXNUM_IEEE
407 0U, // G_FMINIMUM
408 0U, // G_FMAXIMUM
409 0U, // G_FMINIMUMNUM
410 0U, // G_FMAXIMUMNUM
411 0U, // G_GET_FPENV
412 0U, // G_SET_FPENV
413 0U, // G_RESET_FPENV
414 0U, // G_GET_FPMODE
415 0U, // G_SET_FPMODE
416 0U, // G_RESET_FPMODE
417 0U, // G_GET_ROUNDING
418 0U, // G_SET_ROUNDING
419 0U, // G_PTR_ADD
420 0U, // G_PTRMASK
421 0U, // G_SMIN
422 0U, // G_SMAX
423 0U, // G_UMIN
424 0U, // G_UMAX
425 0U, // G_ABS
426 0U, // G_LROUND
427 0U, // G_LLROUND
428 0U, // G_BR
429 0U, // G_BRJT
430 0U, // G_VSCALE
431 0U, // G_INSERT_SUBVECTOR
432 0U, // G_EXTRACT_SUBVECTOR
433 0U, // G_INSERT_VECTOR_ELT
434 0U, // G_EXTRACT_VECTOR_ELT
435 0U, // G_SHUFFLE_VECTOR
436 0U, // G_SPLAT_VECTOR
437 0U, // G_STEP_VECTOR
438 0U, // G_VECTOR_COMPRESS
439 0U, // G_CTTZ
440 0U, // G_CTTZ_ZERO_UNDEF
441 0U, // G_CTLZ
442 0U, // G_CTLZ_ZERO_UNDEF
443 0U, // G_CTLS
444 0U, // G_CTPOP
445 0U, // G_BSWAP
446 0U, // G_BITREVERSE
447 0U, // G_FCEIL
448 0U, // G_FCOS
449 0U, // G_FSIN
450 0U, // G_FSINCOS
451 0U, // G_FTAN
452 0U, // G_FACOS
453 0U, // G_FASIN
454 0U, // G_FATAN
455 0U, // G_FATAN2
456 0U, // G_FCOSH
457 0U, // G_FSINH
458 0U, // G_FTANH
459 0U, // G_FSQRT
460 0U, // G_FFLOOR
461 0U, // G_FRINT
462 0U, // G_FNEARBYINT
463 0U, // G_ADDRSPACE_CAST
464 0U, // G_BLOCK_ADDR
465 0U, // G_JUMP_TABLE
466 0U, // G_DYN_STACKALLOC
467 0U, // G_STACKSAVE
468 0U, // G_STACKRESTORE
469 0U, // G_STRICT_FADD
470 0U, // G_STRICT_FSUB
471 0U, // G_STRICT_FMUL
472 0U, // G_STRICT_FDIV
473 0U, // G_STRICT_FREM
474 0U, // G_STRICT_FMA
475 0U, // G_STRICT_FSQRT
476 0U, // G_STRICT_FLDEXP
477 0U, // G_READ_REGISTER
478 0U, // G_WRITE_REGISTER
479 0U, // G_MEMCPY
480 0U, // G_MEMCPY_INLINE
481 0U, // G_MEMMOVE
482 0U, // G_MEMSET
483 0U, // G_BZERO
484 0U, // G_TRAP
485 0U, // G_DEBUGTRAP
486 0U, // G_UBSANTRAP
487 0U, // G_VECREDUCE_SEQ_FADD
488 0U, // G_VECREDUCE_SEQ_FMUL
489 0U, // G_VECREDUCE_FADD
490 0U, // G_VECREDUCE_FMUL
491 0U, // G_VECREDUCE_FMAX
492 0U, // G_VECREDUCE_FMIN
493 0U, // G_VECREDUCE_FMAXIMUM
494 0U, // G_VECREDUCE_FMINIMUM
495 0U, // G_VECREDUCE_ADD
496 0U, // G_VECREDUCE_MUL
497 0U, // G_VECREDUCE_AND
498 0U, // G_VECREDUCE_OR
499 0U, // G_VECREDUCE_XOR
500 0U, // G_VECREDUCE_SMAX
501 0U, // G_VECREDUCE_SMIN
502 0U, // G_VECREDUCE_UMAX
503 0U, // G_VECREDUCE_UMIN
504 0U, // G_SBFX
505 0U, // G_UBFX
506 2171U, // ADJCALLSTACKDOWN
507 10383U, // ADJCALLSTACKUP
508 283175U, // BR_JT
509 545319U, // BR_JT32
510 2158U, // EH_RETURN
511 10401U, // FRAME_TO_ARGS_OFFSET
512 2130U, // LDAWFI
513 2140U, // LDWFI
514 612U, // SELECT_CC
515 2149U, // STWFI
516 2099402U, // ADD_2rus
517 2099402U, // ADD_3r
518 788976U, // ANDNOT_2r
519 2099407U, // AND_3r
520 2099556U, // ASHR_l2rus
521 2099556U, // ASHR_l3r
522 10769U, // BAU_1r
523 2625U, // BITREV_l2r
524 27558U, // BLACP_lu10
525 27558U, // BLACP_u10
526 10672U, // BLAT_lu6
527 10672U, // BLAT_u6
528 10425U, // BLA_1r
529 10510U, // BLRB_lu10
530 10510U, // BLRB_u10
531 10510U, // BLRF_lu10
532 10510U, // BLRF_u10
533 2266U, // BRBF_lru6
534 2266U, // BRBF_ru6
535 2486U, // BRBT_lru6
536 2486U, // BRBT_ru6
537 10774U, // BRBU_lu6
538 10774U, // BRBU_u6
539 2266U, // BRFF_lru6
540 2266U, // BRFF_ru6
541 2486U, // BRFT_lru6
542 2486U, // BRFT_ru6
543 10774U, // BRFU_lu6
544 10774U, // BRFU_u6
545 10791U, // BRU_1r
546 2616U, // BYTEREV_l2r
547 35868U, // CHKCT_2r
548 35868U, // CHKCT_rus
549 1368U, // CLRE_0R
550 27698U, // CLRPT_1R
551 10614U, // CLRSR_branch_lu6
552 10614U, // CLRSR_branch_u6
553 10614U, // CLRSR_lu6
554 10614U, // CLRSR_u6
555 2655U, // CLZ_l2r
556 5247047U, // CRC8_l4r
557 19662899U, // CRC_l3r
558 1387U, // DCALL_0R
559 1419U, // DENTSP_0R
560 10488U, // DGETREG_1r
561 2099626U, // DIVS_l3r
562 2099762U, // DIVU_l3r
563 1426U, // DRESTSP_0R
564 1461U, // DRET_0R
565 10475U, // ECALLF_1r
566 10723U, // ECALLT_1r
567 27739U, // EDU_1r
568 6334686U, // EEF_2r
569 6334929U, // EET_2r
570 27748U, // EEU_1r
571 6334765U, // ENDIN_2r
572 10569U, // ENTSP_lu6
573 10569U, // ENTSP_u6
574 2099552U, // EQ_2rus
575 2099552U, // EQ_3r
576 10554U, // EXTDP_lu6
577 10554U, // EXTDP_u6
578 10585U, // EXTSP_lu6
579 10585U, // EXTSP_u6
580 27653U, // FREER_1r
581 1455U, // FREET_0R
582 6334676U, // GETD_l2r
583 1344U, // GETED_0R
584 1443U, // GETET_0R
585 1356U, // GETID_0R
586 1393U, // GETKEP_0R
587 1406U, // GETKSP_0R
588 6334772U, // GETN_l2r
589 51670U, // GETPS_l2r
590 2436U, // GETR_rus
591 10252U, // GETSR_lu6
592 10252U, // GETSR_u6
593 6334968U, // GETST_2r
594 6334883U, // GETTS_2r
595 6334906U, // INCT_2r
596 62643U, // INITCP_2r
597 70835U, // INITDP_2r
598 79027U, // INITLR_l2r
599 87219U, // INITPC_2r
600 95411U, // INITSP_2r
601 8432212U, // INPW_l2rus
602 7121258U, // INSHR_2r
603 6334955U, // INT_2r
604 6334768U, // IN_2r
605 10528U, // KCALL_1r
606 10528U, // KCALL_lu6
607 10528U, // KCALL_u6
608 10568U, // KENTSP_lu6
609 10568U, // KENTSP_u6
610 10576U, // KRESTSP_lu6
611 10576U, // KRESTSP_u6
612 1466U, // KRET_0R
613 45093065U, // LADD_l5r
614 12585354U, // LD16S_3r
615 12585483U, // LD8U_3r
616 14682170U, // LDA16B_l3r
617 12585018U, // LDA16F_l3r
618 10241U, // LDAPB_lu10
619 10241U, // LDAPB_u10
620 10241U, // LDAPF_lu10
621 10241U, // LDAPF_lu10_ba
622 10241U, // LDAPF_u10
623 14682697U, // LDAWB_l2rus
624 14682697U, // LDAWB_l3r
625 27531U, // LDAWCP_lu6
626 27531U, // LDAWCP_u6
627 100937U, // LDAWDP_lru6
628 100937U, // LDAWDP_ru6
629 12585545U, // LDAWF_l2rus
630 12585545U, // LDAWF_l3r
631 109129U, // LDAWSP_lru6
632 109129U, // LDAWSP_ru6
633 2244U, // LDC_lru6
634 2244U, // LDC_ru6
635 1310U, // LDET_0R
636 186649137U, // LDIVU_l5r
637 1280U, // LDSED_0R
638 1220U, // LDSPC_0R
639 1250U, // LDSSR_0R
640 117327U, // LDWCP_lru6
641 27545U, // LDWCP_lu10
642 117327U, // LDWCP_ru6
643 27545U, // LDWCP_u10
644 100943U, // LDWDP_lru6
645 100943U, // LDWDP_ru6
646 109135U, // LDWSP_lru6
647 109135U, // LDWSP_ru6
648 12585551U, // LDW_2rus
649 12585551U, // LDW_3r
650 270534951U, // LMUL_l6r
651 2099614U, // LSS_3r
652 45093054U, // LSUB_l5r
653 2099756U, // LSU_3r
654 455084433U, // MACCS_l4r
655 455084570U, // MACCU_l4r
656 27621U, // MJOIN_1r
657 2311U, // MKMSK_2r
658 2311U, // MKMSK_rus
659 27566U, // MSYNC_1r
660 2099496U, // MUL_l3r
661 2291U, // NEG
662 2547U, // NOT
663 2099570U, // OR_3r
664 35879U, // OUTCT_2r
665 35879U, // OUTCT_rus
666 78681218U, // OUTPW_l2rus
667 39952U, // OUTSHR_2r
668 35912U, // OUTT_2r
669 35922U, // OUT_2r
670 6334721U, // PEEK_2r
671 2099608U, // REMS_l3r
672 2099745U, // REMU_l3r
673 10561U, // RETSP_lu6
674 10561U, // RETSP_u6
675 35801U, // SETCLK_l2r
676 10264U, // SETCP_1r
677 35781U, // SETC_l2r
678 35781U, // SETC_lru6
679 35781U, // SETC_ru6
680 10273U, // SETDP_1r
681 35791U, // SETD_2r
682 126061U, // SETEV_1r
683 780U, // SETKEP_0R
684 35824U, // SETN_l2r
685 35769U, // SETPSC_2r
686 36004U, // SETPS_l2r
687 35901U, // SETPT_2r
688 35992U, // SETRDY_l2r
689 10282U, // SETSP_1r
690 10621U, // SETSR_branch_lu6
691 10621U, // SETSR_branch_u6
692 10621U, // SETSR_lu6
693 10621U, // SETSR_u6
694 35981U, // SETTW_l2r
695 126072U, // SETV_1r
696 788991U, // SEXT_2r
697 788991U, // SEXT_rus
698 2099483U, // SHL_2rus
699 2099483U, // SHL_3r
700 2099557U, // SHR_2rus
701 2099557U, // SHR_3r
702 1338U, // SSYNC_0r
703 12585025U, // ST16_l3r
704 12585037U, // ST8_l3r
705 1324U, // STET_0R
706 1295U, // STSED_0R
707 1235U, // STSPC_0R
708 1265U, // STSSR_0R
709 100954U, // STWDP_lru6
710 100954U, // STWDP_ru6
711 109146U, // STWSP_lru6
712 109146U, // STWSP_ru6
713 12585562U, // STW_2rus
714 12585562U, // STW_l3r
715 2099391U, // SUB_2rus
716 2099391U, // SUB_3r
717 27642U, // SYNCR_1r
718 6334912U, // TESTCT_2r
719 6334738U, // TESTLCL_l2r
720 6334920U, // TESTWCT_2r
721 3482U, // TSETMR_2r
722 138412U, // TSETR_3r
723 27835U, // TSTART_1R
724 10467U, // WAITEF_1R
725 10715U, // WAITET_1R
726 1471U, // WAITEU_0R
727 2099569U, // XOR_l3r
728 788997U, // ZEXT_2r
729 788997U, // ZEXT_rus
730 };
731
732 // Emit the opcode for the instruction.
733 uint32_t Bits = 0;
734 Bits |= OpInfo0[MI.getOpcode()] << 0;
735 if (Bits == 0)
736 return {nullptr, Bits};
737 return {AsmStrs+(Bits & 2047)-1, Bits};
738
739}
740/// printInstruction - This method is automatically generated by tablegen
741/// from the instruction set description.
742LLVM_NO_PROFILE_INSTRUMENT_FUNCTION
743void XCoreInstPrinter::printInstruction(const MCInst *MI, uint64_t Address, raw_ostream &O) {
744 O << "\t";
745
746 auto MnemonicInfo = getMnemonic(MI: *MI);
747
748 O << MnemonicInfo.first;
749
750 uint32_t Bits = MnemonicInfo.second;
751 assert(Bits != 0 && "Cannot print this instruction.");
752
753 // Fragment 0 encoded into 2 bits for 4 unique commands.
754 switch ((Bits >> 11) & 3) {
755 default: llvm_unreachable("Invalid command number.");
756 case 0:
757 // DBG_VALUE, DBG_VALUE_LIST, DBG_INSTR_REF, DBG_PHI, DBG_LABEL, BUNDLE, ...
758 return;
759 break;
760 case 1:
761 // ADJCALLSTACKDOWN, ADJCALLSTACKUP, EH_RETURN, FRAME_TO_ARGS_OFFSET, LDA...
762 printOperand(MI, OpNo: 0, O);
763 break;
764 case 2:
765 // BR_JT, BR_JT32, CRC8_l4r, INITCP_2r, INITDP_2r, INITLR_l2r, INITPC_2r,...
766 printOperand(MI, OpNo: 1, O);
767 break;
768 case 3:
769 // OUTSHR_2r, TSETR_3r
770 printOperand(MI, OpNo: 2, O);
771 break;
772 }
773
774
775 // Fragment 1 encoded into 5 bits for 17 unique commands.
776 switch ((Bits >> 13) & 31) {
777 default: llvm_unreachable("Invalid command number.");
778 case 0:
779 // ADJCALLSTACKDOWN, EH_RETURN, LDAWFI, LDWFI, STWFI, ADD_2rus, ADD_3r, A...
780 O << ", ";
781 break;
782 case 1:
783 // ADJCALLSTACKUP, FRAME_TO_ARGS_OFFSET, BAU_1r, BLAT_lu6, BLAT_u6, BLA_1...
784 return;
785 break;
786 case 2:
787 // BR_JT, BR_JT32
788 O << "\n";
789 break;
790 case 3:
791 // BLACP_lu10, BLACP_u10, CLRPT_1R, EDU_1r, EEU_1r, FREER_1r, LDAWCP_lu6,...
792 O << ']';
793 return;
794 break;
795 case 4:
796 // CHKCT_2r, CHKCT_rus, OUTCT_2r, OUTCT_rus, OUTPW_l2rus, OUTSHR_2r, OUTT...
797 O << "], ";
798 break;
799 case 5:
800 // EEF_2r, EET_2r, ENDIN_2r, GETD_l2r, GETN_l2r, GETST_2r, GETTS_2r, INCT...
801 O << ", res[";
802 break;
803 case 6:
804 // GETPS_l2r
805 O << ", ps[";
806 printOperand(MI, OpNo: 1, O);
807 O << ']';
808 return;
809 break;
810 case 7:
811 // INITCP_2r
812 O << "]:cp, ";
813 printOperand(MI, OpNo: 0, O);
814 return;
815 break;
816 case 8:
817 // INITDP_2r
818 O << "]:dp, ";
819 printOperand(MI, OpNo: 0, O);
820 return;
821 break;
822 case 9:
823 // INITLR_l2r
824 O << "]:lr, ";
825 printOperand(MI, OpNo: 0, O);
826 return;
827 break;
828 case 10:
829 // INITPC_2r
830 O << "]:pc, ";
831 printOperand(MI, OpNo: 0, O);
832 return;
833 break;
834 case 11:
835 // INITSP_2r
836 O << "]:sp, ";
837 printOperand(MI, OpNo: 0, O);
838 return;
839 break;
840 case 12:
841 // LDAWDP_lru6, LDAWDP_ru6, LDWDP_lru6, LDWDP_ru6, STWDP_lru6, STWDP_ru6
842 O << ", dp[";
843 printOperand(MI, OpNo: 1, O);
844 O << ']';
845 return;
846 break;
847 case 13:
848 // LDAWSP_lru6, LDAWSP_ru6, LDWSP_lru6, LDWSP_ru6, STWSP_lru6, STWSP_ru6
849 O << ", sp[";
850 printOperand(MI, OpNo: 1, O);
851 O << ']';
852 return;
853 break;
854 case 14:
855 // LDWCP_lru6, LDWCP_ru6
856 O << ", cp[";
857 printOperand(MI, OpNo: 1, O);
858 O << ']';
859 return;
860 break;
861 case 15:
862 // SETEV_1r, SETV_1r
863 O << "], r11";
864 return;
865 break;
866 case 16:
867 // TSETR_3r
868 O << "]:r";
869 printOperand(MI, OpNo: 0, O);
870 O << ", ";
871 printOperand(MI, OpNo: 1, O);
872 return;
873 break;
874 }
875
876
877 // Fragment 2 encoded into 3 bits for 5 unique commands.
878 switch ((Bits >> 18) & 7) {
879 default: llvm_unreachable("Invalid command number.");
880 case 0:
881 // ADJCALLSTACKDOWN, EH_RETURN, LDAWFI, LDWFI, STWFI, ADD_2rus, ADD_3r, A...
882 printOperand(MI, OpNo: 1, O);
883 break;
884 case 1:
885 // BR_JT
886 printInlineJT(MI, opNum: 0, O);
887 return;
888 break;
889 case 2:
890 // BR_JT32
891 printInlineJT32(MI, opNum: 0, O);
892 return;
893 break;
894 case 3:
895 // ANDNOT_2r, CRC_l3r, INSHR_2r, SEXT_2r, SEXT_rus, ZEXT_2r, ZEXT_rus
896 printOperand(MI, OpNo: 2, O);
897 break;
898 case 4:
899 // CRC8_l4r, LADD_l5r, LSUB_l5r, OUTPW_l2rus
900 printOperand(MI, OpNo: 0, O);
901 O << ", ";
902 break;
903 }
904
905
906 // Fragment 3 encoded into 3 bits for 8 unique commands.
907 switch ((Bits >> 21) & 7) {
908 default: llvm_unreachable("Invalid command number.");
909 case 0:
910 // ADJCALLSTACKDOWN, EH_RETURN, LDAWFI, LDWFI, STWFI, ANDNOT_2r, BITREV_l...
911 return;
912 break;
913 case 1:
914 // ADD_2rus, ADD_3r, AND_3r, ASHR_l2rus, ASHR_l3r, CRC_l3r, DIVS_l3r, DIV...
915 O << ", ";
916 break;
917 case 2:
918 // CRC8_l4r
919 printOperand(MI, OpNo: 3, O);
920 O << ", ";
921 printOperand(MI, OpNo: 4, O);
922 return;
923 break;
924 case 3:
925 // EEF_2r, EET_2r, ENDIN_2r, GETD_l2r, GETN_l2r, GETST_2r, GETTS_2r, INCT...
926 O << ']';
927 return;
928 break;
929 case 4:
930 // INPW_l2rus
931 O << "], ";
932 printOperand(MI, OpNo: 2, O);
933 return;
934 break;
935 case 5:
936 // LADD_l5r, LSUB_l5r, OUTPW_l2rus
937 printOperand(MI, OpNo: 2, O);
938 break;
939 case 6:
940 // LD16S_3r, LD8U_3r, LDA16F_l3r, LDAWF_l2rus, LDAWF_l3r, LDW_2rus, LDW_3...
941 O << '[';
942 printOperand(MI, OpNo: 2, O);
943 O << ']';
944 return;
945 break;
946 case 7:
947 // LDA16B_l3r, LDAWB_l2rus, LDAWB_l3r
948 O << "[-";
949 printOperand(MI, OpNo: 2, O);
950 O << ']';
951 return;
952 break;
953 }
954
955
956 // Fragment 4 encoded into 3 bits for 5 unique commands.
957 switch ((Bits >> 24) & 7) {
958 default: llvm_unreachable("Invalid command number.");
959 case 0:
960 // ADD_2rus, ADD_3r, AND_3r, ASHR_l2rus, ASHR_l3r, DIVS_l3r, DIVU_l3r, EQ...
961 printOperand(MI, OpNo: 2, O);
962 break;
963 case 1:
964 // CRC_l3r
965 printOperand(MI, OpNo: 3, O);
966 return;
967 break;
968 case 2:
969 // LADD_l5r, LSUB_l5r
970 O << ", ";
971 printOperand(MI, OpNo: 3, O);
972 O << ", ";
973 printOperand(MI, OpNo: 4, O);
974 return;
975 break;
976 case 3:
977 // LDIVU_l5r, MACCS_l4r, MACCU_l4r
978 printOperand(MI, OpNo: 4, O);
979 O << ", ";
980 break;
981 case 4:
982 // OUTPW_l2rus
983 return;
984 break;
985 }
986
987
988 // Fragment 5 encoded into 2 bits for 4 unique commands.
989 switch ((Bits >> 27) & 3) {
990 default: llvm_unreachable("Invalid command number.");
991 case 0:
992 // ADD_2rus, ADD_3r, AND_3r, ASHR_l2rus, ASHR_l3r, DIVS_l3r, DIVU_l3r, EQ...
993 return;
994 break;
995 case 1:
996 // LDIVU_l5r
997 printOperand(MI, OpNo: 2, O);
998 O << ", ";
999 printOperand(MI, OpNo: 3, O);
1000 return;
1001 break;
1002 case 2:
1003 // LMUL_l6r
1004 O << ", ";
1005 printOperand(MI, OpNo: 3, O);
1006 O << ", ";
1007 printOperand(MI, OpNo: 4, O);
1008 O << ", ";
1009 printOperand(MI, OpNo: 5, O);
1010 return;
1011 break;
1012 case 3:
1013 // MACCS_l4r, MACCU_l4r
1014 printOperand(MI, OpNo: 5, O);
1015 return;
1016 break;
1017 }
1018
1019}
1020
1021
1022/// getRegisterName - This method is automatically generated by tblgen
1023/// from the register set description. This returns the assembler name
1024/// for the specified register.
1025const char *XCoreInstPrinter::getRegisterName(MCRegister Reg) {
1026 unsigned RegNo = Reg.id();
1027 assert(RegNo && RegNo < 17 && "Invalid register number!");
1028
1029
1030#ifdef __GNUC__
1031#pragma GCC diagnostic push
1032#pragma GCC diagnostic ignored "-Woverlength-strings"
1033#endif
1034 static const char AsmStrs[] = {
1035 /* 0 */ "r10\000"
1036 /* 4 */ "r0\000"
1037 /* 7 */ "r11\000"
1038 /* 11 */ "r1\000"
1039 /* 14 */ "r2\000"
1040 /* 17 */ "r3\000"
1041 /* 20 */ "r4\000"
1042 /* 23 */ "r5\000"
1043 /* 26 */ "r6\000"
1044 /* 29 */ "r7\000"
1045 /* 32 */ "r8\000"
1046 /* 35 */ "r9\000"
1047 /* 38 */ "cp\000"
1048 /* 41 */ "dp\000"
1049 /* 44 */ "sp\000"
1050 /* 47 */ "lr\000"
1051};
1052#ifdef __GNUC__
1053#pragma GCC diagnostic pop
1054#endif
1055
1056 static const uint8_t RegAsmOffset[] = {
1057 38, 41, 47, 44, 4, 11, 14, 17, 20, 23, 26, 29, 32, 35,
1058 0, 7,
1059 };
1060
1061 assert (*(AsmStrs+RegAsmOffset[RegNo-1]) &&
1062 "Invalid alt name index for register!");
1063 return AsmStrs+RegAsmOffset[RegNo-1];
1064}
1065
1066#ifdef PRINT_ALIAS_INSTR
1067#undef PRINT_ALIAS_INSTR
1068
1069bool XCoreInstPrinter::printAliasInstr(const MCInst *MI, uint64_t Address, raw_ostream &OS) {
1070 return false;
1071}
1072
1073#endif // PRINT_ALIAS_INSTR
1074