Lines Matching full:x86

1 //===-- X86InstrInfo.cpp - X86 Instruction Information --------------------===//
9 // This file contains the X86 implementation of the TargetInstrInfo class.
14 #include "X86.h"
52 #define DEBUG_TYPE "x86-instr-info"
64 " fuse, but the X86 backend currently can't"),
86 : X86GenInstrInfo((STI.isTarget64BitLP64() ? X86::ADJCALLSTACKDOWN64 in X86InstrInfo()
87 : X86::ADJCALLSTACKDOWN32), in X86InstrInfo()
88 (STI.isTarget64BitLP64() ? X86::ADJCALLSTACKUP64 in X86InstrInfo()
89 : X86::ADJCALLSTACKUP32), in X86InstrInfo()
90 X86::CATCHRET, (STI.is64Bit() ? X86::RET64 : X86::RET32)), in X86InstrInfo()
109 case X86::GR8RegClassID: in getRegClass()
110 return &X86::GR8_NOREX2RegClass; in getRegClass()
111 case X86::GR16RegClassID: in getRegClass()
112 return &X86::GR16_NOREX2RegClass; in getRegClass()
113 case X86::GR32RegClassID: in getRegClass()
114 return &X86::GR32_NOREX2RegClass; in getRegClass()
115 case X86::GR64RegClassID: in getRegClass()
116 return &X86::GR64_NOREX2RegClass; in getRegClass()
117 case X86::GR32_NOSPRegClassID: in getRegClass()
118 return &X86::GR32_NOREX2_NOSPRegClass; in getRegClass()
119 case X86::GR64_NOSPRegClassID: in getRegClass()
120 return &X86::GR64_NOREX2_NOSPRegClass; in getRegClass()
130 case X86::MOVSX16rr8: in isCoalescableExtInstr()
131 case X86::MOVZX16rr8: in isCoalescableExtInstr()
132 case X86::MOVSX32rr8: in isCoalescableExtInstr()
133 case X86::MOVZX32rr8: in isCoalescableExtInstr()
134 case X86::MOVSX64rr8: in isCoalescableExtInstr()
140 case X86::MOVSX32rr16: in isCoalescableExtInstr()
141 case X86::MOVZX32rr16: in isCoalescableExtInstr()
142 case X86::MOVSX64rr16: in isCoalescableExtInstr()
143 case X86::MOVSX64rr32: { in isCoalescableExtInstr()
152 case X86::MOVSX16rr8: in isCoalescableExtInstr()
153 case X86::MOVZX16rr8: in isCoalescableExtInstr()
154 case X86::MOVSX32rr8: in isCoalescableExtInstr()
155 case X86::MOVZX32rr8: in isCoalescableExtInstr()
156 case X86::MOVSX64rr8: in isCoalescableExtInstr()
157 SubIdx = X86::sub_8bit; in isCoalescableExtInstr()
159 case X86::MOVSX32rr16: in isCoalescableExtInstr()
160 case X86::MOVZX32rr16: in isCoalescableExtInstr()
161 case X86::MOVSX64rr16: in isCoalescableExtInstr()
162 SubIdx = X86::sub_16bit; in isCoalescableExtInstr()
164 case X86::MOVSX64rr32: in isCoalescableExtInstr()
165 SubIdx = X86::sub_32bit; in isCoalescableExtInstr()
184 using namespace X86; in isDataInvariant()
185 // On x86 it is believed that imul is constant time w.r.t. the loaded data. in isDataInvariant()
192 // operations like popcnt, but are believed to be constant time on x86. in isDataInvariant()
247 // On x86 it is believed that imul is constant time w.r.t. the loaded data. in isDataInvariantLoad()
250 case X86::IMUL16rm: in isDataInvariantLoad()
251 case X86::IMUL16rmi: in isDataInvariantLoad()
252 case X86::IMUL32rm: in isDataInvariantLoad()
253 case X86::IMUL32rmi: in isDataInvariantLoad()
254 case X86::IMUL64rm: in isDataInvariantLoad()
255 case X86::IMUL64rmi32: in isDataInvariantLoad()
259 // operations like popcnt, but are believed to be constant time on x86. in isDataInvariantLoad()
261 case X86::BSF16rm: in isDataInvariantLoad()
262 case X86::BSF32rm: in isDataInvariantLoad()
263 case X86::BSF64rm: in isDataInvariantLoad()
264 case X86::BSR16rm: in isDataInvariantLoad()
265 case X86::BSR32rm: in isDataInvariantLoad()
266 case X86::BSR64rm: in isDataInvariantLoad()
267 case X86::LZCNT16rm: in isDataInvariantLoad()
268 case X86::LZCNT32rm: in isDataInvariantLoad()
269 case X86::LZCNT64rm: in isDataInvariantLoad()
270 case X86::POPCNT16rm: in isDataInvariantLoad()
271 case X86::POPCNT32rm: in isDataInvariantLoad()
272 case X86::POPCNT64rm: in isDataInvariantLoad()
273 case X86::TZCNT16rm: in isDataInvariantLoad()
274 case X86::TZCNT32rm: in isDataInvariantLoad()
275 case X86::TZCNT64rm: in isDataInvariantLoad()
280 case X86::BLCFILL32rm: in isDataInvariantLoad()
281 case X86::BLCFILL64rm: in isDataInvariantLoad()
282 case X86::BLCI32rm: in isDataInvariantLoad()
283 case X86::BLCI64rm: in isDataInvariantLoad()
284 case X86::BLCIC32rm: in isDataInvariantLoad()
285 case X86::BLCIC64rm: in isDataInvariantLoad()
286 case X86::BLCMSK32rm: in isDataInvariantLoad()
287 case X86::BLCMSK64rm: in isDataInvariantLoad()
288 case X86::BLCS32rm: in isDataInvariantLoad()
289 case X86::BLCS64rm: in isDataInvariantLoad()
290 case X86::BLSFILL32rm: in isDataInvariantLoad()
291 case X86::BLSFILL64rm: in isDataInvariantLoad()
292 case X86::BLSI32rm: in isDataInvariantLoad()
293 case X86::BLSI64rm: in isDataInvariantLoad()
294 case X86::BLSIC32rm: in isDataInvariantLoad()
295 case X86::BLSIC64rm: in isDataInvariantLoad()
296 case X86::BLSMSK32rm: in isDataInvariantLoad()
297 case X86::BLSMSK64rm: in isDataInvariantLoad()
298 case X86::BLSR32rm: in isDataInvariantLoad()
299 case X86::BLSR64rm: in isDataInvariantLoad()
300 case X86::TZMSK32rm: in isDataInvariantLoad()
301 case X86::TZMSK64rm: in isDataInvariantLoad()
305 case X86::BEXTR32rm: in isDataInvariantLoad()
306 case X86::BEXTR64rm: in isDataInvariantLoad()
307 case X86::BEXTRI32mi: in isDataInvariantLoad()
308 case X86::BEXTRI64mi: in isDataInvariantLoad()
309 case X86::BZHI32rm: in isDataInvariantLoad()
310 case X86::BZHI64rm: in isDataInvariantLoad()
313 case X86::ADC8rm: in isDataInvariantLoad()
314 case X86::ADC16rm: in isDataInvariantLoad()
315 case X86::ADC32rm: in isDataInvariantLoad()
316 case X86::ADC64rm: in isDataInvariantLoad()
317 case X86::ADD8rm: in isDataInvariantLoad()
318 case X86::ADD16rm: in isDataInvariantLoad()
319 case X86::ADD32rm: in isDataInvariantLoad()
320 case X86::ADD64rm: in isDataInvariantLoad()
321 case X86::AND8rm: in isDataInvariantLoad()
322 case X86::AND16rm: in isDataInvariantLoad()
323 case X86::AND32rm: in isDataInvariantLoad()
324 case X86::AND64rm: in isDataInvariantLoad()
325 case X86::ANDN32rm: in isDataInvariantLoad()
326 case X86::ANDN64rm: in isDataInvariantLoad()
327 case X86::OR8rm: in isDataInvariantLoad()
328 case X86::OR16rm: in isDataInvariantLoad()
329 case X86::OR32rm: in isDataInvariantLoad()
330 case X86::OR64rm: in isDataInvariantLoad()
331 case X86::SBB8rm: in isDataInvariantLoad()
332 case X86::SBB16rm: in isDataInvariantLoad()
333 case X86::SBB32rm: in isDataInvariantLoad()
334 case X86::SBB64rm: in isDataInvariantLoad()
335 case X86::SUB8rm: in isDataInvariantLoad()
336 case X86::SUB16rm: in isDataInvariantLoad()
337 case X86::SUB32rm: in isDataInvariantLoad()
338 case X86::SUB64rm: in isDataInvariantLoad()
339 case X86::XOR8rm: in isDataInvariantLoad()
340 case X86::XOR16rm: in isDataInvariantLoad()
341 case X86::XOR32rm: in isDataInvariantLoad()
342 case X86::XOR64rm: in isDataInvariantLoad()
345 // time on x86. Called out separately as this is among the most surprising in isDataInvariantLoad()
347 case X86::MULX32rm: in isDataInvariantLoad()
348 case X86::MULX64rm: in isDataInvariantLoad()
351 case X86::RORX32mi: in isDataInvariantLoad()
352 case X86::RORX64mi: in isDataInvariantLoad()
353 case X86::SARX32rm: in isDataInvariantLoad()
354 case X86::SARX64rm: in isDataInvariantLoad()
355 case X86::SHLX32rm: in isDataInvariantLoad()
356 case X86::SHLX64rm: in isDataInvariantLoad()
357 case X86::SHRX32rm: in isDataInvariantLoad()
358 case X86::SHRX64rm: in isDataInvariantLoad()
361 case X86::CVTTSD2SI64rm: in isDataInvariantLoad()
362 case X86::VCVTTSD2SI64rm: in isDataInvariantLoad()
363 case X86::VCVTTSD2SI64Zrm: in isDataInvariantLoad()
364 case X86::CVTTSD2SIrm: in isDataInvariantLoad()
365 case X86::VCVTTSD2SIrm: in isDataInvariantLoad()
366 case X86::VCVTTSD2SIZrm: in isDataInvariantLoad()
367 case X86::CVTTSS2SI64rm: in isDataInvariantLoad()
368 case X86::VCVTTSS2SI64rm: in isDataInvariantLoad()
369 case X86::VCVTTSS2SI64Zrm: in isDataInvariantLoad()
370 case X86::CVTTSS2SIrm: in isDataInvariantLoad()
371 case X86::VCVTTSS2SIrm: in isDataInvariantLoad()
372 case X86::VCVTTSS2SIZrm: in isDataInvariantLoad()
373 case X86::CVTSI2SDrm: in isDataInvariantLoad()
374 case X86::VCVTSI2SDrm: in isDataInvariantLoad()
375 case X86::VCVTSI2SDZrm: in isDataInvariantLoad()
376 case X86::CVTSI2SSrm: in isDataInvariantLoad()
377 case X86::VCVTSI2SSrm: in isDataInvariantLoad()
378 case X86::VCVTSI2SSZrm: in isDataInvariantLoad()
379 case X86::CVTSI642SDrm: in isDataInvariantLoad()
380 case X86::VCVTSI642SDrm: in isDataInvariantLoad()
381 case X86::VCVTSI642SDZrm: in isDataInvariantLoad()
382 case X86::CVTSI642SSrm: in isDataInvariantLoad()
383 case X86::VCVTSI642SSrm: in isDataInvariantLoad()
384 case X86::VCVTSI642SSZrm: in isDataInvariantLoad()
385 case X86::CVTSS2SDrm: in isDataInvariantLoad()
386 case X86::VCVTSS2SDrm: in isDataInvariantLoad()
387 case X86::VCVTSS2SDZrm: in isDataInvariantLoad()
388 case X86::CVTSD2SSrm: in isDataInvariantLoad()
389 case X86::VCVTSD2SSrm: in isDataInvariantLoad()
390 case X86::VCVTSD2SSZrm: in isDataInvariantLoad()
392 case X86::VCVTTSD2USI64Zrm: in isDataInvariantLoad()
393 case X86::VCVTTSD2USIZrm: in isDataInvariantLoad()
394 case X86::VCVTTSS2USI64Zrm: in isDataInvariantLoad()
395 case X86::VCVTTSS2USIZrm: in isDataInvariantLoad()
396 case X86::VCVTUSI2SDZrm: in isDataInvariantLoad()
397 case X86::VCVTUSI642SDZrm: in isDataInvariantLoad()
398 case X86::VCVTUSI2SSZrm: in isDataInvariantLoad()
399 case X86::VCVTUSI642SSZrm: in isDataInvariantLoad()
402 case X86::MOV8rm: in isDataInvariantLoad()
403 case X86::MOV8rm_NOREX: in isDataInvariantLoad()
404 case X86::MOV16rm: in isDataInvariantLoad()
405 case X86::MOV32rm: in isDataInvariantLoad()
406 case X86::MOV64rm: in isDataInvariantLoad()
407 case X86::MOVSX16rm8: in isDataInvariantLoad()
408 case X86::MOVSX32rm16: in isDataInvariantLoad()
409 case X86::MOVSX32rm8: in isDataInvariantLoad()
410 case X86::MOVSX32rm8_NOREX: in isDataInvariantLoad()
411 case X86::MOVSX64rm16: in isDataInvariantLoad()
412 case X86::MOVSX64rm32: in isDataInvariantLoad()
413 case X86::MOVSX64rm8: in isDataInvariantLoad()
414 case X86::MOVZX16rm8: in isDataInvariantLoad()
415 case X86::MOVZX32rm16: in isDataInvariantLoad()
416 case X86::MOVZX32rm8: in isDataInvariantLoad()
417 case X86::MOVZX32rm8_NOREX: in isDataInvariantLoad()
418 case X86::MOVZX64rm16: in isDataInvariantLoad()
419 case X86::MOVZX64rm8: in isDataInvariantLoad()
460 case X86::PUSH32r: in getSPAdjust()
461 case X86::PUSH32rmm: in getSPAdjust()
462 case X86::PUSH32rmr: in getSPAdjust()
463 case X86::PUSH32i: in getSPAdjust()
465 case X86::PUSH64r: in getSPAdjust()
466 case X86::PUSH64rmm: in getSPAdjust()
467 case X86::PUSH64rmr: in getSPAdjust()
468 case X86::PUSH64i32: in getSPAdjust()
477 if (MI.getOperand(Op + X86::AddrBaseReg).isFI() && in isFrameOperand()
478 MI.getOperand(Op + X86::AddrScaleAmt).isImm() && in isFrameOperand()
479 MI.getOperand(Op + X86::AddrIndexReg).isReg() && in isFrameOperand()
480 MI.getOperand(Op + X86::AddrDisp).isImm() && in isFrameOperand()
481 MI.getOperand(Op + X86::AddrScaleAmt).getImm() == 1 && in isFrameOperand()
482 MI.getOperand(Op + X86::AddrIndexReg).getReg() == 0 && in isFrameOperand()
483 MI.getOperand(Op + X86::AddrDisp).getImm() == 0) { in isFrameOperand()
484 FrameIndex = MI.getOperand(Op + X86::AddrBaseReg).getIndex(); in isFrameOperand()
494 case X86::MOV8rm: in isFrameLoadOpcode()
495 case X86::KMOVBkm: in isFrameLoadOpcode()
496 case X86::KMOVBkm_EVEX: in isFrameLoadOpcode()
499 case X86::MOV16rm: in isFrameLoadOpcode()
500 case X86::KMOVWkm: in isFrameLoadOpcode()
501 case X86::KMOVWkm_EVEX: in isFrameLoadOpcode()
502 case X86::VMOVSHZrm: in isFrameLoadOpcode()
503 case X86::VMOVSHZrm_alt: in isFrameLoadOpcode()
506 case X86::MOV32rm: in isFrameLoadOpcode()
507 case X86::MOVSSrm: in isFrameLoadOpcode()
508 case X86::MOVSSrm_alt: in isFrameLoadOpcode()
509 case X86::VMOVSSrm: in isFrameLoadOpcode()
510 case X86::VMOVSSrm_alt: in isFrameLoadOpcode()
511 case X86::VMOVSSZrm: in isFrameLoadOpcode()
512 case X86::VMOVSSZrm_alt: in isFrameLoadOpcode()
513 case X86::KMOVDkm: in isFrameLoadOpcode()
514 case X86::KMOVDkm_EVEX: in isFrameLoadOpcode()
517 case X86::MOV64rm: in isFrameLoadOpcode()
518 case X86::LD_Fp64m: in isFrameLoadOpcode()
519 case X86::MOVSDrm: in isFrameLoadOpcode()
520 case X86::MOVSDrm_alt: in isFrameLoadOpcode()
521 case X86::VMOVSDrm: in isFrameLoadOpcode()
522 case X86::VMOVSDrm_alt: in isFrameLoadOpcode()
523 case X86::VMOVSDZrm: in isFrameLoadOpcode()
524 case X86::VMOVSDZrm_alt: in isFrameLoadOpcode()
525 case X86::MMX_MOVD64rm: in isFrameLoadOpcode()
526 case X86::MMX_MOVQ64rm: in isFrameLoadOpcode()
527 case X86::KMOVQkm: in isFrameLoadOpcode()
528 case X86::KMOVQkm_EVEX: in isFrameLoadOpcode()
531 case X86::MOVAPSrm: in isFrameLoadOpcode()
532 case X86::MOVUPSrm: in isFrameLoadOpcode()
533 case X86::MOVAPDrm: in isFrameLoadOpcode()
534 case X86::MOVUPDrm: in isFrameLoadOpcode()
535 case X86::MOVDQArm: in isFrameLoadOpcode()
536 case X86::MOVDQUrm: in isFrameLoadOpcode()
537 case X86::VMOVAPSrm: in isFrameLoadOpcode()
538 case X86::VMOVUPSrm: in isFrameLoadOpcode()
539 case X86::VMOVAPDrm: in isFrameLoadOpcode()
540 case X86::VMOVUPDrm: in isFrameLoadOpcode()
541 case X86::VMOVDQArm: in isFrameLoadOpcode()
542 case X86::VMOVDQUrm: in isFrameLoadOpcode()
543 case X86::VMOVAPSZ128rm: in isFrameLoadOpcode()
544 case X86::VMOVUPSZ128rm: in isFrameLoadOpcode()
545 case X86::VMOVAPSZ128rm_NOVLX: in isFrameLoadOpcode()
546 case X86::VMOVUPSZ128rm_NOVLX: in isFrameLoadOpcode()
547 case X86::VMOVAPDZ128rm: in isFrameLoadOpcode()
548 case X86::VMOVUPDZ128rm: in isFrameLoadOpcode()
549 case X86::VMOVDQU8Z128rm: in isFrameLoadOpcode()
550 case X86::VMOVDQU16Z128rm: in isFrameLoadOpcode()
551 case X86::VMOVDQA32Z128rm: in isFrameLoadOpcode()
552 case X86::VMOVDQU32Z128rm: in isFrameLoadOpcode()
553 case X86::VMOVDQA64Z128rm: in isFrameLoadOpcode()
554 case X86::VMOVDQU64Z128rm: in isFrameLoadOpcode()
557 case X86::VMOVAPSYrm: in isFrameLoadOpcode()
558 case X86::VMOVUPSYrm: in isFrameLoadOpcode()
559 case X86::VMOVAPDYrm: in isFrameLoadOpcode()
560 case X86::VMOVUPDYrm: in isFrameLoadOpcode()
561 case X86::VMOVDQAYrm: in isFrameLoadOpcode()
562 case X86::VMOVDQUYrm: in isFrameLoadOpcode()
563 case X86::VMOVAPSZ256rm: in isFrameLoadOpcode()
564 case X86::VMOVUPSZ256rm: in isFrameLoadOpcode()
565 case X86::VMOVAPSZ256rm_NOVLX: in isFrameLoadOpcode()
566 case X86::VMOVUPSZ256rm_NOVLX: in isFrameLoadOpcode()
567 case X86::VMOVAPDZ256rm: in isFrameLoadOpcode()
568 case X86::VMOVUPDZ256rm: in isFrameLoadOpcode()
569 case X86::VMOVDQU8Z256rm: in isFrameLoadOpcode()
570 case X86::VMOVDQU16Z256rm: in isFrameLoadOpcode()
571 case X86::VMOVDQA32Z256rm: in isFrameLoadOpcode()
572 case X86::VMOVDQU32Z256rm: in isFrameLoadOpcode()
573 case X86::VMOVDQA64Z256rm: in isFrameLoadOpcode()
574 case X86::VMOVDQU64Z256rm: in isFrameLoadOpcode()
577 case X86::VMOVAPSZrm: in isFrameLoadOpcode()
578 case X86::VMOVUPSZrm: in isFrameLoadOpcode()
579 case X86::VMOVAPDZrm: in isFrameLoadOpcode()
580 case X86::VMOVUPDZrm: in isFrameLoadOpcode()
581 case X86::VMOVDQU8Zrm: in isFrameLoadOpcode()
582 case X86::VMOVDQU16Zrm: in isFrameLoadOpcode()
583 case X86::VMOVDQA32Zrm: in isFrameLoadOpcode()
584 case X86::VMOVDQU32Zrm: in isFrameLoadOpcode()
585 case X86::VMOVDQA64Zrm: in isFrameLoadOpcode()
586 case X86::VMOVDQU64Zrm: in isFrameLoadOpcode()
596 case X86::MOV8mr: in isFrameStoreOpcode()
597 case X86::KMOVBmk: in isFrameStoreOpcode()
598 case X86::KMOVBmk_EVEX: in isFrameStoreOpcode()
601 case X86::MOV16mr: in isFrameStoreOpcode()
602 case X86::KMOVWmk: in isFrameStoreOpcode()
603 case X86::KMOVWmk_EVEX: in isFrameStoreOpcode()
604 case X86::VMOVSHZmr: in isFrameStoreOpcode()
607 case X86::MOV32mr: in isFrameStoreOpcode()
608 case X86::MOVSSmr: in isFrameStoreOpcode()
609 case X86::VMOVSSmr: in isFrameStoreOpcode()
610 case X86::VMOVSSZmr: in isFrameStoreOpcode()
611 case X86::KMOVDmk: in isFrameStoreOpcode()
612 case X86::KMOVDmk_EVEX: in isFrameStoreOpcode()
615 case X86::MOV64mr: in isFrameStoreOpcode()
616 case X86::ST_FpP64m: in isFrameStoreOpcode()
617 case X86::MOVSDmr: in isFrameStoreOpcode()
618 case X86::VMOVSDmr: in isFrameStoreOpcode()
619 case X86::VMOVSDZmr: in isFrameStoreOpcode()
620 case X86::MMX_MOVD64mr: in isFrameStoreOpcode()
621 case X86::MMX_MOVQ64mr: in isFrameStoreOpcode()
622 case X86::MMX_MOVNTQmr: in isFrameStoreOpcode()
623 case X86::KMOVQmk: in isFrameStoreOpcode()
624 case X86::KMOVQmk_EVEX: in isFrameStoreOpcode()
627 case X86::MOVAPSmr: in isFrameStoreOpcode()
628 case X86::MOVUPSmr: in isFrameStoreOpcode()
629 case X86::MOVAPDmr: in isFrameStoreOpcode()
630 case X86::MOVUPDmr: in isFrameStoreOpcode()
631 case X86::MOVDQAmr: in isFrameStoreOpcode()
632 case X86::MOVDQUmr: in isFrameStoreOpcode()
633 case X86::VMOVAPSmr: in isFrameStoreOpcode()
634 case X86::VMOVUPSmr: in isFrameStoreOpcode()
635 case X86::VMOVAPDmr: in isFrameStoreOpcode()
636 case X86::VMOVUPDmr: in isFrameStoreOpcode()
637 case X86::VMOVDQAmr: in isFrameStoreOpcode()
638 case X86::VMOVDQUmr: in isFrameStoreOpcode()
639 case X86::VMOVUPSZ128mr: in isFrameStoreOpcode()
640 case X86::VMOVAPSZ128mr: in isFrameStoreOpcode()
641 case X86::VMOVUPSZ128mr_NOVLX: in isFrameStoreOpcode()
642 case X86::VMOVAPSZ128mr_NOVLX: in isFrameStoreOpcode()
643 case X86::VMOVUPDZ128mr: in isFrameStoreOpcode()
644 case X86::VMOVAPDZ128mr: in isFrameStoreOpcode()
645 case X86::VMOVDQA32Z128mr: in isFrameStoreOpcode()
646 case X86::VMOVDQU32Z128mr: in isFrameStoreOpcode()
647 case X86::VMOVDQA64Z128mr: in isFrameStoreOpcode()
648 case X86::VMOVDQU64Z128mr: in isFrameStoreOpcode()
649 case X86::VMOVDQU8Z128mr: in isFrameStoreOpcode()
650 case X86::VMOVDQU16Z128mr: in isFrameStoreOpcode()
653 case X86::VMOVUPSYmr: in isFrameStoreOpcode()
654 case X86::VMOVAPSYmr: in isFrameStoreOpcode()
655 case X86::VMOVUPDYmr: in isFrameStoreOpcode()
656 case X86::VMOVAPDYmr: in isFrameStoreOpcode()
657 case X86::VMOVDQUYmr: in isFrameStoreOpcode()
658 case X86::VMOVDQAYmr: in isFrameStoreOpcode()
659 case X86::VMOVUPSZ256mr: in isFrameStoreOpcode()
660 case X86::VMOVAPSZ256mr: in isFrameStoreOpcode()
661 case X86::VMOVUPSZ256mr_NOVLX: in isFrameStoreOpcode()
662 case X86::VMOVAPSZ256mr_NOVLX: in isFrameStoreOpcode()
663 case X86::VMOVUPDZ256mr: in isFrameStoreOpcode()
664 case X86::VMOVAPDZ256mr: in isFrameStoreOpcode()
665 case X86::VMOVDQU8Z256mr: in isFrameStoreOpcode()
666 case X86::VMOVDQU16Z256mr: in isFrameStoreOpcode()
667 case X86::VMOVDQA32Z256mr: in isFrameStoreOpcode()
668 case X86::VMOVDQU32Z256mr: in isFrameStoreOpcode()
669 case X86::VMOVDQA64Z256mr: in isFrameStoreOpcode()
670 case X86::VMOVDQU64Z256mr: in isFrameStoreOpcode()
673 case X86::VMOVUPSZmr: in isFrameStoreOpcode()
674 case X86::VMOVAPSZmr: in isFrameStoreOpcode()
675 case X86::VMOVUPDZmr: in isFrameStoreOpcode()
676 case X86::VMOVAPDZmr: in isFrameStoreOpcode()
677 case X86::VMOVDQU8Zmr: in isFrameStoreOpcode()
678 case X86::VMOVDQU16Zmr: in isFrameStoreOpcode()
679 case X86::VMOVDQA32Zmr: in isFrameStoreOpcode()
680 case X86::VMOVDQU32Zmr: in isFrameStoreOpcode()
681 case X86::VMOVDQA64Zmr: in isFrameStoreOpcode()
682 case X86::VMOVDQU64Zmr: in isFrameStoreOpcode()
733 if (MI.getOperand(X86::AddrNumOperands).getSubReg() == 0 && in isStoreToStackSlot()
735 return MI.getOperand(X86::AddrNumOperands).getReg(); in isStoreToStackSlot()
752 return MI.getOperand(X86::AddrNumOperands).getReg(); in isStoreToStackSlotPostFE()
758 /// Return true if register is PIC base; i.e.g defined by X86::MOVPC32r.
765 if (DefMI.getOpcode() != X86::MOVPC32r) in regIsPICBase()
781 case X86::IMPLICIT_DEF: in isReallyTriviallyReMaterializable()
784 case X86::LOAD_STACK_GUARD: in isReallyTriviallyReMaterializable()
785 case X86::LD_Fp032: in isReallyTriviallyReMaterializable()
786 case X86::LD_Fp064: in isReallyTriviallyReMaterializable()
787 case X86::LD_Fp080: in isReallyTriviallyReMaterializable()
788 case X86::LD_Fp132: in isReallyTriviallyReMaterializable()
789 case X86::LD_Fp164: in isReallyTriviallyReMaterializable()
790 case X86::LD_Fp180: in isReallyTriviallyReMaterializable()
791 case X86::AVX1_SETALLONES: in isReallyTriviallyReMaterializable()
792 case X86::AVX2_SETALLONES: in isReallyTriviallyReMaterializable()
793 case X86::AVX512_128_SET0: in isReallyTriviallyReMaterializable()
794 case X86::AVX512_256_SET0: in isReallyTriviallyReMaterializable()
795 case X86::AVX512_512_SET0: in isReallyTriviallyReMaterializable()
796 case X86::AVX512_512_SETALLONES: in isReallyTriviallyReMaterializable()
797 case X86::AVX512_FsFLD0SD: in isReallyTriviallyReMaterializable()
798 case X86::AVX512_FsFLD0SH: in isReallyTriviallyReMaterializable()
799 case X86::AVX512_FsFLD0SS: in isReallyTriviallyReMaterializable()
800 case X86::AVX512_FsFLD0F128: in isReallyTriviallyReMaterializable()
801 case X86::AVX_SET0: in isReallyTriviallyReMaterializable()
802 case X86::FsFLD0SD: in isReallyTriviallyReMaterializable()
803 case X86::FsFLD0SS: in isReallyTriviallyReMaterializable()
804 case X86::FsFLD0SH: in isReallyTriviallyReMaterializable()
805 case X86::FsFLD0F128: in isReallyTriviallyReMaterializable()
806 case X86::KSET0D: in isReallyTriviallyReMaterializable()
807 case X86::KSET0Q: in isReallyTriviallyReMaterializable()
808 case X86::KSET0W: in isReallyTriviallyReMaterializable()
809 case X86::KSET1D: in isReallyTriviallyReMaterializable()
810 case X86::KSET1Q: in isReallyTriviallyReMaterializable()
811 case X86::KSET1W: in isReallyTriviallyReMaterializable()
812 case X86::MMX_SET0: in isReallyTriviallyReMaterializable()
813 case X86::MOV32ImmSExti8: in isReallyTriviallyReMaterializable()
814 case X86::MOV32r0: in isReallyTriviallyReMaterializable()
815 case X86::MOV32r1: in isReallyTriviallyReMaterializable()
816 case X86::MOV32r_1: in isReallyTriviallyReMaterializable()
817 case X86::MOV32ri64: in isReallyTriviallyReMaterializable()
818 case X86::MOV64ImmSExti8: in isReallyTriviallyReMaterializable()
819 case X86::V_SET0: in isReallyTriviallyReMaterializable()
820 case X86::V_SETALLONES: in isReallyTriviallyReMaterializable()
821 case X86::MOV16ri: in isReallyTriviallyReMaterializable()
822 case X86::MOV32ri: in isReallyTriviallyReMaterializable()
823 case X86::MOV64ri: in isReallyTriviallyReMaterializable()
824 case X86::MOV64ri32: in isReallyTriviallyReMaterializable()
825 case X86::MOV8ri: in isReallyTriviallyReMaterializable()
826 case X86::PTILEZEROV: in isReallyTriviallyReMaterializable()
829 case X86::MOV8rm: in isReallyTriviallyReMaterializable()
830 case X86::MOV8rm_NOREX: in isReallyTriviallyReMaterializable()
831 case X86::MOV16rm: in isReallyTriviallyReMaterializable()
832 case X86::MOV32rm: in isReallyTriviallyReMaterializable()
833 case X86::MOV64rm: in isReallyTriviallyReMaterializable()
834 case X86::MOVSSrm: in isReallyTriviallyReMaterializable()
835 case X86::MOVSSrm_alt: in isReallyTriviallyReMaterializable()
836 case X86::MOVSDrm: in isReallyTriviallyReMaterializable()
837 case X86::MOVSDrm_alt: in isReallyTriviallyReMaterializable()
838 case X86::MOVAPSrm: in isReallyTriviallyReMaterializable()
839 case X86::MOVUPSrm: in isReallyTriviallyReMaterializable()
840 case X86::MOVAPDrm: in isReallyTriviallyReMaterializable()
841 case X86::MOVUPDrm: in isReallyTriviallyReMaterializable()
842 case X86::MOVDQArm: in isReallyTriviallyReMaterializable()
843 case X86::MOVDQUrm: in isReallyTriviallyReMaterializable()
844 case X86::VMOVSSrm: in isReallyTriviallyReMaterializable()
845 case X86::VMOVSSrm_alt: in isReallyTriviallyReMaterializable()
846 case X86::VMOVSDrm: in isReallyTriviallyReMaterializable()
847 case X86::VMOVSDrm_alt: in isReallyTriviallyReMaterializable()
848 case X86::VMOVAPSrm: in isReallyTriviallyReMaterializable()
849 case X86::VMOVUPSrm: in isReallyTriviallyReMaterializable()
850 case X86::VMOVAPDrm: in isReallyTriviallyReMaterializable()
851 case X86::VMOVUPDrm: in isReallyTriviallyReMaterializable()
852 case X86::VMOVDQArm: in isReallyTriviallyReMaterializable()
853 case X86::VMOVDQUrm: in isReallyTriviallyReMaterializable()
854 case X86::VMOVAPSYrm: in isReallyTriviallyReMaterializable()
855 case X86::VMOVUPSYrm: in isReallyTriviallyReMaterializable()
856 case X86::VMOVAPDYrm: in isReallyTriviallyReMaterializable()
857 case X86::VMOVUPDYrm: in isReallyTriviallyReMaterializable()
858 case X86::VMOVDQAYrm: in isReallyTriviallyReMaterializable()
859 case X86::VMOVDQUYrm: in isReallyTriviallyReMaterializable()
860 case X86::MMX_MOVD64rm: in isReallyTriviallyReMaterializable()
861 case X86::MMX_MOVQ64rm: in isReallyTriviallyReMaterializable()
862 case X86::VBROADCASTSSrm: in isReallyTriviallyReMaterializable()
863 case X86::VBROADCASTSSYrm: in isReallyTriviallyReMaterializable()
864 case X86::VBROADCASTSDYrm: in isReallyTriviallyReMaterializable()
866 case X86::VPBROADCASTBZ128rm: in isReallyTriviallyReMaterializable()
867 case X86::VPBROADCASTBZ256rm: in isReallyTriviallyReMaterializable()
868 case X86::VPBROADCASTBZrm: in isReallyTriviallyReMaterializable()
869 case X86::VBROADCASTF32X2Z256rm: in isReallyTriviallyReMaterializable()
870 case X86::VBROADCASTF32X2Zrm: in isReallyTriviallyReMaterializable()
871 case X86::VBROADCASTI32X2Z128rm: in isReallyTriviallyReMaterializable()
872 case X86::VBROADCASTI32X2Z256rm: in isReallyTriviallyReMaterializable()
873 case X86::VBROADCASTI32X2Zrm: in isReallyTriviallyReMaterializable()
874 case X86::VPBROADCASTWZ128rm: in isReallyTriviallyReMaterializable()
875 case X86::VPBROADCASTWZ256rm: in isReallyTriviallyReMaterializable()
876 case X86::VPBROADCASTWZrm: in isReallyTriviallyReMaterializable()
877 case X86::VPBROADCASTDZ128rm: in isReallyTriviallyReMaterializable()
878 case X86::VPBROADCASTDZ256rm: in isReallyTriviallyReMaterializable()
879 case X86::VPBROADCASTDZrm: in isReallyTriviallyReMaterializable()
880 case X86::VBROADCASTSSZ128rm: in isReallyTriviallyReMaterializable()
881 case X86::VBROADCASTSSZ256rm: in isReallyTriviallyReMaterializable()
882 case X86::VBROADCASTSSZrm: in isReallyTriviallyReMaterializable()
883 case X86::VPBROADCASTQZ128rm: in isReallyTriviallyReMaterializable()
884 case X86::VPBROADCASTQZ256rm: in isReallyTriviallyReMaterializable()
885 case X86::VPBROADCASTQZrm: in isReallyTriviallyReMaterializable()
886 case X86::VBROADCASTSDZ256rm: in isReallyTriviallyReMaterializable()
887 case X86::VBROADCASTSDZrm: in isReallyTriviallyReMaterializable()
888 case X86::VMOVSSZrm: in isReallyTriviallyReMaterializable()
889 case X86::VMOVSSZrm_alt: in isReallyTriviallyReMaterializable()
890 case X86::VMOVSDZrm: in isReallyTriviallyReMaterializable()
891 case X86::VMOVSDZrm_alt: in isReallyTriviallyReMaterializable()
892 case X86::VMOVSHZrm: in isReallyTriviallyReMaterializable()
893 case X86::VMOVSHZrm_alt: in isReallyTriviallyReMaterializable()
894 case X86::VMOVAPDZ128rm: in isReallyTriviallyReMaterializable()
895 case X86::VMOVAPDZ256rm: in isReallyTriviallyReMaterializable()
896 case X86::VMOVAPDZrm: in isReallyTriviallyReMaterializable()
897 case X86::VMOVAPSZ128rm: in isReallyTriviallyReMaterializable()
898 case X86::VMOVAPSZ256rm: in isReallyTriviallyReMaterializable()
899 case X86::VMOVAPSZ128rm_NOVLX: in isReallyTriviallyReMaterializable()
900 case X86::VMOVAPSZ256rm_NOVLX: in isReallyTriviallyReMaterializable()
901 case X86::VMOVAPSZrm: in isReallyTriviallyReMaterializable()
902 case X86::VMOVDQA32Z128rm: in isReallyTriviallyReMaterializable()
903 case X86::VMOVDQA32Z256rm: in isReallyTriviallyReMaterializable()
904 case X86::VMOVDQA32Zrm: in isReallyTriviallyReMaterializable()
905 case X86::VMOVDQA64Z128rm: in isReallyTriviallyReMaterializable()
906 case X86::VMOVDQA64Z256rm: in isReallyTriviallyReMaterializable()
907 case X86::VMOVDQA64Zrm: in isReallyTriviallyReMaterializable()
908 case X86::VMOVDQU16Z128rm: in isReallyTriviallyReMaterializable()
909 case X86::VMOVDQU16Z256rm: in isReallyTriviallyReMaterializable()
910 case X86::VMOVDQU16Zrm: in isReallyTriviallyReMaterializable()
911 case X86::VMOVDQU32Z128rm: in isReallyTriviallyReMaterializable()
912 case X86::VMOVDQU32Z256rm: in isReallyTriviallyReMaterializable()
913 case X86::VMOVDQU32Zrm: in isReallyTriviallyReMaterializable()
914 case X86::VMOVDQU64Z128rm: in isReallyTriviallyReMaterializable()
915 case X86::VMOVDQU64Z256rm: in isReallyTriviallyReMaterializable()
916 case X86::VMOVDQU64Zrm: in isReallyTriviallyReMaterializable()
917 case X86::VMOVDQU8Z128rm: in isReallyTriviallyReMaterializable()
918 case X86::VMOVDQU8Z256rm: in isReallyTriviallyReMaterializable()
919 case X86::VMOVDQU8Zrm: in isReallyTriviallyReMaterializable()
920 case X86::VMOVUPDZ128rm: in isReallyTriviallyReMaterializable()
921 case X86::VMOVUPDZ256rm: in isReallyTriviallyReMaterializable()
922 case X86::VMOVUPDZrm: in isReallyTriviallyReMaterializable()
923 case X86::VMOVUPSZ128rm: in isReallyTriviallyReMaterializable()
924 case X86::VMOVUPSZ256rm: in isReallyTriviallyReMaterializable()
925 case X86::VMOVUPSZ128rm_NOVLX: in isReallyTriviallyReMaterializable()
926 case X86::VMOVUPSZ256rm_NOVLX: in isReallyTriviallyReMaterializable()
927 case X86::VMOVUPSZrm: { in isReallyTriviallyReMaterializable()
929 if (MI.getOperand(1 + X86::AddrBaseReg).isReg() && in isReallyTriviallyReMaterializable()
930 MI.getOperand(1 + X86::AddrScaleAmt).isImm() && in isReallyTriviallyReMaterializable()
931 MI.getOperand(1 + X86::AddrIndexReg).isReg() && in isReallyTriviallyReMaterializable()
932 MI.getOperand(1 + X86::AddrIndexReg).getReg() == 0 && in isReallyTriviallyReMaterializable()
934 Register BaseReg = MI.getOperand(1 + X86::AddrBaseReg).getReg(); in isReallyTriviallyReMaterializable()
935 if (BaseReg == 0 || BaseReg == X86::RIP) in isReallyTriviallyReMaterializable()
938 if (!(!ReMatPICStubLoad && MI.getOperand(1 + X86::AddrDisp).isGlobal())) { in isReallyTriviallyReMaterializable()
948 case X86::LEA32r: in isReallyTriviallyReMaterializable()
949 case X86::LEA64r: { in isReallyTriviallyReMaterializable()
950 if (MI.getOperand(1 + X86::AddrScaleAmt).isImm() && in isReallyTriviallyReMaterializable()
951 MI.getOperand(1 + X86::AddrIndexReg).isReg() && in isReallyTriviallyReMaterializable()
952 MI.getOperand(1 + X86::AddrIndexReg).getReg() == 0 && in isReallyTriviallyReMaterializable()
953 !MI.getOperand(1 + X86::AddrDisp).isReg()) { in isReallyTriviallyReMaterializable()
955 if (!MI.getOperand(1 + X86::AddrBaseReg).isReg()) in isReallyTriviallyReMaterializable()
957 Register BaseReg = MI.getOperand(1 + X86::AddrBaseReg).getReg(); in isReallyTriviallyReMaterializable()
977 bool ClobbersEFLAGS = Orig.modifiesRegister(X86::EFLAGS, &TRI); in reMaterialize()
978 if (ClobbersEFLAGS && MBB.computeRegisterLiveness(&TRI, X86::EFLAGS, I) != in reMaterialize()
984 case X86::MOV32r0: in reMaterialize()
987 case X86::MOV32r1: in reMaterialize()
990 case X86::MOV32r_1: in reMaterialize()
998 BuildMI(MBB, I, DL, get(X86::MOV32ri)) in reMaterialize()
1013 if (MO.isReg() && MO.isDef() && MO.getReg() == X86::EFLAGS && in hasLiveCondCodeDef()
1047 if (!(CmpValDefInstr.getOpcode() == X86::SUBREG_TO_REG && in findRedundantFlagInstr()
1048 CmpInstr.getOpcode() == X86::TEST64rr) && in findRedundantFlagInstr()
1049 !(CmpValDefInstr.getOpcode() == X86::COPY && in findRedundantFlagInstr()
1050 CmpInstr.getOpcode() == X86::TEST16rr)) in findRedundantFlagInstr()
1070 if (CmpInstr.getOpcode() == X86::TEST16rr) { in findRedundantFlagInstr()
1079 if (!((VregDefInstr->getOpcode() == X86::AND32ri || in findRedundantFlagInstr()
1080 VregDefInstr->getOpcode() == X86::AND64ri32) && in findRedundantFlagInstr()
1085 if (CmpInstr.getOpcode() == X86::TEST64rr) { in findRedundantFlagInstr()
1086 // As seen in X86 td files, CmpValDefInstr.getOperand(1).getImm() is in findRedundantFlagInstr()
1091 // As seen in X86 td files, CmpValDefInstr.getOperand(3) is typically in findRedundantFlagInstr()
1093 if (CmpValDefInstr.getOperand(3).getImm() != X86::sub_32bit) in findRedundantFlagInstr()
1109 if (X86::isAND(VregDefInstr->getOpcode())) { in findRedundantFlagInstr()
1129 if (Instr.modifiesRegister(X86::EFLAGS, TRI)) in findRedundantFlagInstr()
1167 RC = Opc != X86::LEA32r ? &X86::GR64RegClass : &X86::GR32RegClass; in classifyLEAReg()
1169 RC = Opc != X86::LEA32r ? &X86::GR64_NOSPRegClass : &X86::GR32_NOSPRegClass; in classifyLEAReg()
1176 if (Opc != X86::LEA64_32r) { in classifyLEAReg()
1201 .addReg(NewSrc, RegState::Define | RegState::Undef, X86::sub_32bit) in classifyLEAReg()
1239 // Opcode = X86::LEA32r; in convertToThreeAddressWithLEA()
1240 // InRegLEA = RegInfo.createVirtualRegister(&X86::GR32_NOSPRegClass); in convertToThreeAddressWithLEA()
1242 // Is8BitOp ? RegInfo.createVirtualRegister(&X86::GR32ABCD_RegClass) in convertToThreeAddressWithLEA()
1243 // : RegInfo.createVirtualRegister(&X86::GR32RegClass); in convertToThreeAddressWithLEA()
1247 unsigned Opcode = X86::LEA64_32r; in convertToThreeAddressWithLEA()
1248 Register InRegLEA = RegInfo.createVirtualRegister(&X86::GR64_NOSPRegClass); in convertToThreeAddressWithLEA()
1249 Register OutRegLEA = RegInfo.createVirtualRegister(&X86::GR32RegClass); in convertToThreeAddressWithLEA()
1258 // least on modern x86 machines). in convertToThreeAddressWithLEA()
1265 unsigned SubReg = Is8BitOp ? X86::sub_8bit : X86::sub_16bit; in convertToThreeAddressWithLEA()
1268 BuildMI(MBB, MBBI, MI.getDebugLoc(), get(X86::IMPLICIT_DEF), InRegLEA); in convertToThreeAddressWithLEA()
1281 case X86::SHL8ri: in convertToThreeAddressWithLEA()
1282 case X86::SHL16ri: { in convertToThreeAddressWithLEA()
1291 case X86::INC8r: in convertToThreeAddressWithLEA()
1292 case X86::INC16r: in convertToThreeAddressWithLEA()
1295 case X86::DEC8r: in convertToThreeAddressWithLEA()
1296 case X86::DEC16r: in convertToThreeAddressWithLEA()
1299 case X86::ADD8ri: in convertToThreeAddressWithLEA()
1300 case X86::ADD8ri_DB: in convertToThreeAddressWithLEA()
1301 case X86::ADD16ri: in convertToThreeAddressWithLEA()
1302 case X86::ADD16ri_DB: in convertToThreeAddressWithLEA()
1305 case X86::ADD8rr: in convertToThreeAddressWithLEA()
1306 case X86::ADD8rr_DB: in convertToThreeAddressWithLEA()
1307 case X86::ADD16rr: in convertToThreeAddressWithLEA()
1308 case X86::ADD16rr_DB: { in convertToThreeAddressWithLEA()
1318 InRegLEA2 = RegInfo.createVirtualRegister(&X86::GR64_NOSPRegClass); in convertToThreeAddressWithLEA()
1320 InRegLEA2 = RegInfo.createVirtualRegister(&X86::GR32_NOSPRegClass); in convertToThreeAddressWithLEA()
1323 ImpDef2 = BuildMI(MBB, &*MIB, MI.getDebugLoc(), get(X86::IMPLICIT_DEF), in convertToThreeAddressWithLEA()
1399 /// three-address instruction on demand. This allows the X86 target (for
1440 case X86::SHL64ri: { in convertToThreeAddress()
1448 Src.getReg(), &X86::GR64_NOSPRegClass)) in convertToThreeAddress()
1451 NewMI = BuildMI(MF, MI.getDebugLoc(), get(X86::LEA64r)) in convertToThreeAddress()
1460 case X86::SHL32ri: { in convertToThreeAddress()
1466 unsigned Opc = Is64Bit ? X86::LEA64_32r : X86::LEA32r; in convertToThreeAddress()
1491 case X86::SHL8ri: in convertToThreeAddress()
1494 case X86::SHL16ri: { in convertToThreeAddress()
1501 case X86::INC64r: in convertToThreeAddress()
1502 case X86::INC32r: { in convertToThreeAddress()
1504 unsigned Opc = MIOpc == X86::INC64r in convertToThreeAddress()
1505 ? X86::LEA64r in convertToThreeAddress()
1506 : (Is64Bit ? X86::LEA64_32r : X86::LEA32r); in convertToThreeAddress()
1526 case X86::DEC64r: in convertToThreeAddress()
1527 case X86::DEC32r: { in convertToThreeAddress()
1529 unsigned Opc = MIOpc == X86::DEC64r in convertToThreeAddress()
1530 ? X86::LEA64r in convertToThreeAddress()
1531 : (Is64Bit ? X86::LEA64_32r : X86::LEA32r); in convertToThreeAddress()
1552 case X86::DEC8r: in convertToThreeAddress()
1553 case X86::INC8r: in convertToThreeAddress()
1556 case X86::DEC16r: in convertToThreeAddress()
1557 case X86::INC16r: in convertToThreeAddress()
1559 case X86::ADD64rr: in convertToThreeAddress()
1560 case X86::ADD64rr_DB: in convertToThreeAddress()
1561 case X86::ADD32rr: in convertToThreeAddress()
1562 case X86::ADD32rr_DB: { in convertToThreeAddress()
1565 if (MIOpc == X86::ADD64rr || MIOpc == X86::ADD64rr_DB) in convertToThreeAddress()
1566 Opc = X86::LEA64r; in convertToThreeAddress()
1568 Opc = Is64Bit ? X86::LEA64_32r : X86::LEA32r; in convertToThreeAddress()
1608 case X86::ADD8rr: in convertToThreeAddress()
1609 case X86::ADD8rr_DB: in convertToThreeAddress()
1612 case X86::ADD16rr: in convertToThreeAddress()
1613 case X86::ADD16rr_DB: in convertToThreeAddress()
1615 case X86::ADD64ri32: in convertToThreeAddress()
1616 case X86::ADD64ri32_DB: in convertToThreeAddress()
1619 BuildMI(MF, MI.getDebugLoc(), get(X86::LEA64r)).add(Dest).add(Src), in convertToThreeAddress()
1622 case X86::ADD32ri: in convertToThreeAddress()
1623 case X86::ADD32ri_DB: { in convertToThreeAddress()
1625 unsigned Opc = Is64Bit ? X86::LEA64_32r : X86::LEA32r; in convertToThreeAddress()
1646 case X86::ADD8ri: in convertToThreeAddress()
1647 case X86::ADD8ri_DB: in convertToThreeAddress()
1650 case X86::ADD16ri: in convertToThreeAddress()
1651 case X86::ADD16ri_DB: in convertToThreeAddress()
1653 case X86::SUB8ri: in convertToThreeAddress()
1654 case X86::SUB16ri: in convertToThreeAddress()
1657 case X86::SUB32ri: { in convertToThreeAddress()
1665 unsigned Opc = Is64Bit ? X86::LEA64_32r : X86::LEA32r; in convertToThreeAddress()
1687 case X86::SUB64ri32: { in convertToThreeAddress()
1697 BuildMI(MF, MI.getDebugLoc(), get(X86::LEA64r)).add(Dest).add(Src); in convertToThreeAddress()
1702 case X86::VMOVDQU8Z128rmk: in convertToThreeAddress()
1703 case X86::VMOVDQU8Z256rmk: in convertToThreeAddress()
1704 case X86::VMOVDQU8Zrmk: in convertToThreeAddress()
1705 case X86::VMOVDQU16Z128rmk: in convertToThreeAddress()
1706 case X86::VMOVDQU16Z256rmk: in convertToThreeAddress()
1707 case X86::VMOVDQU16Zrmk: in convertToThreeAddress()
1708 case X86::VMOVDQU32Z128rmk: in convertToThreeAddress()
1709 case X86::VMOVDQA32Z128rmk: in convertToThreeAddress()
1710 case X86::VMOVDQU32Z256rmk: in convertToThreeAddress()
1711 case X86::VMOVDQA32Z256rmk: in convertToThreeAddress()
1712 case X86::VMOVDQU32Zrmk: in convertToThreeAddress()
1713 case X86::VMOVDQA32Zrmk: in convertToThreeAddress()
1714 case X86::VMOVDQU64Z128rmk: in convertToThreeAddress()
1715 case X86::VMOVDQA64Z128rmk: in convertToThreeAddress()
1716 case X86::VMOVDQU64Z256rmk: in convertToThreeAddress()
1717 case X86::VMOVDQA64Z256rmk: in convertToThreeAddress()
1718 case X86::VMOVDQU64Zrmk: in convertToThreeAddress()
1719 case X86::VMOVDQA64Zrmk: in convertToThreeAddress()
1720 case X86::VMOVUPDZ128rmk: in convertToThreeAddress()
1721 case X86::VMOVAPDZ128rmk: in convertToThreeAddress()
1722 case X86::VMOVUPDZ256rmk: in convertToThreeAddress()
1723 case X86::VMOVAPDZ256rmk: in convertToThreeAddress()
1724 case X86::VMOVUPDZrmk: in convertToThreeAddress()
1725 case X86::VMOVAPDZrmk: in convertToThreeAddress()
1726 case X86::VMOVUPSZ128rmk: in convertToThreeAddress()
1727 case X86::VMOVAPSZ128rmk: in convertToThreeAddress()
1728 case X86::VMOVUPSZ256rmk: in convertToThreeAddress()
1729 case X86::VMOVAPSZ256rmk: in convertToThreeAddress()
1730 case X86::VMOVUPSZrmk: in convertToThreeAddress()
1731 case X86::VMOVAPSZrmk: in convertToThreeAddress()
1732 case X86::VBROADCASTSDZ256rmk: in convertToThreeAddress()
1733 case X86::VBROADCASTSDZrmk: in convertToThreeAddress()
1734 case X86::VBROADCASTSSZ128rmk: in convertToThreeAddress()
1735 case X86::VBROADCASTSSZ256rmk: in convertToThreeAddress()
1736 case X86::VBROADCASTSSZrmk: in convertToThreeAddress()
1737 case X86::VPBROADCASTDZ128rmk: in convertToThreeAddress()
1738 case X86::VPBROADCASTDZ256rmk: in convertToThreeAddress()
1739 case X86::VPBROADCASTDZrmk: in convertToThreeAddress()
1740 case X86::VPBROADCASTQZ128rmk: in convertToThreeAddress()
1741 case X86::VPBROADCASTQZ256rmk: in convertToThreeAddress()
1742 case X86::VPBROADCASTQZrmk: { in convertToThreeAddress()
1747 case X86::VMOVDQU8Z128rmk: in convertToThreeAddress()
1748 Opc = X86::VPBLENDMBZ128rmk; in convertToThreeAddress()
1750 case X86::VMOVDQU8Z256rmk: in convertToThreeAddress()
1751 Opc = X86::VPBLENDMBZ256rmk; in convertToThreeAddress()
1753 case X86::VMOVDQU8Zrmk: in convertToThreeAddress()
1754 Opc = X86::VPBLENDMBZrmk; in convertToThreeAddress()
1756 case X86::VMOVDQU16Z128rmk: in convertToThreeAddress()
1757 Opc = X86::VPBLENDMWZ128rmk; in convertToThreeAddress()
1759 case X86::VMOVDQU16Z256rmk: in convertToThreeAddress()
1760 Opc = X86::VPBLENDMWZ256rmk; in convertToThreeAddress()
1762 case X86::VMOVDQU16Zrmk: in convertToThreeAddress()
1763 Opc = X86::VPBLENDMWZrmk; in convertToThreeAddress()
1765 case X86::VMOVDQU32Z128rmk: in convertToThreeAddress()
1766 Opc = X86::VPBLENDMDZ128rmk; in convertToThreeAddress()
1768 case X86::VMOVDQU32Z256rmk: in convertToThreeAddress()
1769 Opc = X86::VPBLENDMDZ256rmk; in convertToThreeAddress()
1771 case X86::VMOVDQU32Zrmk: in convertToThreeAddress()
1772 Opc = X86::VPBLENDMDZrmk; in convertToThreeAddress()
1774 case X86::VMOVDQU64Z128rmk: in convertToThreeAddress()
1775 Opc = X86::VPBLENDMQZ128rmk; in convertToThreeAddress()
1777 case X86::VMOVDQU64Z256rmk: in convertToThreeAddress()
1778 Opc = X86::VPBLENDMQZ256rmk; in convertToThreeAddress()
1780 case X86::VMOVDQU64Zrmk: in convertToThreeAddress()
1781 Opc = X86::VPBLENDMQZrmk; in convertToThreeAddress()
1783 case X86::VMOVUPDZ128rmk: in convertToThreeAddress()
1784 Opc = X86::VBLENDMPDZ128rmk; in convertToThreeAddress()
1786 case X86::VMOVUPDZ256rmk: in convertToThreeAddress()
1787 Opc = X86::VBLENDMPDZ256rmk; in convertToThreeAddress()
1789 case X86::VMOVUPDZrmk: in convertToThreeAddress()
1790 Opc = X86::VBLENDMPDZrmk; in convertToThreeAddress()
1792 case X86::VMOVUPSZ128rmk: in convertToThreeAddress()
1793 Opc = X86::VBLENDMPSZ128rmk; in convertToThreeAddress()
1795 case X86::VMOVUPSZ256rmk: in convertToThreeAddress()
1796 Opc = X86::VBLENDMPSZ256rmk; in convertToThreeAddress()
1798 case X86::VMOVUPSZrmk: in convertToThreeAddress()
1799 Opc = X86::VBLENDMPSZrmk; in convertToThreeAddress()
1801 case X86::VMOVDQA32Z128rmk: in convertToThreeAddress()
1802 Opc = X86::VPBLENDMDZ128rmk; in convertToThreeAddress()
1804 case X86::VMOVDQA32Z256rmk: in convertToThreeAddress()
1805 Opc = X86::VPBLENDMDZ256rmk; in convertToThreeAddress()
1807 case X86::VMOVDQA32Zrmk: in convertToThreeAddress()
1808 Opc = X86::VPBLENDMDZrmk; in convertToThreeAddress()
1810 case X86::VMOVDQA64Z128rmk: in convertToThreeAddress()
1811 Opc = X86::VPBLENDMQZ128rmk; in convertToThreeAddress()
1813 case X86::VMOVDQA64Z256rmk: in convertToThreeAddress()
1814 Opc = X86::VPBLENDMQZ256rmk; in convertToThreeAddress()
1816 case X86::VMOVDQA64Zrmk: in convertToThreeAddress()
1817 Opc = X86::VPBLENDMQZrmk; in convertToThreeAddress()
1819 case X86::VMOVAPDZ128rmk: in convertToThreeAddress()
1820 Opc = X86::VBLENDMPDZ128rmk; in convertToThreeAddress()
1822 case X86::VMOVAPDZ256rmk: in convertToThreeAddress()
1823 Opc = X86::VBLENDMPDZ256rmk; in convertToThreeAddress()
1825 case X86::VMOVAPDZrmk: in convertToThreeAddress()
1826 Opc = X86::VBLENDMPDZrmk; in convertToThreeAddress()
1828 case X86::VMOVAPSZ128rmk: in convertToThreeAddress()
1829 Opc = X86::VBLENDMPSZ128rmk; in convertToThreeAddress()
1831 case X86::VMOVAPSZ256rmk: in convertToThreeAddress()
1832 Opc = X86::VBLENDMPSZ256rmk; in convertToThreeAddress()
1834 case X86::VMOVAPSZrmk: in convertToThreeAddress()
1835 Opc = X86::VBLENDMPSZrmk; in convertToThreeAddress()
1837 case X86::VBROADCASTSDZ256rmk: in convertToThreeAddress()
1838 Opc = X86::VBLENDMPDZ256rmbk; in convertToThreeAddress()
1840 case X86::VBROADCASTSDZrmk: in convertToThreeAddress()
1841 Opc = X86::VBLENDMPDZrmbk; in convertToThreeAddress()
1843 case X86::VBROADCASTSSZ128rmk: in convertToThreeAddress()
1844 Opc = X86::VBLENDMPSZ128rmbk; in convertToThreeAddress()
1846 case X86::VBROADCASTSSZ256rmk: in convertToThreeAddress()
1847 Opc = X86::VBLENDMPSZ256rmbk; in convertToThreeAddress()
1849 case X86::VBROADCASTSSZrmk: in convertToThreeAddress()
1850 Opc = X86::VBLENDMPSZrmbk; in convertToThreeAddress()
1852 case X86::VPBROADCASTDZ128rmk: in convertToThreeAddress()
1853 Opc = X86::VPBLENDMDZ128rmbk; in convertToThreeAddress()
1855 case X86::VPBROADCASTDZ256rmk: in convertToThreeAddress()
1856 Opc = X86::VPBLENDMDZ256rmbk; in convertToThreeAddress()
1858 case X86::VPBROADCASTDZrmk: in convertToThreeAddress()
1859 Opc = X86::VPBLENDMDZrmbk; in convertToThreeAddress()
1861 case X86::VPBROADCASTQZ128rmk: in convertToThreeAddress()
1862 Opc = X86::VPBLENDMQZ128rmbk; in convertToThreeAddress()
1864 case X86::VPBROADCASTQZ256rmk: in convertToThreeAddress()
1865 Opc = X86::VPBLENDMQZ256rmbk; in convertToThreeAddress()
1867 case X86::VPBROADCASTQZrmk: in convertToThreeAddress()
1868 Opc = X86::VPBLENDMQZrmbk; in convertToThreeAddress()
1885 case X86::VMOVDQU8Z128rrk: in convertToThreeAddress()
1886 case X86::VMOVDQU8Z256rrk: in convertToThreeAddress()
1887 case X86::VMOVDQU8Zrrk: in convertToThreeAddress()
1888 case X86::VMOVDQU16Z128rrk: in convertToThreeAddress()
1889 case X86::VMOVDQU16Z256rrk: in convertToThreeAddress()
1890 case X86::VMOVDQU16Zrrk: in convertToThreeAddress()
1891 case X86::VMOVDQU32Z128rrk: in convertToThreeAddress()
1892 case X86::VMOVDQA32Z128rrk: in convertToThreeAddress()
1893 case X86::VMOVDQU32Z256rrk: in convertToThreeAddress()
1894 case X86::VMOVDQA32Z256rrk: in convertToThreeAddress()
1895 case X86::VMOVDQU32Zrrk: in convertToThreeAddress()
1896 case X86::VMOVDQA32Zrrk: in convertToThreeAddress()
1897 case X86::VMOVDQU64Z128rrk: in convertToThreeAddress()
1898 case X86::VMOVDQA64Z128rrk: in convertToThreeAddress()
1899 case X86::VMOVDQU64Z256rrk: in convertToThreeAddress()
1900 case X86::VMOVDQA64Z256rrk: in convertToThreeAddress()
1901 case X86::VMOVDQU64Zrrk: in convertToThreeAddress()
1902 case X86::VMOVDQA64Zrrk: in convertToThreeAddress()
1903 case X86::VMOVUPDZ128rrk: in convertToThreeAddress()
1904 case X86::VMOVAPDZ128rrk: in convertToThreeAddress()
1905 case X86::VMOVUPDZ256rrk: in convertToThreeAddress()
1906 case X86::VMOVAPDZ256rrk: in convertToThreeAddress()
1907 case X86::VMOVUPDZrrk: in convertToThreeAddress()
1908 case X86::VMOVAPDZrrk: in convertToThreeAddress()
1909 case X86::VMOVUPSZ128rrk: in convertToThreeAddress()
1910 case X86::VMOVAPSZ128rrk: in convertToThreeAddress()
1911 case X86::VMOVUPSZ256rrk: in convertToThreeAddress()
1912 case X86::VMOVAPSZ256rrk: in convertToThreeAddress()
1913 case X86::VMOVUPSZrrk: in convertToThreeAddress()
1914 case X86::VMOVAPSZrrk: { in convertToThreeAddress()
1919 case X86::VMOVDQU8Z128rrk: in convertToThreeAddress()
1920 Opc = X86::VPBLENDMBZ128rrk; in convertToThreeAddress()
1922 case X86::VMOVDQU8Z256rrk: in convertToThreeAddress()
1923 Opc = X86::VPBLENDMBZ256rrk; in convertToThreeAddress()
1925 case X86::VMOVDQU8Zrrk: in convertToThreeAddress()
1926 Opc = X86::VPBLENDMBZrrk; in convertToThreeAddress()
1928 case X86::VMOVDQU16Z128rrk: in convertToThreeAddress()
1929 Opc = X86::VPBLENDMWZ128rrk; in convertToThreeAddress()
1931 case X86::VMOVDQU16Z256rrk: in convertToThreeAddress()
1932 Opc = X86::VPBLENDMWZ256rrk; in convertToThreeAddress()
1934 case X86::VMOVDQU16Zrrk: in convertToThreeAddress()
1935 Opc = X86::VPBLENDMWZrrk; in convertToThreeAddress()
1937 case X86::VMOVDQU32Z128rrk: in convertToThreeAddress()
1938 Opc = X86::VPBLENDMDZ128rrk; in convertToThreeAddress()
1940 case X86::VMOVDQU32Z256rrk: in convertToThreeAddress()
1941 Opc = X86::VPBLENDMDZ256rrk; in convertToThreeAddress()
1943 case X86::VMOVDQU32Zrrk: in convertToThreeAddress()
1944 Opc = X86::VPBLENDMDZrrk; in convertToThreeAddress()
1946 case X86::VMOVDQU64Z128rrk: in convertToThreeAddress()
1947 Opc = X86::VPBLENDMQZ128rrk; in convertToThreeAddress()
1949 case X86::VMOVDQU64Z256rrk: in convertToThreeAddress()
1950 Opc = X86::VPBLENDMQZ256rrk; in convertToThreeAddress()
1952 case X86::VMOVDQU64Zrrk: in convertToThreeAddress()
1953 Opc = X86::VPBLENDMQZrrk; in convertToThreeAddress()
1955 case X86::VMOVUPDZ128rrk: in convertToThreeAddress()
1956 Opc = X86::VBLENDMPDZ128rrk; in convertToThreeAddress()
1958 case X86::VMOVUPDZ256rrk: in convertToThreeAddress()
1959 Opc = X86::VBLENDMPDZ256rrk; in convertToThreeAddress()
1961 case X86::VMOVUPDZrrk: in convertToThreeAddress()
1962 Opc = X86::VBLENDMPDZrrk; in convertToThreeAddress()
1964 case X86::VMOVUPSZ128rrk: in convertToThreeAddress()
1965 Opc = X86::VBLENDMPSZ128rrk; in convertToThreeAddress()
1967 case X86::VMOVUPSZ256rrk: in convertToThreeAddress()
1968 Opc = X86::VBLENDMPSZ256rrk; in convertToThreeAddress()
1970 case X86::VMOVUPSZrrk: in convertToThreeAddress()
1971 Opc = X86::VBLENDMPSZrrk; in convertToThreeAddress()
1973 case X86::VMOVDQA32Z128rrk: in convertToThreeAddress()
1974 Opc = X86::VPBLENDMDZ128rrk; in convertToThreeAddress()
1976 case X86::VMOVDQA32Z256rrk: in convertToThreeAddress()
1977 Opc = X86::VPBLENDMDZ256rrk; in convertToThreeAddress()
1979 case X86::VMOVDQA32Zrrk: in convertToThreeAddress()
1980 Opc = X86::VPBLENDMDZrrk; in convertToThreeAddress()
1982 case X86::VMOVDQA64Z128rrk: in convertToThreeAddress()
1983 Opc = X86::VPBLENDMQZ128rrk; in convertToThreeAddress()
1985 case X86::VMOVDQA64Z256rrk: in convertToThreeAddress()
1986 Opc = X86::VPBLENDMQZ256rrk; in convertToThreeAddress()
1988 case X86::VMOVDQA64Zrrk: in convertToThreeAddress()
1989 Opc = X86::VPBLENDMQZrrk; in convertToThreeAddress()
1991 case X86::VMOVAPDZ128rrk: in convertToThreeAddress()
1992 Opc = X86::VBLENDMPDZ128rrk; in convertToThreeAddress()
1994 case X86::VMOVAPDZ256rrk: in convertToThreeAddress()
1995 Opc = X86::VBLENDMPDZ256rrk; in convertToThreeAddress()
1997 case X86::VMOVAPDZrrk: in convertToThreeAddress()
1998 Opc = X86::VBLENDMPDZrrk; in convertToThreeAddress()
2000 case X86::VMOVAPSZ128rrk: in convertToThreeAddress()
2001 Opc = X86::VBLENDMPSZ128rrk; in convertToThreeAddress()
2003 case X86::VMOVAPSZ256rrk: in convertToThreeAddress()
2004 Opc = X86::VBLENDMPSZ256rrk; in convertToThreeAddress()
2006 case X86::VMOVAPSZrrk: in convertToThreeAddress()
2007 Opc = X86::VBLENDMPSZrrk; in convertToThreeAddress()
2164 case X86::VPERMI2##Suffix##Z128rr: \ in isCommutableVPERMV3Instruction()
2165 case X86::VPERMT2##Suffix##Z128rr: \ in isCommutableVPERMV3Instruction()
2166 case X86::VPERMI2##Suffix##Z256rr: \ in isCommutableVPERMV3Instruction()
2167 case X86::VPERMT2##Suffix##Z256rr: \ in isCommutableVPERMV3Instruction()
2168 case X86::VPERMI2##Suffix##Zrr: \ in isCommutableVPERMV3Instruction()
2169 case X86::VPERMT2##Suffix##Zrr: \ in isCommutableVPERMV3Instruction()
2170 case X86::VPERMI2##Suffix##Z128rm: \ in isCommutableVPERMV3Instruction()
2171 case X86::VPERMT2##Suffix##Z128rm: \ in isCommutableVPERMV3Instruction()
2172 case X86::VPERMI2##Suffix##Z256rm: \ in isCommutableVPERMV3Instruction()
2173 case X86::VPERMT2##Suffix##Z256rm: \ in isCommutableVPERMV3Instruction()
2174 case X86::VPERMI2##Suffix##Zrm: \ in isCommutableVPERMV3Instruction()
2175 case X86::VPERMT2##Suffix##Zrm: \ in isCommutableVPERMV3Instruction()
2176 case X86::VPERMI2##Suffix##Z128rrkz: \ in isCommutableVPERMV3Instruction()
2177 case X86::VPERMT2##Suffix##Z128rrkz: \ in isCommutableVPERMV3Instruction()
2178 case X86::VPERMI2##Suffix##Z256rrkz: \ in isCommutableVPERMV3Instruction()
2179 case X86::VPERMT2##Suffix##Z256rrkz: \ in isCommutableVPERMV3Instruction()
2180 case X86::VPERMI2##Suffix##Zrrkz: \ in isCommutableVPERMV3Instruction()
2181 case X86::VPERMT2##Suffix##Zrrkz: \ in isCommutableVPERMV3Instruction()
2182 case X86::VPERMI2##Suffix##Z128rmkz: \ in isCommutableVPERMV3Instruction()
2183 case X86::VPERMT2##Suffix##Z128rmkz: \ in isCommutableVPERMV3Instruction()
2184 case X86::VPERMI2##Suffix##Z256rmkz: \ in isCommutableVPERMV3Instruction()
2185 case X86::VPERMT2##Suffix##Z256rmkz: \ in isCommutableVPERMV3Instruction()
2186 case X86::VPERMI2##Suffix##Zrmkz: \ in isCommutableVPERMV3Instruction()
2187 case X86::VPERMT2##Suffix##Zrmkz: in isCommutableVPERMV3Instruction()
2191 case X86::VPERMI2##Suffix##Z128rmb: \ in isCommutableVPERMV3Instruction()
2192 case X86::VPERMT2##Suffix##Z128rmb: \ in isCommutableVPERMV3Instruction()
2193 case X86::VPERMI2##Suffix##Z256rmb: \ in isCommutableVPERMV3Instruction()
2194 case X86::VPERMT2##Suffix##Z256rmb: \ in isCommutableVPERMV3Instruction()
2195 case X86::VPERMI2##Suffix##Zrmb: \ in isCommutableVPERMV3Instruction()
2196 case X86::VPERMT2##Suffix##Zrmb: \ in isCommutableVPERMV3Instruction()
2197 case X86::VPERMI2##Suffix##Z128rmbkz: \ in isCommutableVPERMV3Instruction()
2198 case X86::VPERMT2##Suffix##Z128rmbkz: \ in isCommutableVPERMV3Instruction()
2199 case X86::VPERMI2##Suffix##Z256rmbkz: \ in isCommutableVPERMV3Instruction()
2200 case X86::VPERMT2##Suffix##Z256rmbkz: \ in isCommutableVPERMV3Instruction()
2201 case X86::VPERMI2##Suffix##Zrmbkz: \ in isCommutableVPERMV3Instruction()
2202 case X86::VPERMT2##Suffix##Zrmbkz: in isCommutableVPERMV3Instruction()
2223 case X86::Orig##Z128rr: \ in getCommutedVPERMV3Opcode()
2224 return X86::New##Z128rr; \ in getCommutedVPERMV3Opcode()
2225 case X86::Orig##Z128rrkz: \ in getCommutedVPERMV3Opcode()
2226 return X86::New##Z128rrkz; \ in getCommutedVPERMV3Opcode()
2227 case X86::Orig##Z128rm: \ in getCommutedVPERMV3Opcode()
2228 return X86::New##Z128rm; \ in getCommutedVPERMV3Opcode()
2229 case X86::Orig##Z128rmkz: \ in getCommutedVPERMV3Opcode()
2230 return X86::New##Z128rmkz; \ in getCommutedVPERMV3Opcode()
2231 case X86::Orig##Z256rr: \ in getCommutedVPERMV3Opcode()
2232 return X86::New##Z256rr; \ in getCommutedVPERMV3Opcode()
2233 case X86::Orig##Z256rrkz: \ in getCommutedVPERMV3Opcode()
2234 return X86::New##Z256rrkz; \ in getCommutedVPERMV3Opcode()
2235 case X86::Orig##Z256rm: \ in getCommutedVPERMV3Opcode()
2236 return X86::New##Z256rm; \ in getCommutedVPERMV3Opcode()
2237 case X86::Orig##Z256rmkz: \ in getCommutedVPERMV3Opcode()
2238 return X86::New##Z256rmkz; \ in getCommutedVPERMV3Opcode()
2239 case X86::Orig##Zrr: \ in getCommutedVPERMV3Opcode()
2240 return X86::New##Zrr; \ in getCommutedVPERMV3Opcode()
2241 case X86::Orig##Zrrkz: \ in getCommutedVPERMV3Opcode()
2242 return X86::New##Zrrkz; \ in getCommutedVPERMV3Opcode()
2243 case X86::Orig##Zrm: \ in getCommutedVPERMV3Opcode()
2244 return X86::New##Zrm; \ in getCommutedVPERMV3Opcode()
2245 case X86::Orig##Zrmkz: \ in getCommutedVPERMV3Opcode()
2246 return X86::New##Zrmkz; in getCommutedVPERMV3Opcode()
2250 case X86::Orig##Z128rmb: \ in getCommutedVPERMV3Opcode()
2251 return X86::New##Z128rmb; \ in getCommutedVPERMV3Opcode()
2252 case X86::Orig##Z128rmbkz: \ in getCommutedVPERMV3Opcode()
2253 return X86::New##Z128rmbkz; \ in getCommutedVPERMV3Opcode()
2254 case X86::Orig##Z256rmb: \ in getCommutedVPERMV3Opcode()
2255 return X86::New##Z256rmb; \ in getCommutedVPERMV3Opcode()
2256 case X86::Orig##Z256rmbkz: \ in getCommutedVPERMV3Opcode()
2257 return X86::New##Z256rmbkz; \ in getCommutedVPERMV3Opcode()
2258 case X86::Orig##Zrmb: \ in getCommutedVPERMV3Opcode()
2259 return X86::New##Zrmb; \ in getCommutedVPERMV3Opcode()
2260 case X86::Orig##Zrmbkz: \ in getCommutedVPERMV3Opcode()
2261 return X86::New##Zrmbkz; in getCommutedVPERMV3Opcode()
2295 case X86::OP: \ in commuteInstructionImpl()
2296 case X86::OP##_ND: in commuteInstructionImpl()
2311 case X86::A: \ in commuteInstructionImpl()
2312 Opc = X86::B; \ in commuteInstructionImpl()
2315 case X86::A##_ND: \ in commuteInstructionImpl()
2316 Opc = X86::B##_ND; \ in commuteInstructionImpl()
2319 case X86::B: \ in commuteInstructionImpl()
2320 Opc = X86::A; \ in commuteInstructionImpl()
2323 case X86::B##_ND: \ in commuteInstructionImpl()
2324 Opc = X86::A##_ND; \ in commuteInstructionImpl()
2338 case X86::PFSUBrr: in commuteInstructionImpl()
2339 case X86::PFSUBRrr: in commuteInstructionImpl()
2344 get(X86::PFSUBRrr == Opc ? X86::PFSUBrr : X86::PFSUBRrr)); in commuteInstructionImpl()
2346 case X86::BLENDPDrri: in commuteInstructionImpl()
2347 case X86::BLENDPSrri: in commuteInstructionImpl()
2348 case X86::VBLENDPDrri: in commuteInstructionImpl()
2349 case X86::VBLENDPSrri: in commuteInstructionImpl()
2352 unsigned Mask = (Opc == X86::BLENDPDrri || Opc == X86::VBLENDPDrri) ? 0x03: 0x0F; in commuteInstructionImpl()
2355 case X86::FROM: \ in commuteInstructionImpl()
2356 Opc = X86::TO; \ in commuteInstructionImpl()
2374 case X86::PBLENDWrri: in commuteInstructionImpl()
2375 case X86::VBLENDPDYrri: in commuteInstructionImpl()
2376 case X86::VBLENDPSYrri: in commuteInstructionImpl()
2377 case X86::VPBLENDDrri: in commuteInstructionImpl()
2378 case X86::VPBLENDWrri: in commuteInstructionImpl()
2379 case X86::VPBLENDDYrri: in commuteInstructionImpl()
2380 case X86::VPBLENDWYrri: { in commuteInstructionImpl()
2385 case X86::BLENDPDrri: in commuteInstructionImpl()
2388 case X86::BLENDPSrri: in commuteInstructionImpl()
2391 case X86::PBLENDWrri: in commuteInstructionImpl()
2394 case X86::VBLENDPDrri: in commuteInstructionImpl()
2397 case X86::VBLENDPSrri: in commuteInstructionImpl()
2400 case X86::VBLENDPDYrri: in commuteInstructionImpl()
2403 case X86::VBLENDPSYrri: in commuteInstructionImpl()
2406 case X86::VPBLENDDrri: in commuteInstructionImpl()
2409 case X86::VPBLENDWrri: in commuteInstructionImpl()
2412 case X86::VPBLENDDYrri: in commuteInstructionImpl()
2415 case X86::VPBLENDWYrri: in commuteInstructionImpl()
2427 case X86::INSERTPSrr: in commuteInstructionImpl()
2428 case X86::VINSERTPSrr: in commuteInstructionImpl()
2429 case X86::VINSERTPSZrr: { in commuteInstructionImpl()
2448 case X86::MOVSDrr: in commuteInstructionImpl()
2449 case X86::MOVSSrr: in commuteInstructionImpl()
2450 case X86::VMOVSDrr: in commuteInstructionImpl()
2451 case X86::VMOVSSrr: { in commuteInstructionImpl()
2458 case X86::MOVSDrr: in commuteInstructionImpl()
2459 Opc = X86::BLENDPDrri; in commuteInstructionImpl()
2462 case X86::MOVSSrr: in commuteInstructionImpl()
2463 Opc = X86::BLENDPSrri; in commuteInstructionImpl()
2466 case X86::VMOVSDrr: in commuteInstructionImpl()
2467 Opc = X86::VBLENDPDrri; in commuteInstructionImpl()
2470 case X86::VMOVSSrr: in commuteInstructionImpl()
2471 Opc = X86::VBLENDPSrri; in commuteInstructionImpl()
2483 WorkingMI->setDesc(get(X86::SHUFPDrri)); in commuteInstructionImpl()
2487 case X86::SHUFPDrri: { in commuteInstructionImpl()
2491 WorkingMI->setDesc(get(X86::MOVSDrr)); in commuteInstructionImpl()
2495 case X86::PCLMULQDQrri: in commuteInstructionImpl()
2496 case X86::VPCLMULQDQrri: in commuteInstructionImpl()
2497 case X86::VPCLMULQDQYrri: in commuteInstructionImpl()
2498 case X86::VPCLMULQDQZrri: in commuteInstructionImpl()
2499 case X86::VPCLMULQDQZ128rri: in commuteInstructionImpl()
2500 case X86::VPCLMULQDQZ256rri: { in commuteInstructionImpl()
2510 case X86::VPCMPBZ128rri: in commuteInstructionImpl()
2511 case X86::VPCMPUBZ128rri: in commuteInstructionImpl()
2512 case X86::VPCMPBZ256rri: in commuteInstructionImpl()
2513 case X86::VPCMPUBZ256rri: in commuteInstructionImpl()
2514 case X86::VPCMPBZrri: in commuteInstructionImpl()
2515 case X86::VPCMPUBZrri: in commuteInstructionImpl()
2516 case X86::VPCMPDZ128rri: in commuteInstructionImpl()
2517 case X86::VPCMPUDZ128rri: in commuteInstructionImpl()
2518 case X86::VPCMPDZ256rri: in commuteInstructionImpl()
2519 case X86::VPCMPUDZ256rri: in commuteInstructionImpl()
2520 case X86::VPCMPDZrri: in commuteInstructionImpl()
2521 case X86::VPCMPUDZrri: in commuteInstructionImpl()
2522 case X86::VPCMPQZ128rri: in commuteInstructionImpl()
2523 case X86::VPCMPUQZ128rri: in commuteInstructionImpl()
2524 case X86::VPCMPQZ256rri: in commuteInstructionImpl()
2525 case X86::VPCMPUQZ256rri: in commuteInstructionImpl()
2526 case X86::VPCMPQZrri: in commuteInstructionImpl()
2527 case X86::VPCMPUQZrri: in commuteInstructionImpl()
2528 case X86::VPCMPWZ128rri: in commuteInstructionImpl()
2529 case X86::VPCMPUWZ128rri: in commuteInstructionImpl()
2530 case X86::VPCMPWZ256rri: in commuteInstructionImpl()
2531 case X86::VPCMPUWZ256rri: in commuteInstructionImpl()
2532 case X86::VPCMPWZrri: in commuteInstructionImpl()
2533 case X86::VPCMPUWZrri: in commuteInstructionImpl()
2534 case X86::VPCMPBZ128rrik: in commuteInstructionImpl()
2535 case X86::VPCMPUBZ128rrik: in commuteInstructionImpl()
2536 case X86::VPCMPBZ256rrik: in commuteInstructionImpl()
2537 case X86::VPCMPUBZ256rrik: in commuteInstructionImpl()
2538 case X86::VPCMPBZrrik: in commuteInstructionImpl()
2539 case X86::VPCMPUBZrrik: in commuteInstructionImpl()
2540 case X86::VPCMPDZ128rrik: in commuteInstructionImpl()
2541 case X86::VPCMPUDZ128rrik: in commuteInstructionImpl()
2542 case X86::VPCMPDZ256rrik: in commuteInstructionImpl()
2543 case X86::VPCMPUDZ256rrik: in commuteInstructionImpl()
2544 case X86::VPCMPDZrrik: in commuteInstructionImpl()
2545 case X86::VPCMPUDZrrik: in commuteInstructionImpl()
2546 case X86::VPCMPQZ128rrik: in commuteInstructionImpl()
2547 case X86::VPCMPUQZ128rrik: in commuteInstructionImpl()
2548 case X86::VPCMPQZ256rrik: in commuteInstructionImpl()
2549 case X86::VPCMPUQZ256rrik: in commuteInstructionImpl()
2550 case X86::VPCMPQZrrik: in commuteInstructionImpl()
2551 case X86::VPCMPUQZrrik: in commuteInstructionImpl()
2552 case X86::VPCMPWZ128rrik: in commuteInstructionImpl()
2553 case X86::VPCMPUWZ128rrik: in commuteInstructionImpl()
2554 case X86::VPCMPWZ256rrik: in commuteInstructionImpl()
2555 case X86::VPCMPUWZ256rrik: in commuteInstructionImpl()
2556 case X86::VPCMPWZrrik: in commuteInstructionImpl()
2557 case X86::VPCMPUWZrrik: in commuteInstructionImpl()
2561 .setImm(X86::getSwappedVPCMPImm( in commuteInstructionImpl()
2564 case X86::VPCOMBri: in commuteInstructionImpl()
2565 case X86::VPCOMUBri: in commuteInstructionImpl()
2566 case X86::VPCOMDri: in commuteInstructionImpl()
2567 case X86::VPCOMUDri: in commuteInstructionImpl()
2568 case X86::VPCOMQri: in commuteInstructionImpl()
2569 case X86::VPCOMUQri: in commuteInstructionImpl()
2570 case X86::VPCOMWri: in commuteInstructionImpl()
2571 case X86::VPCOMUWri: in commuteInstructionImpl()
2575 X86::getSwappedVPCOMImm(MI.getOperand(3).getImm() & 0x7)); in commuteInstructionImpl()
2577 case X86::VCMPSDZrri: in commuteInstructionImpl()
2578 case X86::VCMPSSZrri: in commuteInstructionImpl()
2579 case X86::VCMPPDZrri: in commuteInstructionImpl()
2580 case X86::VCMPPSZrri: in commuteInstructionImpl()
2581 case X86::VCMPSHZrri: in commuteInstructionImpl()
2582 case X86::VCMPPHZrri: in commuteInstructionImpl()
2583 case X86::VCMPPHZ128rri: in commuteInstructionImpl()
2584 case X86::VCMPPHZ256rri: in commuteInstructionImpl()
2585 case X86::VCMPPDZ128rri: in commuteInstructionImpl()
2586 case X86::VCMPPSZ128rri: in commuteInstructionImpl()
2587 case X86::VCMPPDZ256rri: in commuteInstructionImpl()
2588 case X86::VCMPPSZ256rri: in commuteInstructionImpl()
2589 case X86::VCMPPDZrrik: in commuteInstructionImpl()
2590 case X86::VCMPPSZrrik: in commuteInstructionImpl()
2591 case X86::VCMPPDZ128rrik: in commuteInstructionImpl()
2592 case X86::VCMPPSZ128rrik: in commuteInstructionImpl()
2593 case X86::VCMPPDZ256rrik: in commuteInstructionImpl()
2594 case X86::VCMPPSZ256rrik: in commuteInstructionImpl()
2597 .setImm(X86::getSwappedVCMPImm( in commuteInstructionImpl()
2600 case X86::VPERM2F128rr: in commuteInstructionImpl()
2601 case X86::VPERM2I128rr: in commuteInstructionImpl()
2608 case X86::MOVHLPSrr: in commuteInstructionImpl()
2609 case X86::UNPCKHPDrr: in commuteInstructionImpl()
2610 case X86::VMOVHLPSrr: in commuteInstructionImpl()
2611 case X86::VUNPCKHPDrr: in commuteInstructionImpl()
2612 case X86::VMOVHLPSZrr: in commuteInstructionImpl()
2613 case X86::VUNPCKHPDZ128rr: in commuteInstructionImpl()
2619 case X86::MOVHLPSrr: in commuteInstructionImpl()
2620 Opc = X86::UNPCKHPDrr; in commuteInstructionImpl()
2622 case X86::UNPCKHPDrr: in commuteInstructionImpl()
2623 Opc = X86::MOVHLPSrr; in commuteInstructionImpl()
2625 case X86::VMOVHLPSrr: in commuteInstructionImpl()
2626 Opc = X86::VUNPCKHPDrr; in commuteInstructionImpl()
2628 case X86::VUNPCKHPDrr: in commuteInstructionImpl()
2629 Opc = X86::VMOVHLPSrr; in commuteInstructionImpl()
2631 case X86::VMOVHLPSZrr: in commuteInstructionImpl()
2632 Opc = X86::VUNPCKHPDZ128rr; in commuteInstructionImpl()
2634 case X86::VUNPCKHPDZ128rr: in commuteInstructionImpl()
2635 Opc = X86::VMOVHLPSZrr; in commuteInstructionImpl()
2646 X86::CondCode CC = static_cast<X86::CondCode>(MI.getOperand(OpNo).getImm()); in commuteInstructionImpl()
2647 WorkingMI->getOperand(OpNo).setImm(X86::GetOppositeBranchCondition(CC)); in commuteInstructionImpl()
2650 case X86::VPTERNLOGDZrri: in commuteInstructionImpl()
2651 case X86::VPTERNLOGDZrmi: in commuteInstructionImpl()
2652 case X86::VPTERNLOGDZ128rri: in commuteInstructionImpl()
2653 case X86::VPTERNLOGDZ128rmi: in commuteInstructionImpl()
2654 case X86::VPTERNLOGDZ256rri: in commuteInstructionImpl()
2655 case X86::VPTERNLOGDZ256rmi: in commuteInstructionImpl()
2656 case X86::VPTERNLOGQZrri: in commuteInstructionImpl()
2657 case X86::VPTERNLOGQZrmi: in commuteInstructionImpl()
2658 case X86::VPTERNLOGQZ128rri: in commuteInstructionImpl()
2659 case X86::VPTERNLOGQZ128rmi: in commuteInstructionImpl()
2660 case X86::VPTERNLOGQZ256rri: in commuteInstructionImpl()
2661 case X86::VPTERNLOGQZ256rmi: in commuteInstructionImpl()
2662 case X86::VPTERNLOGDZrrik: in commuteInstructionImpl()
2663 case X86::VPTERNLOGDZ128rrik: in commuteInstructionImpl()
2664 case X86::VPTERNLOGDZ256rrik: in commuteInstructionImpl()
2665 case X86::VPTERNLOGQZrrik: in commuteInstructionImpl()
2666 case X86::VPTERNLOGQZ128rrik: in commuteInstructionImpl()
2667 case X86::VPTERNLOGQZ256rrik: in commuteInstructionImpl()
2668 case X86::VPTERNLOGDZrrikz: in commuteInstructionImpl()
2669 case X86::VPTERNLOGDZrmikz: in commuteInstructionImpl()
2670 case X86::VPTERNLOGDZ128rrikz: in commuteInstructionImpl()
2671 case X86::VPTERNLOGDZ128rmikz: in commuteInstructionImpl()
2672 case X86::VPTERNLOGDZ256rrikz: in commuteInstructionImpl()
2673 case X86::VPTERNLOGDZ256rmikz: in commuteInstructionImpl()
2674 case X86::VPTERNLOGQZrrikz: in commuteInstructionImpl()
2675 case X86::VPTERNLOGQZrmikz: in commuteInstructionImpl()
2676 case X86::VPTERNLOGQZ128rrikz: in commuteInstructionImpl()
2677 case X86::VPTERNLOGQZ128rmikz: in commuteInstructionImpl()
2678 case X86::VPTERNLOGQZ256rrikz: in commuteInstructionImpl()
2679 case X86::VPTERNLOGQZ256rmikz: in commuteInstructionImpl()
2680 case X86::VPTERNLOGDZ128rmbi: in commuteInstructionImpl()
2681 case X86::VPTERNLOGDZ256rmbi: in commuteInstructionImpl()
2682 case X86::VPTERNLOGDZrmbi: in commuteInstructionImpl()
2683 case X86::VPTERNLOGQZ128rmbi: in commuteInstructionImpl()
2684 case X86::VPTERNLOGQZ256rmbi: in commuteInstructionImpl()
2685 case X86::VPTERNLOGQZrmbi: in commuteInstructionImpl()
2686 case X86::VPTERNLOGDZ128rmbikz: in commuteInstructionImpl()
2687 case X86::VPTERNLOGDZ256rmbikz: in commuteInstructionImpl()
2688 case X86::VPTERNLOGDZrmbikz: in commuteInstructionImpl()
2689 case X86::VPTERNLOGQZ128rmbikz: in commuteInstructionImpl()
2690 case X86::VPTERNLOGQZ256rmbikz: in commuteInstructionImpl()
2691 case X86::VPTERNLOGQZrmbikz: { in commuteInstructionImpl()
2824 case X86::CMPSDrri: in findCommutedOpIndices()
2825 case X86::CMPSSrri: in findCommutedOpIndices()
2826 case X86::CMPPDrri: in findCommutedOpIndices()
2827 case X86::CMPPSrri: in findCommutedOpIndices()
2828 case X86::VCMPSDrri: in findCommutedOpIndices()
2829 case X86::VCMPSSrri: in findCommutedOpIndices()
2830 case X86::VCMPPDrri: in findCommutedOpIndices()
2831 case X86::VCMPPSrri: in findCommutedOpIndices()
2832 case X86::VCMPPDYrri: in findCommutedOpIndices()
2833 case X86::VCMPPSYrri: in findCommutedOpIndices()
2834 case X86::VCMPSDZrri: in findCommutedOpIndices()
2835 case X86::VCMPSSZrri: in findCommutedOpIndices()
2836 case X86::VCMPPDZrri: in findCommutedOpIndices()
2837 case X86::VCMPPSZrri: in findCommutedOpIndices()
2838 case X86::VCMPSHZrri: in findCommutedOpIndices()
2839 case X86::VCMPPHZrri: in findCommutedOpIndices()
2840 case X86::VCMPPHZ128rri: in findCommutedOpIndices()
2841 case X86::VCMPPHZ256rri: in findCommutedOpIndices()
2842 case X86::VCMPPDZ128rri: in findCommutedOpIndices()
2843 case X86::VCMPPSZ128rri: in findCommutedOpIndices()
2844 case X86::VCMPPDZ256rri: in findCommutedOpIndices()
2845 case X86::VCMPPSZ256rri: in findCommutedOpIndices()
2846 case X86::VCMPPDZrrik: in findCommutedOpIndices()
2847 case X86::VCMPPSZrrik: in findCommutedOpIndices()
2848 case X86::VCMPPDZ128rrik: in findCommutedOpIndices()
2849 case X86::VCMPPSZ128rrik: in findCommutedOpIndices()
2850 case X86::VCMPPDZ256rrik: in findCommutedOpIndices()
2851 case X86::VCMPPSZ256rrik: { in findCommutedOpIndices()
2876 case X86::MOVSSrr: in findCommutedOpIndices()
2877 // X86::MOVSDrr is always commutable. MOVSS is only commutable if we can in findCommutedOpIndices()
2883 case X86::SHUFPDrri: in findCommutedOpIndices()
2888 case X86::MOVHLPSrr: in findCommutedOpIndices()
2889 case X86::UNPCKHPDrr: in findCommutedOpIndices()
2890 case X86::VMOVHLPSrr: in findCommutedOpIndices()
2891 case X86::VUNPCKHPDrr: in findCommutedOpIndices()
2892 case X86::VMOVHLPSZrr: in findCommutedOpIndices()
2893 case X86::VUNPCKHPDZ128rr: in findCommutedOpIndices()
2897 case X86::VPTERNLOGDZrri: in findCommutedOpIndices()
2898 case X86::VPTERNLOGDZrmi: in findCommutedOpIndices()
2899 case X86::VPTERNLOGDZ128rri: in findCommutedOpIndices()
2900 case X86::VPTERNLOGDZ128rmi: in findCommutedOpIndices()
2901 case X86::VPTERNLOGDZ256rri: in findCommutedOpIndices()
2902 case X86::VPTERNLOGDZ256rmi: in findCommutedOpIndices()
2903 case X86::VPTERNLOGQZrri: in findCommutedOpIndices()
2904 case X86::VPTERNLOGQZrmi: in findCommutedOpIndices()
2905 case X86::VPTERNLOGQZ128rri: in findCommutedOpIndices()
2906 case X86::VPTERNLOGQZ128rmi: in findCommutedOpIndices()
2907 case X86::VPTERNLOGQZ256rri: in findCommutedOpIndices()
2908 case X86::VPTERNLOGQZ256rmi: in findCommutedOpIndices()
2909 case X86::VPTERNLOGDZrrik: in findCommutedOpIndices()
2910 case X86::VPTERNLOGDZ128rrik: in findCommutedOpIndices()
2911 case X86::VPTERNLOGDZ256rrik: in findCommutedOpIndices()
2912 case X86::VPTERNLOGQZrrik: in findCommutedOpIndices()
2913 case X86::VPTERNLOGQZ128rrik: in findCommutedOpIndices()
2914 case X86::VPTERNLOGQZ256rrik: in findCommutedOpIndices()
2915 case X86::VPTERNLOGDZrrikz: in findCommutedOpIndices()
2916 case X86::VPTERNLOGDZrmikz: in findCommutedOpIndices()
2917 case X86::VPTERNLOGDZ128rrikz: in findCommutedOpIndices()
2918 case X86::VPTERNLOGDZ128rmikz: in findCommutedOpIndices()
2919 case X86::VPTERNLOGDZ256rrikz: in findCommutedOpIndices()
2920 case X86::VPTERNLOGDZ256rmikz: in findCommutedOpIndices()
2921 case X86::VPTERNLOGQZrrikz: in findCommutedOpIndices()
2922 case X86::VPTERNLOGQZrmikz: in findCommutedOpIndices()
2923 case X86::VPTERNLOGQZ128rrikz: in findCommutedOpIndices()
2924 case X86::VPTERNLOGQZ128rmikz: in findCommutedOpIndices()
2925 case X86::VPTERNLOGQZ256rrikz: in findCommutedOpIndices()
2926 case X86::VPTERNLOGQZ256rmikz: in findCommutedOpIndices()
2927 case X86::VPTERNLOGDZ128rmbi: in findCommutedOpIndices()
2928 case X86::VPTERNLOGDZ256rmbi: in findCommutedOpIndices()
2929 case X86::VPTERNLOGDZrmbi: in findCommutedOpIndices()
2930 case X86::VPTERNLOGQZ128rmbi: in findCommutedOpIndices()
2931 case X86::VPTERNLOGQZ256rmbi: in findCommutedOpIndices()
2932 case X86::VPTERNLOGQZrmbi: in findCommutedOpIndices()
2933 case X86::VPTERNLOGDZ128rmbikz: in findCommutedOpIndices()
2934 case X86::VPTERNLOGDZ256rmbikz: in findCommutedOpIndices()
2935 case X86::VPTERNLOGDZrmbikz: in findCommutedOpIndices()
2936 case X86::VPTERNLOGQZ128rmbikz: in findCommutedOpIndices()
2937 case X86::VPTERNLOGQZ256rmbikz: in findCommutedOpIndices()
2938 case X86::VPTERNLOGQZrmbikz: in findCommutedOpIndices()
2940 case X86::VPDPWSSDYrr: in findCommutedOpIndices()
2941 case X86::VPDPWSSDrr: in findCommutedOpIndices()
2942 case X86::VPDPWSSDSYrr: in findCommutedOpIndices()
2943 case X86::VPDPWSSDSrr: in findCommutedOpIndices()
2944 case X86::VPDPWUUDrr: in findCommutedOpIndices()
2945 case X86::VPDPWUUDYrr: in findCommutedOpIndices()
2946 case X86::VPDPWUUDSrr: in findCommutedOpIndices()
2947 case X86::VPDPWUUDSYrr: in findCommutedOpIndices()
2948 case X86::VPDPBSSDSrr: in findCommutedOpIndices()
2949 case X86::VPDPBSSDSYrr: in findCommutedOpIndices()
2950 case X86::VPDPBSSDrr: in findCommutedOpIndices()
2951 case X86::VPDPBSSDYrr: in findCommutedOpIndices()
2952 case X86::VPDPBUUDSrr: in findCommutedOpIndices()
2953 case X86::VPDPBUUDSYrr: in findCommutedOpIndices()
2954 case X86::VPDPBUUDrr: in findCommutedOpIndices()
2955 case X86::VPDPBUUDYrr: in findCommutedOpIndices()
2956 case X86::VPDPWSSDZ128r: in findCommutedOpIndices()
2957 case X86::VPDPWSSDZ128rk: in findCommutedOpIndices()
2958 case X86::VPDPWSSDZ128rkz: in findCommutedOpIndices()
2959 case X86::VPDPWSSDZ256r: in findCommutedOpIndices()
2960 case X86::VPDPWSSDZ256rk: in findCommutedOpIndices()
2961 case X86::VPDPWSSDZ256rkz: in findCommutedOpIndices()
2962 case X86::VPDPWSSDZr: in findCommutedOpIndices()
2963 case X86::VPDPWSSDZrk: in findCommutedOpIndices()
2964 case X86::VPDPWSSDZrkz: in findCommutedOpIndices()
2965 case X86::VPDPWSSDSZ128r: in findCommutedOpIndices()
2966 case X86::VPDPWSSDSZ128rk: in findCommutedOpIndices()
2967 case X86::VPDPWSSDSZ128rkz: in findCommutedOpIndices()
2968 case X86::VPDPWSSDSZ256r: in findCommutedOpIndices()
2969 case X86::VPDPWSSDSZ256rk: in findCommutedOpIndices()
2970 case X86::VPDPWSSDSZ256rkz: in findCommutedOpIndices()
2971 case X86::VPDPWSSDSZr: in findCommutedOpIndices()
2972 case X86::VPDPWSSDSZrk: in findCommutedOpIndices()
2973 case X86::VPDPWSSDSZrkz: in findCommutedOpIndices()
2974 case X86::VPMADD52HUQrr: in findCommutedOpIndices()
2975 case X86::VPMADD52HUQYrr: in findCommutedOpIndices()
2976 case X86::VPMADD52HUQZ128r: in findCommutedOpIndices()
2977 case X86::VPMADD52HUQZ128rk: in findCommutedOpIndices()
2978 case X86::VPMADD52HUQZ128rkz: in findCommutedOpIndices()
2979 case X86::VPMADD52HUQZ256r: in findCommutedOpIndices()
2980 case X86::VPMADD52HUQZ256rk: in findCommutedOpIndices()
2981 case X86::VPMADD52HUQZ256rkz: in findCommutedOpIndices()
2982 case X86::VPMADD52HUQZr: in findCommutedOpIndices()
2983 case X86::VPMADD52HUQZrk: in findCommutedOpIndices()
2984 case X86::VPMADD52HUQZrkz: in findCommutedOpIndices()
2985 case X86::VPMADD52LUQrr: in findCommutedOpIndices()
2986 case X86::VPMADD52LUQYrr: in findCommutedOpIndices()
2987 case X86::VPMADD52LUQZ128r: in findCommutedOpIndices()
2988 case X86::VPMADD52LUQZ128rk: in findCommutedOpIndices()
2989 case X86::VPMADD52LUQZ128rkz: in findCommutedOpIndices()
2990 case X86::VPMADD52LUQZ256r: in findCommutedOpIndices()
2991 case X86::VPMADD52LUQZ256rk: in findCommutedOpIndices()
2992 case X86::VPMADD52LUQZ256rkz: in findCommutedOpIndices()
2993 case X86::VPMADD52LUQZr: in findCommutedOpIndices()
2994 case X86::VPMADD52LUQZrk: in findCommutedOpIndices()
2995 case X86::VPMADD52LUQZrkz: in findCommutedOpIndices()
2996 case X86::VFMADDCPHZr: in findCommutedOpIndices()
2997 case X86::VFMADDCPHZrk: in findCommutedOpIndices()
2998 case X86::VFMADDCPHZrkz: in findCommutedOpIndices()
2999 case X86::VFMADDCPHZ128r: in findCommutedOpIndices()
3000 case X86::VFMADDCPHZ128rk: in findCommutedOpIndices()
3001 case X86::VFMADDCPHZ128rkz: in findCommutedOpIndices()
3002 case X86::VFMADDCPHZ256r: in findCommutedOpIndices()
3003 case X86::VFMADDCPHZ256rk: in findCommutedOpIndices()
3004 case X86::VFMADDCPHZ256rkz: in findCommutedOpIndices()
3005 case X86::VFMADDCSHZr: in findCommutedOpIndices()
3006 case X86::VFMADDCSHZrk: in findCommutedOpIndices()
3007 case X86::VFMADDCSHZrkz: { in findCommutedOpIndices()
3072 if (Opcode != X86::LEA32r && Opcode != X86::LEA64r && in isConvertibleLEA()
3073 Opcode != X86::LEA64_32r) in isConvertibleLEA()
3076 const MachineOperand &Scale = MI->getOperand(1 + X86::AddrScaleAmt); in isConvertibleLEA()
3077 const MachineOperand &Disp = MI->getOperand(1 + X86::AddrDisp); in isConvertibleLEA()
3078 const MachineOperand &Segment = MI->getOperand(1 + X86::AddrSegmentReg); in isConvertibleLEA()
3096 if (Opcode != X86::ADD32rr && Opcode != X86::ADD64rr) in hasCommutePreference()
3122 int X86::getCondSrcNoFromDesc(const MCInstrDesc &MCID) { in getCondSrcNoFromDesc()
3124 if (!(X86::isJCC(Opcode) || X86::isSETCC(Opcode) || X86::isCMOVCC(Opcode) || in getCondSrcNoFromDesc()
3125 X86::isCFCMOVCC(Opcode) || X86::isCCMPCC(Opcode) || in getCondSrcNoFromDesc()
3126 X86::isCTESTCC(Opcode))) in getCondSrcNoFromDesc()
3133 X86::CondCode X86::getCondFromMI(const MachineInstr &MI) { in getCondFromMI()
3137 return X86::COND_INVALID; in getCondFromMI()
3139 return static_cast<X86::CondCode>(MI.getOperand(CondNo).getImm()); in getCondFromMI()
3142 X86::CondCode X86::getCondFromBranch(const MachineInstr &MI) { in getCondFromBranch()
3143 return X86::isJCC(MI.getOpcode()) ? X86::getCondFromMI(MI) in getCondFromBranch()
3144 : X86::COND_INVALID; in getCondFromBranch()
3147 X86::CondCode X86::getCondFromSETCC(const MachineInstr &MI) { in getCondFromSETCC()
3148 return X86::isSETCC(MI.getOpcode()) ? X86::getCondFromMI(MI) in getCondFromSETCC()
3149 : X86::COND_INVALID; in getCondFromSETCC()
3152 X86::CondCode X86::getCondFromCMov(const MachineInstr &MI) { in getCondFromCMov()
3153 return X86::isCMOVCC(MI.getOpcode()) ? X86::getCondFromMI(MI) in getCondFromCMov()
3154 : X86::COND_INVALID; in getCondFromCMov()
3157 X86::CondCode X86::getCondFromCFCMov(const MachineInstr &MI) { in getCondFromCFCMov()
3158 return X86::isCFCMOVCC(MI.getOpcode()) ? X86::getCondFromMI(MI) in getCondFromCFCMov()
3159 : X86::COND_INVALID; in getCondFromCFCMov()
3162 X86::CondCode X86::getCondFromCCMP(const MachineInstr &MI) { in getCondFromCCMP()
3163 return X86::isCCMPCC(MI.getOpcode()) || X86::isCTESTCC(MI.getOpcode()) in getCondFromCCMP()
3164 ? X86::getCondFromMI(MI) in getCondFromCCMP()
3165 : X86::COND_INVALID; in getCondFromCCMP()
3168 int X86::getCCMPCondFlagsFromCondCode(X86::CondCode CC) { in getCCMPCondFlagsFromCondCode()
3199 case X86::COND_NO: in getCCMPCondFlagsFromCondCode()
3200 case X86::COND_NE: in getCCMPCondFlagsFromCondCode()
3201 case X86::COND_GE: in getCCMPCondFlagsFromCondCode()
3202 case X86::COND_G: in getCCMPCondFlagsFromCondCode()
3203 case X86::COND_AE: in getCCMPCondFlagsFromCondCode()
3204 case X86::COND_A: in getCCMPCondFlagsFromCondCode()
3205 case X86::COND_NS: in getCCMPCondFlagsFromCondCode()
3206 case X86::COND_NP: in getCCMPCondFlagsFromCondCode()
3208 case X86::COND_O: in getCCMPCondFlagsFromCondCode()
3210 case X86::COND_B: in getCCMPCondFlagsFromCondCode()
3211 case X86::COND_BE: in getCCMPCondFlagsFromCondCode()
3214 case X86::COND_E: in getCCMPCondFlagsFromCondCode()
3215 case X86::COND_LE: in getCCMPCondFlagsFromCondCode()
3217 case X86::COND_S: in getCCMPCondFlagsFromCondCode()
3218 case X86::COND_L: in getCCMPCondFlagsFromCondCode()
3220 case X86::COND_P: in getCCMPCondFlagsFromCondCode()
3234 unsigned X86::getNFVariant(unsigned Opc) { in getNFVariant()
3238 unsigned X86::getNonNDVariant(unsigned Opc) { in getNonNDVariant()
3244 X86::CondCode X86::GetOppositeBranchCondition(X86::CondCode CC) { in GetOppositeBranchCondition()
3248 case X86::COND_E: in GetOppositeBranchCondition()
3249 return X86::COND_NE; in GetOppositeBranchCondition()
3250 case X86::COND_NE: in GetOppositeBranchCondition()
3251 return X86::COND_E; in GetOppositeBranchCondition()
3252 case X86::COND_L: in GetOppositeBranchCondition()
3253 return X86::COND_GE; in GetOppositeBranchCondition()
3254 case X86::COND_LE: in GetOppositeBranchCondition()
3255 return X86::COND_G; in GetOppositeBranchCondition()
3256 case X86::COND_G: in GetOppositeBranchCondition()
3257 return X86::COND_LE; in GetOppositeBranchCondition()
3258 case X86::COND_GE: in GetOppositeBranchCondition()
3259 return X86::COND_L; in GetOppositeBranchCondition()
3260 case X86::COND_B: in GetOppositeBranchCondition()
3261 return X86::COND_AE; in GetOppositeBranchCondition()
3262 case X86::COND_BE: in GetOppositeBranchCondition()
3263 return X86::COND_A; in GetOppositeBranchCondition()
3264 case X86::COND_A: in GetOppositeBranchCondition()
3265 return X86::COND_BE; in GetOppositeBranchCondition()
3266 case X86::COND_AE: in GetOppositeBranchCondition()
3267 return X86::COND_B; in GetOppositeBranchCondition()
3268 case X86::COND_S: in GetOppositeBranchCondition()
3269 return X86::COND_NS; in GetOppositeBranchCondition()
3270 case X86::COND_NS: in GetOppositeBranchCondition()
3271 return X86::COND_S; in GetOppositeBranchCondition()
3272 case X86::COND_P: in GetOppositeBranchCondition()
3273 return X86::COND_NP; in GetOppositeBranchCondition()
3274 case X86::COND_NP: in GetOppositeBranchCondition()
3275 return X86::COND_P; in GetOppositeBranchCondition()
3276 case X86::COND_O: in GetOppositeBranchCondition()
3277 return X86::COND_NO; in GetOppositeBranchCondition()
3278 case X86::COND_NO: in GetOppositeBranchCondition()
3279 return X86::COND_O; in GetOppositeBranchCondition()
3280 case X86::COND_NE_OR_P: in GetOppositeBranchCondition()
3281 return X86::COND_E_AND_NP; in GetOppositeBranchCondition()
3282 case X86::COND_E_AND_NP: in GetOppositeBranchCondition()
3283 return X86::COND_NE_OR_P; in GetOppositeBranchCondition()
3289 static X86::CondCode getSwappedCondition(X86::CondCode CC) { in getSwappedCondition()
3292 return X86::COND_INVALID; in getSwappedCondition()
3293 case X86::COND_E: in getSwappedCondition()
3294 return X86::COND_E; in getSwappedCondition()
3295 case X86::COND_NE: in getSwappedCondition()
3296 return X86::COND_NE; in getSwappedCondition()
3297 case X86::COND_L: in getSwappedCondition()
3298 return X86::COND_G; in getSwappedCondition()
3299 case X86::COND_LE: in getSwappedCondition()
3300 return X86::COND_GE; in getSwappedCondition()
3301 case X86::COND_G: in getSwappedCondition()
3302 return X86::COND_L; in getSwappedCondition()
3303 case X86::COND_GE: in getSwappedCondition()
3304 return X86::COND_LE; in getSwappedCondition()
3305 case X86::COND_B: in getSwappedCondition()
3306 return X86::COND_A; in getSwappedCondition()
3307 case X86::COND_BE: in getSwappedCondition()
3308 return X86::COND_AE; in getSwappedCondition()
3309 case X86::COND_A: in getSwappedCondition()
3310 return X86::COND_B; in getSwappedCondition()
3311 case X86::COND_AE: in getSwappedCondition()
3312 return X86::COND_BE; in getSwappedCondition()
3316 std::pair<X86::CondCode, bool>
3317 X86::getX86ConditionCode(CmpInst::Predicate Predicate) { in getX86ConditionCode()
3318 X86::CondCode CC = X86::COND_INVALID; in getX86ConditionCode()
3325 CC = X86::COND_E; in getX86ConditionCode()
3331 CC = X86::COND_A; in getX86ConditionCode()
3337 CC = X86::COND_AE; in getX86ConditionCode()
3343 CC = X86::COND_B; in getX86ConditionCode()
3349 CC = X86::COND_BE; in getX86ConditionCode()
3352 CC = X86::COND_NE; in getX86ConditionCode()
3355 CC = X86::COND_P; in getX86ConditionCode()
3358 CC = X86::COND_NP; in getX86ConditionCode()
3363 CC = X86::COND_INVALID; in getX86ConditionCode()
3368 CC = X86::COND_E; in getX86ConditionCode()
3371 CC = X86::COND_NE; in getX86ConditionCode()
3374 CC = X86::COND_A; in getX86ConditionCode()
3377 CC = X86::COND_AE; in getX86ConditionCode()
3380 CC = X86::COND_B; in getX86ConditionCode()
3383 CC = X86::COND_BE; in getX86ConditionCode()
3386 CC = X86::COND_G; in getX86ConditionCode()
3389 CC = X86::COND_GE; in getX86ConditionCode()
3392 CC = X86::COND_L; in getX86ConditionCode()
3395 CC = X86::COND_LE; in getX86ConditionCode()
3403 unsigned X86::getCMovOpcode(unsigned RegBytes, bool HasMemoryOperand, in getCMovOpcode()
3410 return HasMemoryOperand ? GET_ND_IF_ENABLED(X86::CMOV16rm) in getCMovOpcode()
3411 : GET_ND_IF_ENABLED(X86::CMOV16rr); in getCMovOpcode()
3413 return HasMemoryOperand ? GET_ND_IF_ENABLED(X86::CMOV32rm) in getCMovOpcode()
3414 : GET_ND_IF_ENABLED(X86::CMOV32rr); in getCMovOpcode()
3416 return HasMemoryOperand ? GET_ND_IF_ENABLED(X86::CMOV64rm) in getCMovOpcode()
3417 : GET_ND_IF_ENABLED(X86::CMOV64rr); in getCMovOpcode()
3422 unsigned X86::getVPCMPImmForCond(ISD::CondCode CC) { in getVPCMPImmForCond()
3446 unsigned X86::getSwappedVPCMPImm(unsigned Imm) { in getSwappedVPCMPImm()
3473 unsigned X86::getSwappedVPCOMImm(unsigned Imm) { in getSwappedVPCOMImm()
3500 unsigned X86::getSwappedVCMPImm(unsigned Imm) { in getSwappedVCMPImm()
3519 unsigned X86::getVectorRegisterWidth(const MCOperandInfo &Info) { in getVectorRegisterWidth()
3520 if (Info.RegClass == X86::VR128RegClassID || in getVectorRegisterWidth()
3521 Info.RegClass == X86::VR128XRegClassID) in getVectorRegisterWidth()
3523 if (Info.RegClass == X86::VR256RegClassID || in getVectorRegisterWidth()
3524 Info.RegClass == X86::VR256XRegClassID) in getVectorRegisterWidth()
3526 if (Info.RegClass == X86::VR512RegClassID) in getVectorRegisterWidth()
3533 return (Reg == X86::FPCW || Reg == X86::FPSW || in isX87Reg()
3534 (Reg >= X86::ST0 && Reg <= X86::ST7)); in isX87Reg()
3538 bool X86::isX87Instruction(MachineInstr &MI) { in isX87Instruction()
3553 int X86::getFirstAddrOperandIdx(const MachineInstr &MI) { in getFirstAddrOperandIdx()
3577 if (NumOps < X86::AddrNumOperands) { in getFirstAddrOperandIdx()
3588 for (unsigned I = 0, E = NumOps - X86::AddrNumOperands; I != E; ++I) { in getFirstAddrOperandIdx()
3592 Desc.operands().begin() + I + X86::AddrNumOperands, in getFirstAddrOperandIdx()
3604 const Constant *X86::getConstantFromPool(const MachineInstr &MI, in getConstantFromPool()
3606 assert(MI.getNumOperands() >= (OpNo + X86::AddrNumOperands) && in getConstantFromPool()
3609 const MachineOperand &Index = MI.getOperand(OpNo + X86::AddrIndexReg); in getConstantFromPool()
3610 if (!Index.isReg() || Index.getReg() != X86::NoRegister) in getConstantFromPool()
3613 const MachineOperand &Disp = MI.getOperand(OpNo + X86::AddrDisp); in getConstantFromPool()
3631 case X86::TCRETURNdi: in isUnconditionalTailCall()
3632 case X86::TCRETURNri: in isUnconditionalTailCall()
3633 case X86::TCRETURNmi: in isUnconditionalTailCall()
3634 case X86::TCRETURNdi64: in isUnconditionalTailCall()
3635 case X86::TCRETURNri64: in isUnconditionalTailCall()
3636 case X86::TCRETURNmi64: in isUnconditionalTailCall()
3660 if (TailCall.getOpcode() != X86::TCRETURNdi && in canMakeTailCallConditional()
3661 TailCall.getOpcode() != X86::TCRETURNdi64) { in canMakeTailCallConditional()
3672 if (BranchCond[0].getImm() > X86::LAST_VALID_COND) { in canMakeTailCallConditional()
3700 X86::CondCode CC = X86::getCondFromBranch(*I); in replaceBranchWithTailCall()
3708 unsigned Opc = TailCall.getOpcode() == X86::TCRETURNdi ? X86::TCRETURNdicc in replaceBranchWithTailCall()
3709 : X86::TCRETURNdi64cc; in replaceBranchWithTailCall()
3777 if (I->getOpcode() == X86::JMP_1) { in analyzeBranchImpl()
3806 X86::CondCode BranchCode = X86::getCondFromBranch(*I); in analyzeBranchImpl()
3807 if (BranchCode == X86::COND_INVALID) in analyzeBranchImpl()
3812 if (I->findRegisterUseOperand(X86::EFLAGS, /*TRI=*/nullptr)->isUndef()) in analyzeBranchImpl()
3831 X86::CondCode OldBranchCode = (X86::CondCode)Cond[0].getImm(); in analyzeBranchImpl()
3840 ((OldBranchCode == X86::COND_P && BranchCode == X86::COND_NE) || in analyzeBranchImpl()
3841 (OldBranchCode == X86::COND_NE && BranchCode == X86::COND_P))) { in analyzeBranchImpl()
3842 BranchCode = X86::COND_NE_OR_P; in analyzeBranchImpl()
3843 } else if ((OldBranchCode == X86::COND_NP && BranchCode == X86::COND_NE) || in analyzeBranchImpl()
3844 (OldBranchCode == X86::COND_E && BranchCode == X86::COND_P)) { in analyzeBranchImpl()
3848 // X86::COND_E_AND_NP usually has two different branch destinations. in analyzeBranchImpl()
3867 BranchCode = X86::COND_E_AND_NP; in analyzeBranchImpl()
3894 const MachineOperand &MO = MI.getOperand(MemRefBegin + X86::AddrDisp); in getJumpTableIndexFromAddr()
3909 if (Opcode != X86::LEA64r && Opcode != X86::LEA32r) in getJumpTableIndexFromReg()
3918 if (Opcode == X86::JMP64m || Opcode == X86::JMP32m) { in getJumpTableIndex()
3926 if (Opcode == X86::JMP64r || Opcode == X86::JMP32r) { in getJumpTableIndex()
3935 if (Add->getOpcode() != X86::ADD64rr && Add->getOpcode() != X86::ADD32rr) in getJumpTableIndex()
3972 if (MI.modifiesRegister(X86::EFLAGS, TRI)) { in analyzeBranchPredicate()
3977 if (MI.readsRegister(X86::EFLAGS, TRI)) in analyzeBranchPredicate()
3986 if (Succ->isLiveIn(X86::EFLAGS)) in analyzeBranchPredicate()
3999 Subtarget.is64Bit() ? X86::TEST64rr : X86::TEST32rr; in analyzeBranchPredicate()
4004 (Cond[0].getImm() == X86::COND_NE || Cond[0].getImm() == X86::COND_E)) { in analyzeBranchPredicate()
4007 MBP.Predicate = Cond[0].getImm() == X86::COND_NE in analyzeBranchPredicate()
4027 if (I->getOpcode() != X86::JMP_1 && in removeBranch()
4028 X86::getCondFromBranch(*I) == X86::COND_INVALID) in removeBranch()
4047 "X86 branch conditions have one component!"); in insertBranch()
4053 BuildMI(&MBB, DL, get(X86::JMP_1)).addMBB(TBB); in insertBranch()
4062 X86::CondCode CC = (X86::CondCode)Cond[0].getImm(); in insertBranch()
4064 case X86::COND_NE_OR_P: in insertBranch()
4066 BuildMI(&MBB, DL, get(X86::JCC_1)).addMBB(TBB).addImm(X86::COND_NE); in insertBranch()
4068 BuildMI(&MBB, DL, get(X86::JCC_1)).addMBB(TBB).addImm(X86::COND_P); in insertBranch()
4071 case X86::COND_E_AND_NP: in insertBranch()
4079 BuildMI(&MBB, DL, get(X86::JCC_1)).addMBB(FBB).addImm(X86::COND_NE); in insertBranch()
4081 BuildMI(&MBB, DL, get(X86::JCC_1)).addMBB(TBB).addImm(X86::COND_NP); in insertBranch()
4085 BuildMI(&MBB, DL, get(X86::JCC_1)).addMBB(TBB).addImm(CC); in insertBranch()
4091 BuildMI(&MBB, DL, get(X86::JMP_1)).addMBB(FBB); in insertBranch()
4108 if ((X86::CondCode)Cond[0].getImm() > X86::LAST_VALID_COND) in canInsertSelect()
4119 if (X86::GR16RegClass.hasSubClassEq(RC) || in canInsertSelect()
4120 X86::GR32RegClass.hasSubClassEq(RC) || in canInsertSelect()
4121 X86::GR64RegClass.hasSubClassEq(RC)) { in canInsertSelect()
4144 X86::getCMovOpcode(TRI.getRegSizeInBits(RC) / 8, in insertSelect()
4154 return X86::GR8_ABCD_HRegClass.contains(Reg); in isHReg()
4169 if (X86::VK16RegClass.contains(SrcReg)) { in CopyToFromAsymmetricReg()
4170 if (X86::GR64RegClass.contains(DestReg)) { in CopyToFromAsymmetricReg()
4172 return HasEGPR ? X86::KMOVQrk_EVEX : X86::KMOVQrk; in CopyToFromAsymmetricReg()
4174 if (X86::GR32RegClass.contains(DestReg)) in CopyToFromAsymmetricReg()
4175 return Subtarget.hasBWI() ? (HasEGPR ? X86::KMOVDrk_EVEX : X86::KMOVDrk) in CopyToFromAsymmetricReg()
4176 : (HasEGPR ? X86::KMOVWrk_EVEX : X86::KMOVWrk); in CopyToFromAsymmetricReg()
4184 if (X86::VK16RegClass.contains(DestReg)) { in CopyToFromAsymmetricReg()
4185 if (X86::GR64RegClass.contains(SrcReg)) { in CopyToFromAsymmetricReg()
4187 return HasEGPR ? X86::KMOVQkr_EVEX : X86::KMOVQkr; in CopyToFromAsymmetricReg()
4189 if (X86::GR32RegClass.contains(SrcReg)) in CopyToFromAsymmetricReg()
4190 return Subtarget.hasBWI() ? (HasEGPR ? X86::KMOVDkr_EVEX : X86::KMOVDkr) in CopyToFromAsymmetricReg()
4191 : (HasEGPR ? X86::KMOVWkr_EVEX : X86::KMOVWkr); in CopyToFromAsymmetricReg()
4199 if (X86::GR64RegClass.contains(DestReg)) { in CopyToFromAsymmetricReg()
4200 if (X86::VR128XRegClass.contains(SrcReg)) in CopyToFromAsymmetricReg()
4202 return HasAVX512 ? X86::VMOVPQIto64Zrr in CopyToFromAsymmetricReg()
4203 : HasAVX ? X86::VMOVPQIto64rr in CopyToFromAsymmetricReg()
4204 : X86::MOVPQIto64rr; in CopyToFromAsymmetricReg()
4205 if (X86::VR64RegClass.contains(SrcReg)) in CopyToFromAsymmetricReg()
4207 return X86::MMX_MOVD64from64rr; in CopyToFromAsymmetricReg()
4208 } else if (X86::GR64RegClass.contains(SrcReg)) { in CopyToFromAsymmetricReg()
4210 if (X86::VR128XRegClass.contains(DestReg)) in CopyToFromAsymmetricReg()
4211 return HasAVX512 ? X86::VMOV64toPQIZrr in CopyToFromAsymmetricReg()
4212 : HasAVX ? X86::VMOV64toPQIrr in CopyToFromAsymmetricReg()
4213 : X86::MOV64toPQIrr; in CopyToFromAsymmetricReg()
4215 if (X86::VR64RegClass.contains(DestReg)) in CopyToFromAsymmetricReg()
4216 return X86::MMX_MOVD64to64rr; in CopyToFromAsymmetricReg()
4222 if (X86::GR32RegClass.contains(DestReg) && in CopyToFromAsymmetricReg()
4223 X86::VR128XRegClass.contains(SrcReg)) in CopyToFromAsymmetricReg()
4225 return HasAVX512 ? X86::VMOVPDI2DIZrr in CopyToFromAsymmetricReg()
4226 : HasAVX ? X86::VMOVPDI2DIrr in CopyToFromAsymmetricReg()
4227 : X86::MOVPDI2DIrr; in CopyToFromAsymmetricReg()
4229 if (X86::VR128XRegClass.contains(DestReg) && in CopyToFromAsymmetricReg()
4230 X86::GR32RegClass.contains(SrcReg)) in CopyToFromAsymmetricReg()
4232 return HasAVX512 ? X86::VMOVDI2PDIZrr in CopyToFromAsymmetricReg()
4233 : HasAVX ? X86::VMOVDI2PDIrr in CopyToFromAsymmetricReg()
4234 : X86::MOVDI2PDIrr; in CopyToFromAsymmetricReg()
4247 if (X86::GR64RegClass.contains(DestReg, SrcReg)) in copyPhysReg()
4248 Opc = X86::MOV64rr; in copyPhysReg()
4249 else if (X86::GR32RegClass.contains(DestReg, SrcReg)) in copyPhysReg()
4250 Opc = X86::MOV32rr; in copyPhysReg()
4251 else if (X86::GR16RegClass.contains(DestReg, SrcReg)) in copyPhysReg()
4252 Opc = X86::MOV16rr; in copyPhysReg()
4253 else if (X86::GR8RegClass.contains(DestReg, SrcReg)) { in copyPhysReg()
4254 // Copying to or from a physical H register on x86-64 requires a NOREX in copyPhysReg()
4257 Opc = X86::MOV8rr_NOREX; in copyPhysReg()
4259 assert(X86::GR8_NOREXRegClass.contains(SrcReg, DestReg) && in copyPhysReg()
4262 Opc = X86::MOV8rr; in copyPhysReg()
4263 } else if (X86::VR64RegClass.contains(DestReg, SrcReg)) in copyPhysReg()
4264 Opc = X86::MMX_MOVQ64rr; in copyPhysReg()
4265 else if (X86::VR128XRegClass.contains(DestReg, SrcReg)) { in copyPhysReg()
4267 Opc = X86::VMOVAPSZ128rr; in copyPhysReg()
4268 else if (X86::VR128RegClass.contains(DestReg, SrcReg)) in copyPhysReg()
4269 Opc = HasAVX ? X86::VMOVAPSrr : X86::MOVAPSrr; in copyPhysReg()
4273 Opc = X86::VMOVAPSZrr; in copyPhysReg()
4276 TRI->getMatchingSuperReg(DestReg, X86::sub_xmm, &X86::VR512RegClass); in copyPhysReg()
4278 TRI->getMatchingSuperReg(SrcReg, X86::sub_xmm, &X86::VR512RegClass); in copyPhysReg()
4280 } else if (X86::VR256XRegClass.contains(DestReg, SrcReg)) { in copyPhysReg()
4282 Opc = X86::VMOVAPSZ256rr; in copyPhysReg()
4283 else if (X86::VR256RegClass.contains(DestReg, SrcReg)) in copyPhysReg()
4284 Opc = X86::VMOVAPSYrr; in copyPhysReg()
4288 Opc = X86::VMOVAPSZrr; in copyPhysReg()
4291 TRI->getMatchingSuperReg(DestReg, X86::sub_ymm, &X86::VR512RegClass); in copyPhysReg()
4293 TRI->getMatchingSuperReg(SrcReg, X86::sub_ymm, &X86::VR512RegClass); in copyPhysReg()
4295 } else if (X86::VR512RegClass.contains(DestReg, SrcReg)) in copyPhysReg()
4296 Opc = X86::VMOVAPSZrr; in copyPhysReg()
4299 else if (X86::VK16RegClass.contains(DestReg, SrcReg)) in copyPhysReg()
4300 Opc = Subtarget.hasBWI() ? (HasEGPR ? X86::KMOVQkk_EVEX : X86::KMOVQkk) in copyPhysReg()
4301 : (HasEGPR ? X86::KMOVQkk_EVEX : X86::KMOVWkk); in copyPhysReg()
4311 if (SrcReg == X86::EFLAGS || DestReg == X86::EFLAGS) { in copyPhysReg()
4340 return Load ? X86::VMOVSHZrm_alt : X86::VMOVSHZmr; in getLoadStoreOpcodeForFP16()
4342 return STI.hasAVX512() ? X86::VMOVSSZrm in getLoadStoreOpcodeForFP16()
4343 : STI.hasAVX() ? X86::VMOVSSrm in getLoadStoreOpcodeForFP16()
4344 : X86::MOVSSrm; in getLoadStoreOpcodeForFP16()
4346 return STI.hasAVX512() ? X86::VMOVSSZmr in getLoadStoreOpcodeForFP16()
4347 : STI.hasAVX() ? X86::VMOVSSmr in getLoadStoreOpcodeForFP16()
4348 : X86::MOVSSmr; in getLoadStoreOpcodeForFP16()
4365 assert(X86::GR8RegClass.hasSubClassEq(RC) && "Unknown 1-byte regclass"); in getLoadStoreRegOpcode()
4367 // Copying to or from a physical H register on x86-64 requires a NOREX in getLoadStoreRegOpcode()
4369 if (isHReg(Reg) || X86::GR8_ABCD_HRegClass.hasSubClassEq(RC)) in getLoadStoreRegOpcode()
4370 return Load ? X86::MOV8rm_NOREX : X86::MOV8mr_NOREX; in getLoadStoreRegOpcode()
4371 return Load ? X86::MOV8rm : X86::MOV8mr; in getLoadStoreRegOpcode()
4373 if (X86::VK16RegClass.hasSubClassEq(RC)) in getLoadStoreRegOpcode()
4374 return Load ? (HasEGPR ? X86::KMOVWkm_EVEX : X86::KMOVWkm) in getLoadStoreRegOpcode()
4375 : (HasEGPR ? X86::KMOVWmk_EVEX : X86::KMOVWmk); in getLoadStoreRegOpcode()
4376 assert(X86::GR16RegClass.hasSubClassEq(RC) && "Unknown 2-byte regclass"); in getLoadStoreRegOpcode()
4377 return Load ? X86::MOV16rm : X86::MOV16mr; in getLoadStoreRegOpcode()
4379 if (X86::GR32RegClass.hasSubClassEq(RC)) in getLoadStoreRegOpcode()
4380 return Load ? X86::MOV32rm : X86::MOV32mr; in getLoadStoreRegOpcode()
4381 if (X86::FR32XRegClass.hasSubClassEq(RC)) in getLoadStoreRegOpcode()
4382 return Load ? (HasAVX512 ? X86::VMOVSSZrm_alt in getLoadStoreRegOpcode()
4383 : HasAVX ? X86::VMOVSSrm_alt in getLoadStoreRegOpcode()
4384 : X86::MOVSSrm_alt) in getLoadStoreRegOpcode()
4385 : (HasAVX512 ? X86::VMOVSSZmr in getLoadStoreRegOpcode()
4386 : HasAVX ? X86::VMOVSSmr in getLoadStoreRegOpcode()
4387 : X86::MOVSSmr); in getLoadStoreRegOpcode()
4388 if (X86::RFP32RegClass.hasSubClassEq(RC)) in getLoadStoreRegOpcode()
4389 return Load ? X86::LD_Fp32m : X86::ST_Fp32m; in getLoadStoreRegOpcode()
4390 if (X86::VK32RegClass.hasSubClassEq(RC)) { in getLoadStoreRegOpcode()
4392 return Load ? (HasEGPR ? X86::KMOVDkm_EVEX : X86::KMOVDkm) in getLoadStoreRegOpcode()
4393 : (HasEGPR ? X86::KMOVDmk_EVEX : X86::KMOVDmk); in getLoadStoreRegOpcode()
4397 if (X86::VK1PAIRRegClass.hasSubClassEq(RC) || in getLoadStoreRegOpcode()
4398 X86::VK2PAIRRegClass.hasSubClassEq(RC) || in getLoadStoreRegOpcode()
4399 X86::VK4PAIRRegClass.hasSubClassEq(RC) || in getLoadStoreRegOpcode()
4400 X86::VK8PAIRRegClass.hasSubClassEq(RC) || in getLoadStoreRegOpcode()
4401 X86::VK16PAIRRegClass.hasSubClassEq(RC)) in getLoadStoreRegOpcode()
4402 return Load ? X86::MASKPAIR16LOAD : X86::MASKPAIR16STORE; in getLoadStoreRegOpcode()
4403 if (X86::FR16RegClass.hasSubClassEq(RC) || in getLoadStoreRegOpcode()
4404 X86::FR16XRegClass.hasSubClassEq(RC)) in getLoadStoreRegOpcode()
4408 if (X86::GR64RegClass.hasSubClassEq(RC)) in getLoadStoreRegOpcode()
4409 return Load ? X86::MOV64rm : X86::MOV64mr; in getLoadStoreRegOpcode()
4410 if (X86::FR64XRegClass.hasSubClassEq(RC)) in getLoadStoreRegOpcode()
4411 return Load ? (HasAVX512 ? X86::VMOVSDZrm_alt in getLoadStoreRegOpcode()
4412 : HasAVX ? X86::VMOVSDrm_alt in getLoadStoreRegOpcode()
4413 : X86::MOVSDrm_alt) in getLoadStoreRegOpcode()
4414 : (HasAVX512 ? X86::VMOVSDZmr in getLoadStoreRegOpcode()
4415 : HasAVX ? X86::VMOVSDmr in getLoadStoreRegOpcode()
4416 : X86::MOVSDmr); in getLoadStoreRegOpcode()
4417 if (X86::VR64RegClass.hasSubClassEq(RC)) in getLoadStoreRegOpcode()
4418 return Load ? X86::MMX_MOVQ64rm : X86::MMX_MOVQ64mr; in getLoadStoreRegOpcode()
4419 if (X86::RFP64RegClass.hasSubClassEq(RC)) in getLoadStoreRegOpcode()
4420 return Load ? X86::LD_Fp64m : X86::ST_Fp64m; in getLoadStoreRegOpcode()
4421 if (X86::VK64RegClass.hasSubClassEq(RC)) { in getLoadStoreRegOpcode()
4423 return Load ? (HasEGPR ? X86::KMOVQkm_EVEX : X86::KMOVQkm) in getLoadStoreRegOpcode()
4424 : (HasEGPR ? X86::KMOVQmk_EVEX : X86::KMOVQmk); in getLoadStoreRegOpcode()
4428 assert(X86::RFP80RegClass.hasSubClassEq(RC) && "Unknown 10-byte regclass"); in getLoadStoreRegOpcode()
4429 return Load ? X86::LD_Fp80m : X86::ST_FpP80m; in getLoadStoreRegOpcode()
4431 if (X86::VR128XRegClass.hasSubClassEq(RC)) { in getLoadStoreRegOpcode()
4434 return Load ? (HasVLX ? X86::VMOVAPSZ128rm in getLoadStoreRegOpcode()
4435 : HasAVX512 ? X86::VMOVAPSZ128rm_NOVLX in getLoadStoreRegOpcode()
4436 : HasAVX ? X86::VMOVAPSrm in getLoadStoreRegOpcode()
4437 : X86::MOVAPSrm) in getLoadStoreRegOpcode()
4438 : (HasVLX ? X86::VMOVAPSZ128mr in getLoadStoreRegOpcode()
4439 : HasAVX512 ? X86::VMOVAPSZ128mr_NOVLX in getLoadStoreRegOpcode()
4440 : HasAVX ? X86::VMOVAPSmr in getLoadStoreRegOpcode()
4441 : X86::MOVAPSmr); in getLoadStoreRegOpcode()
4443 return Load ? (HasVLX ? X86::VMOVUPSZ128rm in getLoadStoreRegOpcode()
4444 : HasAVX512 ? X86::VMOVUPSZ128rm_NOVLX in getLoadStoreRegOpcode()
4445 : HasAVX ? X86::VMOVUPSrm in getLoadStoreRegOpcode()
4446 : X86::MOVUPSrm) in getLoadStoreRegOpcode()
4447 : (HasVLX ? X86::VMOVUPSZ128mr in getLoadStoreRegOpcode()
4448 : HasAVX512 ? X86::VMOVUPSZ128mr_NOVLX in getLoadStoreRegOpcode()
4449 : HasAVX ? X86::VMOVUPSmr in getLoadStoreRegOpcode()
4450 : X86::MOVUPSmr); in getLoadStoreRegOpcode()
4455 assert(X86::VR256XRegClass.hasSubClassEq(RC) && "Unknown 32-byte regclass"); in getLoadStoreRegOpcode()
4458 return Load ? (HasVLX ? X86::VMOVAPSZ256rm in getLoadStoreRegOpcode()
4459 : HasAVX512 ? X86::VMOVAPSZ256rm_NOVLX in getLoadStoreRegOpcode()
4460 : X86::VMOVAPSYrm) in getLoadStoreRegOpcode()
4461 : (HasVLX ? X86::VMOVAPSZ256mr in getLoadStoreRegOpcode()
4462 : HasAVX512 ? X86::VMOVAPSZ256mr_NOVLX in getLoadStoreRegOpcode()
4463 : X86::VMOVAPSYmr); in getLoadStoreRegOpcode()
4465 return Load ? (HasVLX ? X86::VMOVUPSZ256rm in getLoadStoreRegOpcode()
4466 : HasAVX512 ? X86::VMOVUPSZ256rm_NOVLX in getLoadStoreRegOpcode()
4467 : X86::VMOVUPSYrm) in getLoadStoreRegOpcode()
4468 : (HasVLX ? X86::VMOVUPSZ256mr in getLoadStoreRegOpcode()
4469 : HasAVX512 ? X86::VMOVUPSZ256mr_NOVLX in getLoadStoreRegOpcode()
4470 : X86::VMOVUPSYmr); in getLoadStoreRegOpcode()
4472 assert(X86::VR512RegClass.hasSubClassEq(RC) && "Unknown 64-byte regclass"); in getLoadStoreRegOpcode()
4475 return Load ? X86::VMOVAPSZrm : X86::VMOVAPSZmr; in getLoadStoreRegOpcode()
4477 return Load ? X86::VMOVUPSZrm : X86::VMOVUPSZmr; in getLoadStoreRegOpcode()
4479 assert(X86::TILERegClass.hasSubClassEq(RC) && "Unknown 1024-byte regclass"); in getLoadStoreRegOpcode()
4482 return Load ? GET_EGPR_IF_ENABLED(X86::TILELOADD) in getLoadStoreRegOpcode()
4483 : GET_EGPR_IF_ENABLED(X86::TILESTORED); in getLoadStoreRegOpcode()
4498 auto &BaseOp = MemI.getOperand(MemRefBegin + X86::AddrBaseReg); in getAddrModeFromMemoryOp()
4502 const MachineOperand &DispMO = MemI.getOperand(MemRefBegin + X86::AddrDisp); in getAddrModeFromMemoryOp()
4509 AM.ScaledReg = MemI.getOperand(MemRefBegin + X86::AddrIndexReg).getReg(); in getAddrModeFromMemoryOp()
4510 AM.Scale = MemI.getOperand(MemRefBegin + X86::AddrScaleAmt).getImm(); in getAddrModeFromMemoryOp()
4523 if (AM.ScaledReg != X86::NoRegister) { in verifyInstruction()
4551 // instruction. It is quite common for x86-64. in getConstValDefinedInReg()
4561 if (SubIdx != X86::sub_32bit || FillBits != 0) in getConstValDefinedInReg()
4569 if (MovMI->getOpcode() == X86::MOV32r0 && in getConstValDefinedInReg()
4575 if (MovMI->getOpcode() != X86::MOV32ri && in getConstValDefinedInReg()
4576 MovMI->getOpcode() != X86::MOV64ri && in getConstValDefinedInReg()
4577 MovMI->getOpcode() != X86::MOV32ri64 && MovMI->getOpcode() != X86::MOV8ri) in getConstValDefinedInReg()
4594 case X86::SHR64ri: in preservesZeroValueInReg()
4595 case X86::SHR32ri: in preservesZeroValueInReg()
4596 case X86::SHL64ri: in preservesZeroValueInReg()
4597 case X86::SHL32ri: in preservesZeroValueInReg()
4604 case X86::MOV32rr: in preservesZeroValueInReg()
4626 &MemOp.getOperand(MemRefBegin + X86::AddrBaseReg); in getMemOperandsWithOffsetWidth()
4630 if (MemOp.getOperand(MemRefBegin + X86::AddrScaleAmt).getImm() != 1) in getMemOperandsWithOffsetWidth()
4633 if (MemOp.getOperand(MemRefBegin + X86::AddrIndexReg).getReg() != in getMemOperandsWithOffsetWidth()
4634 X86::NoRegister) in getMemOperandsWithOffsetWidth()
4637 const MachineOperand &DispMO = MemOp.getOperand(MemRefBegin + X86::AddrDisp); in getMemOperandsWithOffsetWidth()
4650 // with X86 maintainers, and fix it accordingly. For now, it is ok, since in getMemOperandsWithOffsetWidth()
4651 // there is no use of `Width` for X86 back-end at the moment. in getMemOperandsWithOffsetWidth()
4675 case X86::TILELOADD: in isAMXOpcode()
4676 case X86::TILESTORED: in isAMXOpcode()
4677 case X86::TILELOADD_EVEX: in isAMXOpcode()
4678 case X86::TILESTORED_EVEX: in isAMXOpcode()
4690 case X86::TILESTORED: in loadStoreTileReg()
4691 case X86::TILESTORED_EVEX: { in loadStoreTileReg()
4694 Register VirtReg = RegInfo.createVirtualRegister(&X86::GR64_NOSPRegClass); in loadStoreTileReg()
4695 BuildMI(MBB, MI, DebugLoc(), get(X86::MOV64ri), VirtReg).addImm(64); in loadStoreTileReg()
4699 MachineOperand &MO = NewMI->getOperand(X86::AddrIndexReg); in loadStoreTileReg()
4704 case X86::TILELOADD: in loadStoreTileReg()
4705 case X86::TILELOADD_EVEX: { in loadStoreTileReg()
4708 Register VirtReg = RegInfo.createVirtualRegister(&X86::GR64_NOSPRegClass); in loadStoreTileReg()
4709 BuildMI(MBB, MI, DebugLoc(), get(X86::MOV64ri), VirtReg).addImm(64); in loadStoreTileReg()
4712 MachineOperand &MO = NewMI->getOperand(1 + X86::AddrIndexReg); in loadStoreTileReg()
4771 case X86::CMP64ri32: in analyzeCompare()
4772 case X86::CMP32ri: in analyzeCompare()
4773 case X86::CMP16ri: in analyzeCompare()
4774 case X86::CMP8ri: in analyzeCompare()
4816 case X86::CMP64rr: in analyzeCompare()
4817 case X86::CMP32rr: in analyzeCompare()
4818 case X86::CMP16rr: in analyzeCompare()
4819 case X86::CMP8rr: in analyzeCompare()
4825 case X86::TEST8rr: in analyzeCompare()
4826 case X86::TEST16rr: in analyzeCompare()
4827 case X86::TEST32rr: in analyzeCompare()
4828 case X86::TEST64rr: in analyzeCompare()
4847 case X86::CMP64rr: in isRedundantFlagInstr()
4848 case X86::CMP32rr: in isRedundantFlagInstr()
4849 case X86::CMP16rr: in isRedundantFlagInstr()
4850 case X86::CMP8rr: in isRedundantFlagInstr()
4872 case X86::CMP64ri32: in isRedundantFlagInstr()
4873 case X86::CMP32ri: in isRedundantFlagInstr()
4874 case X86::CMP16ri: in isRedundantFlagInstr()
4875 case X86::CMP8ri: in isRedundantFlagInstr()
4880 case X86::TEST64rr: in isRedundantFlagInstr()
4881 case X86::TEST32rr: in isRedundantFlagInstr()
4882 case X86::TEST16rr: in isRedundantFlagInstr()
4883 case X86::TEST8rr: { in isRedundantFlagInstr()
4921 // "ELF Handling for Thread-Local Storage" specifies that x86-64 GOTTPOFF, and in isDefConvertible()
4925 if (MI.getOpcode() == X86::ADD64rm || MI.getOpcode() == X86::ADD32rm) { in isDefConvertible()
5028 case X86::LZCNT16rr: in isDefConvertible()
5029 case X86::LZCNT16rm: in isDefConvertible()
5030 case X86::LZCNT32rr: in isDefConvertible()
5031 case X86::LZCNT32rm: in isDefConvertible()
5032 case X86::LZCNT64rr: in isDefConvertible()
5033 case X86::LZCNT64rm: in isDefConvertible()
5034 case X86::POPCNT16rr: in isDefConvertible()
5035 case X86::POPCNT16rm: in isDefConvertible()
5036 case X86::POPCNT32rr: in isDefConvertible()
5037 case X86::POPCNT32rm: in isDefConvertible()
5038 case X86::POPCNT64rr: in isDefConvertible()
5039 case X86::POPCNT64rm: in isDefConvertible()
5040 case X86::TZCNT16rr: in isDefConvertible()
5041 case X86::TZCNT16rm: in isDefConvertible()
5042 case X86::TZCNT32rr: in isDefConvertible()
5043 case X86::TZCNT32rm: in isDefConvertible()
5044 case X86::TZCNT64rr: in isDefConvertible()
5045 case X86::TZCNT64rm: in isDefConvertible()
5083 case X86::ANDN32rr: in isDefConvertible()
5084 case X86::ANDN32rm: in isDefConvertible()
5085 case X86::ANDN64rr: in isDefConvertible()
5086 case X86::ANDN64rm: in isDefConvertible()
5087 case X86::BLSI32rr: in isDefConvertible()
5088 case X86::BLSI32rm: in isDefConvertible()
5089 case X86::BLSI64rr: in isDefConvertible()
5090 case X86::BLSI64rm: in isDefConvertible()
5091 case X86::BLSMSK32rr: in isDefConvertible()
5092 case X86::BLSMSK32rm: in isDefConvertible()
5093 case X86::BLSMSK64rr: in isDefConvertible()
5094 case X86::BLSMSK64rm: in isDefConvertible()
5095 case X86::BLSR32rr: in isDefConvertible()
5096 case X86::BLSR32rm: in isDefConvertible()
5097 case X86::BLSR64rr: in isDefConvertible()
5098 case X86::BLSR64rm: in isDefConvertible()
5099 case X86::BLCFILL32rr: in isDefConvertible()
5100 case X86::BLCFILL32rm: in isDefConvertible()
5101 case X86::BLCFILL64rr: in isDefConvertible()
5102 case X86::BLCFILL64rm: in isDefConvertible()
5103 case X86::BLCI32rr: in isDefConvertible()
5104 case X86::BLCI32rm: in isDefConvertible()
5105 case X86::BLCI64rr: in isDefConvertible()
5106 case X86::BLCI64rm: in isDefConvertible()
5107 case X86::BLCIC32rr: in isDefConvertible()
5108 case X86::BLCIC32rm: in isDefConvertible()
5109 case X86::BLCIC64rr: in isDefConvertible()
5110 case X86::BLCIC64rm: in isDefConvertible()
5111 case X86::BLCMSK32rr: in isDefConvertible()
5112 case X86::BLCMSK32rm: in isDefConvertible()
5113 case X86::BLCMSK64rr: in isDefConvertible()
5114 case X86::BLCMSK64rm: in isDefConvertible()
5115 case X86::BLCS32rr: in isDefConvertible()
5116 case X86::BLCS32rm: in isDefConvertible()
5117 case X86::BLCS64rr: in isDefConvertible()
5118 case X86::BLCS64rm: in isDefConvertible()
5119 case X86::BLSFILL32rr: in isDefConvertible()
5120 case X86::BLSFILL32rm: in isDefConvertible()
5121 case X86::BLSFILL64rr: in isDefConvertible()
5122 case X86::BLSFILL64rm: in isDefConvertible()
5123 case X86::BLSIC32rr: in isDefConvertible()
5124 case X86::BLSIC32rm: in isDefConvertible()
5125 case X86::BLSIC64rr: in isDefConvertible()
5126 case X86::BLSIC64rm: in isDefConvertible()
5127 case X86::BZHI32rr: in isDefConvertible()
5128 case X86::BZHI32rm: in isDefConvertible()
5129 case X86::BZHI64rr: in isDefConvertible()
5130 case X86::BZHI64rm: in isDefConvertible()
5131 case X86::T1MSKC32rr: in isDefConvertible()
5132 case X86::T1MSKC32rm: in isDefConvertible()
5133 case X86::T1MSKC64rr: in isDefConvertible()
5134 case X86::T1MSKC64rm: in isDefConvertible()
5135 case X86::TZMSK32rr: in isDefConvertible()
5136 case X86::TZMSK32rm: in isDefConvertible()
5137 case X86::TZMSK64rr: in isDefConvertible()
5138 case X86::TZMSK64rm: in isDefConvertible()
5144 case X86::BEXTR32rr: in isDefConvertible()
5145 case X86::BEXTR64rr: in isDefConvertible()
5146 case X86::BEXTR32rm: in isDefConvertible()
5147 case X86::BEXTR64rm: in isDefConvertible()
5148 case X86::BEXTRI32ri: in isDefConvertible()
5149 case X86::BEXTRI32mi: in isDefConvertible()
5150 case X86::BEXTRI64ri: in isDefConvertible()
5151 case X86::BEXTRI64mi: in isDefConvertible()
5160 static X86::CondCode isUseDefConvertible(const MachineInstr &MI) { in isUseDefConvertible()
5163 return X86::COND_INVALID; in isUseDefConvertible()
5168 return X86::COND_AE; in isUseDefConvertible()
5169 case X86::LZCNT16rr: in isUseDefConvertible()
5170 case X86::LZCNT32rr: in isUseDefConvertible()
5171 case X86::LZCNT64rr: in isUseDefConvertible()
5172 return X86::COND_B; in isUseDefConvertible()
5173 case X86::POPCNT16rr: in isUseDefConvertible()
5174 case X86::POPCNT32rr: in isUseDefConvertible()
5175 case X86::POPCNT64rr: in isUseDefConvertible()
5176 return X86::COND_E; in isUseDefConvertible()
5177 case X86::TZCNT16rr: in isUseDefConvertible()
5178 case X86::TZCNT32rr: in isUseDefConvertible()
5179 case X86::TZCNT64rr: in isUseDefConvertible()
5180 return X86::COND_B; in isUseDefConvertible()
5181 case X86::BSF16rr: in isUseDefConvertible()
5182 case X86::BSF32rr: in isUseDefConvertible()
5183 case X86::BSF64rr: in isUseDefConvertible()
5184 case X86::BSR16rr: in isUseDefConvertible()
5185 case X86::BSR32rr: in isUseDefConvertible()
5186 case X86::BSR64rr: in isUseDefConvertible()
5187 return X86::COND_E; in isUseDefConvertible()
5188 case X86::BLSI32rr: in isUseDefConvertible()
5189 case X86::BLSI64rr: in isUseDefConvertible()
5190 return X86::COND_AE; in isUseDefConvertible()
5191 case X86::BLSR32rr: in isUseDefConvertible()
5192 case X86::BLSR64rr: in isUseDefConvertible()
5193 case X86::BLSMSK32rr: in isUseDefConvertible()
5194 case X86::BLSMSK64rr: in isUseDefConvertible()
5195 return X86::COND_B; in isUseDefConvertible()
5228 CASE_ND(A) NewOpcode = X86::B; \ in optimizeCompareInstr()
5252 if (NewOpcode == X86::CMP64rm || NewOpcode == X86::CMP32rm || in optimizeCompareInstr()
5253 NewOpcode == X86::CMP16rm || NewOpcode == X86::CMP8rm) in optimizeCompareInstr()
5276 X86::CondCode NewCC = X86::COND_INVALID; in optimizeCompareInstr()
5314 assert(AndInstr != nullptr && X86::isAND(AndInstr->getOpcode())); in optimizeCompareInstr()
5322 if (Inst.modifiesRegister(X86::EFLAGS, TRI)) { in optimizeCompareInstr()
5332 if (NewCC != X86::COND_INVALID && Inst.getOperand(1).isReg() && in optimizeCompareInstr()
5354 if (!Movr0Inst && Inst.getOpcode() == X86::MOV32r0 && in optimizeCompareInstr()
5355 Inst.registerDefIsDead(X86::EFLAGS, TRI)) { in optimizeCompareInstr()
5381 SmallVector<std::pair<MachineInstr *, X86::CondCode>, 4> OpsToUpdate; in optimizeCompareInstr()
5385 bool ModifyEFLAGS = Instr.modifiesRegister(X86::EFLAGS, TRI); in optimizeCompareInstr()
5386 bool UseEFLAGS = Instr.readsRegister(X86::EFLAGS, TRI); in optimizeCompareInstr()
5397 X86::CondCode OldCC = X86::getCondFromMI(Instr); in optimizeCompareInstr()
5398 if ((MI || IsSwapped || ImmDelta != 0) && OldCC == X86::COND_INVALID) in optimizeCompareInstr()
5401 X86::CondCode ReplacementCC = X86::COND_INVALID; in optimizeCompareInstr()
5406 case X86::COND_A: in optimizeCompareInstr()
5407 case X86::COND_AE: in optimizeCompareInstr()
5408 case X86::COND_B: in optimizeCompareInstr()
5409 case X86::COND_BE: in optimizeCompareInstr()
5412 case X86::COND_G: in optimizeCompareInstr()
5413 case X86::COND_GE: in optimizeCompareInstr()
5414 case X86::COND_L: in optimizeCompareInstr()
5415 case X86::COND_LE: in optimizeCompareInstr()
5421 case X86::COND_O: in optimizeCompareInstr()
5422 case X86::COND_NO: in optimizeCompareInstr()
5427 case X86::COND_S: in optimizeCompareInstr()
5428 case X86::COND_NS: in optimizeCompareInstr()
5442 case X86::COND_E: in optimizeCompareInstr()
5445 case X86::COND_NE: in optimizeCompareInstr()
5454 if (ReplacementCC == X86::COND_INVALID) in optimizeCompareInstr()
5462 case X86::COND_L: // x <s (C + 1) --> x <=s C in optimizeCompareInstr()
5465 ReplacementCC = X86::COND_LE; in optimizeCompareInstr()
5467 case X86::COND_B: // x <u (C + 1) --> x <=u C in optimizeCompareInstr()
5470 ReplacementCC = X86::COND_BE; in optimizeCompareInstr()
5472 case X86::COND_GE: // x >=s (C + 1) --> x >s C in optimizeCompareInstr()
5475 ReplacementCC = X86::COND_G; in optimizeCompareInstr()
5477 case X86::COND_AE: // x >=u (C + 1) --> x >u C in optimizeCompareInstr()
5480 ReplacementCC = X86::COND_A; in optimizeCompareInstr()
5482 case X86::COND_G: // x >s (C - 1) --> x >=s C in optimizeCompareInstr()
5485 ReplacementCC = X86::COND_GE; in optimizeCompareInstr()
5487 case X86::COND_A: // x >u (C - 1) --> x >=u C in optimizeCompareInstr()
5490 ReplacementCC = X86::COND_AE; in optimizeCompareInstr()
5492 case X86::COND_LE: // x <=s (C - 1) --> x <s C in optimizeCompareInstr()
5495 ReplacementCC = X86::COND_L; in optimizeCompareInstr()
5497 case X86::COND_BE: // x <=u (C - 1) --> x <u C in optimizeCompareInstr()
5500 ReplacementCC = X86::COND_B; in optimizeCompareInstr()
5514 if (ModifyEFLAGS || Instr.killsRegister(X86::EFLAGS, TRI)) { in optimizeCompareInstr()
5525 if (Successor->isLiveIn(X86::EFLAGS)) in optimizeCompareInstr()
5544 if (!Instr->readsRegister(X86::EFLAGS, TRI) && in optimizeCompareInstr()
5545 Instr->modifiesRegister(X86::EFLAGS, TRI)) { in optimizeCompareInstr()
5558 Sub->findRegisterDefOperand(X86::EFLAGS, /*TRI=*/nullptr); in optimizeCompareInstr()
5573 if (!MBB->isLiveIn(X86::EFLAGS)) in optimizeCompareInstr()
5574 MBB->addLiveIn(X86::EFLAGS); in optimizeCompareInstr()
5644 case X86::FROM: \ in convertALUrr2ALUri()
5645 return X86::TO; \ in convertALUrr2ALUri()
5646 case X86::FROM##_ND: \ in convertALUrr2ALUri()
5647 return X86::TO##_ND; in convertALUrr2ALUri()
5678 case X86::FROM: \ in convertALUrr2ALUri()
5679 return X86::TO; in convertALUrr2ALUri()
5709 if ((Reg.isPhysical() && X86::GR64RegClass.contains(Reg)) || in foldImmediateImpl()
5710 (Reg.isVirtual() && X86::GR64RegClass.hasSubClassEq(RC))) { in foldImmediateImpl()
5730 bool GR32Reg = (ToReg.isVirtual() && X86::GR32RegClass.hasSubClassEq(RC)) || in foldImmediateImpl()
5731 (ToReg.isPhysical() && X86::GR32RegClass.contains(ToReg)); in foldImmediateImpl()
5732 bool GR64Reg = (ToReg.isVirtual() && X86::GR64RegClass.hasSubClassEq(RC)) || in foldImmediateImpl()
5733 (ToReg.isPhysical() && X86::GR64RegClass.contains(ToReg)); in foldImmediateImpl()
5734 bool GR8Reg = (ToReg.isVirtual() && X86::GR8RegClass.hasSubClassEq(RC)) || in foldImmediateImpl()
5735 (ToReg.isPhysical() && X86::GR8RegClass.contains(ToReg)); in foldImmediateImpl()
5745 NewOpc = X86::MOV32ri64; in foldImmediateImpl()
5747 NewOpc = X86::MOV64ri; in foldImmediateImpl()
5749 NewOpc = X86::MOV32ri; in foldImmediateImpl()
5754 TRI, X86::EFLAGS, UseMI) != MachineBasicBlock::LQR_Dead) in foldImmediateImpl()
5761 UseMI.setDesc(get(X86::MOV32r0)); in foldImmediateImpl()
5764 UseMI.addOperand(MachineOperand::CreateReg(X86::EFLAGS, /*isDef=*/true, in foldImmediateImpl()
5771 NewOpc = X86::MOV8ri; in foldImmediateImpl()
5781 if ((NewOpc == X86::SUB64ri32 || NewOpc == X86::SUB32ri || in foldImmediateImpl()
5782 NewOpc == X86::SBB64ri32 || NewOpc == X86::SBB32ri || in foldImmediateImpl()
5783 NewOpc == X86::SUB64ri32_ND || NewOpc == X86::SUB32ri_ND || in foldImmediateImpl()
5784 NewOpc == X86::SBB64ri32_ND || NewOpc == X86::SBB32ri_ND) && in foldImmediateImpl()
5788 if (((NewOpc == X86::CMP64ri32 || NewOpc == X86::CMP32ri) || in foldImmediateImpl()
5789 (NewOpc == X86::CCMP64ri32 || NewOpc == X86::CCMP32ri)) && in foldImmediateImpl()
5793 using namespace X86; in foldImmediateImpl()
5801 assert(Reg == X86::CL); in foldImmediateImpl()
5820 UseMI.registerDefIsDead(X86::EFLAGS, /*TRI=*/nullptr)) { in foldImmediateImpl()
5828 UseMI.findRegisterDefOperandIdx(X86::EFLAGS, /*TRI=*/nullptr)); in foldImmediateImpl()
5910 BuildMI(MBB, MIB.getInstr(), DL, TII.get(X86::XOR32rr), Reg) in expandMOV32r1()
5915 MIB->setDesc(TII.get(MinusOne ? X86::DEC32r : X86::INC32r)); in expandMOV32r1()
5933 assert(MIB->getOpcode() == X86::MOV64ImmSExti8 || in ExpandMOVImmSExti8()
5934 MIB->getOpcode() == X86::MOV32ImmSExti8); in ExpandMOVImmSExti8()
5940 MIB->setDesc(TII.get(MIB->getOpcode() == X86::MOV32ImmSExti8 in ExpandMOVImmSExti8()
5941 ? X86::MOV32ri in ExpandMOVImmSExti8()
5942 : X86::MOV64ri)); in ExpandMOVImmSExti8()
5949 BuildMI(MBB, I, DL, TII.get(X86::PUSH64i32)).addImm(Imm); in ExpandMOVImmSExti8()
5950 MIB->setDesc(TII.get(X86::POP64r)); in ExpandMOVImmSExti8()
5953 assert(MIB->getOpcode() == X86::MOV32ImmSExti8); in ExpandMOVImmSExti8()
5955 BuildMI(MBB, I, DL, TII.get(X86::PUSH32i)).addImm(Imm); in ExpandMOVImmSExti8()
5956 MIB->setDesc(TII.get(X86::POP32r)); in ExpandMOVImmSExti8()
5995 BuildMI(MBB, I, DL, TII.get(X86::MOV64rm), Reg) in expandLoadStackGuard()
5996 .addReg(X86::RIP) in expandLoadStackGuard()
6003 MIB->setDesc(TII.get(X86::MOV64rm)); in expandLoadStackGuard()
6013 MIB->getOpcode() == X86::XOR64_FP ? X86::XOR64rr : X86::XOR32rr; in expandXorFP()
6035 DestReg = TRI->getMatchingSuperReg(DestReg, SubIdx, &X86::VR512RegClass); in expandNOVLXLoad()
6048 Register SrcReg = MIB.getReg(X86::AddrNumOperands); in expandNOVLXStore()
6057 SrcReg = TRI->getMatchingSuperReg(SrcReg, SubIdx, &X86::VR512RegClass); in expandNOVLXStore()
6058 MIB->getOperand(X86::AddrNumOperands).setReg(SrcReg); in expandNOVLXStore()
6081 case X86::MOV32r0: in expandPostRAPseudo()
6082 return Expand2AddrUndef(MIB, get(X86::XOR32rr)); in expandPostRAPseudo()
6083 case X86::MOV32r1: in expandPostRAPseudo()
6085 case X86::MOV32r_1: in expandPostRAPseudo()
6087 case X86::MOV32ImmSExti8: in expandPostRAPseudo()
6088 case X86::MOV64ImmSExti8: in expandPostRAPseudo()
6090 case X86::SETB_C32r: in expandPostRAPseudo()
6091 return Expand2AddrUndef(MIB, get(X86::SBB32rr)); in expandPostRAPseudo()
6092 case X86::SETB_C64r: in expandPostRAPseudo()
6093 return Expand2AddrUndef(MIB, get(X86::SBB64rr)); in expandPostRAPseudo()
6094 case X86::MMX_SET0: in expandPostRAPseudo()
6095 return Expand2AddrUndef(MIB, get(X86::MMX_PXORrr)); in expandPostRAPseudo()
6096 case X86::V_SET0: in expandPostRAPseudo()
6097 case X86::FsFLD0SS: in expandPostRAPseudo()
6098 case X86::FsFLD0SD: in expandPostRAPseudo()
6099 case X86::FsFLD0SH: in expandPostRAPseudo()
6100 case X86::FsFLD0F128: in expandPostRAPseudo()
6101 return Expand2AddrUndef(MIB, get(HasAVX ? X86::VXORPSrr : X86::XORPSrr)); in expandPostRAPseudo()
6102 case X86::AVX_SET0: { in expandPostRAPseudo()
6106 Register XReg = TRI->getSubReg(SrcReg, X86::sub_xmm); in expandPostRAPseudo()
6108 Expand2AddrUndef(MIB, get(X86::VXORPSrr)); in expandPostRAPseudo()
6112 case X86::AVX512_128_SET0: in expandPostRAPseudo()
6113 case X86::AVX512_FsFLD0SH: in expandPostRAPseudo()
6114 case X86::AVX512_FsFLD0SS: in expandPostRAPseudo()
6115 case X86::AVX512_FsFLD0SD: in expandPostRAPseudo()
6116 case X86::AVX512_FsFLD0F128: { in expandPostRAPseudo()
6122 get(HasVLX ? X86::VPXORDZ128rr : X86::VXORPSrr)); in expandPostRAPseudo()
6125 TRI->getMatchingSuperReg(SrcReg, X86::sub_xmm, &X86::VR512RegClass); in expandPostRAPseudo()
6127 return Expand2AddrUndef(MIB, get(X86::VPXORDZrr)); in expandPostRAPseudo()
6129 case X86::AVX512_256_SET0: in expandPostRAPseudo()
6130 case X86::AVX512_512_SET0: { in expandPostRAPseudo()
6135 Register XReg = TRI->getSubReg(SrcReg, X86::sub_xmm); in expandPostRAPseudo()
6137 Expand2AddrUndef(MIB, get(HasVLX ? X86::VPXORDZ128rr : X86::VXORPSrr)); in expandPostRAPseudo()
6141 if (MI.getOpcode() == X86::AVX512_256_SET0) { in expandPostRAPseudo()
6144 TRI->getMatchingSuperReg(SrcReg, X86::sub_ymm, &X86::VR512RegClass); in expandPostRAPseudo()
6147 return Expand2AddrUndef(MIB, get(X86::VPXORDZrr)); in expandPostRAPseudo()
6149 case X86::V_SETALLONES: in expandPostRAPseudo()
6151 get(HasAVX ? X86::VPCMPEQDrr : X86::PCMPEQDrr)); in expandPostRAPseudo()
6152 case X86::AVX2_SETALLONES: in expandPostRAPseudo()
6153 return Expand2AddrUndef(MIB, get(X86::VPCMPEQDYrr)); in expandPostRAPseudo()
6154 case X86::AVX1_SETALLONES: { in expandPostRAPseudo()
6157 MIB->setDesc(get(X86::VCMPPSYrri)); in expandPostRAPseudo()
6161 case X86::AVX512_512_SETALLONES: { in expandPostRAPseudo()
6163 MIB->setDesc(get(X86::VPTERNLOGDZrri)); in expandPostRAPseudo()
6172 case X86::AVX512_512_SEXT_MASK_32: in expandPostRAPseudo()
6173 case X86::AVX512_512_SEXT_MASK_64: { in expandPostRAPseudo()
6177 unsigned Opc = (MI.getOpcode() == X86::AVX512_512_SEXT_MASK_64) in expandPostRAPseudo()
6178 ? X86::VPTERNLOGQZrrikz in expandPostRAPseudo()
6179 : X86::VPTERNLOGDZrrikz; in expandPostRAPseudo()
6191 case X86::VMOVAPSZ128rm_NOVLX: in expandPostRAPseudo()
6192 return expandNOVLXLoad(MIB, &getRegisterInfo(), get(X86::VMOVAPSrm), in expandPostRAPseudo()
6193 get(X86::VBROADCASTF32X4rm), X86::sub_xmm); in expandPostRAPseudo()
6194 case X86::VMOVUPSZ128rm_NOVLX: in expandPostRAPseudo()
6195 return expandNOVLXLoad(MIB, &getRegisterInfo(), get(X86::VMOVUPSrm), in expandPostRAPseudo()
6196 get(X86::VBROADCASTF32X4rm), X86::sub_xmm); in expandPostRAPseudo()
6197 case X86::VMOVAPSZ256rm_NOVLX: in expandPostRAPseudo()
6198 return expandNOVLXLoad(MIB, &getRegisterInfo(), get(X86::VMOVAPSYrm), in expandPostRAPseudo()
6199 get(X86::VBROADCASTF64X4rm), X86::sub_ymm); in expandPostRAPseudo()
6200 case X86::VMOVUPSZ256rm_NOVLX: in expandPostRAPseudo()
6201 return expandNOVLXLoad(MIB, &getRegisterInfo(), get(X86::VMOVUPSYrm), in expandPostRAPseudo()
6202 get(X86::VBROADCASTF64X4rm), X86::sub_ymm); in expandPostRAPseudo()
6203 case X86::VMOVAPSZ128mr_NOVLX: in expandPostRAPseudo()
6204 return expandNOVLXStore(MIB, &getRegisterInfo(), get(X86::VMOVAPSmr), in expandPostRAPseudo()
6205 get(X86::VEXTRACTF32x4Zmr), X86::sub_xmm); in expandPostRAPseudo()
6206 case X86::VMOVUPSZ128mr_NOVLX: in expandPostRAPseudo()
6207 return expandNOVLXStore(MIB, &getRegisterInfo(), get(X86::VMOVUPSmr), in expandPostRAPseudo()
6208 get(X86::VEXTRACTF32x4Zmr), X86::sub_xmm); in expandPostRAPseudo()
6209 case X86::VMOVAPSZ256mr_NOVLX: in expandPostRAPseudo()
6210 return expandNOVLXStore(MIB, &getRegisterInfo(), get(X86::VMOVAPSYmr), in expandPostRAPseudo()
6211 get(X86::VEXTRACTF64x4Zmr), X86::sub_ymm); in expandPostRAPseudo()
6212 case X86::VMOVUPSZ256mr_NOVLX: in expandPostRAPseudo()
6213 return expandNOVLXStore(MIB, &getRegisterInfo(), get(X86::VMOVUPSYmr), in expandPostRAPseudo()
6214 get(X86::VEXTRACTF64x4Zmr), X86::sub_ymm); in expandPostRAPseudo()
6215 case X86::MOV32ri64: { in expandPostRAPseudo()
6217 Register Reg32 = RI.getSubReg(Reg, X86::sub_32bit); in expandPostRAPseudo()
6218 MI.setDesc(get(X86::MOV32ri)); in expandPostRAPseudo()
6224 case X86::RDFLAGS32: in expandPostRAPseudo()
6225 case X86::RDFLAGS64: { in expandPostRAPseudo()
6226 unsigned Is64Bit = MI.getOpcode() == X86::RDFLAGS64; in expandPostRAPseudo()
6230 get(Is64Bit ? X86::PUSHF64 : X86::PUSHF32)) in expandPostRAPseudo()
6237 assert(NewMI->getOperand(2).getReg() == X86::EFLAGS && in expandPostRAPseudo()
6240 assert(NewMI->getOperand(3).getReg() == X86::DF && in expandPostRAPseudo()
6244 MIB->setDesc(get(Is64Bit ? X86::POP64r : X86::POP32r)); in expandPostRAPseudo()
6248 case X86::WRFLAGS32: in expandPostRAPseudo()
6249 case X86::WRFLAGS64: { in expandPostRAPseudo()
6250 unsigned Is64Bit = MI.getOpcode() == X86::WRFLAGS64; in expandPostRAPseudo()
6254 get(Is64Bit ? X86::PUSH64r : X86::PUSH32r)) in expandPostRAPseudo()
6257 get(Is64Bit ? X86::POPF64 : X86::POPF32)); in expandPostRAPseudo()
6269 case X86::KSET0W: in expandPostRAPseudo()
6270 return Expand2AddrKreg(MIB, get(X86::KXORWrr), X86::K0); in expandPostRAPseudo()
6271 case X86::KSET0D: in expandPostRAPseudo()
6272 return Expand2AddrKreg(MIB, get(X86::KXORDrr), X86::K0); in expandPostRAPseudo()
6273 case X86::KSET0Q: in expandPostRAPseudo()
6274 return Expand2AddrKreg(MIB, get(X86::KXORQrr), X86::K0); in expandPostRAPseudo()
6275 case X86::KSET1W: in expandPostRAPseudo()
6276 return Expand2AddrKreg(MIB, get(X86::KXNORWrr), X86::K0); in expandPostRAPseudo()
6277 case X86::KSET1D: in expandPostRAPseudo()
6278 return Expand2AddrKreg(MIB, get(X86::KXNORDrr), X86::K0); in expandPostRAPseudo()
6279 case X86::KSET1Q: in expandPostRAPseudo()
6280 return Expand2AddrKreg(MIB, get(X86::KXNORQrr), X86::K0); in expandPostRAPseudo()
6284 case X86::XOR64_FP: in expandPostRAPseudo()
6285 case X86::XOR32_FP: in expandPostRAPseudo()
6287 case X86::SHLDROT32ri: in expandPostRAPseudo()
6288 return expandSHXDROT(MIB, get(X86::SHLD32rri8)); in expandPostRAPseudo()
6289 case X86::SHLDROT64ri: in expandPostRAPseudo()
6290 return expandSHXDROT(MIB, get(X86::SHLD64rri8)); in expandPostRAPseudo()
6291 case X86::SHRDROT32ri: in expandPostRAPseudo()
6292 return expandSHXDROT(MIB, get(X86::SHRD32rri8)); in expandPostRAPseudo()
6293 case X86::SHRDROT64ri: in expandPostRAPseudo()
6294 return expandSHXDROT(MIB, get(X86::SHRD64rri8)); in expandPostRAPseudo()
6295 case X86::ADD8rr_DB: in expandPostRAPseudo()
6296 MIB->setDesc(get(X86::OR8rr)); in expandPostRAPseudo()
6298 case X86::ADD16rr_DB: in expandPostRAPseudo()
6299 MIB->setDesc(get(X86::OR16rr)); in expandPostRAPseudo()
6301 case X86::ADD32rr_DB: in expandPostRAPseudo()
6302 MIB->setDesc(get(X86::OR32rr)); in expandPostRAPseudo()
6304 case X86::ADD64rr_DB: in expandPostRAPseudo()
6305 MIB->setDesc(get(X86::OR64rr)); in expandPostRAPseudo()
6307 case X86::ADD8ri_DB: in expandPostRAPseudo()
6308 MIB->setDesc(get(X86::OR8ri)); in expandPostRAPseudo()
6310 case X86::ADD16ri_DB: in expandPostRAPseudo()
6311 MIB->setDesc(get(X86::OR16ri)); in expandPostRAPseudo()
6313 case X86::ADD32ri_DB: in expandPostRAPseudo()
6314 MIB->setDesc(get(X86::OR32ri)); in expandPostRAPseudo()
6316 case X86::ADD64ri32_DB: in expandPostRAPseudo()
6317 MIB->setDesc(get(X86::OR64ri32)); in expandPostRAPseudo()
6342 case X86::CVTSI2SSrr: in hasPartialRegUpdate()
6343 case X86::CVTSI2SSrm: in hasPartialRegUpdate()
6344 case X86::CVTSI642SSrr: in hasPartialRegUpdate()
6345 case X86::CVTSI642SSrm: in hasPartialRegUpdate()
6346 case X86::CVTSI2SDrr: in hasPartialRegUpdate()
6347 case X86::CVTSI2SDrm: in hasPartialRegUpdate()
6348 case X86::CVTSI642SDrr: in hasPartialRegUpdate()
6349 case X86::CVTSI642SDrm: in hasPartialRegUpdate()
6353 case X86::CVTSD2SSrr: in hasPartialRegUpdate()
6354 case X86::CVTSD2SSrm: in hasPartialRegUpdate()
6355 case X86::CVTSS2SDrr: in hasPartialRegUpdate()
6356 case X86::CVTSS2SDrm: in hasPartialRegUpdate()
6357 case X86::MOVHPDrm: in hasPartialRegUpdate()
6358 case X86::MOVHPSrm: in hasPartialRegUpdate()
6359 case X86::MOVLPDrm: in hasPartialRegUpdate()
6360 case X86::MOVLPSrm: in hasPartialRegUpdate()
6361 case X86::RCPSSr: in hasPartialRegUpdate()
6362 case X86::RCPSSm: in hasPartialRegUpdate()
6363 case X86::RCPSSr_Int: in hasPartialRegUpdate()
6364 case X86::RCPSSm_Int: in hasPartialRegUpdate()
6365 case X86::ROUNDSDri: in hasPartialRegUpdate()
6366 case X86::ROUNDSDmi: in hasPartialRegUpdate()
6367 case X86::ROUNDSSri: in hasPartialRegUpdate()
6368 case X86::ROUNDSSmi: in hasPartialRegUpdate()
6369 case X86::RSQRTSSr: in hasPartialRegUpdate()
6370 case X86::RSQRTSSm: in hasPartialRegUpdate()
6371 case X86::RSQRTSSr_Int: in hasPartialRegUpdate()
6372 case X86::RSQRTSSm_Int: in hasPartialRegUpdate()
6373 case X86::SQRTSSr: in hasPartialRegUpdate()
6374 case X86::SQRTSSm: in hasPartialRegUpdate()
6375 case X86::SQRTSSr_Int: in hasPartialRegUpdate()
6376 case X86::SQRTSSm_Int: in hasPartialRegUpdate()
6377 case X86::SQRTSDr: in hasPartialRegUpdate()
6378 case X86::SQRTSDm: in hasPartialRegUpdate()
6379 case X86::SQRTSDr_Int: in hasPartialRegUpdate()
6380 case X86::SQRTSDm_Int: in hasPartialRegUpdate()
6382 case X86::VFCMULCPHZ128rm: in hasPartialRegUpdate()
6383 case X86::VFCMULCPHZ128rmb: in hasPartialRegUpdate()
6384 case X86::VFCMULCPHZ128rmbkz: in hasPartialRegUpdate()
6385 case X86::VFCMULCPHZ128rmkz: in hasPartialRegUpdate()
6386 case X86::VFCMULCPHZ128rr: in hasPartialRegUpdate()
6387 case X86::VFCMULCPHZ128rrkz: in hasPartialRegUpdate()
6388 case X86::VFCMULCPHZ256rm: in hasPartialRegUpdate()
6389 case X86::VFCMULCPHZ256rmb: in hasPartialRegUpdate()
6390 case X86::VFCMULCPHZ256rmbkz: in hasPartialRegUpdate()
6391 case X86::VFCMULCPHZ256rmkz: in hasPartialRegUpdate()
6392 case X86::VFCMULCPHZ256rr: in hasPartialRegUpdate()
6393 case X86::VFCMULCPHZ256rrkz: in hasPartialRegUpdate()
6394 case X86::VFCMULCPHZrm: in hasPartialRegUpdate()
6395 case X86::VFCMULCPHZrmb: in hasPartialRegUpdate()
6396 case X86::VFCMULCPHZrmbkz: in hasPartialRegUpdate()
6397 case X86::VFCMULCPHZrmkz: in hasPartialRegUpdate()
6398 case X86::VFCMULCPHZrr: in hasPartialRegUpdate()
6399 case X86::VFCMULCPHZrrb: in hasPartialRegUpdate()
6400 case X86::VFCMULCPHZrrbkz: in hasPartialRegUpdate()
6401 case X86::VFCMULCPHZrrkz: in hasPartialRegUpdate()
6402 case X86::VFMULCPHZ128rm: in hasPartialRegUpdate()
6403 case X86::VFMULCPHZ128rmb: in hasPartialRegUpdate()
6404 case X86::VFMULCPHZ128rmbkz: in hasPartialRegUpdate()
6405 case X86::VFMULCPHZ128rmkz: in hasPartialRegUpdate()
6406 case X86::VFMULCPHZ128rr: in hasPartialRegUpdate()
6407 case X86::VFMULCPHZ128rrkz: in hasPartialRegUpdate()
6408 case X86::VFMULCPHZ256rm: in hasPartialRegUpdate()
6409 case X86::VFMULCPHZ256rmb: in hasPartialRegUpdate()
6410 case X86::VFMULCPHZ256rmbkz: in hasPartialRegUpdate()
6411 case X86::VFMULCPHZ256rmkz: in hasPartialRegUpdate()
6412 case X86::VFMULCPHZ256rr: in hasPartialRegUpdate()
6413 case X86::VFMULCPHZ256rrkz: in hasPartialRegUpdate()
6414 case X86::VFMULCPHZrm: in hasPartialRegUpdate()
6415 case X86::VFMULCPHZrmb: in hasPartialRegUpdate()
6416 case X86::VFMULCPHZrmbkz: in hasPartialRegUpdate()
6417 case X86::VFMULCPHZrmkz: in hasPartialRegUpdate()
6418 case X86::VFMULCPHZrr: in hasPartialRegUpdate()
6419 case X86::VFMULCPHZrrb: in hasPartialRegUpdate()
6420 case X86::VFMULCPHZrrbkz: in hasPartialRegUpdate()
6421 case X86::VFMULCPHZrrkz: in hasPartialRegUpdate()
6422 case X86::VFCMULCSHZrm: in hasPartialRegUpdate()
6423 case X86::VFCMULCSHZrmkz: in hasPartialRegUpdate()
6424 case X86::VFCMULCSHZrr: in hasPartialRegUpdate()
6425 case X86::VFCMULCSHZrrb: in hasPartialRegUpdate()
6426 case X86::VFCMULCSHZrrbkz: in hasPartialRegUpdate()
6427 case X86::VFCMULCSHZrrkz: in hasPartialRegUpdate()
6428 case X86::VFMULCSHZrm: in hasPartialRegUpdate()
6429 case X86::VFMULCSHZrmkz: in hasPartialRegUpdate()
6430 case X86::VFMULCSHZrr: in hasPartialRegUpdate()
6431 case X86::VFMULCSHZrrb: in hasPartialRegUpdate()
6432 case X86::VFMULCSHZrrbkz: in hasPartialRegUpdate()
6433 case X86::VFMULCSHZrrkz: in hasPartialRegUpdate()
6435 case X86::VPERMDYrm: in hasPartialRegUpdate()
6436 case X86::VPERMDYrr: in hasPartialRegUpdate()
6437 case X86::VPERMQYmi: in hasPartialRegUpdate()
6438 case X86::VPERMQYri: in hasPartialRegUpdate()
6439 case X86::VPERMPSYrm: in hasPartialRegUpdate()
6440 case X86::VPERMPSYrr: in hasPartialRegUpdate()
6441 case X86::VPERMPDYmi: in hasPartialRegUpdate()
6442 case X86::VPERMPDYri: in hasPartialRegUpdate()
6443 case X86::VPERMDZ256rm: in hasPartialRegUpdate()
6444 case X86::VPERMDZ256rmb: in hasPartialRegUpdate()
6445 case X86::VPERMDZ256rmbkz: in hasPartialRegUpdate()
6446 case X86::VPERMDZ256rmkz: in hasPartialRegUpdate()
6447 case X86::VPERMDZ256rr: in hasPartialRegUpdate()
6448 case X86::VPERMDZ256rrkz: in hasPartialRegUpdate()
6449 case X86::VPERMDZrm: in hasPartialRegUpdate()
6450 case X86::VPERMDZrmb: in hasPartialRegUpdate()
6451 case X86::VPERMDZrmbkz: in hasPartialRegUpdate()
6452 case X86::VPERMDZrmkz: in hasPartialRegUpdate()
6453 case X86::VPERMDZrr: in hasPartialRegUpdate()
6454 case X86::VPERMDZrrkz: in hasPartialRegUpdate()
6455 case X86::VPERMQZ256mbi: in hasPartialRegUpdate()
6456 case X86::VPERMQZ256mbikz: in hasPartialRegUpdate()
6457 case X86::VPERMQZ256mi: in hasPartialRegUpdate()
6458 case X86::VPERMQZ256mikz: in hasPartialRegUpdate()
6459 case X86::VPERMQZ256ri: in hasPartialRegUpdate()
6460 case X86::VPERMQZ256rikz: in hasPartialRegUpdate()
6461 case X86::VPERMQZ256rm: in hasPartialRegUpdate()
6462 case X86::VPERMQZ256rmb: in hasPartialRegUpdate()
6463 case X86::VPERMQZ256rmbkz: in hasPartialRegUpdate()
6464 case X86::VPERMQZ256rmkz: in hasPartialRegUpdate()
6465 case X86::VPERMQZ256rr: in hasPartialRegUpdate()
6466 case X86::VPERMQZ256rrkz: in hasPartialRegUpdate()
6467 case X86::VPERMQZmbi: in hasPartialRegUpdate()
6468 case X86::VPERMQZmbikz: in hasPartialRegUpdate()
6469 case X86::VPERMQZmi: in hasPartialRegUpdate()
6470 case X86::VPERMQZmikz: in hasPartialRegUpdate()
6471 case X86::VPERMQZri: in hasPartialRegUpdate()
6472 case X86::VPERMQZrikz: in hasPartialRegUpdate()
6473 case X86::VPERMQZrm: in hasPartialRegUpdate()
6474 case X86::VPERMQZrmb: in hasPartialRegUpdate()
6475 case X86::VPERMQZrmbkz: in hasPartialRegUpdate()
6476 case X86::VPERMQZrmkz: in hasPartialRegUpdate()
6477 case X86::VPERMQZrr: in hasPartialRegUpdate()
6478 case X86::VPERMQZrrkz: in hasPartialRegUpdate()
6479 case X86::VPERMPSZ256rm: in hasPartialRegUpdate()
6480 case X86::VPERMPSZ256rmb: in hasPartialRegUpdate()
6481 case X86::VPERMPSZ256rmbkz: in hasPartialRegUpdate()
6482 case X86::VPERMPSZ256rmkz: in hasPartialRegUpdate()
6483 case X86::VPERMPSZ256rr: in hasPartialRegUpdate()
6484 case X86::VPERMPSZ256rrkz: in hasPartialRegUpdate()
6485 case X86::VPERMPSZrm: in hasPartialRegUpdate()
6486 case X86::VPERMPSZrmb: in hasPartialRegUpdate()
6487 case X86::VPERMPSZrmbkz: in hasPartialRegUpdate()
6488 case X86::VPERMPSZrmkz: in hasPartialRegUpdate()
6489 case X86::VPERMPSZrr: in hasPartialRegUpdate()
6490 case X86::VPERMPSZrrkz: in hasPartialRegUpdate()
6491 case X86::VPERMPDZ256mbi: in hasPartialRegUpdate()
6492 case X86::VPERMPDZ256mbikz: in hasPartialRegUpdate()
6493 case X86::VPERMPDZ256mi: in hasPartialRegUpdate()
6494 case X86::VPERMPDZ256mikz: in hasPartialRegUpdate()
6495 case X86::VPERMPDZ256ri: in hasPartialRegUpdate()
6496 case X86::VPERMPDZ256rikz: in hasPartialRegUpdate()
6497 case X86::VPERMPDZ256rm: in hasPartialRegUpdate()
6498 case X86::VPERMPDZ256rmb: in hasPartialRegUpdate()
6499 case X86::VPERMPDZ256rmbkz: in hasPartialRegUpdate()
6500 case X86::VPERMPDZ256rmkz: in hasPartialRegUpdate()
6501 case X86::VPERMPDZ256rr: in hasPartialRegUpdate()
6502 case X86::VPERMPDZ256rrkz: in hasPartialRegUpdate()
6503 case X86::VPERMPDZmbi: in hasPartialRegUpdate()
6504 case X86::VPERMPDZmbikz: in hasPartialRegUpdate()
6505 case X86::VPERMPDZmi: in hasPartialRegUpdate()
6506 case X86::VPERMPDZmikz: in hasPartialRegUpdate()
6507 case X86::VPERMPDZri: in hasPartialRegUpdate()
6508 case X86::VPERMPDZrikz: in hasPartialRegUpdate()
6509 case X86::VPERMPDZrm: in hasPartialRegUpdate()
6510 case X86::VPERMPDZrmb: in hasPartialRegUpdate()
6511 case X86::VPERMPDZrmbkz: in hasPartialRegUpdate()
6512 case X86::VPERMPDZrmkz: in hasPartialRegUpdate()
6513 case X86::VPERMPDZrr: in hasPartialRegUpdate()
6514 case X86::VPERMPDZrrkz: in hasPartialRegUpdate()
6516 case X86::VRANGEPDZ128rmbi: in hasPartialRegUpdate()
6517 case X86::VRANGEPDZ128rmbikz: in hasPartialRegUpdate()
6518 case X86::VRANGEPDZ128rmi: in hasPartialRegUpdate()
6519 case X86::VRANGEPDZ128rmikz: in hasPartialRegUpdate()
6520 case X86::VRANGEPDZ128rri: in hasPartialRegUpdate()
6521 case X86::VRANGEPDZ128rrikz: in hasPartialRegUpdate()
6522 case X86::VRANGEPDZ256rmbi: in hasPartialRegUpdate()
6523 case X86::VRANGEPDZ256rmbikz: in hasPartialRegUpdate()
6524 case X86::VRANGEPDZ256rmi: in hasPartialRegUpdate()
6525 case X86::VRANGEPDZ256rmikz: in hasPartialRegUpdate()
6526 case X86::VRANGEPDZ256rri: in hasPartialRegUpdate()
6527 case X86::VRANGEPDZ256rrikz: in hasPartialRegUpdate()
6528 case X86::VRANGEPDZrmbi: in hasPartialRegUpdate()
6529 case X86::VRANGEPDZrmbikz: in hasPartialRegUpdate()
6530 case X86::VRANGEPDZrmi: in hasPartialRegUpdate()
6531 case X86::VRANGEPDZrmikz: in hasPartialRegUpdate()
6532 case X86::VRANGEPDZrri: in hasPartialRegUpdate()
6533 case X86::VRANGEPDZrrib: in hasPartialRegUpdate()
6534 case X86::VRANGEPDZrribkz: in hasPartialRegUpdate()
6535 case X86::VRANGEPDZrrikz: in hasPartialRegUpdate()
6536 case X86::VRANGEPSZ128rmbi: in hasPartialRegUpdate()
6537 case X86::VRANGEPSZ128rmbikz: in hasPartialRegUpdate()
6538 case X86::VRANGEPSZ128rmi: in hasPartialRegUpdate()
6539 case X86::VRANGEPSZ128rmikz: in hasPartialRegUpdate()
6540 case X86::VRANGEPSZ128rri: in hasPartialRegUpdate()
6541 case X86::VRANGEPSZ128rrikz: in hasPartialRegUpdate()
6542 case X86::VRANGEPSZ256rmbi: in hasPartialRegUpdate()
6543 case X86::VRANGEPSZ256rmbikz: in hasPartialRegUpdate()
6544 case X86::VRANGEPSZ256rmi: in hasPartialRegUpdate()
6545 case X86::VRANGEPSZ256rmikz: in hasPartialRegUpdate()
6546 case X86::VRANGEPSZ256rri: in hasPartialRegUpdate()
6547 case X86::VRANGEPSZ256rrikz: in hasPartialRegUpdate()
6548 case X86::VRANGEPSZrmbi: in hasPartialRegUpdate()
6549 case X86::VRANGEPSZrmbikz: in hasPartialRegUpdate()
6550 case X86::VRANGEPSZrmi: in hasPartialRegUpdate()
6551 case X86::VRANGEPSZrmikz: in hasPartialRegUpdate()
6552 case X86::VRANGEPSZrri: in hasPartialRegUpdate()
6553 case X86::VRANGEPSZrrib: in hasPartialRegUpdate()
6554 case X86::VRANGEPSZrribkz: in hasPartialRegUpdate()
6555 case X86::VRANGEPSZrrikz: in hasPartialRegUpdate()
6556 case X86::VRANGESDZrmi: in hasPartialRegUpdate()
6557 case X86::VRANGESDZrmikz: in hasPartialRegUpdate()
6558 case X86::VRANGESDZrri: in hasPartialRegUpdate()
6559 case X86::VRANGESDZrrib: in hasPartialRegUpdate()
6560 case X86::VRANGESDZrribkz: in hasPartialRegUpdate()
6561 case X86::VRANGESDZrrikz: in hasPartialRegUpdate()
6562 case X86::VRANGESSZrmi: in hasPartialRegUpdate()
6563 case X86::VRANGESSZrmikz: in hasPartialRegUpdate()
6564 case X86::VRANGESSZrri: in hasPartialRegUpdate()
6565 case X86::VRANGESSZrrib: in hasPartialRegUpdate()
6566 case X86::VRANGESSZrribkz: in hasPartialRegUpdate()
6567 case X86::VRANGESSZrrikz: in hasPartialRegUpdate()
6569 case X86::VGETMANTSSZrmi: in hasPartialRegUpdate()
6570 case X86::VGETMANTSSZrmikz: in hasPartialRegUpdate()
6571 case X86::VGETMANTSSZrri: in hasPartialRegUpdate()
6572 case X86::VGETMANTSSZrrib: in hasPartialRegUpdate()
6573 case X86::VGETMANTSSZrribkz: in hasPartialRegUpdate()
6574 case X86::VGETMANTSSZrrikz: in hasPartialRegUpdate()
6575 case X86::VGETMANTSDZrmi: in hasPartialRegUpdate()
6576 case X86::VGETMANTSDZrmikz: in hasPartialRegUpdate()
6577 case X86::VGETMANTSDZrri: in hasPartialRegUpdate()
6578 case X86::VGETMANTSDZrrib: in hasPartialRegUpdate()
6579 case X86::VGETMANTSDZrribkz: in hasPartialRegUpdate()
6580 case X86::VGETMANTSDZrrikz: in hasPartialRegUpdate()
6581 case X86::VGETMANTSHZrmi: in hasPartialRegUpdate()
6582 case X86::VGETMANTSHZrmikz: in hasPartialRegUpdate()
6583 case X86::VGETMANTSHZrri: in hasPartialRegUpdate()
6584 case X86::VGETMANTSHZrrib: in hasPartialRegUpdate()
6585 case X86::VGETMANTSHZrribkz: in hasPartialRegUpdate()
6586 case X86::VGETMANTSHZrrikz: in hasPartialRegUpdate()
6587 case X86::VGETMANTPSZ128rmbi: in hasPartialRegUpdate()
6588 case X86::VGETMANTPSZ128rmbikz: in hasPartialRegUpdate()
6589 case X86::VGETMANTPSZ128rmi: in hasPartialRegUpdate()
6590 case X86::VGETMANTPSZ128rmikz: in hasPartialRegUpdate()
6591 case X86::VGETMANTPSZ256rmbi: in hasPartialRegUpdate()
6592 case X86::VGETMANTPSZ256rmbikz: in hasPartialRegUpdate()
6593 case X86::VGETMANTPSZ256rmi: in hasPartialRegUpdate()
6594 case X86::VGETMANTPSZ256rmikz: in hasPartialRegUpdate()
6595 case X86::VGETMANTPSZrmbi: in hasPartialRegUpdate()
6596 case X86::VGETMANTPSZrmbikz: in hasPartialRegUpdate()
6597 case X86::VGETMANTPSZrmi: in hasPartialRegUpdate()
6598 case X86::VGETMANTPSZrmikz: in hasPartialRegUpdate()
6599 case X86::VGETMANTPDZ128rmbi: in hasPartialRegUpdate()
6600 case X86::VGETMANTPDZ128rmbikz: in hasPartialRegUpdate()
6601 case X86::VGETMANTPDZ128rmi: in hasPartialRegUpdate()
6602 case X86::VGETMANTPDZ128rmikz: in hasPartialRegUpdate()
6603 case X86::VGETMANTPDZ256rmbi: in hasPartialRegUpdate()
6604 case X86::VGETMANTPDZ256rmbikz: in hasPartialRegUpdate()
6605 case X86::VGETMANTPDZ256rmi: in hasPartialRegUpdate()
6606 case X86::VGETMANTPDZ256rmikz: in hasPartialRegUpdate()
6607 case X86::VGETMANTPDZrmbi: in hasPartialRegUpdate()
6608 case X86::VGETMANTPDZrmbikz: in hasPartialRegUpdate()
6609 case X86::VGETMANTPDZrmi: in hasPartialRegUpdate()
6610 case X86::VGETMANTPDZrmikz: in hasPartialRegUpdate()
6612 case X86::VPMULLQZ128rm: in hasPartialRegUpdate()
6613 case X86::VPMULLQZ128rmb: in hasPartialRegUpdate()
6614 case X86::VPMULLQZ128rmbkz: in hasPartialRegUpdate()
6615 case X86::VPMULLQZ128rmkz: in hasPartialRegUpdate()
6616 case X86::VPMULLQZ128rr: in hasPartialRegUpdate()
6617 case X86::VPMULLQZ128rrkz: in hasPartialRegUpdate()
6618 case X86::VPMULLQZ256rm: in hasPartialRegUpdate()
6619 case X86::VPMULLQZ256rmb: in hasPartialRegUpdate()
6620 case X86::VPMULLQZ256rmbkz: in hasPartialRegUpdate()
6621 case X86::VPMULLQZ256rmkz: in hasPartialRegUpdate()
6622 case X86::VPMULLQZ256rr: in hasPartialRegUpdate()
6623 case X86::VPMULLQZ256rrkz: in hasPartialRegUpdate()
6624 case X86::VPMULLQZrm: in hasPartialRegUpdate()
6625 case X86::VPMULLQZrmb: in hasPartialRegUpdate()
6626 case X86::VPMULLQZrmbkz: in hasPartialRegUpdate()
6627 case X86::VPMULLQZrmkz: in hasPartialRegUpdate()
6628 case X86::VPMULLQZrr: in hasPartialRegUpdate()
6629 case X86::VPMULLQZrrkz: in hasPartialRegUpdate()
6632 case X86::POPCNT32rm: in hasPartialRegUpdate()
6633 case X86::POPCNT32rr: in hasPartialRegUpdate()
6634 case X86::POPCNT64rm: in hasPartialRegUpdate()
6635 case X86::POPCNT64rr: in hasPartialRegUpdate()
6637 case X86::LZCNT32rm: in hasPartialRegUpdate()
6638 case X86::LZCNT32rr: in hasPartialRegUpdate()
6639 case X86::LZCNT64rm: in hasPartialRegUpdate()
6640 case X86::LZCNT64rr: in hasPartialRegUpdate()
6641 case X86::TZCNT32rm: in hasPartialRegUpdate()
6642 case X86::TZCNT32rr: in hasPartialRegUpdate()
6643 case X86::TZCNT64rm: in hasPartialRegUpdate()
6644 case X86::TZCNT64rr: in hasPartialRegUpdate()
6684 case X86::MMX_PUNPCKHBWrr: in hasUndefRegUpdate()
6685 case X86::MMX_PUNPCKHWDrr: in hasUndefRegUpdate()
6686 case X86::MMX_PUNPCKHDQrr: in hasUndefRegUpdate()
6687 case X86::MMX_PUNPCKLBWrr: in hasUndefRegUpdate()
6688 case X86::MMX_PUNPCKLWDrr: in hasUndefRegUpdate()
6689 case X86::MMX_PUNPCKLDQrr: in hasUndefRegUpdate()
6690 case X86::MOVHLPSrr: in hasUndefRegUpdate()
6691 case X86::PACKSSWBrr: in hasUndefRegUpdate()
6692 case X86::PACKUSWBrr: in hasUndefRegUpdate()
6693 case X86::PACKSSDWrr: in hasUndefRegUpdate()
6694 case X86::PACKUSDWrr: in hasUndefRegUpdate()
6695 case X86::PUNPCKHBWrr: in hasUndefRegUpdate()
6696 case X86::PUNPCKLBWrr: in hasUndefRegUpdate()
6697 case X86::PUNPCKHWDrr: in hasUndefRegUpdate()
6698 case X86::PUNPCKLWDrr: in hasUndefRegUpdate()
6699 case X86::PUNPCKHDQrr: in hasUndefRegUpdate()
6700 case X86::PUNPCKLDQrr: in hasUndefRegUpdate()
6701 case X86::PUNPCKHQDQrr: in hasUndefRegUpdate()
6702 case X86::PUNPCKLQDQrr: in hasUndefRegUpdate()
6703 case X86::SHUFPDrri: in hasUndefRegUpdate()
6704 case X86::SHUFPSrri: in hasUndefRegUpdate()
6712 case X86::VMOVLHPSrr: in hasUndefRegUpdate()
6713 case X86::VMOVLHPSZrr: in hasUndefRegUpdate()
6714 case X86::VPACKSSWBrr: in hasUndefRegUpdate()
6715 case X86::VPACKUSWBrr: in hasUndefRegUpdate()
6716 case X86::VPACKSSDWrr: in hasUndefRegUpdate()
6717 case X86::VPACKUSDWrr: in hasUndefRegUpdate()
6718 case X86::VPACKSSWBZ128rr: in hasUndefRegUpdate()
6719 case X86::VPACKUSWBZ128rr: in hasUndefRegUpdate()
6720 case X86::VPACKSSDWZ128rr: in hasUndefRegUpdate()
6721 case X86::VPACKUSDWZ128rr: in hasUndefRegUpdate()
6722 case X86::VPERM2F128rr: in hasUndefRegUpdate()
6723 case X86::VPERM2I128rr: in hasUndefRegUpdate()
6724 case X86::VSHUFF32X4Z256rri: in hasUndefRegUpdate()
6725 case X86::VSHUFF32X4Zrri: in hasUndefRegUpdate()
6726 case X86::VSHUFF64X2Z256rri: in hasUndefRegUpdate()
6727 case X86::VSHUFF64X2Zrri: in hasUndefRegUpdate()
6728 case X86::VSHUFI32X4Z256rri: in hasUndefRegUpdate()
6729 case X86::VSHUFI32X4Zrri: in hasUndefRegUpdate()
6730 case X86::VSHUFI64X2Z256rri: in hasUndefRegUpdate()
6731 case X86::VSHUFI64X2Zrri: in hasUndefRegUpdate()
6732 case X86::VPUNPCKHBWrr: in hasUndefRegUpdate()
6733 case X86::VPUNPCKLBWrr: in hasUndefRegUpdate()
6734 case X86::VPUNPCKHBWYrr: in hasUndefRegUpdate()
6735 case X86::VPUNPCKLBWYrr: in hasUndefRegUpdate()
6736 case X86::VPUNPCKHBWZ128rr: in hasUndefRegUpdate()
6737 case X86::VPUNPCKLBWZ128rr: in hasUndefRegUpdate()
6738 case X86::VPUNPCKHBWZ256rr: in hasUndefRegUpdate()
6739 case X86::VPUNPCKLBWZ256rr: in hasUndefRegUpdate()
6740 case X86::VPUNPCKHBWZrr: in hasUndefRegUpdate()
6741 case X86::VPUNPCKLBWZrr: in hasUndefRegUpdate()
6742 case X86::VPUNPCKHWDrr: in hasUndefRegUpdate()
6743 case X86::VPUNPCKLWDrr: in hasUndefRegUpdate()
6744 case X86::VPUNPCKHWDYrr: in hasUndefRegUpdate()
6745 case X86::VPUNPCKLWDYrr: in hasUndefRegUpdate()
6746 case X86::VPUNPCKHWDZ128rr: in hasUndefRegUpdate()
6747 case X86::VPUNPCKLWDZ128rr: in hasUndefRegUpdate()
6748 case X86::VPUNPCKHWDZ256rr: in hasUndefRegUpdate()
6749 case X86::VPUNPCKLWDZ256rr: in hasUndefRegUpdate()
6750 case X86::VPUNPCKHWDZrr: in hasUndefRegUpdate()
6751 case X86::VPUNPCKLWDZrr: in hasUndefRegUpdate()
6752 case X86::VPUNPCKHDQrr: in hasUndefRegUpdate()
6753 case X86::VPUNPCKLDQrr: in hasUndefRegUpdate()
6754 case X86::VPUNPCKHDQYrr: in hasUndefRegUpdate()
6755 case X86::VPUNPCKLDQYrr: in hasUndefRegUpdate()
6756 case X86::VPUNPCKHDQZ128rr: in hasUndefRegUpdate()
6757 case X86::VPUNPCKLDQZ128rr: in hasUndefRegUpdate()
6758 case X86::VPUNPCKHDQZ256rr: in hasUndefRegUpdate()
6759 case X86::VPUNPCKLDQZ256rr: in hasUndefRegUpdate()
6760 case X86::VPUNPCKHDQZrr: in hasUndefRegUpdate()
6761 case X86::VPUNPCKLDQZrr: in hasUndefRegUpdate()
6762 case X86::VPUNPCKHQDQrr: in hasUndefRegUpdate()
6763 case X86::VPUNPCKLQDQrr: in hasUndefRegUpdate()
6764 case X86::VPUNPCKHQDQYrr: in hasUndefRegUpdate()
6765 case X86::VPUNPCKLQDQYrr: in hasUndefRegUpdate()
6766 case X86::VPUNPCKHQDQZ128rr: in hasUndefRegUpdate()
6767 case X86::VPUNPCKLQDQZ128rr: in hasUndefRegUpdate()
6768 case X86::VPUNPCKHQDQZ256rr: in hasUndefRegUpdate()
6769 case X86::VPUNPCKLQDQZ256rr: in hasUndefRegUpdate()
6770 case X86::VPUNPCKHQDQZrr: in hasUndefRegUpdate()
6771 case X86::VPUNPCKLQDQZrr: in hasUndefRegUpdate()
6777 case X86::VCVTSI2SSrr: in hasUndefRegUpdate()
6778 case X86::VCVTSI2SSrm: in hasUndefRegUpdate()
6779 case X86::VCVTSI2SSrr_Int: in hasUndefRegUpdate()
6780 case X86::VCVTSI2SSrm_Int: in hasUndefRegUpdate()
6781 case X86::VCVTSI642SSrr: in hasUndefRegUpdate()
6782 case X86::VCVTSI642SSrm: in hasUndefRegUpdate()
6783 case X86::VCVTSI642SSrr_Int: in hasUndefRegUpdate()
6784 case X86::VCVTSI642SSrm_Int: in hasUndefRegUpdate()
6785 case X86::VCVTSI2SDrr: in hasUndefRegUpdate()
6786 case X86::VCVTSI2SDrm: in hasUndefRegUpdate()
6787 case X86::VCVTSI2SDrr_Int: in hasUndefRegUpdate()
6788 case X86::VCVTSI2SDrm_Int: in hasUndefRegUpdate()
6789 case X86::VCVTSI642SDrr: in hasUndefRegUpdate()
6790 case X86::VCVTSI642SDrm: in hasUndefRegUpdate()
6791 case X86::VCVTSI642SDrr_Int: in hasUndefRegUpdate()
6792 case X86::VCVTSI642SDrm_Int: in hasUndefRegUpdate()
6794 case X86::VCVTSI2SSZrr: in hasUndefRegUpdate()
6795 case X86::VCVTSI2SSZrm: in hasUndefRegUpdate()
6796 case X86::VCVTSI2SSZrr_Int: in hasUndefRegUpdate()
6797 case X86::VCVTSI2SSZrrb_Int: in hasUndefRegUpdate()
6798 case X86::VCVTSI2SSZrm_Int: in hasUndefRegUpdate()
6799 case X86::VCVTSI642SSZrr: in hasUndefRegUpdate()
6800 case X86::VCVTSI642SSZrm: in hasUndefRegUpdate()
6801 case X86::VCVTSI642SSZrr_Int: in hasUndefRegUpdate()
6802 case X86::VCVTSI642SSZrrb_Int: in hasUndefRegUpdate()
6803 case X86::VCVTSI642SSZrm_Int: in hasUndefRegUpdate()
6804 case X86::VCVTSI2SDZrr: in hasUndefRegUpdate()
6805 case X86::VCVTSI2SDZrm: in hasUndefRegUpdate()
6806 case X86::VCVTSI2SDZrr_Int: in hasUndefRegUpdate()
6807 case X86::VCVTSI2SDZrm_Int: in hasUndefRegUpdate()
6808 case X86::VCVTSI642SDZrr: in hasUndefRegUpdate()
6809 case X86::VCVTSI642SDZrm: in hasUndefRegUpdate()
6810 case X86::VCVTSI642SDZrr_Int: in hasUndefRegUpdate()
6811 case X86::VCVTSI642SDZrrb_Int: in hasUndefRegUpdate()
6812 case X86::VCVTSI642SDZrm_Int: in hasUndefRegUpdate()
6813 case X86::VCVTUSI2SSZrr: in hasUndefRegUpdate()
6814 case X86::VCVTUSI2SSZrm: in hasUndefRegUpdate()
6815 case X86::VCVTUSI2SSZrr_Int: in hasUndefRegUpdate()
6816 case X86::VCVTUSI2SSZrrb_Int: in hasUndefRegUpdate()
6817 case X86::VCVTUSI2SSZrm_Int: in hasUndefRegUpdate()
6818 case X86::VCVTUSI642SSZrr: in hasUndefRegUpdate()
6819 case X86::VCVTUSI642SSZrm: in hasUndefRegUpdate()
6820 case X86::VCVTUSI642SSZrr_Int: in hasUndefRegUpdate()
6821 case X86::VCVTUSI642SSZrrb_Int: in hasUndefRegUpdate()
6822 case X86::VCVTUSI642SSZrm_Int: in hasUndefRegUpdate()
6823 case X86::VCVTUSI2SDZrr: in hasUndefRegUpdate()
6824 case X86::VCVTUSI2SDZrm: in hasUndefRegUpdate()
6825 case X86::VCVTUSI2SDZrr_Int: in hasUndefRegUpdate()
6826 case X86::VCVTUSI2SDZrm_Int: in hasUndefRegUpdate()
6827 case X86::VCVTUSI642SDZrr: in hasUndefRegUpdate()
6828 case X86::VCVTUSI642SDZrm: in hasUndefRegUpdate()
6829 case X86::VCVTUSI642SDZrr_Int: in hasUndefRegUpdate()
6830 case X86::VCVTUSI642SDZrrb_Int: in hasUndefRegUpdate()
6831 case X86::VCVTUSI642SDZrm_Int: in hasUndefRegUpdate()
6832 case X86::VCVTSI2SHZrr: in hasUndefRegUpdate()
6833 case X86::VCVTSI2SHZrm: in hasUndefRegUpdate()
6834 case X86::VCVTSI2SHZrr_Int: in hasUndefRegUpdate()
6835 case X86::VCVTSI2SHZrrb_Int: in hasUndefRegUpdate()
6836 case X86::VCVTSI2SHZrm_Int: in hasUndefRegUpdate()
6837 case X86::VCVTSI642SHZrr: in hasUndefRegUpdate()
6838 case X86::VCVTSI642SHZrm: in hasUndefRegUpdate()
6839 case X86::VCVTSI642SHZrr_Int: in hasUndefRegUpdate()
6840 case X86::VCVTSI642SHZrrb_Int: in hasUndefRegUpdate()
6841 case X86::VCVTSI642SHZrm_Int: in hasUndefRegUpdate()
6842 case X86::VCVTUSI2SHZrr: in hasUndefRegUpdate()
6843 case X86::VCVTUSI2SHZrm: in hasUndefRegUpdate()
6844 case X86::VCVTUSI2SHZrr_Int: in hasUndefRegUpdate()
6845 case X86::VCVTUSI2SHZrrb_Int: in hasUndefRegUpdate()
6846 case X86::VCVTUSI2SHZrm_Int: in hasUndefRegUpdate()
6847 case X86::VCVTUSI642SHZrr: in hasUndefRegUpdate()
6848 case X86::VCVTUSI642SHZrm: in hasUndefRegUpdate()
6849 case X86::VCVTUSI642SHZrr_Int: in hasUndefRegUpdate()
6850 case X86::VCVTUSI642SHZrrb_Int: in hasUndefRegUpdate()
6851 case X86::VCVTUSI642SHZrm_Int: in hasUndefRegUpdate()
6855 case X86::VCVTSD2SSrr: in hasUndefRegUpdate()
6856 case X86::VCVTSD2SSrm: in hasUndefRegUpdate()
6857 case X86::VCVTSD2SSrr_Int: in hasUndefRegUpdate()
6858 case X86::VCVTSD2SSrm_Int: in hasUndefRegUpdate()
6859 case X86::VCVTSS2SDrr: in hasUndefRegUpdate()
6860 case X86::VCVTSS2SDrm: in hasUndefRegUpdate()
6861 case X86::VCVTSS2SDrr_Int: in hasUndefRegUpdate()
6862 case X86::VCVTSS2SDrm_Int: in hasUndefRegUpdate()
6863 case X86::VRCPSSr: in hasUndefRegUpdate()
6864 case X86::VRCPSSr_Int: in hasUndefRegUpdate()
6865 case X86::VRCPSSm: in hasUndefRegUpdate()
6866 case X86::VRCPSSm_Int: in hasUndefRegUpdate()
6867 case X86::VROUNDSDri: in hasUndefRegUpdate()
6868 case X86::VROUNDSDmi: in hasUndefRegUpdate()
6869 case X86::VROUNDSDri_Int: in hasUndefRegUpdate()
6870 case X86::VROUNDSDmi_Int: in hasUndefRegUpdate()
6871 case X86::VROUNDSSri: in hasUndefRegUpdate()
6872 case X86::VROUNDSSmi: in hasUndefRegUpdate()
6873 case X86::VROUNDSSri_Int: in hasUndefRegUpdate()
6874 case X86::VROUNDSSmi_Int: in hasUndefRegUpdate()
6875 case X86::VRSQRTSSr: in hasUndefRegUpdate()
6876 case X86::VRSQRTSSr_Int: in hasUndefRegUpdate()
6877 case X86::VRSQRTSSm: in hasUndefRegUpdate()
6878 case X86::VRSQRTSSm_Int: in hasUndefRegUpdate()
6879 case X86::VSQRTSSr: in hasUndefRegUpdate()
6880 case X86::VSQRTSSr_Int: in hasUndefRegUpdate()
6881 case X86::VSQRTSSm: in hasUndefRegUpdate()
6882 case X86::VSQRTSSm_Int: in hasUndefRegUpdate()
6883 case X86::VSQRTSDr: in hasUndefRegUpdate()
6884 case X86::VSQRTSDr_Int: in hasUndefRegUpdate()
6885 case X86::VSQRTSDm: in hasUndefRegUpdate()
6886 case X86::VSQRTSDm_Int: in hasUndefRegUpdate()
6888 case X86::VCVTSD2SSZrr: in hasUndefRegUpdate()
6889 case X86::VCVTSD2SSZrr_Int: in hasUndefRegUpdate()
6890 case X86::VCVTSD2SSZrrb_Int: in hasUndefRegUpdate()
6891 case X86::VCVTSD2SSZrm: in hasUndefRegUpdate()
6892 case X86::VCVTSD2SSZrm_Int: in hasUndefRegUpdate()
6893 case X86::VCVTSS2SDZrr: in hasUndefRegUpdate()
6894 case X86::VCVTSS2SDZrr_Int: in hasUndefRegUpdate()
6895 case X86::VCVTSS2SDZrrb_Int: in hasUndefRegUpdate()
6896 case X86::VCVTSS2SDZrm: in hasUndefRegUpdate()
6897 case X86::VCVTSS2SDZrm_Int: in hasUndefRegUpdate()
6898 case X86::VGETEXPSDZr: in hasUndefRegUpdate()
6899 case X86::VGETEXPSDZrb: in hasUndefRegUpdate()
6900 case X86::VGETEXPSDZm: in hasUndefRegUpdate()
6901 case X86::VGETEXPSSZr: in hasUndefRegUpdate()
6902 case X86::VGETEXPSSZrb: in hasUndefRegUpdate()
6903 case X86::VGETEXPSSZm: in hasUndefRegUpdate()
6904 case X86::VGETMANTSDZrri: in hasUndefRegUpdate()
6905 case X86::VGETMANTSDZrrib: in hasUndefRegUpdate()
6906 case X86::VGETMANTSDZrmi: in hasUndefRegUpdate()
6907 case X86::VGETMANTSSZrri: in hasUndefRegUpdate()
6908 case X86::VGETMANTSSZrrib: in hasUndefRegUpdate()
6909 case X86::VGETMANTSSZrmi: in hasUndefRegUpdate()
6910 case X86::VRNDSCALESDZr: in hasUndefRegUpdate()
6911 case X86::VRNDSCALESDZr_Int: in hasUndefRegUpdate()
6912 case X86::VRNDSCALESDZrb_Int: in hasUndefRegUpdate()
6913 case X86::VRNDSCALESDZm: in hasUndefRegUpdate()
6914 case X86::VRNDSCALESDZm_Int: in hasUndefRegUpdate()
6915 case X86::VRNDSCALESSZr: in hasUndefRegUpdate()
6916 case X86::VRNDSCALESSZr_Int: in hasUndefRegUpdate()
6917 case X86::VRNDSCALESSZrb_Int: in hasUndefRegUpdate()
6918 case X86::VRNDSCALESSZm: in hasUndefRegUpdate()
6919 case X86::VRNDSCALESSZm_Int: in hasUndefRegUpdate()
6920 case X86::VRCP14SDZrr: in hasUndefRegUpdate()
6921 case X86::VRCP14SDZrm: in hasUndefRegUpdate()
6922 case X86::VRCP14SSZrr: in hasUndefRegUpdate()
6923 case X86::VRCP14SSZrm: in hasUndefRegUpdate()
6924 case X86::VRCPSHZrr: in hasUndefRegUpdate()
6925 case X86::VRCPSHZrm: in hasUndefRegUpdate()
6926 case X86::VRSQRTSHZrr: in hasUndefRegUpdate()
6927 case X86::VRSQRTSHZrm: in hasUndefRegUpdate()
6928 case X86::VREDUCESHZrmi: in hasUndefRegUpdate()
6929 case X86::VREDUCESHZrri: in hasUndefRegUpdate()
6930 case X86::VREDUCESHZrrib: in hasUndefRegUpdate()
6931 case X86::VGETEXPSHZr: in hasUndefRegUpdate()
6932 case X86::VGETEXPSHZrb: in hasUndefRegUpdate()
6933 case X86::VGETEXPSHZm: in hasUndefRegUpdate()
6934 case X86::VGETMANTSHZrri: in hasUndefRegUpdate()
6935 case X86::VGETMANTSHZrrib: in hasUndefRegUpdate()
6936 case X86::VGETMANTSHZrmi: in hasUndefRegUpdate()
6937 case X86::VRNDSCALESHZr: in hasUndefRegUpdate()
6938 case X86::VRNDSCALESHZr_Int: in hasUndefRegUpdate()
6939 case X86::VRNDSCALESHZrb_Int: in hasUndefRegUpdate()
6940 case X86::VRNDSCALESHZm: in hasUndefRegUpdate()
6941 case X86::VRNDSCALESHZm_Int: in hasUndefRegUpdate()
6942 case X86::VSQRTSHZr: in hasUndefRegUpdate()
6943 case X86::VSQRTSHZr_Int: in hasUndefRegUpdate()
6944 case X86::VSQRTSHZrb_Int: in hasUndefRegUpdate()
6945 case X86::VSQRTSHZm: in hasUndefRegUpdate()
6946 case X86::VSQRTSHZm_Int: in hasUndefRegUpdate()
6947 case X86::VRCP28SDZr: in hasUndefRegUpdate()
6948 case X86::VRCP28SDZrb: in hasUndefRegUpdate()
6949 case X86::VRCP28SDZm: in hasUndefRegUpdate()
6950 case X86::VRCP28SSZr: in hasUndefRegUpdate()
6951 case X86::VRCP28SSZrb: in hasUndefRegUpdate()
6952 case X86::VRCP28SSZm: in hasUndefRegUpdate()
6953 case X86::VREDUCESSZrmi: in hasUndefRegUpdate()
6954 case X86::VREDUCESSZrri: in hasUndefRegUpdate()
6955 case X86::VREDUCESSZrrib: in hasUndefRegUpdate()
6956 case X86::VRSQRT14SDZrr: in hasUndefRegUpdate()
6957 case X86::VRSQRT14SDZrm: in hasUndefRegUpdate()
6958 case X86::VRSQRT14SSZrr: in hasUndefRegUpdate()
6959 case X86::VRSQRT14SSZrm: in hasUndefRegUpdate()
6960 case X86::VRSQRT28SDZr: in hasUndefRegUpdate()
6961 case X86::VRSQRT28SDZrb: in hasUndefRegUpdate()
6962 case X86::VRSQRT28SDZm: in hasUndefRegUpdate()
6963 case X86::VRSQRT28SSZr: in hasUndefRegUpdate()
6964 case X86::VRSQRT28SSZrb: in hasUndefRegUpdate()
6965 case X86::VRSQRT28SSZm: in hasUndefRegUpdate()
6966 case X86::VSQRTSSZr: in hasUndefRegUpdate()
6967 case X86::VSQRTSSZr_Int: in hasUndefRegUpdate()
6968 case X86::VSQRTSSZrb_Int: in hasUndefRegUpdate()
6969 case X86::VSQRTSSZm: in hasUndefRegUpdate()
6970 case X86::VSQRTSSZm_Int: in hasUndefRegUpdate()
6971 case X86::VSQRTSDZr: in hasUndefRegUpdate()
6972 case X86::VSQRTSDZr_Int: in hasUndefRegUpdate()
6973 case X86::VSQRTSDZrb_Int: in hasUndefRegUpdate()
6974 case X86::VSQRTSDZm: in hasUndefRegUpdate()
6975 case X86::VSQRTSDZm_Int: in hasUndefRegUpdate()
6976 case X86::VCVTSD2SHZrr: in hasUndefRegUpdate()
6977 case X86::VCVTSD2SHZrr_Int: in hasUndefRegUpdate()
6978 case X86::VCVTSD2SHZrrb_Int: in hasUndefRegUpdate()
6979 case X86::VCVTSD2SHZrm: in hasUndefRegUpdate()
6980 case X86::VCVTSD2SHZrm_Int: in hasUndefRegUpdate()
6981 case X86::VCVTSS2SHZrr: in hasUndefRegUpdate()
6982 case X86::VCVTSS2SHZrr_Int: in hasUndefRegUpdate()
6983 case X86::VCVTSS2SHZrrb_Int: in hasUndefRegUpdate()
6984 case X86::VCVTSS2SHZrm: in hasUndefRegUpdate()
6985 case X86::VCVTSS2SHZrm_Int: in hasUndefRegUpdate()
6986 case X86::VCVTSH2SDZrr: in hasUndefRegUpdate()
6987 case X86::VCVTSH2SDZrr_Int: in hasUndefRegUpdate()
6988 case X86::VCVTSH2SDZrrb_Int: in hasUndefRegUpdate()
6989 case X86::VCVTSH2SDZrm: in hasUndefRegUpdate()
6990 case X86::VCVTSH2SDZrm_Int: in hasUndefRegUpdate()
6991 case X86::VCVTSH2SSZrr: in hasUndefRegUpdate()
6992 case X86::VCVTSH2SSZrr_Int: in hasUndefRegUpdate()
6993 case X86::VCVTSH2SSZrrb_Int: in hasUndefRegUpdate()
6994 case X86::VCVTSH2SSZrm: in hasUndefRegUpdate()
6995 case X86::VCVTSH2SSZrm_Int: in hasUndefRegUpdate()
6997 case X86::VMOVSSZrrk: in hasUndefRegUpdate()
6998 case X86::VMOVSDZrrk: in hasUndefRegUpdate()
7000 case X86::VMOVSSZrrkz: in hasUndefRegUpdate()
7001 case X86::VMOVSDZrrkz: in hasUndefRegUpdate()
7039 if (X86::VR128RegClass.contains(Reg)) { in breakPartialRegDependency()
7042 unsigned Opc = Subtarget.hasAVX() ? X86::VXORPSrr : X86::XORPSrr; in breakPartialRegDependency()
7047 } else if (X86::VR256RegClass.contains(Reg)) { in breakPartialRegDependency()
7050 Register XReg = TRI->getSubReg(Reg, X86::sub_xmm); in breakPartialRegDependency()
7051 BuildMI(*MI.getParent(), MI, MI.getDebugLoc(), get(X86::VXORPSrr), XReg) in breakPartialRegDependency()
7056 } else if (X86::VR128XRegClass.contains(Reg)) { in breakPartialRegDependency()
7061 BuildMI(*MI.getParent(), MI, MI.getDebugLoc(), get(X86::VPXORDZ128rr), Reg) in breakPartialRegDependency()
7065 } else if (X86::VR256XRegClass.contains(Reg) || in breakPartialRegDependency()
7066 X86::VR512RegClass.contains(Reg)) { in breakPartialRegDependency()
7072 Register XReg = TRI->getSubReg(Reg, X86::sub_xmm); in breakPartialRegDependency()
7073 BuildMI(*MI.getParent(), MI, MI.getDebugLoc(), get(X86::VPXORDZ128rr), XReg) in breakPartialRegDependency()
7078 } else if (X86::GR64RegClass.contains(Reg)) { in breakPartialRegDependency()
7081 Register XReg = TRI->getSubReg(Reg, X86::sub_32bit); in breakPartialRegDependency()
7082 BuildMI(*MI.getParent(), MI, MI.getDebugLoc(), get(X86::XOR32rr), XReg) in breakPartialRegDependency()
7087 } else if (X86::GR32RegClass.contains(Reg)) { in breakPartialRegDependency()
7088 BuildMI(*MI.getParent(), MI, MI.getDebugLoc(), get(X86::XOR32rr), Reg) in breakPartialRegDependency()
7221 case X86::INSERTPSrr: in foldMemoryOperandCustom()
7222 case X86::VINSERTPSrr: in foldMemoryOperandCustom()
7223 case X86::VINSERTPSZrr: in foldMemoryOperandCustom()
7236 (MI.getOpcode() != X86::INSERTPSrr || Alignment >= Align(4))) { in foldMemoryOperandCustom()
7240 (MI.getOpcode() == X86::VINSERTPSZrr) ? X86::VINSERTPSZrm in foldMemoryOperandCustom()
7241 : (MI.getOpcode() == X86::VINSERTPSrr) ? X86::VINSERTPSrm in foldMemoryOperandCustom()
7242 : X86::INSERTPSrm; in foldMemoryOperandCustom()
7250 case X86::MOVHLPSrr: in foldMemoryOperandCustom()
7251 case X86::VMOVHLPSrr: in foldMemoryOperandCustom()
7252 case X86::VMOVHLPSZrr: in foldMemoryOperandCustom()
7262 (MI.getOpcode() == X86::VMOVHLPSZrr) ? X86::VMOVLPSZ128rm in foldMemoryOperandCustom()
7263 : (MI.getOpcode() == X86::VMOVHLPSrr) ? X86::VMOVLPSrm in foldMemoryOperandCustom()
7264 : X86::MOVLPSrm; in foldMemoryOperandCustom()
7271 case X86::UNPCKLPDrr: in foldMemoryOperandCustom()
7281 fuseInst(MF, X86::MOVHPDrm, OpNum, MOs, InsertPt, MI, *this); in foldMemoryOperandCustom()
7286 case X86::MOV32r0: in foldMemoryOperandCustom()
7288 makeM0Inst(*this, (Size == 4) ? X86::MOV32mi : X86::MOV64mi32, MOs, in foldMemoryOperandCustom()
7353 (Opc == X86::CALL32r || Opc == X86::CALL64r || Opc == X86::PUSH16r || in foldMemoryOperandImpl()
7354 Opc == X86::PUSH32r || Opc == X86::PUSH64r)) in foldMemoryOperandImpl()
7370 if (Opc == X86::ADD32ri && in foldMemoryOperandImpl()
7377 if (MOs.size() == X86::AddrNumOperands && in foldMemoryOperandImpl()
7378 MOs[X86::AddrDisp].getTargetFlags() == X86II::MO_GOTTPOFF && in foldMemoryOperandImpl()
7379 Opc != X86::ADD64rr) in foldMemoryOperandImpl()
7397 unsigned NonNDOpc = Subtarget.hasNDD() ? X86::getNonNDVariant(Opc) : 0U; in foldMemoryOperandImpl()
7420 if (Opcode != X86::MOV64rm || RCSize != 8 || Size != 4) in foldMemoryOperandImpl()
7424 Opcode = X86::MOV32rm; in foldMemoryOperandImpl()
7443 NewMI->getOperand(0).setReg(RI.getSubReg(DstReg, X86::sub_32bit)); in foldMemoryOperandImpl()
7445 NewMI->getOperand(0).setSubReg(X86::sub_32bit); in foldMemoryOperandImpl()
7491 if (MI.getOpcode() == X86::MOV32r0 && SubReg == X86::sub_32bit) in foldMemoryOperandImpl()
7493 if (SubReg && (MO.isDef() || SubReg == X86::sub_8bit_hi)) in foldMemoryOperandImpl()
7518 return (Subtarget.hasNDD() ? X86::getNonNDVariant(Opc) : 0U) ? Impl() in foldMemoryOperandImpl()
7520 case X86::TEST8rr: in foldMemoryOperandImpl()
7521 NewOpc = X86::CMP8ri; in foldMemoryOperandImpl()
7524 case X86::TEST16rr: in foldMemoryOperandImpl()
7525 NewOpc = X86::CMP16ri; in foldMemoryOperandImpl()
7528 case X86::TEST32rr: in foldMemoryOperandImpl()
7529 NewOpc = X86::CMP32ri; in foldMemoryOperandImpl()
7532 case X86::TEST64rr: in foldMemoryOperandImpl()
7533 NewOpc = X86::CMP64ri32; in foldMemoryOperandImpl()
7574 if ((Opc == X86::MOVSSrm || Opc == X86::VMOVSSrm || Opc == X86::VMOVSSZrm || in isNonFoldablePartialRegisterLoad()
7575 Opc == X86::MOVSSrm_alt || Opc == X86::VMOVSSrm_alt || in isNonFoldablePartialRegisterLoad()
7576 Opc == X86::VMOVSSZrm_alt) && in isNonFoldablePartialRegisterLoad()
7582 case X86::CVTSS2SDrr_Int: in isNonFoldablePartialRegisterLoad()
7583 case X86::VCVTSS2SDrr_Int: in isNonFoldablePartialRegisterLoad()
7584 case X86::VCVTSS2SDZrr_Int: in isNonFoldablePartialRegisterLoad()
7585 case X86::VCVTSS2SDZrr_Intk: in isNonFoldablePartialRegisterLoad()
7586 case X86::VCVTSS2SDZrr_Intkz: in isNonFoldablePartialRegisterLoad()
7587 case X86::CVTSS2SIrr_Int: in isNonFoldablePartialRegisterLoad()
7588 case X86::CVTSS2SI64rr_Int: in isNonFoldablePartialRegisterLoad()
7589 case X86::VCVTSS2SIrr_Int: in isNonFoldablePartialRegisterLoad()
7590 case X86::VCVTSS2SI64rr_Int: in isNonFoldablePartialRegisterLoad()
7591 case X86::VCVTSS2SIZrr_Int: in isNonFoldablePartialRegisterLoad()
7592 case X86::VCVTSS2SI64Zrr_Int: in isNonFoldablePartialRegisterLoad()
7593 case X86::CVTTSS2SIrr_Int: in isNonFoldablePartialRegisterLoad()
7594 case X86::CVTTSS2SI64rr_Int: in isNonFoldablePartialRegisterLoad()
7595 case X86::VCVTTSS2SIrr_Int: in isNonFoldablePartialRegisterLoad()
7596 case X86::VCVTTSS2SI64rr_Int: in isNonFoldablePartialRegisterLoad()
7597 case X86::VCVTTSS2SIZrr_Int: in isNonFoldablePartialRegisterLoad()
7598 case X86::VCVTTSS2SI64Zrr_Int: in isNonFoldablePartialRegisterLoad()
7599 case X86::VCVTSS2USIZrr_Int: in isNonFoldablePartialRegisterLoad()
7600 case X86::VCVTSS2USI64Zrr_Int: in isNonFoldablePartialRegisterLoad()
7601 case X86::VCVTTSS2USIZrr_Int: in isNonFoldablePartialRegisterLoad()
7602 case X86::VCVTTSS2USI64Zrr_Int: in isNonFoldablePartialRegisterLoad()
7603 case X86::RCPSSr_Int: in isNonFoldablePartialRegisterLoad()
7604 case X86::VRCPSSr_Int: in isNonFoldablePartialRegisterLoad()
7605 case X86::RSQRTSSr_Int: in isNonFoldablePartialRegisterLoad()
7606 case X86::VRSQRTSSr_Int: in isNonFoldablePartialRegisterLoad()
7607 case X86::ROUNDSSri_Int: in isNonFoldablePartialRegisterLoad()
7608 case X86::VROUNDSSri_Int: in isNonFoldablePartialRegisterLoad()
7609 case X86::COMISSrr_Int: in isNonFoldablePartialRegisterLoad()
7610 case X86::VCOMISSrr_Int: in isNonFoldablePartialRegisterLoad()
7611 case X86::VCOMISSZrr_Int: in isNonFoldablePartialRegisterLoad()
7612 case X86::UCOMISSrr_Int: in isNonFoldablePartialRegisterLoad()
7613 case X86::VUCOMISSrr_Int: in isNonFoldablePartialRegisterLoad()
7614 case X86::VUCOMISSZrr_Int: in isNonFoldablePartialRegisterLoad()
7615 case X86::ADDSSrr_Int: in isNonFoldablePartialRegisterLoad()
7616 case X86::VADDSSrr_Int: in isNonFoldablePartialRegisterLoad()
7617 case X86::VADDSSZrr_Int: in isNonFoldablePartialRegisterLoad()
7618 case X86::CMPSSrri_Int: in isNonFoldablePartialRegisterLoad()
7619 case X86::VCMPSSrri_Int: in isNonFoldablePartialRegisterLoad()
7620 case X86::VCMPSSZrri_Int: in isNonFoldablePartialRegisterLoad()
7621 case X86::DIVSSrr_Int: in isNonFoldablePartialRegisterLoad()
7622 case X86::VDIVSSrr_Int: in isNonFoldablePartialRegisterLoad()
7623 case X86::VDIVSSZrr_Int: in isNonFoldablePartialRegisterLoad()
7624 case X86::MAXSSrr_Int: in isNonFoldablePartialRegisterLoad()
7625 case X86::VMAXSSrr_Int: in isNonFoldablePartialRegisterLoad()
7626 case X86::VMAXSSZrr_Int: in isNonFoldablePartialRegisterLoad()
7627 case X86::MINSSrr_Int: in isNonFoldablePartialRegisterLoad()
7628 case X86::VMINSSrr_Int: in isNonFoldablePartialRegisterLoad()
7629 case X86::VMINSSZrr_Int: in isNonFoldablePartialRegisterLoad()
7630 case X86::MULSSrr_Int: in isNonFoldablePartialRegisterLoad()
7631 case X86::VMULSSrr_Int: in isNonFoldablePartialRegisterLoad()
7632 case X86::VMULSSZrr_Int: in isNonFoldablePartialRegisterLoad()
7633 case X86::SQRTSSr_Int: in isNonFoldablePartialRegisterLoad()
7634 case X86::VSQRTSSr_Int: in isNonFoldablePartialRegisterLoad()
7635 case X86::VSQRTSSZr_Int: in isNonFoldablePartialRegisterLoad()
7636 case X86::SUBSSrr_Int: in isNonFoldablePartialRegisterLoad()
7637 case X86::VSUBSSrr_Int: in isNonFoldablePartialRegisterLoad()
7638 case X86::VSUBSSZrr_Int: in isNonFoldablePartialRegisterLoad()
7639 case X86::VADDSSZrr_Intk: in isNonFoldablePartialRegisterLoad()
7640 case X86::VADDSSZrr_Intkz: in isNonFoldablePartialRegisterLoad()
7641 case X86::VCMPSSZrri_Intk: in isNonFoldablePartialRegisterLoad()
7642 case X86::VDIVSSZrr_Intk: in isNonFoldablePartialRegisterLoad()
7643 case X86::VDIVSSZrr_Intkz: in isNonFoldablePartialRegisterLoad()
7644 case X86::VMAXSSZrr_Intk: in isNonFoldablePartialRegisterLoad()
7645 case X86::VMAXSSZrr_Intkz: in isNonFoldablePartialRegisterLoad()
7646 case X86::VMINSSZrr_Intk: in isNonFoldablePartialRegisterLoad()
7647 case X86::VMINSSZrr_Intkz: in isNonFoldablePartialRegisterLoad()
7648 case X86::VMULSSZrr_Intk: in isNonFoldablePartialRegisterLoad()
7649 case X86::VMULSSZrr_Intkz: in isNonFoldablePartialRegisterLoad()
7650 case X86::VSQRTSSZr_Intk: in isNonFoldablePartialRegisterLoad()
7651 case X86::VSQRTSSZr_Intkz: in isNonFoldablePartialRegisterLoad()
7652 case X86::VSUBSSZrr_Intk: in isNonFoldablePartialRegisterLoad()
7653 case X86::VSUBSSZrr_Intkz: in isNonFoldablePartialRegisterLoad()
7654 case X86::VFMADDSS4rr_Int: in isNonFoldablePartialRegisterLoad()
7655 case X86::VFNMADDSS4rr_Int: in isNonFoldablePartialRegisterLoad()
7656 case X86::VFMSUBSS4rr_Int: in isNonFoldablePartialRegisterLoad()
7657 case X86::VFNMSUBSS4rr_Int: in isNonFoldablePartialRegisterLoad()
7658 case X86::VFMADD132SSr_Int: in isNonFoldablePartialRegisterLoad()
7659 case X86::VFNMADD132SSr_Int: in isNonFoldablePartialRegisterLoad()
7660 case X86::VFMADD213SSr_Int: in isNonFoldablePartialRegisterLoad()
7661 case X86::VFNMADD213SSr_Int: in isNonFoldablePartialRegisterLoad()
7662 case X86::VFMADD231SSr_Int: in isNonFoldablePartialRegisterLoad()
7663 case X86::VFNMADD231SSr_Int: in isNonFoldablePartialRegisterLoad()
7664 case X86::VFMSUB132SSr_Int: in isNonFoldablePartialRegisterLoad()
7665 case X86::VFNMSUB132SSr_Int: in isNonFoldablePartialRegisterLoad()
7666 case X86::VFMSUB213SSr_Int: in isNonFoldablePartialRegisterLoad()
7667 case X86::VFNMSUB213SSr_Int: in isNonFoldablePartialRegisterLoad()
7668 case X86::VFMSUB231SSr_Int: in isNonFoldablePartialRegisterLoad()
7669 case X86::VFNMSUB231SSr_Int: in isNonFoldablePartialRegisterLoad()
7670 case X86::VFMADD132SSZr_Int: in isNonFoldablePartialRegisterLoad()
7671 case X86::VFNMADD132SSZr_Int: in isNonFoldablePartialRegisterLoad()
7672 case X86::VFMADD213SSZr_Int: in isNonFoldablePartialRegisterLoad()
7673 case X86::VFNMADD213SSZr_Int: in isNonFoldablePartialRegisterLoad()
7674 case X86::VFMADD231SSZr_Int: in isNonFoldablePartialRegisterLoad()
7675 case X86::VFNMADD231SSZr_Int: in isNonFoldablePartialRegisterLoad()
7676 case X86::VFMSUB132SSZr_Int: in isNonFoldablePartialRegisterLoad()
7677 case X86::VFNMSUB132SSZr_Int: in isNonFoldablePartialRegisterLoad()
7678 case X86::VFMSUB213SSZr_Int: in isNonFoldablePartialRegisterLoad()
7679 case X86::VFNMSUB213SSZr_Int: in isNonFoldablePartialRegisterLoad()
7680 case X86::VFMSUB231SSZr_Int: in isNonFoldablePartialRegisterLoad()
7681 case X86::VFNMSUB231SSZr_Int: in isNonFoldablePartialRegisterLoad()
7682 case X86::VFMADD132SSZr_Intk: in isNonFoldablePartialRegisterLoad()
7683 case X86::VFNMADD132SSZr_Intk: in isNonFoldablePartialRegisterLoad()
7684 case X86::VFMADD213SSZr_Intk: in isNonFoldablePartialRegisterLoad()
7685 case X86::VFNMADD213SSZr_Intk: in isNonFoldablePartialRegisterLoad()
7686 case X86::VFMADD231SSZr_Intk: in isNonFoldablePartialRegisterLoad()
7687 case X86::VFNMADD231SSZr_Intk: in isNonFoldablePartialRegisterLoad()
7688 case X86::VFMSUB132SSZr_Intk: in isNonFoldablePartialRegisterLoad()
7689 case X86::VFNMSUB132SSZr_Intk: in isNonFoldablePartialRegisterLoad()
7690 case X86::VFMSUB213SSZr_Intk: in isNonFoldablePartialRegisterLoad()
7691 case X86::VFNMSUB213SSZr_Intk: in isNonFoldablePartialRegisterLoad()
7692 case X86::VFMSUB231SSZr_Intk: in isNonFoldablePartialRegisterLoad()
7693 case X86::VFNMSUB231SSZr_Intk: in isNonFoldablePartialRegisterLoad()
7694 case X86::VFMADD132SSZr_Intkz: in isNonFoldablePartialRegisterLoad()
7695 case X86::VFNMADD132SSZr_Intkz: in isNonFoldablePartialRegisterLoad()
7696 case X86::VFMADD213SSZr_Intkz: in isNonFoldablePartialRegisterLoad()
7697 case X86::VFNMADD213SSZr_Intkz: in isNonFoldablePartialRegisterLoad()
7698 case X86::VFMADD231SSZr_Intkz: in isNonFoldablePartialRegisterLoad()
7699 case X86::VFNMADD231SSZr_Intkz: in isNonFoldablePartialRegisterLoad()
7700 case X86::VFMSUB132SSZr_Intkz: in isNonFoldablePartialRegisterLoad()
7701 case X86::VFNMSUB132SSZr_Intkz: in isNonFoldablePartialRegisterLoad()
7702 case X86::VFMSUB213SSZr_Intkz: in isNonFoldablePartialRegisterLoad()
7703 case X86::VFNMSUB213SSZr_Intkz: in isNonFoldablePartialRegisterLoad()
7704 case X86::VFMSUB231SSZr_Intkz: in isNonFoldablePartialRegisterLoad()
7705 case X86::VFNMSUB231SSZr_Intkz: in isNonFoldablePartialRegisterLoad()
7706 case X86::VFIXUPIMMSSZrri: in isNonFoldablePartialRegisterLoad()
7707 case X86::VFIXUPIMMSSZrrik: in isNonFoldablePartialRegisterLoad()
7708 case X86::VFIXUPIMMSSZrrikz: in isNonFoldablePartialRegisterLoad()
7709 case X86::VFPCLASSSSZrr: in isNonFoldablePartialRegisterLoad()
7710 case X86::VFPCLASSSSZrrk: in isNonFoldablePartialRegisterLoad()
7711 case X86::VGETEXPSSZr: in isNonFoldablePartialRegisterLoad()
7712 case X86::VGETEXPSSZrk: in isNonFoldablePartialRegisterLoad()
7713 case X86::VGETEXPSSZrkz: in isNonFoldablePartialRegisterLoad()
7714 case X86::VGETMANTSSZrri: in isNonFoldablePartialRegisterLoad()
7715 case X86::VGETMANTSSZrrik: in isNonFoldablePartialRegisterLoad()
7716 case X86::VGETMANTSSZrrikz: in isNonFoldablePartialRegisterLoad()
7717 case X86::VRANGESSZrri: in isNonFoldablePartialRegisterLoad()
7718 case X86::VRANGESSZrrik: in isNonFoldablePartialRegisterLoad()
7719 case X86::VRANGESSZrrikz: in isNonFoldablePartialRegisterLoad()
7720 case X86::VRCP14SSZrr: in isNonFoldablePartialRegisterLoad()
7721 case X86::VRCP14SSZrrk: in isNonFoldablePartialRegisterLoad()
7722 case X86::VRCP14SSZrrkz: in isNonFoldablePartialRegisterLoad()
7723 case X86::VRCP28SSZr: in isNonFoldablePartialRegisterLoad()
7724 case X86::VRCP28SSZrk: in isNonFoldablePartialRegisterLoad()
7725 case X86::VRCP28SSZrkz: in isNonFoldablePartialRegisterLoad()
7726 case X86::VREDUCESSZrri: in isNonFoldablePartialRegisterLoad()
7727 case X86::VREDUCESSZrrik: in isNonFoldablePartialRegisterLoad()
7728 case X86::VREDUCESSZrrikz: in isNonFoldablePartialRegisterLoad()
7729 case X86::VRNDSCALESSZr_Int: in isNonFoldablePartialRegisterLoad()
7730 case X86::VRNDSCALESSZr_Intk: in isNonFoldablePartialRegisterLoad()
7731 case X86::VRNDSCALESSZr_Intkz: in isNonFoldablePartialRegisterLoad()
7732 case X86::VRSQRT14SSZrr: in isNonFoldablePartialRegisterLoad()
7733 case X86::VRSQRT14SSZrrk: in isNonFoldablePartialRegisterLoad()
7734 case X86::VRSQRT14SSZrrkz: in isNonFoldablePartialRegisterLoad()
7735 case X86::VRSQRT28SSZr: in isNonFoldablePartialRegisterLoad()
7736 case X86::VRSQRT28SSZrk: in isNonFoldablePartialRegisterLoad()
7737 case X86::VRSQRT28SSZrkz: in isNonFoldablePartialRegisterLoad()
7738 case X86::VSCALEFSSZrr: in isNonFoldablePartialRegisterLoad()
7739 case X86::VSCALEFSSZrrk: in isNonFoldablePartialRegisterLoad()
7740 case X86::VSCALEFSSZrrkz: in isNonFoldablePartialRegisterLoad()
7747 if ((Opc == X86::MOVSDrm || Opc == X86::VMOVSDrm || Opc == X86::VMOVSDZrm || in isNonFoldablePartialRegisterLoad()
7748 Opc == X86::MOVSDrm_alt || Opc == X86::VMOVSDrm_alt || in isNonFoldablePartialRegisterLoad()
7749 Opc == X86::VMOVSDZrm_alt) && in isNonFoldablePartialRegisterLoad()
7755 case X86::CVTSD2SSrr_Int: in isNonFoldablePartialRegisterLoad()
7756 case X86::VCVTSD2SSrr_Int: in isNonFoldablePartialRegisterLoad()
7757 case X86::VCVTSD2SSZrr_Int: in isNonFoldablePartialRegisterLoad()
7758 case X86::VCVTSD2SSZrr_Intk: in isNonFoldablePartialRegisterLoad()
7759 case X86::VCVTSD2SSZrr_Intkz: in isNonFoldablePartialRegisterLoad()
7760 case X86::CVTSD2SIrr_Int: in isNonFoldablePartialRegisterLoad()
7761 case X86::CVTSD2SI64rr_Int: in isNonFoldablePartialRegisterLoad()
7762 case X86::VCVTSD2SIrr_Int: in isNonFoldablePartialRegisterLoad()
7763 case X86::VCVTSD2SI64rr_Int: in isNonFoldablePartialRegisterLoad()
7764 case X86::VCVTSD2SIZrr_Int: in isNonFoldablePartialRegisterLoad()
7765 case X86::VCVTSD2SI64Zrr_Int: in isNonFoldablePartialRegisterLoad()
7766 case X86::CVTTSD2SIrr_Int: in isNonFoldablePartialRegisterLoad()
7767 case X86::CVTTSD2SI64rr_Int: in isNonFoldablePartialRegisterLoad()
7768 case X86::VCVTTSD2SIrr_Int: in isNonFoldablePartialRegisterLoad()
7769 case X86::VCVTTSD2SI64rr_Int: in isNonFoldablePartialRegisterLoad()
7770 case X86::VCVTTSD2SIZrr_Int: in isNonFoldablePartialRegisterLoad()
7771 case X86::VCVTTSD2SI64Zrr_Int: in isNonFoldablePartialRegisterLoad()
7772 case X86::VCVTSD2USIZrr_Int: in isNonFoldablePartialRegisterLoad()
7773 case X86::VCVTSD2USI64Zrr_Int: in isNonFoldablePartialRegisterLoad()
7774 case X86::VCVTTSD2USIZrr_Int: in isNonFoldablePartialRegisterLoad()
7775 case X86::VCVTTSD2USI64Zrr_Int: in isNonFoldablePartialRegisterLoad()
7776 case X86::ROUNDSDri_Int: in isNonFoldablePartialRegisterLoad()
7777 case X86::VROUNDSDri_Int: in isNonFoldablePartialRegisterLoad()
7778 case X86::COMISDrr_Int: in isNonFoldablePartialRegisterLoad()
7779 case X86::VCOMISDrr_Int: in isNonFoldablePartialRegisterLoad()
7780 case X86::VCOMISDZrr_Int: in isNonFoldablePartialRegisterLoad()
7781 case X86::UCOMISDrr_Int: in isNonFoldablePartialRegisterLoad()
7782 case X86::VUCOMISDrr_Int: in isNonFoldablePartialRegisterLoad()
7783 case X86::VUCOMISDZrr_Int: in isNonFoldablePartialRegisterLoad()
7784 case X86::ADDSDrr_Int: in isNonFoldablePartialRegisterLoad()
7785 case X86::VADDSDrr_Int: in isNonFoldablePartialRegisterLoad()
7786 case X86::VADDSDZrr_Int: in isNonFoldablePartialRegisterLoad()
7787 case X86::CMPSDrri_Int: in isNonFoldablePartialRegisterLoad()
7788 case X86::VCMPSDrri_Int: in isNonFoldablePartialRegisterLoad()
7789 case X86::VCMPSDZrri_Int: in isNonFoldablePartialRegisterLoad()
7790 case X86::DIVSDrr_Int: in isNonFoldablePartialRegisterLoad()
7791 case X86::VDIVSDrr_Int: in isNonFoldablePartialRegisterLoad()
7792 case X86::VDIVSDZrr_Int: in isNonFoldablePartialRegisterLoad()
7793 case X86::MAXSDrr_Int: in isNonFoldablePartialRegisterLoad()
7794 case X86::VMAXSDrr_Int: in isNonFoldablePartialRegisterLoad()
7795 case X86::VMAXSDZrr_Int: in isNonFoldablePartialRegisterLoad()
7796 case X86::MINSDrr_Int: in isNonFoldablePartialRegisterLoad()
7797 case X86::VMINSDrr_Int: in isNonFoldablePartialRegisterLoad()
7798 case X86::VMINSDZrr_Int: in isNonFoldablePartialRegisterLoad()
7799 case X86::MULSDrr_Int: in isNonFoldablePartialRegisterLoad()
7800 case X86::VMULSDrr_Int: in isNonFoldablePartialRegisterLoad()
7801 case X86::VMULSDZrr_Int: in isNonFoldablePartialRegisterLoad()
7802 case X86::SQRTSDr_Int: in isNonFoldablePartialRegisterLoad()
7803 case X86::VSQRTSDr_Int: in isNonFoldablePartialRegisterLoad()
7804 case X86::VSQRTSDZr_Int: in isNonFoldablePartialRegisterLoad()
7805 case X86::SUBSDrr_Int: in isNonFoldablePartialRegisterLoad()
7806 case X86::VSUBSDrr_Int: in isNonFoldablePartialRegisterLoad()
7807 case X86::VSUBSDZrr_Int: in isNonFoldablePartialRegisterLoad()
7808 case X86::VADDSDZrr_Intk: in isNonFoldablePartialRegisterLoad()
7809 case X86::VADDSDZrr_Intkz: in isNonFoldablePartialRegisterLoad()
7810 case X86::VCMPSDZrri_Intk: in isNonFoldablePartialRegisterLoad()
7811 case X86::VDIVSDZrr_Intk: in isNonFoldablePartialRegisterLoad()
7812 case X86::VDIVSDZrr_Intkz: in isNonFoldablePartialRegisterLoad()
7813 case X86::VMAXSDZrr_Intk: in isNonFoldablePartialRegisterLoad()
7814 case X86::VMAXSDZrr_Intkz: in isNonFoldablePartialRegisterLoad()
7815 case X86::VMINSDZrr_Intk: in isNonFoldablePartialRegisterLoad()
7816 case X86::VMINSDZrr_Intkz: in isNonFoldablePartialRegisterLoad()
7817 case X86::VMULSDZrr_Intk: in isNonFoldablePartialRegisterLoad()
7818 case X86::VMULSDZrr_Intkz: in isNonFoldablePartialRegisterLoad()
7819 case X86::VSQRTSDZr_Intk: in isNonFoldablePartialRegisterLoad()
7820 case X86::VSQRTSDZr_Intkz: in isNonFoldablePartialRegisterLoad()
7821 case X86::VSUBSDZrr_Intk: in isNonFoldablePartialRegisterLoad()
7822 case X86::VSUBSDZrr_Intkz: in isNonFoldablePartialRegisterLoad()
7823 case X86::VFMADDSD4rr_Int: in isNonFoldablePartialRegisterLoad()
7824 case X86::VFNMADDSD4rr_Int: in isNonFoldablePartialRegisterLoad()
7825 case X86::VFMSUBSD4rr_Int: in isNonFoldablePartialRegisterLoad()
7826 case X86::VFNMSUBSD4rr_Int: in isNonFoldablePartialRegisterLoad()
7827 case X86::VFMADD132SDr_Int: in isNonFoldablePartialRegisterLoad()
7828 case X86::VFNMADD132SDr_Int: in isNonFoldablePartialRegisterLoad()
7829 case X86::VFMADD213SDr_Int: in isNonFoldablePartialRegisterLoad()
7830 case X86::VFNMADD213SDr_Int: in isNonFoldablePartialRegisterLoad()
7831 case X86::VFMADD231SDr_Int: in isNonFoldablePartialRegisterLoad()
7832 case X86::VFNMADD231SDr_Int: in isNonFoldablePartialRegisterLoad()
7833 case X86::VFMSUB132SDr_Int: in isNonFoldablePartialRegisterLoad()
7834 case X86::VFNMSUB132SDr_Int: in isNonFoldablePartialRegisterLoad()
7835 case X86::VFMSUB213SDr_Int: in isNonFoldablePartialRegisterLoad()
7836 case X86::VFNMSUB213SDr_Int: in isNonFoldablePartialRegisterLoad()
7837 case X86::VFMSUB231SDr_Int: in isNonFoldablePartialRegisterLoad()
7838 case X86::VFNMSUB231SDr_Int: in isNonFoldablePartialRegisterLoad()
7839 case X86::VFMADD132SDZr_Int: in isNonFoldablePartialRegisterLoad()
7840 case X86::VFNMADD132SDZr_Int: in isNonFoldablePartialRegisterLoad()
7841 case X86::VFMADD213SDZr_Int: in isNonFoldablePartialRegisterLoad()
7842 case X86::VFNMADD213SDZr_Int: in isNonFoldablePartialRegisterLoad()
7843 case X86::VFMADD231SDZr_Int: in isNonFoldablePartialRegisterLoad()
7844 case X86::VFNMADD231SDZr_Int: in isNonFoldablePartialRegisterLoad()
7845 case X86::VFMSUB132SDZr_Int: in isNonFoldablePartialRegisterLoad()
7846 case X86::VFNMSUB132SDZr_Int: in isNonFoldablePartialRegisterLoad()
7847 case X86::VFMSUB213SDZr_Int: in isNonFoldablePartialRegisterLoad()
7848 case X86::VFNMSUB213SDZr_Int: in isNonFoldablePartialRegisterLoad()
7849 case X86::VFMSUB231SDZr_Int: in isNonFoldablePartialRegisterLoad()
7850 case X86::VFNMSUB231SDZr_Int: in isNonFoldablePartialRegisterLoad()
7851 case X86::VFMADD132SDZr_Intk: in isNonFoldablePartialRegisterLoad()
7852 case X86::VFNMADD132SDZr_Intk: in isNonFoldablePartialRegisterLoad()
7853 case X86::VFMADD213SDZr_Intk: in isNonFoldablePartialRegisterLoad()
7854 case X86::VFNMADD213SDZr_Intk: in isNonFoldablePartialRegisterLoad()
7855 case X86::VFMADD231SDZr_Intk: in isNonFoldablePartialRegisterLoad()
7856 case X86::VFNMADD231SDZr_Intk: in isNonFoldablePartialRegisterLoad()
7857 case X86::VFMSUB132SDZr_Intk: in isNonFoldablePartialRegisterLoad()
7858 case X86::VFNMSUB132SDZr_Intk: in isNonFoldablePartialRegisterLoad()
7859 case X86::VFMSUB213SDZr_Intk: in isNonFoldablePartialRegisterLoad()
7860 case X86::VFNMSUB213SDZr_Intk: in isNonFoldablePartialRegisterLoad()
7861 case X86::VFMSUB231SDZr_Intk: in isNonFoldablePartialRegisterLoad()
7862 case X86::VFNMSUB231SDZr_Intk: in isNonFoldablePartialRegisterLoad()
7863 case X86::VFMADD132SDZr_Intkz: in isNonFoldablePartialRegisterLoad()
7864 case X86::VFNMADD132SDZr_Intkz: in isNonFoldablePartialRegisterLoad()
7865 case X86::VFMADD213SDZr_Intkz: in isNonFoldablePartialRegisterLoad()
7866 case X86::VFNMADD213SDZr_Intkz: in isNonFoldablePartialRegisterLoad()
7867 case X86::VFMADD231SDZr_Intkz: in isNonFoldablePartialRegisterLoad()
7868 case X86::VFNMADD231SDZr_Intkz: in isNonFoldablePartialRegisterLoad()
7869 case X86::VFMSUB132SDZr_Intkz: in isNonFoldablePartialRegisterLoad()
7870 case X86::VFNMSUB132SDZr_Intkz: in isNonFoldablePartialRegisterLoad()
7871 case X86::VFMSUB213SDZr_Intkz: in isNonFoldablePartialRegisterLoad()
7872 case X86::VFNMSUB213SDZr_Intkz: in isNonFoldablePartialRegisterLoad()
7873 case X86::VFMSUB231SDZr_Intkz: in isNonFoldablePartialRegisterLoad()
7874 case X86::VFNMSUB231SDZr_Intkz: in isNonFoldablePartialRegisterLoad()
7875 case X86::VFIXUPIMMSDZrri: in isNonFoldablePartialRegisterLoad()
7876 case X86::VFIXUPIMMSDZrrik: in isNonFoldablePartialRegisterLoad()
7877 case X86::VFIXUPIMMSDZrrikz: in isNonFoldablePartialRegisterLoad()
7878 case X86::VFPCLASSSDZrr: in isNonFoldablePartialRegisterLoad()
7879 case X86::VFPCLASSSDZrrk: in isNonFoldablePartialRegisterLoad()
7880 case X86::VGETEXPSDZr: in isNonFoldablePartialRegisterLoad()
7881 case X86::VGETEXPSDZrk: in isNonFoldablePartialRegisterLoad()
7882 case X86::VGETEXPSDZrkz: in isNonFoldablePartialRegisterLoad()
7883 case X86::VGETMANTSDZrri: in isNonFoldablePartialRegisterLoad()
7884 case X86::VGETMANTSDZrrik: in isNonFoldablePartialRegisterLoad()
7885 case X86::VGETMANTSDZrrikz: in isNonFoldablePartialRegisterLoad()
7886 case X86::VRANGESDZrri: in isNonFoldablePartialRegisterLoad()
7887 case X86::VRANGESDZrrik: in isNonFoldablePartialRegisterLoad()
7888 case X86::VRANGESDZrrikz: in isNonFoldablePartialRegisterLoad()
7889 case X86::VRCP14SDZrr: in isNonFoldablePartialRegisterLoad()
7890 case X86::VRCP14SDZrrk: in isNonFoldablePartialRegisterLoad()
7891 case X86::VRCP14SDZrrkz: in isNonFoldablePartialRegisterLoad()
7892 case X86::VRCP28SDZr: in isNonFoldablePartialRegisterLoad()
7893 case X86::VRCP28SDZrk: in isNonFoldablePartialRegisterLoad()
7894 case X86::VRCP28SDZrkz: in isNonFoldablePartialRegisterLoad()
7895 case X86::VREDUCESDZrri: in isNonFoldablePartialRegisterLoad()
7896 case X86::VREDUCESDZrrik: in isNonFoldablePartialRegisterLoad()
7897 case X86::VREDUCESDZrrikz: in isNonFoldablePartialRegisterLoad()
7898 case X86::VRNDSCALESDZr_Int: in isNonFoldablePartialRegisterLoad()
7899 case X86::VRNDSCALESDZr_Intk: in isNonFoldablePartialRegisterLoad()
7900 case X86::VRNDSCALESDZr_Intkz: in isNonFoldablePartialRegisterLoad()
7901 case X86::VRSQRT14SDZrr: in isNonFoldablePartialRegisterLoad()
7902 case X86::VRSQRT14SDZrrk: in isNonFoldablePartialRegisterLoad()
7903 case X86::VRSQRT14SDZrrkz: in isNonFoldablePartialRegisterLoad()
7904 case X86::VRSQRT28SDZr: in isNonFoldablePartialRegisterLoad()
7905 case X86::VRSQRT28SDZrk: in isNonFoldablePartialRegisterLoad()
7906 case X86::VRSQRT28SDZrkz: in isNonFoldablePartialRegisterLoad()
7907 case X86::VSCALEFSDZrr: in isNonFoldablePartialRegisterLoad()
7908 case X86::VSCALEFSDZrrk: in isNonFoldablePartialRegisterLoad()
7909 case X86::VSCALEFSDZrrkz: in isNonFoldablePartialRegisterLoad()
7916 if ((Opc == X86::VMOVSHZrm || Opc == X86::VMOVSHZrm_alt) && RegSize > 16) { in isNonFoldablePartialRegisterLoad()
7921 case X86::VADDSHZrr_Int: in isNonFoldablePartialRegisterLoad()
7922 case X86::VCMPSHZrri_Int: in isNonFoldablePartialRegisterLoad()
7923 case X86::VDIVSHZrr_Int: in isNonFoldablePartialRegisterLoad()
7924 case X86::VMAXSHZrr_Int: in isNonFoldablePartialRegisterLoad()
7925 case X86::VMINSHZrr_Int: in isNonFoldablePartialRegisterLoad()
7926 case X86::VMULSHZrr_Int: in isNonFoldablePartialRegisterLoad()
7927 case X86::VSUBSHZrr_Int: in isNonFoldablePartialRegisterLoad()
7928 case X86::VADDSHZrr_Intk: in isNonFoldablePartialRegisterLoad()
7929 case X86::VADDSHZrr_Intkz: in isNonFoldablePartialRegisterLoad()
7930 case X86::VCMPSHZrri_Intk: in isNonFoldablePartialRegisterLoad()
7931 case X86::VDIVSHZrr_Intk: in isNonFoldablePartialRegisterLoad()
7932 case X86::VDIVSHZrr_Intkz: in isNonFoldablePartialRegisterLoad()
7933 case X86::VMAXSHZrr_Intk: in isNonFoldablePartialRegisterLoad()
7934 case X86::VMAXSHZrr_Intkz: in isNonFoldablePartialRegisterLoad()
7935 case X86::VMINSHZrr_Intk: in isNonFoldablePartialRegisterLoad()
7936 case X86::VMINSHZrr_Intkz: in isNonFoldablePartialRegisterLoad()
7937 case X86::VMULSHZrr_Intk: in isNonFoldablePartialRegisterLoad()
7938 case X86::VMULSHZrr_Intkz: in isNonFoldablePartialRegisterLoad()
7939 case X86::VSUBSHZrr_Intk: in isNonFoldablePartialRegisterLoad()
7940 case X86::VSUBSHZrr_Intkz: in isNonFoldablePartialRegisterLoad()
7941 case X86::VFMADD132SHZr_Int: in isNonFoldablePartialRegisterLoad()
7942 case X86::VFNMADD132SHZr_Int: in isNonFoldablePartialRegisterLoad()
7943 case X86::VFMADD213SHZr_Int: in isNonFoldablePartialRegisterLoad()
7944 case X86::VFNMADD213SHZr_Int: in isNonFoldablePartialRegisterLoad()
7945 case X86::VFMADD231SHZr_Int: in isNonFoldablePartialRegisterLoad()
7946 case X86::VFNMADD231SHZr_Int: in isNonFoldablePartialRegisterLoad()
7947 case X86::VFMSUB132SHZr_Int: in isNonFoldablePartialRegisterLoad()
7948 case X86::VFNMSUB132SHZr_Int: in isNonFoldablePartialRegisterLoad()
7949 case X86::VFMSUB213SHZr_Int: in isNonFoldablePartialRegisterLoad()
7950 case X86::VFNMSUB213SHZr_Int: in isNonFoldablePartialRegisterLoad()
7951 case X86::VFMSUB231SHZr_Int: in isNonFoldablePartialRegisterLoad()
7952 case X86::VFNMSUB231SHZr_Int: in isNonFoldablePartialRegisterLoad()
7953 case X86::VFMADD132SHZr_Intk: in isNonFoldablePartialRegisterLoad()
7954 case X86::VFNMADD132SHZr_Intk: in isNonFoldablePartialRegisterLoad()
7955 case X86::VFMADD213SHZr_Intk: in isNonFoldablePartialRegisterLoad()
7956 case X86::VFNMADD213SHZr_Intk: in isNonFoldablePartialRegisterLoad()
7957 case X86::VFMADD231SHZr_Intk: in isNonFoldablePartialRegisterLoad()
7958 case X86::VFNMADD231SHZr_Intk: in isNonFoldablePartialRegisterLoad()
7959 case X86::VFMSUB132SHZr_Intk: in isNonFoldablePartialRegisterLoad()
7960 case X86::VFNMSUB132SHZr_Intk: in isNonFoldablePartialRegisterLoad()
7961 case X86::VFMSUB213SHZr_Intk: in isNonFoldablePartialRegisterLoad()
7962 case X86::VFNMSUB213SHZr_Intk: in isNonFoldablePartialRegisterLoad()
7963 case X86::VFMSUB231SHZr_Intk: in isNonFoldablePartialRegisterLoad()
7964 case X86::VFNMSUB231SHZr_Intk: in isNonFoldablePartialRegisterLoad()
7965 case X86::VFMADD132SHZr_Intkz: in isNonFoldablePartialRegisterLoad()
7966 case X86::VFNMADD132SHZr_Intkz: in isNonFoldablePartialRegisterLoad()
7967 case X86::VFMADD213SHZr_Intkz: in isNonFoldablePartialRegisterLoad()
7968 case X86::VFNMADD213SHZr_Intkz: in isNonFoldablePartialRegisterLoad()
7969 case X86::VFMADD231SHZr_Intkz: in isNonFoldablePartialRegisterLoad()
7970 case X86::VFNMADD231SHZr_Intkz: in isNonFoldablePartialRegisterLoad()
7971 case X86::VFMSUB132SHZr_Intkz: in isNonFoldablePartialRegisterLoad()
7972 case X86::VFNMSUB132SHZr_Intkz: in isNonFoldablePartialRegisterLoad()
7973 case X86::VFMSUB213SHZr_Intkz: in isNonFoldablePartialRegisterLoad()
7974 case X86::VFNMSUB213SHZr_Intkz: in isNonFoldablePartialRegisterLoad()
7975 case X86::VFMSUB231SHZr_Intkz: in isNonFoldablePartialRegisterLoad()
7976 case X86::VFNMSUB231SHZr_Intkz: in isNonFoldablePartialRegisterLoad()
8024 case X86::AVX512_512_SET0: in foldMemoryOperandImpl()
8025 case X86::AVX512_512_SETALLONES: in foldMemoryOperandImpl()
8028 case X86::AVX2_SETALLONES: in foldMemoryOperandImpl()
8029 case X86::AVX1_SETALLONES: in foldMemoryOperandImpl()
8030 case X86::AVX_SET0: in foldMemoryOperandImpl()
8031 case X86::AVX512_256_SET0: in foldMemoryOperandImpl()
8034 case X86::V_SET0: in foldMemoryOperandImpl()
8035 case X86::V_SETALLONES: in foldMemoryOperandImpl()
8036 case X86::AVX512_128_SET0: in foldMemoryOperandImpl()
8037 case X86::FsFLD0F128: in foldMemoryOperandImpl()
8038 case X86::AVX512_FsFLD0F128: in foldMemoryOperandImpl()
8041 case X86::MMX_SET0: in foldMemoryOperandImpl()
8042 case X86::FsFLD0SD: in foldMemoryOperandImpl()
8043 case X86::AVX512_FsFLD0SD: in foldMemoryOperandImpl()
8046 case X86::FsFLD0SS: in foldMemoryOperandImpl()
8047 case X86::AVX512_FsFLD0SS: in foldMemoryOperandImpl()
8050 case X86::FsFLD0SH: in foldMemoryOperandImpl()
8051 case X86::AVX512_FsFLD0SH: in foldMemoryOperandImpl()
8062 case X86::TEST8rr: in foldMemoryOperandImpl()
8063 NewOpc = X86::CMP8ri; in foldMemoryOperandImpl()
8065 case X86::TEST16rr: in foldMemoryOperandImpl()
8066 NewOpc = X86::CMP16ri; in foldMemoryOperandImpl()
8068 case X86::TEST32rr: in foldMemoryOperandImpl()
8069 NewOpc = X86::CMP32ri; in foldMemoryOperandImpl()
8071 case X86::TEST64rr: in foldMemoryOperandImpl()
8072 NewOpc = X86::CMP64ri32; in foldMemoryOperandImpl()
8086 SmallVector<MachineOperand, X86::AddrNumOperands> MOs; in foldMemoryOperandImpl()
8088 case X86::MMX_SET0: in foldMemoryOperandImpl()
8089 case X86::V_SET0: in foldMemoryOperandImpl()
8090 case X86::V_SETALLONES: in foldMemoryOperandImpl()
8091 case X86::AVX2_SETALLONES: in foldMemoryOperandImpl()
8092 case X86::AVX1_SETALLONES: in foldMemoryOperandImpl()
8093 case X86::AVX_SET0: in foldMemoryOperandImpl()
8094 case X86::AVX512_128_SET0: in foldMemoryOperandImpl()
8095 case X86::AVX512_256_SET0: in foldMemoryOperandImpl()
8096 case X86::AVX512_512_SET0: in foldMemoryOperandImpl()
8097 case X86::AVX512_512_SETALLONES: in foldMemoryOperandImpl()
8098 case X86::FsFLD0SH: in foldMemoryOperandImpl()
8099 case X86::AVX512_FsFLD0SH: in foldMemoryOperandImpl()
8100 case X86::FsFLD0SD: in foldMemoryOperandImpl()
8101 case X86::AVX512_FsFLD0SD: in foldMemoryOperandImpl()
8102 case X86::FsFLD0SS: in foldMemoryOperandImpl()
8103 case X86::AVX512_FsFLD0SS: in foldMemoryOperandImpl()
8104 case X86::FsFLD0F128: in foldMemoryOperandImpl()
8105 case X86::AVX512_FsFLD0F128: { in foldMemoryOperandImpl()
8113 // x86-32 PIC requires a PIC base register for constant pools. in foldMemoryOperandImpl()
8118 PICBase = X86::RIP; in foldMemoryOperandImpl()
8132 case X86::FsFLD0SS: in foldMemoryOperandImpl()
8133 case X86::AVX512_FsFLD0SS: in foldMemoryOperandImpl()
8136 case X86::FsFLD0SD: in foldMemoryOperandImpl()
8137 case X86::AVX512_FsFLD0SD: in foldMemoryOperandImpl()
8140 case X86::FsFLD0F128: in foldMemoryOperandImpl()
8141 case X86::AVX512_FsFLD0F128: in foldMemoryOperandImpl()
8144 case X86::FsFLD0SH: in foldMemoryOperandImpl()
8145 case X86::AVX512_FsFLD0SH: in foldMemoryOperandImpl()
8148 case X86::AVX512_512_SETALLONES: in foldMemoryOperandImpl()
8151 case X86::AVX512_512_SET0: in foldMemoryOperandImpl()
8155 case X86::AVX1_SETALLONES: in foldMemoryOperandImpl()
8156 case X86::AVX2_SETALLONES: in foldMemoryOperandImpl()
8159 case X86::AVX512_256_SET0: in foldMemoryOperandImpl()
8160 case X86::AVX_SET0: in foldMemoryOperandImpl()
8165 case X86::MMX_SET0: in foldMemoryOperandImpl()
8169 case X86::V_SETALLONES: in foldMemoryOperandImpl()
8172 case X86::V_SET0: in foldMemoryOperandImpl()
8173 case X86::AVX512_128_SET0: in foldMemoryOperandImpl()
8191 case X86::VPBROADCASTBZ128rm: in foldMemoryOperandImpl()
8192 case X86::VPBROADCASTBZ256rm: in foldMemoryOperandImpl()
8193 case X86::VPBROADCASTBZrm: in foldMemoryOperandImpl()
8194 case X86::VBROADCASTF32X2Z256rm: in foldMemoryOperandImpl()
8195 case X86::VBROADCASTF32X2Zrm: in foldMemoryOperandImpl()
8196 case X86::VBROADCASTI32X2Z128rm: in foldMemoryOperandImpl()
8197 case X86::VBROADCASTI32X2Z256rm: in foldMemoryOperandImpl()
8198 case X86::VBROADCASTI32X2Zrm: in foldMemoryOperandImpl()
8203 MOs.append(LoadMI.operands_begin() + NumOps - X86::AddrNumOperands, \ in foldMemoryOperandImpl()
8207 case X86::VPBROADCASTWZ128rm: in foldMemoryOperandImpl()
8208 case X86::VPBROADCASTWZ256rm: in foldMemoryOperandImpl()
8209 case X86::VPBROADCASTWZrm: in foldMemoryOperandImpl()
8211 case X86::VPBROADCASTDZ128rm: in foldMemoryOperandImpl()
8212 case X86::VPBROADCASTDZ256rm: in foldMemoryOperandImpl()
8213 case X86::VPBROADCASTDZrm: in foldMemoryOperandImpl()
8214 case X86::VBROADCASTSSZ128rm: in foldMemoryOperandImpl()
8215 case X86::VBROADCASTSSZ256rm: in foldMemoryOperandImpl()
8216 case X86::VBROADCASTSSZrm: in foldMemoryOperandImpl()
8218 case X86::VPBROADCASTQZ128rm: in foldMemoryOperandImpl()
8219 case X86::VPBROADCASTQZ256rm: in foldMemoryOperandImpl()
8220 case X86::VPBROADCASTQZrm: in foldMemoryOperandImpl()
8221 case X86::VBROADCASTSDZ256rm: in foldMemoryOperandImpl()
8222 case X86::VBROADCASTSDZrm: in foldMemoryOperandImpl()
8229 MOs.append(LoadMI.operands_begin() + NumOps - X86::AddrNumOperands, in foldMemoryOperandImpl()
8326 return X86::OP16; \ in getBroadcastOpcode()
8328 return X86::OP32; \ in getBroadcastOpcode()
8330 return X86::OP64; \ in getBroadcastOpcode()
8374 if (!MI.hasOneMemOperand() && RC == &X86::VR128RegClass && in unfoldMemoryOperand()
8380 SmallVector<MachineOperand, X86::AddrNumOperands> AddrOps; in unfoldMemoryOperand()
8386 if (i >= Index && i < Index + X86::AddrNumOperands) in unfoldMemoryOperand()
8418 for (unsigned i = 1; i != 1 + X86::AddrNumOperands; ++i) { in unfoldMemoryOperand()
8449 case X86::CMP64ri32: in unfoldMemoryOperand()
8450 case X86::CMP32ri: in unfoldMemoryOperand()
8451 case X86::CMP16ri: in unfoldMemoryOperand()
8452 case X86::CMP8ri: { in unfoldMemoryOperand()
8460 case X86::CMP64ri32: in unfoldMemoryOperand()
8461 NewOpc = X86::TEST64rr; in unfoldMemoryOperand()
8463 case X86::CMP32ri: in unfoldMemoryOperand()
8464 NewOpc = X86::TEST32rr; in unfoldMemoryOperand()
8466 case X86::CMP16ri: in unfoldMemoryOperand()
8467 NewOpc = X86::TEST16rr; in unfoldMemoryOperand()
8469 case X86::CMP8ri: in unfoldMemoryOperand()
8470 NewOpc = X86::TEST8rr; in unfoldMemoryOperand()
8523 if (i >= Index - NumDefs && i < Index - NumDefs + X86::AddrNumOperands) in unfoldMemoryOperand()
8538 if (MMOs.empty() && RC == &X86::VR128RegClass && in unfoldMemoryOperand()
8580 case X86::CMP64ri32: in unfoldMemoryOperand()
8581 case X86::CMP32ri: in unfoldMemoryOperand()
8582 case X86::CMP16ri: in unfoldMemoryOperand()
8583 case X86::CMP8ri: in unfoldMemoryOperand()
8588 case X86::CMP64ri32: in unfoldMemoryOperand()
8589 Opc = X86::TEST64rr; in unfoldMemoryOperand()
8591 case X86::CMP32ri: in unfoldMemoryOperand()
8592 Opc = X86::TEST32rr; in unfoldMemoryOperand()
8594 case X86::CMP16ri: in unfoldMemoryOperand()
8595 Opc = X86::TEST16rr; in unfoldMemoryOperand()
8597 case X86::CMP8ri: in unfoldMemoryOperand()
8598 Opc = X86::TEST8rr; in unfoldMemoryOperand()
8613 if (MMOs.empty() && RC == &X86::VR128RegClass && in unfoldMemoryOperand()
8661 case X86::MOV8rm: in areLoadsFromSameBasePtr()
8662 case X86::MOV16rm: in areLoadsFromSameBasePtr()
8663 case X86::MOV32rm: in areLoadsFromSameBasePtr()
8664 case X86::MOV64rm: in areLoadsFromSameBasePtr()
8665 case X86::LD_Fp32m: in areLoadsFromSameBasePtr()
8666 case X86::LD_Fp64m: in areLoadsFromSameBasePtr()
8667 case X86::LD_Fp80m: in areLoadsFromSameBasePtr()
8668 case X86::MOVSSrm: in areLoadsFromSameBasePtr()
8669 case X86::MOVSSrm_alt: in areLoadsFromSameBasePtr()
8670 case X86::MOVSDrm: in areLoadsFromSameBasePtr()
8671 case X86::MOVSDrm_alt: in areLoadsFromSameBasePtr()
8672 case X86::MMX_MOVD64rm: in areLoadsFromSameBasePtr()
8673 case X86::MMX_MOVQ64rm: in areLoadsFromSameBasePtr()
8674 case X86::MOVAPSrm: in areLoadsFromSameBasePtr()
8675 case X86::MOVUPSrm: in areLoadsFromSameBasePtr()
8676 case X86::MOVAPDrm: in areLoadsFromSameBasePtr()
8677 case X86::MOVUPDrm: in areLoadsFromSameBasePtr()
8678 case X86::MOVDQArm: in areLoadsFromSameBasePtr()
8679 case X86::MOVDQUrm: in areLoadsFromSameBasePtr()
8681 case X86::VMOVSSrm: in areLoadsFromSameBasePtr()
8682 case X86::VMOVSSrm_alt: in areLoadsFromSameBasePtr()
8683 case X86::VMOVSDrm: in areLoadsFromSameBasePtr()
8684 case X86::VMOVSDrm_alt: in areLoadsFromSameBasePtr()
8685 case X86::VMOVAPSrm: in areLoadsFromSameBasePtr()
8686 case X86::VMOVUPSrm: in areLoadsFromSameBasePtr()
8687 case X86::VMOVAPDrm: in areLoadsFromSameBasePtr()
8688 case X86::VMOVUPDrm: in areLoadsFromSameBasePtr()
8689 case X86::VMOVDQArm: in areLoadsFromSameBasePtr()
8690 case X86::VMOVDQUrm: in areLoadsFromSameBasePtr()
8691 case X86::VMOVAPSYrm: in areLoadsFromSameBasePtr()
8692 case X86::VMOVUPSYrm: in areLoadsFromSameBasePtr()
8693 case X86::VMOVAPDYrm: in areLoadsFromSameBasePtr()
8694 case X86::VMOVUPDYrm: in areLoadsFromSameBasePtr()
8695 case X86::VMOVDQAYrm: in areLoadsFromSameBasePtr()
8696 case X86::VMOVDQUYrm: in areLoadsFromSameBasePtr()
8698 case X86::VMOVSSZrm: in areLoadsFromSameBasePtr()
8699 case X86::VMOVSSZrm_alt: in areLoadsFromSameBasePtr()
8700 case X86::VMOVSDZrm: in areLoadsFromSameBasePtr()
8701 case X86::VMOVSDZrm_alt: in areLoadsFromSameBasePtr()
8702 case X86::VMOVAPSZ128rm: in areLoadsFromSameBasePtr()
8703 case X86::VMOVUPSZ128rm: in areLoadsFromSameBasePtr()
8704 case X86::VMOVAPSZ128rm_NOVLX: in areLoadsFromSameBasePtr()
8705 case X86::VMOVUPSZ128rm_NOVLX: in areLoadsFromSameBasePtr()
8706 case X86::VMOVAPDZ128rm: in areLoadsFromSameBasePtr()
8707 case X86::VMOVUPDZ128rm: in areLoadsFromSameBasePtr()
8708 case X86::VMOVDQU8Z128rm: in areLoadsFromSameBasePtr()
8709 case X86::VMOVDQU16Z128rm: in areLoadsFromSameBasePtr()
8710 case X86::VMOVDQA32Z128rm: in areLoadsFromSameBasePtr()
8711 case X86::VMOVDQU32Z128rm: in areLoadsFromSameBasePtr()
8712 case X86::VMOVDQA64Z128rm: in areLoadsFromSameBasePtr()
8713 case X86::VMOVDQU64Z128rm: in areLoadsFromSameBasePtr()
8714 case X86::VMOVAPSZ256rm: in areLoadsFromSameBasePtr()
8715 case X86::VMOVUPSZ256rm: in areLoadsFromSameBasePtr()
8716 case X86::VMOVAPSZ256rm_NOVLX: in areLoadsFromSameBasePtr()
8717 case X86::VMOVUPSZ256rm_NOVLX: in areLoadsFromSameBasePtr()
8718 case X86::VMOVAPDZ256rm: in areLoadsFromSameBasePtr()
8719 case X86::VMOVUPDZ256rm: in areLoadsFromSameBasePtr()
8720 case X86::VMOVDQU8Z256rm: in areLoadsFromSameBasePtr()
8721 case X86::VMOVDQU16Z256rm: in areLoadsFromSameBasePtr()
8722 case X86::VMOVDQA32Z256rm: in areLoadsFromSameBasePtr()
8723 case X86::VMOVDQU32Z256rm: in areLoadsFromSameBasePtr()
8724 case X86::VMOVDQA64Z256rm: in areLoadsFromSameBasePtr()
8725 case X86::VMOVDQU64Z256rm: in areLoadsFromSameBasePtr()
8726 case X86::VMOVAPSZrm: in areLoadsFromSameBasePtr()
8727 case X86::VMOVUPSZrm: in areLoadsFromSameBasePtr()
8728 case X86::VMOVAPDZrm: in areLoadsFromSameBasePtr()
8729 case X86::VMOVUPDZrm: in areLoadsFromSameBasePtr()
8730 case X86::VMOVDQU8Zrm: in areLoadsFromSameBasePtr()
8731 case X86::VMOVDQU16Zrm: in areLoadsFromSameBasePtr()
8732 case X86::VMOVDQA32Zrm: in areLoadsFromSameBasePtr()
8733 case X86::VMOVDQU32Zrm: in areLoadsFromSameBasePtr()
8734 case X86::VMOVDQA64Zrm: in areLoadsFromSameBasePtr()
8735 case X86::VMOVDQU64Zrm: in areLoadsFromSameBasePtr()
8736 case X86::KMOVBkm: in areLoadsFromSameBasePtr()
8737 case X86::KMOVBkm_EVEX: in areLoadsFromSameBasePtr()
8738 case X86::KMOVWkm: in areLoadsFromSameBasePtr()
8739 case X86::KMOVWkm_EVEX: in areLoadsFromSameBasePtr()
8740 case X86::KMOVDkm: in areLoadsFromSameBasePtr()
8741 case X86::KMOVDkm_EVEX: in areLoadsFromSameBasePtr()
8742 case X86::KMOVQkm: in areLoadsFromSameBasePtr()
8743 case X86::KMOVQkm_EVEX: in areLoadsFromSameBasePtr()
8758 if (!HasSameOp(X86::AddrBaseReg) || !HasSameOp(X86::AddrScaleAmt) || in areLoadsFromSameBasePtr()
8759 !HasSameOp(X86::AddrIndexReg) || !HasSameOp(X86::AddrSegmentReg)) in areLoadsFromSameBasePtr()
8767 auto Disp1 = dyn_cast<ConstantSDNode>(Load1->getOperand(X86::AddrDisp)); in areLoadsFromSameBasePtr()
8768 auto Disp2 = dyn_cast<ConstantSDNode>(Load2->getOperand(X86::AddrDisp)); in areLoadsFromSameBasePtr()
8792 case X86::LD_Fp32m: in shouldScheduleLoadsNear()
8793 case X86::LD_Fp64m: in shouldScheduleLoadsNear()
8794 case X86::LD_Fp80m: in shouldScheduleLoadsNear()
8795 case X86::MMX_MOVD64rm: in shouldScheduleLoadsNear()
8796 case X86::MMX_MOVQ64rm: in shouldScheduleLoadsNear()
8832 if (Opcode == X86::ENDBR64 || Opcode == X86::ENDBR32 || in isSchedulingBoundary()
8833 Opcode == X86::PLDTILECFGV) in isSchedulingBoundary()
8846 assert(Cond.size() == 1 && "Invalid X86 branch condition!"); in reverseBranchCondition()
8847 X86::CondCode CC = static_cast<X86::CondCode>(Cond[0].getImm()); in reverseBranchCondition()
8856 return !(RC == &X86::CCRRegClass || RC == &X86::DFCCRRegClass || in isSafeToMoveRegClassDefs()
8857 RC == &X86::RFP32RegClass || RC == &X86::RFP64RegClass || in isSafeToMoveRegClassDefs()
8858 RC == &X86::RFP80RegClass); in isSafeToMoveRegClassDefs()
8877 Subtarget.is64Bit() ? &X86::GR64_NOSPRegClass : &X86::GR32_NOSPRegClass); in getGlobalBaseReg()
8953 case X86::BLENDPDrmi: in getExecutionDomainCustom()
8954 case X86::BLENDPDrri: in getExecutionDomainCustom()
8955 case X86::VBLENDPDrmi: in getExecutionDomainCustom()
8956 case X86::VBLENDPDrri: in getExecutionDomainCustom()
8958 case X86::VBLENDPDYrmi: in getExecutionDomainCustom()
8959 case X86::VBLENDPDYrri: in getExecutionDomainCustom()
8961 case X86::BLENDPSrmi: in getExecutionDomainCustom()
8962 case X86::BLENDPSrri: in getExecutionDomainCustom()
8963 case X86::VBLENDPSrmi: in getExecutionDomainCustom()
8964 case X86::VBLENDPSrri: in getExecutionDomainCustom()
8965 case X86::VPBLENDDrmi: in getExecutionDomainCustom()
8966 case X86::VPBLENDDrri: in getExecutionDomainCustom()
8968 case X86::VBLENDPSYrmi: in getExecutionDomainCustom()
8969 case X86::VBLENDPSYrri: in getExecutionDomainCustom()
8970 case X86::VPBLENDDYrmi: in getExecutionDomainCustom()
8971 case X86::VPBLENDDYrri: in getExecutionDomainCustom()
8973 case X86::PBLENDWrmi: in getExecutionDomainCustom()
8974 case X86::PBLENDWrri: in getExecutionDomainCustom()
8975 case X86::VPBLENDWrmi: in getExecutionDomainCustom()
8976 case X86::VPBLENDWrri: in getExecutionDomainCustom()
8978 case X86::VPBLENDWYrmi: in getExecutionDomainCustom()
8979 case X86::VPBLENDWYrri: in getExecutionDomainCustom()
8981 case X86::VPANDDZ128rr: in getExecutionDomainCustom()
8982 case X86::VPANDDZ128rm: in getExecutionDomainCustom()
8983 case X86::VPANDDZ256rr: in getExecutionDomainCustom()
8984 case X86::VPANDDZ256rm: in getExecutionDomainCustom()
8985 case X86::VPANDQZ128rr: in getExecutionDomainCustom()
8986 case X86::VPANDQZ128rm: in getExecutionDomainCustom()
8987 case X86::VPANDQZ256rr: in getExecutionDomainCustom()
8988 case X86::VPANDQZ256rm: in getExecutionDomainCustom()
8989 case X86::VPANDNDZ128rr: in getExecutionDomainCustom()
8990 case X86::VPANDNDZ128rm: in getExecutionDomainCustom()
8991 case X86::VPANDNDZ256rr: in getExecutionDomainCustom()
8992 case X86::VPANDNDZ256rm: in getExecutionDomainCustom()
8993 case X86::VPANDNQZ128rr: in getExecutionDomainCustom()
8994 case X86::VPANDNQZ128rm: in getExecutionDomainCustom()
8995 case X86::VPANDNQZ256rr: in getExecutionDomainCustom()
8996 case X86::VPANDNQZ256rm: in getExecutionDomainCustom()
8997 case X86::VPORDZ128rr: in getExecutionDomainCustom()
8998 case X86::VPORDZ128rm: in getExecutionDomainCustom()
8999 case X86::VPORDZ256rr: in getExecutionDomainCustom()
9000 case X86::VPORDZ256rm: in getExecutionDomainCustom()
9001 case X86::VPORQZ128rr: in getExecutionDomainCustom()
9002 case X86::VPORQZ128rm: in getExecutionDomainCustom()
9003 case X86::VPORQZ256rr: in getExecutionDomainCustom()
9004 case X86::VPORQZ256rm: in getExecutionDomainCustom()
9005 case X86::VPXORDZ128rr: in getExecutionDomainCustom()
9006 case X86::VPXORDZ128rm: in getExecutionDomainCustom()
9007 case X86::VPXORDZ256rr: in getExecutionDomainCustom()
9008 case X86::VPXORDZ256rm: in getExecutionDomainCustom()
9009 case X86::VPXORQZ128rr: in getExecutionDomainCustom()
9010 case X86::VPXORQZ128rm: in getExecutionDomainCustom()
9011 case X86::VPXORQZ256rr: in getExecutionDomainCustom()
9012 case X86::VPXORQZ256rm: in getExecutionDomainCustom()
9029 case X86::MOVHLPSrr: in getExecutionDomainCustom()
9041 case X86::SHUFPDrri: in getExecutionDomainCustom()
9093 case X86::BLENDPDrmi: in setExecutionDomainCustom()
9094 case X86::BLENDPDrri: in setExecutionDomainCustom()
9095 case X86::VBLENDPDrmi: in setExecutionDomainCustom()
9096 case X86::VBLENDPDrri: in setExecutionDomainCustom()
9098 case X86::VBLENDPDYrmi: in setExecutionDomainCustom()
9099 case X86::VBLENDPDYrri: in setExecutionDomainCustom()
9101 case X86::BLENDPSrmi: in setExecutionDomainCustom()
9102 case X86::BLENDPSrri: in setExecutionDomainCustom()
9103 case X86::VBLENDPSrmi: in setExecutionDomainCustom()
9104 case X86::VBLENDPSrri: in setExecutionDomainCustom()
9105 case X86::VPBLENDDrmi: in setExecutionDomainCustom()
9106 case X86::VPBLENDDrri: in setExecutionDomainCustom()
9108 case X86::VBLENDPSYrmi: in setExecutionDomainCustom()
9109 case X86::VBLENDPSYrri: in setExecutionDomainCustom()
9110 case X86::VPBLENDDYrmi: in setExecutionDomainCustom()
9111 case X86::VPBLENDDYrri: in setExecutionDomainCustom()
9113 case X86::PBLENDWrmi: in setExecutionDomainCustom()
9114 case X86::PBLENDWrri: in setExecutionDomainCustom()
9115 case X86::VPBLENDWrmi: in setExecutionDomainCustom()
9116 case X86::VPBLENDWrri: in setExecutionDomainCustom()
9118 case X86::VPBLENDWYrmi: in setExecutionDomainCustom()
9119 case X86::VPBLENDWYrri: in setExecutionDomainCustom()
9121 case X86::VPANDDZ128rr: in setExecutionDomainCustom()
9122 case X86::VPANDDZ128rm: in setExecutionDomainCustom()
9123 case X86::VPANDDZ256rr: in setExecutionDomainCustom()
9124 case X86::VPANDDZ256rm: in setExecutionDomainCustom()
9125 case X86::VPANDQZ128rr: in setExecutionDomainCustom()
9126 case X86::VPANDQZ128rm: in setExecutionDomainCustom()
9127 case X86::VPANDQZ256rr: in setExecutionDomainCustom()
9128 case X86::VPANDQZ256rm: in setExecutionDomainCustom()
9129 case X86::VPANDNDZ128rr: in setExecutionDomainCustom()
9130 case X86::VPANDNDZ128rm: in setExecutionDomainCustom()
9131 case X86::VPANDNDZ256rr: in setExecutionDomainCustom()
9132 case X86::VPANDNDZ256rm: in setExecutionDomainCustom()
9133 case X86::VPANDNQZ128rr: in setExecutionDomainCustom()
9134 case X86::VPANDNQZ128rm: in setExecutionDomainCustom()
9135 case X86::VPANDNQZ256rr: in setExecutionDomainCustom()
9136 case X86::VPANDNQZ256rm: in setExecutionDomainCustom()
9137 case X86::VPORDZ128rr: in setExecutionDomainCustom()
9138 case X86::VPORDZ128rm: in setExecutionDomainCustom()
9139 case X86::VPORDZ256rr: in setExecutionDomainCustom()
9140 case X86::VPORDZ256rm: in setExecutionDomainCustom()
9141 case X86::VPORQZ128rr: in setExecutionDomainCustom()
9142 case X86::VPORQZ128rm: in setExecutionDomainCustom()
9143 case X86::VPORQZ256rr: in setExecutionDomainCustom()
9144 case X86::VPORQZ256rm: in setExecutionDomainCustom()
9145 case X86::VPXORDZ128rr: in setExecutionDomainCustom()
9146 case X86::VPXORDZ128rm: in setExecutionDomainCustom()
9147 case X86::VPXORDZ256rr: in setExecutionDomainCustom()
9148 case X86::VPXORDZ256rm: in setExecutionDomainCustom()
9149 case X86::VPXORQZ128rr: in setExecutionDomainCustom()
9150 case X86::VPXORQZ128rm: in setExecutionDomainCustom()
9151 case X86::VPXORQZ256rr: in setExecutionDomainCustom()
9152 case X86::VPXORQZ256rm: { in setExecutionDomainCustom()
9167 case X86::UNPCKHPDrr: in setExecutionDomainCustom()
9168 case X86::MOVHLPSrr: in setExecutionDomainCustom()
9179 if (Opcode == X86::MOVHLPSrr) in setExecutionDomainCustom()
9182 case X86::SHUFPDrri: { in setExecutionDomainCustom()
9191 MI.setDesc(get(X86::SHUFPSrri)); in setExecutionDomainCustom()
9293 BuildMI(MBB, MI, DL, get(X86::NOOP)); in insertNoop()
9299 Nop.setOpcode(X86::NOOP); in getNop()
9307 case X86::DIVPDrm: in isHighLatencyDef()
9308 case X86::DIVPDrr: in isHighLatencyDef()
9309 case X86::DIVPSrm: in isHighLatencyDef()
9310 case X86::DIVPSrr: in isHighLatencyDef()
9311 case X86::DIVSDrm: in isHighLatencyDef()
9312 case X86::DIVSDrm_Int: in isHighLatencyDef()
9313 case X86::DIVSDrr: in isHighLatencyDef()
9314 case X86::DIVSDrr_Int: in isHighLatencyDef()
9315 case X86::DIVSSrm: in isHighLatencyDef()
9316 case X86::DIVSSrm_Int: in isHighLatencyDef()
9317 case X86::DIVSSrr: in isHighLatencyDef()
9318 case X86::DIVSSrr_Int: in isHighLatencyDef()
9319 case X86::SQRTPDm: in isHighLatencyDef()
9320 case X86::SQRTPDr: in isHighLatencyDef()
9321 case X86::SQRTPSm: in isHighLatencyDef()
9322 case X86::SQRTPSr: in isHighLatencyDef()
9323 case X86::SQRTSDm: in isHighLatencyDef()
9324 case X86::SQRTSDm_Int: in isHighLatencyDef()
9325 case X86::SQRTSDr: in isHighLatencyDef()
9326 case X86::SQRTSDr_Int: in isHighLatencyDef()
9327 case X86::SQRTSSm: in isHighLatencyDef()
9328 case X86::SQRTSSm_Int: in isHighLatencyDef()
9329 case X86::SQRTSSr: in isHighLatencyDef()
9330 case X86::SQRTSSr_Int: in isHighLatencyDef()
9332 case X86::VDIVPDrm: in isHighLatencyDef()
9333 case X86::VDIVPDrr: in isHighLatencyDef()
9334 case X86::VDIVPDYrm: in isHighLatencyDef()
9335 case X86::VDIVPDYrr: in isHighLatencyDef()
9336 case X86::VDIVPSrm: in isHighLatencyDef()
9337 case X86::VDIVPSrr: in isHighLatencyDef()
9338 case X86::VDIVPSYrm: in isHighLatencyDef()
9339 case X86::VDIVPSYrr: in isHighLatencyDef()
9340 case X86::VDIVSDrm: in isHighLatencyDef()
9341 case X86::VDIVSDrm_Int: in isHighLatencyDef()
9342 case X86::VDIVSDrr: in isHighLatencyDef()
9343 case X86::VDIVSDrr_Int: in isHighLatencyDef()
9344 case X86::VDIVSSrm: in isHighLatencyDef()
9345 case X86::VDIVSSrm_Int: in isHighLatencyDef()
9346 case X86::VDIVSSrr: in isHighLatencyDef()
9347 case X86::VDIVSSrr_Int: in isHighLatencyDef()
9348 case X86::VSQRTPDm: in isHighLatencyDef()
9349 case X86::VSQRTPDr: in isHighLatencyDef()
9350 case X86::VSQRTPDYm: in isHighLatencyDef()
9351 case X86::VSQRTPDYr: in isHighLatencyDef()
9352 case X86::VSQRTPSm: in isHighLatencyDef()
9353 case X86::VSQRTPSr: in isHighLatencyDef()
9354 case X86::VSQRTPSYm: in isHighLatencyDef()
9355 case X86::VSQRTPSYr: in isHighLatencyDef()
9356 case X86::VSQRTSDm: in isHighLatencyDef()
9357 case X86::VSQRTSDm_Int: in isHighLatencyDef()
9358 case X86::VSQRTSDr: in isHighLatencyDef()
9359 case X86::VSQRTSDr_Int: in isHighLatencyDef()
9360 case X86::VSQRTSSm: in isHighLatencyDef()
9361 case X86::VSQRTSSm_Int: in isHighLatencyDef()
9362 case X86::VSQRTSSr: in isHighLatencyDef()
9363 case X86::VSQRTSSr_Int: in isHighLatencyDef()
9365 case X86::VDIVPDZ128rm: in isHighLatencyDef()
9366 case X86::VDIVPDZ128rmb: in isHighLatencyDef()
9367 case X86::VDIVPDZ128rmbk: in isHighLatencyDef()
9368 case X86::VDIVPDZ128rmbkz: in isHighLatencyDef()
9369 case X86::VDIVPDZ128rmk: in isHighLatencyDef()
9370 case X86::VDIVPDZ128rmkz: in isHighLatencyDef()
9371 case X86::VDIVPDZ128rr: in isHighLatencyDef()
9372 case X86::VDIVPDZ128rrk: in isHighLatencyDef()
9373 case X86::VDIVPDZ128rrkz: in isHighLatencyDef()
9374 case X86::VDIVPDZ256rm: in isHighLatencyDef()
9375 case X86::VDIVPDZ256rmb: in isHighLatencyDef()
9376 case X86::VDIVPDZ256rmbk: in isHighLatencyDef()
9377 case X86::VDIVPDZ256rmbkz: in isHighLatencyDef()
9378 case X86::VDIVPDZ256rmk: in isHighLatencyDef()
9379 case X86::VDIVPDZ256rmkz: in isHighLatencyDef()
9380 case X86::VDIVPDZ256rr: in isHighLatencyDef()
9381 case X86::VDIVPDZ256rrk: in isHighLatencyDef()
9382 case X86::VDIVPDZ256rrkz: in isHighLatencyDef()
9383 case X86::VDIVPDZrrb: in isHighLatencyDef()
9384 case X86::VDIVPDZrrbk: in isHighLatencyDef()
9385 case X86::VDIVPDZrrbkz: in isHighLatencyDef()
9386 case X86::VDIVPDZrm: in isHighLatencyDef()
9387 case X86::VDIVPDZrmb: in isHighLatencyDef()
9388 case X86::VDIVPDZrmbk: in isHighLatencyDef()
9389 case X86::VDIVPDZrmbkz: in isHighLatencyDef()
9390 case X86::VDIVPDZrmk: in isHighLatencyDef()
9391 case X86::VDIVPDZrmkz: in isHighLatencyDef()
9392 case X86::VDIVPDZrr: in isHighLatencyDef()
9393 case X86::VDIVPDZrrk: in isHighLatencyDef()
9394 case X86::VDIVPDZrrkz: in isHighLatencyDef()
9395 case X86::VDIVPSZ128rm: in isHighLatencyDef()
9396 case X86::VDIVPSZ128rmb: in isHighLatencyDef()
9397 case X86::VDIVPSZ128rmbk: in isHighLatencyDef()
9398 case X86::VDIVPSZ128rmbkz: in isHighLatencyDef()
9399 case X86::VDIVPSZ128rmk: in isHighLatencyDef()
9400 case X86::VDIVPSZ128rmkz: in isHighLatencyDef()
9401 case X86::VDIVPSZ128rr: in isHighLatencyDef()
9402 case X86::VDIVPSZ128rrk: in isHighLatencyDef()
9403 case X86::VDIVPSZ128rrkz: in isHighLatencyDef()
9404 case X86::VDIVPSZ256rm: in isHighLatencyDef()
9405 case X86::VDIVPSZ256rmb: in isHighLatencyDef()
9406 case X86::VDIVPSZ256rmbk: in isHighLatencyDef()
9407 case X86::VDIVPSZ256rmbkz: in isHighLatencyDef()
9408 case X86::VDIVPSZ256rmk: in isHighLatencyDef()
9409 case X86::VDIVPSZ256rmkz: in isHighLatencyDef()
9410 case X86::VDIVPSZ256rr: in isHighLatencyDef()
9411 case X86::VDIVPSZ256rrk: in isHighLatencyDef()
9412 case X86::VDIVPSZ256rrkz: in isHighLatencyDef()
9413 case X86::VDIVPSZrrb: in isHighLatencyDef()
9414 case X86::VDIVPSZrrbk: in isHighLatencyDef()
9415 case X86::VDIVPSZrrbkz: in isHighLatencyDef()
9416 case X86::VDIVPSZrm: in isHighLatencyDef()
9417 case X86::VDIVPSZrmb: in isHighLatencyDef()
9418 case X86::VDIVPSZrmbk: in isHighLatencyDef()
9419 case X86::VDIVPSZrmbkz: in isHighLatencyDef()
9420 case X86::VDIVPSZrmk: in isHighLatencyDef()
9421 case X86::VDIVPSZrmkz: in isHighLatencyDef()
9422 case X86::VDIVPSZrr: in isHighLatencyDef()
9423 case X86::VDIVPSZrrk: in isHighLatencyDef()
9424 case X86::VDIVPSZrrkz: in isHighLatencyDef()
9425 case X86::VDIVSDZrm: in isHighLatencyDef()
9426 case X86::VDIVSDZrr: in isHighLatencyDef()
9427 case X86::VDIVSDZrm_Int: in isHighLatencyDef()
9428 case X86::VDIVSDZrm_Intk: in isHighLatencyDef()
9429 case X86::VDIVSDZrm_Intkz: in isHighLatencyDef()
9430 case X86::VDIVSDZrr_Int: in isHighLatencyDef()
9431 case X86::VDIVSDZrr_Intk: in isHighLatencyDef()
9432 case X86::VDIVSDZrr_Intkz: in isHighLatencyDef()
9433 case X86::VDIVSDZrrb_Int: in isHighLatencyDef()
9434 case X86::VDIVSDZrrb_Intk: in isHighLatencyDef()
9435 case X86::VDIVSDZrrb_Intkz: in isHighLatencyDef()
9436 case X86::VDIVSSZrm: in isHighLatencyDef()
9437 case X86::VDIVSSZrr: in isHighLatencyDef()
9438 case X86::VDIVSSZrm_Int: in isHighLatencyDef()
9439 case X86::VDIVSSZrm_Intk: in isHighLatencyDef()
9440 case X86::VDIVSSZrm_Intkz: in isHighLatencyDef()
9441 case X86::VDIVSSZrr_Int: in isHighLatencyDef()
9442 case X86::VDIVSSZrr_Intk: in isHighLatencyDef()
9443 case X86::VDIVSSZrr_Intkz: in isHighLatencyDef()
9444 case X86::VDIVSSZrrb_Int: in isHighLatencyDef()
9445 case X86::VDIVSSZrrb_Intk: in isHighLatencyDef()
9446 case X86::VDIVSSZrrb_Intkz: in isHighLatencyDef()
9447 case X86::VSQRTPDZ128m: in isHighLatencyDef()
9448 case X86::VSQRTPDZ128mb: in isHighLatencyDef()
9449 case X86::VSQRTPDZ128mbk: in isHighLatencyDef()
9450 case X86::VSQRTPDZ128mbkz: in isHighLatencyDef()
9451 case X86::VSQRTPDZ128mk: in isHighLatencyDef()
9452 case X86::VSQRTPDZ128mkz: in isHighLatencyDef()
9453 case X86::VSQRTPDZ128r: in isHighLatencyDef()
9454 case X86::VSQRTPDZ128rk: in isHighLatencyDef()
9455 case X86::VSQRTPDZ128rkz: in isHighLatencyDef()
9456 case X86::VSQRTPDZ256m: in isHighLatencyDef()
9457 case X86::VSQRTPDZ256mb: in isHighLatencyDef()
9458 case X86::VSQRTPDZ256mbk: in isHighLatencyDef()
9459 case X86::VSQRTPDZ256mbkz: in isHighLatencyDef()
9460 case X86::VSQRTPDZ256mk: in isHighLatencyDef()
9461 case X86::VSQRTPDZ256mkz: in isHighLatencyDef()
9462 case X86::VSQRTPDZ256r: in isHighLatencyDef()
9463 case X86::VSQRTPDZ256rk: in isHighLatencyDef()
9464 case X86::VSQRTPDZ256rkz: in isHighLatencyDef()
9465 case X86::VSQRTPDZm: in isHighLatencyDef()
9466 case X86::VSQRTPDZmb: in isHighLatencyDef()
9467 case X86::VSQRTPDZmbk: in isHighLatencyDef()
9468 case X86::VSQRTPDZmbkz: in isHighLatencyDef()
9469 case X86::VSQRTPDZmk: in isHighLatencyDef()
9470 case X86::VSQRTPDZmkz: in isHighLatencyDef()
9471 case X86::VSQRTPDZr: in isHighLatencyDef()
9472 case X86::VSQRTPDZrb: in isHighLatencyDef()
9473 case X86::VSQRTPDZrbk: in isHighLatencyDef()
9474 case X86::VSQRTPDZrbkz: in isHighLatencyDef()
9475 case X86::VSQRTPDZrk: in isHighLatencyDef()
9476 case X86::VSQRTPDZrkz: in isHighLatencyDef()
9477 case X86::VSQRTPSZ128m: in isHighLatencyDef()
9478 case X86::VSQRTPSZ128mb: in isHighLatencyDef()
9479 case X86::VSQRTPSZ128mbk: in isHighLatencyDef()
9480 case X86::VSQRTPSZ128mbkz: in isHighLatencyDef()
9481 case X86::VSQRTPSZ128mk: in isHighLatencyDef()
9482 case X86::VSQRTPSZ128mkz: in isHighLatencyDef()
9483 case X86::VSQRTPSZ128r: in isHighLatencyDef()
9484 case X86::VSQRTPSZ128rk: in isHighLatencyDef()
9485 case X86::VSQRTPSZ128rkz: in isHighLatencyDef()
9486 case X86::VSQRTPSZ256m: in isHighLatencyDef()
9487 case X86::VSQRTPSZ256mb: in isHighLatencyDef()
9488 case X86::VSQRTPSZ256mbk: in isHighLatencyDef()
9489 case X86::VSQRTPSZ256mbkz: in isHighLatencyDef()
9490 case X86::VSQRTPSZ256mk: in isHighLatencyDef()
9491 case X86::VSQRTPSZ256mkz: in isHighLatencyDef()
9492 case X86::VSQRTPSZ256r: in isHighLatencyDef()
9493 case X86::VSQRTPSZ256rk: in isHighLatencyDef()
9494 case X86::VSQRTPSZ256rkz: in isHighLatencyDef()
9495 case X86::VSQRTPSZm: in isHighLatencyDef()
9496 case X86::VSQRTPSZmb: in isHighLatencyDef()
9497 case X86::VSQRTPSZmbk: in isHighLatencyDef()
9498 case X86::VSQRTPSZmbkz: in isHighLatencyDef()
9499 case X86::VSQRTPSZmk: in isHighLatencyDef()
9500 case X86::VSQRTPSZmkz: in isHighLatencyDef()
9501 case X86::VSQRTPSZr: in isHighLatencyDef()
9502 case X86::VSQRTPSZrb: in isHighLatencyDef()
9503 case X86::VSQRTPSZrbk: in isHighLatencyDef()
9504 case X86::VSQRTPSZrbkz: in isHighLatencyDef()
9505 case X86::VSQRTPSZrk: in isHighLatencyDef()
9506 case X86::VSQRTPSZrkz: in isHighLatencyDef()
9507 case X86::VSQRTSDZm: in isHighLatencyDef()
9508 case X86::VSQRTSDZm_Int: in isHighLatencyDef()
9509 case X86::VSQRTSDZm_Intk: in isHighLatencyDef()
9510 case X86::VSQRTSDZm_Intkz: in isHighLatencyDef()
9511 case X86::VSQRTSDZr: in isHighLatencyDef()
9512 case X86::VSQRTSDZr_Int: in isHighLatencyDef()
9513 case X86::VSQRTSDZr_Intk: in isHighLatencyDef()
9514 case X86::VSQRTSDZr_Intkz: in isHighLatencyDef()
9515 case X86::VSQRTSDZrb_Int: in isHighLatencyDef()
9516 case X86::VSQRTSDZrb_Intk: in isHighLatencyDef()
9517 case X86::VSQRTSDZrb_Intkz: in isHighLatencyDef()
9518 case X86::VSQRTSSZm: in isHighLatencyDef()
9519 case X86::VSQRTSSZm_Int: in isHighLatencyDef()
9520 case X86::VSQRTSSZm_Intk: in isHighLatencyDef()
9521 case X86::VSQRTSSZm_Intkz: in isHighLatencyDef()
9522 case X86::VSQRTSSZr: in isHighLatencyDef()
9523 case X86::VSQRTSSZr_Int: in isHighLatencyDef()
9524 case X86::VSQRTSSZr_Intk: in isHighLatencyDef()
9525 case X86::VSQRTSSZr_Intkz: in isHighLatencyDef()
9526 case X86::VSQRTSSZrb_Int: in isHighLatencyDef()
9527 case X86::VSQRTSSZrb_Intk: in isHighLatencyDef()
9528 case X86::VSQRTSSZrb_Intkz: in isHighLatencyDef()
9530 case X86::VGATHERDPDYrm: in isHighLatencyDef()
9531 case X86::VGATHERDPDZ128rm: in isHighLatencyDef()
9532 case X86::VGATHERDPDZ256rm: in isHighLatencyDef()
9533 case X86::VGATHERDPDZrm: in isHighLatencyDef()
9534 case X86::VGATHERDPDrm: in isHighLatencyDef()
9535 case X86::VGATHERDPSYrm: in isHighLatencyDef()
9536 case X86::VGATHERDPSZ128rm: in isHighLatencyDef()
9537 case X86::VGATHERDPSZ256rm: in isHighLatencyDef()
9538 case X86::VGATHERDPSZrm: in isHighLatencyDef()
9539 case X86::VGATHERDPSrm: in isHighLatencyDef()
9540 case X86::VGATHERPF0DPDm: in isHighLatencyDef()
9541 case X86::VGATHERPF0DPSm: in isHighLatencyDef()
9542 case X86::VGATHERPF0QPDm: in isHighLatencyDef()
9543 case X86::VGATHERPF0QPSm: in isHighLatencyDef()
9544 case X86::VGATHERPF1DPDm: in isHighLatencyDef()
9545 case X86::VGATHERPF1DPSm: in isHighLatencyDef()
9546 case X86::VGATHERPF1QPDm: in isHighLatencyDef()
9547 case X86::VGATHERPF1QPSm: in isHighLatencyDef()
9548 case X86::VGATHERQPDYrm: in isHighLatencyDef()
9549 case X86::VGATHERQPDZ128rm: in isHighLatencyDef()
9550 case X86::VGATHERQPDZ256rm: in isHighLatencyDef()
9551 case X86::VGATHERQPDZrm: in isHighLatencyDef()
9552 case X86::VGATHERQPDrm: in isHighLatencyDef()
9553 case X86::VGATHERQPSYrm: in isHighLatencyDef()
9554 case X86::VGATHERQPSZ128rm: in isHighLatencyDef()
9555 case X86::VGATHERQPSZ256rm: in isHighLatencyDef()
9556 case X86::VGATHERQPSZrm: in isHighLatencyDef()
9557 case X86::VGATHERQPSrm: in isHighLatencyDef()
9558 case X86::VPGATHERDDYrm: in isHighLatencyDef()
9559 case X86::VPGATHERDDZ128rm: in isHighLatencyDef()
9560 case X86::VPGATHERDDZ256rm: in isHighLatencyDef()
9561 case X86::VPGATHERDDZrm: in isHighLatencyDef()
9562 case X86::VPGATHERDDrm: in isHighLatencyDef()
9563 case X86::VPGATHERDQYrm: in isHighLatencyDef()
9564 case X86::VPGATHERDQZ128rm: in isHighLatencyDef()
9565 case X86::VPGATHERDQZ256rm: in isHighLatencyDef()
9566 case X86::VPGATHERDQZrm: in isHighLatencyDef()
9567 case X86::VPGATHERDQrm: in isHighLatencyDef()
9568 case X86::VPGATHERQDYrm: in isHighLatencyDef()
9569 case X86::VPGATHERQDZ128rm: in isHighLatencyDef()
9570 case X86::VPGATHERQDZ256rm: in isHighLatencyDef()
9571 case X86::VPGATHERQDZrm: in isHighLatencyDef()
9572 case X86::VPGATHERQDrm: in isHighLatencyDef()
9573 case X86::VPGATHERQQYrm: in isHighLatencyDef()
9574 case X86::VPGATHERQQZ128rm: in isHighLatencyDef()
9575 case X86::VPGATHERQQZ256rm: in isHighLatencyDef()
9576 case X86::VPGATHERQQZrm: in isHighLatencyDef()
9577 case X86::VPGATHERQQrm: in isHighLatencyDef()
9578 case X86::VSCATTERDPDZ128mr: in isHighLatencyDef()
9579 case X86::VSCATTERDPDZ256mr: in isHighLatencyDef()
9580 case X86::VSCATTERDPDZmr: in isHighLatencyDef()
9581 case X86::VSCATTERDPSZ128mr: in isHighLatencyDef()
9582 case X86::VSCATTERDPSZ256mr: in isHighLatencyDef()
9583 case X86::VSCATTERDPSZmr: in isHighLatencyDef()
9584 case X86::VSCATTERPF0DPDm: in isHighLatencyDef()
9585 case X86::VSCATTERPF0DPSm: in isHighLatencyDef()
9586 case X86::VSCATTERPF0QPDm: in isHighLatencyDef()
9587 case X86::VSCATTERPF0QPSm: in isHighLatencyDef()
9588 case X86::VSCATTERPF1DPDm: in isHighLatencyDef()
9589 case X86::VSCATTERPF1DPSm: in isHighLatencyDef()
9590 case X86::VSCATTERPF1QPDm: in isHighLatencyDef()
9591 case X86::VSCATTERPF1QPSm: in isHighLatencyDef()
9592 case X86::VSCATTERQPDZ128mr: in isHighLatencyDef()
9593 case X86::VSCATTERQPDZ256mr: in isHighLatencyDef()
9594 case X86::VSCATTERQPDZmr: in isHighLatencyDef()
9595 case X86::VSCATTERQPSZ128mr: in isHighLatencyDef()
9596 case X86::VSCATTERQPSZ256mr: in isHighLatencyDef()
9597 case X86::VSCATTERQPSZmr: in isHighLatencyDef()
9598 case X86::VPSCATTERDDZ128mr: in isHighLatencyDef()
9599 case X86::VPSCATTERDDZ256mr: in isHighLatencyDef()
9600 case X86::VPSCATTERDDZmr: in isHighLatencyDef()
9601 case X86::VPSCATTERDQZ128mr: in isHighLatencyDef()
9602 case X86::VPSCATTERDQZ256mr: in isHighLatencyDef()
9603 case X86::VPSCATTERDQZmr: in isHighLatencyDef()
9604 case X86::VPSCATTERQDZ128mr: in isHighLatencyDef()
9605 case X86::VPSCATTERQDZ256mr: in isHighLatencyDef()
9606 case X86::VPSCATTERQDZmr: in isHighLatencyDef()
9607 case X86::VPSCATTERQQZ128mr: in isHighLatencyDef()
9608 case X86::VPSCATTERQQZ256mr: in isHighLatencyDef()
9609 case X86::VPSCATTERQQZmr: in isHighLatencyDef()
9635 Inst.findRegisterDefOperand(X86::EFLAGS, /*TRI=*/nullptr); in hasReassociableOperands()
9671 case X86::PANDrr: in isAssociativeAndCommutative()
9672 case X86::PORrr: in isAssociativeAndCommutative()
9673 case X86::PXORrr: in isAssociativeAndCommutative()
9674 case X86::ANDPDrr: in isAssociativeAndCommutative()
9675 case X86::ANDPSrr: in isAssociativeAndCommutative()
9676 case X86::ORPDrr: in isAssociativeAndCommutative()
9677 case X86::ORPSrr: in isAssociativeAndCommutative()
9678 case X86::XORPDrr: in isAssociativeAndCommutative()
9679 case X86::XORPSrr: in isAssociativeAndCommutative()
9680 case X86::PADDBrr: in isAssociativeAndCommutative()
9681 case X86::PADDWrr: in isAssociativeAndCommutative()
9682 case X86::PADDDrr: in isAssociativeAndCommutative()
9683 case X86::PADDQrr: in isAssociativeAndCommutative()
9684 case X86::PMULLWrr: in isAssociativeAndCommutative()
9685 case X86::PMULLDrr: in isAssociativeAndCommutative()
9686 case X86::PMAXSBrr: in isAssociativeAndCommutative()
9687 case X86::PMAXSDrr: in isAssociativeAndCommutative()
9688 case X86::PMAXSWrr: in isAssociativeAndCommutative()
9689 case X86::PMAXUBrr: in isAssociativeAndCommutative()
9690 case X86::PMAXUDrr: in isAssociativeAndCommutative()
9691 case X86::PMAXUWrr: in isAssociativeAndCommutative()
9692 case X86::PMINSBrr: in isAssociativeAndCommutative()
9693 case X86::PMINSDrr: in isAssociativeAndCommutative()
9694 case X86::PMINSWrr: in isAssociativeAndCommutative()
9695 case X86::PMINUBrr: in isAssociativeAndCommutative()
9696 case X86::PMINUDrr: in isAssociativeAndCommutative()
9697 case X86::PMINUWrr: in isAssociativeAndCommutative()
9698 case X86::VPANDrr: in isAssociativeAndCommutative()
9699 case X86::VPANDYrr: in isAssociativeAndCommutative()
9700 case X86::VPANDDZ128rr: in isAssociativeAndCommutative()
9701 case X86::VPANDDZ256rr: in isAssociativeAndCommutative()
9702 case X86::VPANDDZrr: in isAssociativeAndCommutative()
9703 case X86::VPANDQZ128rr: in isAssociativeAndCommutative()
9704 case X86::VPANDQZ256rr: in isAssociativeAndCommutative()
9705 case X86::VPANDQZrr: in isAssociativeAndCommutative()
9706 case X86::VPORrr: in isAssociativeAndCommutative()
9707 case X86::VPORYrr: in isAssociativeAndCommutative()
9708 case X86::VPORDZ128rr: in isAssociativeAndCommutative()
9709 case X86::VPORDZ256rr: in isAssociativeAndCommutative()
9710 case X86::VPORDZrr: in isAssociativeAndCommutative()
9711 case X86::VPORQZ128rr: in isAssociativeAndCommutative()
9712 case X86::VPORQZ256rr: in isAssociativeAndCommutative()
9713 case X86::VPORQZrr: in isAssociativeAndCommutative()
9714 case X86::VPXORrr: in isAssociativeAndCommutative()
9715 case X86::VPXORYrr: in isAssociativeAndCommutative()
9716 case X86::VPXORDZ128rr: in isAssociativeAndCommutative()
9717 case X86::VPXORDZ256rr: in isAssociativeAndCommutative()
9718 case X86::VPXORDZrr: in isAssociativeAndCommutative()
9719 case X86::VPXORQZ128rr: in isAssociativeAndCommutative()
9720 case X86::VPXORQZ256rr: in isAssociativeAndCommutative()
9721 case X86::VPXORQZrr: in isAssociativeAndCommutative()
9722 case X86::VANDPDrr: in isAssociativeAndCommutative()
9723 case X86::VANDPSrr: in isAssociativeAndCommutative()
9724 case X86::VANDPDYrr: in isAssociativeAndCommutative()
9725 case X86::VANDPSYrr: in isAssociativeAndCommutative()
9726 case X86::VANDPDZ128rr: in isAssociativeAndCommutative()
9727 case X86::VANDPSZ128rr: in isAssociativeAndCommutative()
9728 case X86::VANDPDZ256rr: in isAssociativeAndCommutative()
9729 case X86::VANDPSZ256rr: in isAssociativeAndCommutative()
9730 case X86::VANDPDZrr: in isAssociativeAndCommutative()
9731 case X86::VANDPSZrr: in isAssociativeAndCommutative()
9732 case X86::VORPDrr: in isAssociativeAndCommutative()
9733 case X86::VORPSrr: in isAssociativeAndCommutative()
9734 case X86::VORPDYrr: in isAssociativeAndCommutative()
9735 case X86::VORPSYrr: in isAssociativeAndCommutative()
9736 case X86::VORPDZ128rr: in isAssociativeAndCommutative()
9737 case X86::VORPSZ128rr: in isAssociativeAndCommutative()
9738 case X86::VORPDZ256rr: in isAssociativeAndCommutative()
9739 case X86::VORPSZ256rr: in isAssociativeAndCommutative()
9740 case X86::VORPDZrr: in isAssociativeAndCommutative()
9741 case X86::VORPSZrr: in isAssociativeAndCommutative()
9742 case X86::VXORPDrr: in isAssociativeAndCommutative()
9743 case X86::VXORPSrr: in isAssociativeAndCommutative()
9744 case X86::VXORPDYrr: in isAssociativeAndCommutative()
9745 case X86::VXORPSYrr: in isAssociativeAndCommutative()
9746 case X86::VXORPDZ128rr: in isAssociativeAndCommutative()
9747 case X86::VXORPSZ128rr: in isAssociativeAndCommutative()
9748 case X86::VXORPDZ256rr: in isAssociativeAndCommutative()
9749 case X86::VXORPSZ256rr: in isAssociativeAndCommutative()
9750 case X86::VXORPDZrr: in isAssociativeAndCommutative()
9751 case X86::VXORPSZrr: in isAssociativeAndCommutative()
9752 case X86::KADDBrr: in isAssociativeAndCommutative()
9753 case X86::KADDWrr: in isAssociativeAndCommutative()
9754 case X86::KADDDrr: in isAssociativeAndCommutative()
9755 case X86::KADDQrr: in isAssociativeAndCommutative()
9756 case X86::KANDBrr: in isAssociativeAndCommutative()
9757 case X86::KANDWrr: in isAssociativeAndCommutative()
9758 case X86::KANDDrr: in isAssociativeAndCommutative()
9759 case X86::KANDQrr: in isAssociativeAndCommutative()
9760 case X86::KORBrr: in isAssociativeAndCommutative()
9761 case X86::KORWrr: in isAssociativeAndCommutative()
9762 case X86::KORDrr: in isAssociativeAndCommutative()
9763 case X86::KORQrr: in isAssociativeAndCommutative()
9764 case X86::KXORBrr: in isAssociativeAndCommutative()
9765 case X86::KXORWrr: in isAssociativeAndCommutative()
9766 case X86::KXORDrr: in isAssociativeAndCommutative()
9767 case X86::KXORQrr: in isAssociativeAndCommutative()
9768 case X86::VPADDBrr: in isAssociativeAndCommutative()
9769 case X86::VPADDWrr: in isAssociativeAndCommutative()
9770 case X86::VPADDDrr: in isAssociativeAndCommutative()
9771 case X86::VPADDQrr: in isAssociativeAndCommutative()
9772 case X86::VPADDBYrr: in isAssociativeAndCommutative()
9773 case X86::VPADDWYrr: in isAssociativeAndCommutative()
9774 case X86::VPADDDYrr: in isAssociativeAndCommutative()
9775 case X86::VPADDQYrr: in isAssociativeAndCommutative()
9776 case X86::VPADDBZ128rr: in isAssociativeAndCommutative()
9777 case X86::VPADDWZ128rr: in isAssociativeAndCommutative()
9778 case X86::VPADDDZ128rr: in isAssociativeAndCommutative()
9779 case X86::VPADDQZ128rr: in isAssociativeAndCommutative()
9780 case X86::VPADDBZ256rr: in isAssociativeAndCommutative()
9781 case X86::VPADDWZ256rr: in isAssociativeAndCommutative()
9782 case X86::VPADDDZ256rr: in isAssociativeAndCommutative()
9783 case X86::VPADDQZ256rr: in isAssociativeAndCommutative()
9784 case X86::VPADDBZrr: in isAssociativeAndCommutative()
9785 case X86::VPADDWZrr: in isAssociativeAndCommutative()
9786 case X86::VPADDDZrr: in isAssociativeAndCommutative()
9787 case X86::VPADDQZrr: in isAssociativeAndCommutative()
9788 case X86::VPMULLWrr: in isAssociativeAndCommutative()
9789 case X86::VPMULLWYrr: in isAssociativeAndCommutative()
9790 case X86::VPMULLWZ128rr: in isAssociativeAndCommutative()
9791 case X86::VPMULLWZ256rr: in isAssociativeAndCommutative()
9792 case X86::VPMULLWZrr: in isAssociativeAndCommutative()
9793 case X86::VPMULLDrr: in isAssociativeAndCommutative()
9794 case X86::VPMULLDYrr: in isAssociativeAndCommutative()
9795 case X86::VPMULLDZ128rr: in isAssociativeAndCommutative()
9796 case X86::VPMULLDZ256rr: in isAssociativeAndCommutative()
9797 case X86::VPMULLDZrr: in isAssociativeAndCommutative()
9798 case X86::VPMULLQZ128rr: in isAssociativeAndCommutative()
9799 case X86::VPMULLQZ256rr: in isAssociativeAndCommutative()
9800 case X86::VPMULLQZrr: in isAssociativeAndCommutative()
9801 case X86::VPMAXSBrr: in isAssociativeAndCommutative()
9802 case X86::VPMAXSBYrr: in isAssociativeAndCommutative()
9803 case X86::VPMAXSBZ128rr: in isAssociativeAndCommutative()
9804 case X86::VPMAXSBZ256rr: in isAssociativeAndCommutative()
9805 case X86::VPMAXSBZrr: in isAssociativeAndCommutative()
9806 case X86::VPMAXSDrr: in isAssociativeAndCommutative()
9807 case X86::VPMAXSDYrr: in isAssociativeAndCommutative()
9808 case X86::VPMAXSDZ128rr: in isAssociativeAndCommutative()
9809 case X86::VPMAXSDZ256rr: in isAssociativeAndCommutative()
9810 case X86::VPMAXSDZrr: in isAssociativeAndCommutative()
9811 case X86::VPMAXSQZ128rr: in isAssociativeAndCommutative()
9812 case X86::VPMAXSQZ256rr: in isAssociativeAndCommutative()
9813 case X86::VPMAXSQZrr: in isAssociativeAndCommutative()
9814 case X86::VPMAXSWrr: in isAssociativeAndCommutative()
9815 case X86::VPMAXSWYrr: in isAssociativeAndCommutative()
9816 case X86::VPMAXSWZ128rr: in isAssociativeAndCommutative()
9817 case X86::VPMAXSWZ256rr: in isAssociativeAndCommutative()
9818 case X86::VPMAXSWZrr: in isAssociativeAndCommutative()
9819 case X86::VPMAXUBrr: in isAssociativeAndCommutative()
9820 case X86::VPMAXUBYrr: in isAssociativeAndCommutative()
9821 case X86::VPMAXUBZ128rr: in isAssociativeAndCommutative()
9822 case X86::VPMAXUBZ256rr: in isAssociativeAndCommutative()
9823 case X86::VPMAXUBZrr: in isAssociativeAndCommutative()
9824 case X86::VPMAXUDrr: in isAssociativeAndCommutative()
9825 case X86::VPMAXUDYrr: in isAssociativeAndCommutative()
9826 case X86::VPMAXUDZ128rr: in isAssociativeAndCommutative()
9827 case X86::VPMAXUDZ256rr: in isAssociativeAndCommutative()
9828 case X86::VPMAXUDZrr: in isAssociativeAndCommutative()
9829 case X86::VPMAXUQZ128rr: in isAssociativeAndCommutative()
9830 case X86::VPMAXUQZ256rr: in isAssociativeAndCommutative()
9831 case X86::VPMAXUQZrr: in isAssociativeAndCommutative()
9832 case X86::VPMAXUWrr: in isAssociativeAndCommutative()
9833 case X86::VPMAXUWYrr: in isAssociativeAndCommutative()
9834 case X86::VPMAXUWZ128rr: in isAssociativeAndCommutative()
9835 case X86::VPMAXUWZ256rr: in isAssociativeAndCommutative()
9836 case X86::VPMAXUWZrr: in isAssociativeAndCommutative()
9837 case X86::VPMINSBrr: in isAssociativeAndCommutative()
9838 case X86::VPMINSBYrr: in isAssociativeAndCommutative()
9839 case X86::VPMINSBZ128rr: in isAssociativeAndCommutative()
9840 case X86::VPMINSBZ256rr: in isAssociativeAndCommutative()
9841 case X86::VPMINSBZrr: in isAssociativeAndCommutative()
9842 case X86::VPMINSDrr: in isAssociativeAndCommutative()
9843 case X86::VPMINSDYrr: in isAssociativeAndCommutative()
9844 case X86::VPMINSDZ128rr: in isAssociativeAndCommutative()
9845 case X86::VPMINSDZ256rr: in isAssociativeAndCommutative()
9846 case X86::VPMINSDZrr: in isAssociativeAndCommutative()
9847 case X86::VPMINSQZ128rr: in isAssociativeAndCommutative()
9848 case X86::VPMINSQZ256rr: in isAssociativeAndCommutative()
9849 case X86::VPMINSQZrr: in isAssociativeAndCommutative()
9850 case X86::VPMINSWrr: in isAssociativeAndCommutative()
9851 case X86::VPMINSWYrr: in isAssociativeAndCommutative()
9852 case X86::VPMINSWZ128rr: in isAssociativeAndCommutative()
9853 case X86::VPMINSWZ256rr: in isAssociativeAndCommutative()
9854 case X86::VPMINSWZrr: in isAssociativeAndCommutative()
9855 case X86::VPMINUBrr: in isAssociativeAndCommutative()
9856 case X86::VPMINUBYrr: in isAssociativeAndCommutative()
9857 case X86::VPMINUBZ128rr: in isAssociativeAndCommutative()
9858 case X86::VPMINUBZ256rr: in isAssociativeAndCommutative()
9859 case X86::VPMINUBZrr: in isAssociativeAndCommutative()
9860 case X86::VPMINUDrr: in isAssociativeAndCommutative()
9861 case X86::VPMINUDYrr: in isAssociativeAndCommutative()
9862 case X86::VPMINUDZ128rr: in isAssociativeAndCommutative()
9863 case X86::VPMINUDZ256rr: in isAssociativeAndCommutative()
9864 case X86::VPMINUDZrr: in isAssociativeAndCommutative()
9865 case X86::VPMINUQZ128rr: in isAssociativeAndCommutative()
9866 case X86::VPMINUQZ256rr: in isAssociativeAndCommutative()
9867 case X86::VPMINUQZrr: in isAssociativeAndCommutative()
9868 case X86::VPMINUWrr: in isAssociativeAndCommutative()
9869 case X86::VPMINUWYrr: in isAssociativeAndCommutative()
9870 case X86::VPMINUWZ128rr: in isAssociativeAndCommutative()
9871 case X86::VPMINUWZ256rr: in isAssociativeAndCommutative()
9872 case X86::VPMINUWZrr: in isAssociativeAndCommutative()
9876 case X86::MAXCPDrr: in isAssociativeAndCommutative()
9877 case X86::MAXCPSrr: in isAssociativeAndCommutative()
9878 case X86::MAXCSDrr: in isAssociativeAndCommutative()
9879 case X86::MAXCSSrr: in isAssociativeAndCommutative()
9880 case X86::MINCPDrr: in isAssociativeAndCommutative()
9881 case X86::MINCPSrr: in isAssociativeAndCommutative()
9882 case X86::MINCSDrr: in isAssociativeAndCommutative()
9883 case X86::MINCSSrr: in isAssociativeAndCommutative()
9884 case X86::VMAXCPDrr: in isAssociativeAndCommutative()
9885 case X86::VMAXCPSrr: in isAssociativeAndCommutative()
9886 case X86::VMAXCPDYrr: in isAssociativeAndCommutative()
9887 case X86::VMAXCPSYrr: in isAssociativeAndCommutative()
9888 case X86::VMAXCPDZ128rr: in isAssociativeAndCommutative()
9889 case X86::VMAXCPSZ128rr: in isAssociativeAndCommutative()
9890 case X86::VMAXCPDZ256rr: in isAssociativeAndCommutative()
9891 case X86::VMAXCPSZ256rr: in isAssociativeAndCommutative()
9892 case X86::VMAXCPDZrr: in isAssociativeAndCommutative()
9893 case X86::VMAXCPSZrr: in isAssociativeAndCommutative()
9894 case X86::VMAXCSDrr: in isAssociativeAndCommutative()
9895 case X86::VMAXCSSrr: in isAssociativeAndCommutative()
9896 case X86::VMAXCSDZrr: in isAssociativeAndCommutative()
9897 case X86::VMAXCSSZrr: in isAssociativeAndCommutative()
9898 case X86::VMINCPDrr: in isAssociativeAndCommutative()
9899 case X86::VMINCPSrr: in isAssociativeAndCommutative()
9900 case X86::VMINCPDYrr: in isAssociativeAndCommutative()
9901 case X86::VMINCPSYrr: in isAssociativeAndCommutative()
9902 case X86::VMINCPDZ128rr: in isAssociativeAndCommutative()
9903 case X86::VMINCPSZ128rr: in isAssociativeAndCommutative()
9904 case X86::VMINCPDZ256rr: in isAssociativeAndCommutative()
9905 case X86::VMINCPSZ256rr: in isAssociativeAndCommutative()
9906 case X86::VMINCPDZrr: in isAssociativeAndCommutative()
9907 case X86::VMINCPSZrr: in isAssociativeAndCommutative()
9908 case X86::VMINCSDrr: in isAssociativeAndCommutative()
9909 case X86::VMINCSSrr: in isAssociativeAndCommutative()
9910 case X86::VMINCSDZrr: in isAssociativeAndCommutative()
9911 case X86::VMINCSSZrr: in isAssociativeAndCommutative()
9912 case X86::VMAXCPHZ128rr: in isAssociativeAndCommutative()
9913 case X86::VMAXCPHZ256rr: in isAssociativeAndCommutative()
9914 case X86::VMAXCPHZrr: in isAssociativeAndCommutative()
9915 case X86::VMAXCSHZrr: in isAssociativeAndCommutative()
9916 case X86::VMINCPHZ128rr: in isAssociativeAndCommutative()
9917 case X86::VMINCPHZ256rr: in isAssociativeAndCommutative()
9918 case X86::VMINCPHZrr: in isAssociativeAndCommutative()
9919 case X86::VMINCSHZrr: in isAssociativeAndCommutative()
9921 case X86::ADDPDrr: in isAssociativeAndCommutative()
9922 case X86::ADDPSrr: in isAssociativeAndCommutative()
9923 case X86::ADDSDrr: in isAssociativeAndCommutative()
9924 case X86::ADDSSrr: in isAssociativeAndCommutative()
9925 case X86::MULPDrr: in isAssociativeAndCommutative()
9926 case X86::MULPSrr: in isAssociativeAndCommutative()
9927 case X86::MULSDrr: in isAssociativeAndCommutative()
9928 case X86::MULSSrr: in isAssociativeAndCommutative()
9929 case X86::VADDPDrr: in isAssociativeAndCommutative()
9930 case X86::VADDPSrr: in isAssociativeAndCommutative()
9931 case X86::VADDPDYrr: in isAssociativeAndCommutative()
9932 case X86::VADDPSYrr: in isAssociativeAndCommutative()
9933 case X86::VADDPDZ128rr: in isAssociativeAndCommutative()
9934 case X86::VADDPSZ128rr: in isAssociativeAndCommutative()
9935 case X86::VADDPDZ256rr: in isAssociativeAndCommutative()
9936 case X86::VADDPSZ256rr: in isAssociativeAndCommutative()
9937 case X86::VADDPDZrr: in isAssociativeAndCommutative()
9938 case X86::VADDPSZrr: in isAssociativeAndCommutative()
9939 case X86::VADDSDrr: in isAssociativeAndCommutative()
9940 case X86::VADDSSrr: in isAssociativeAndCommutative()
9941 case X86::VADDSDZrr: in isAssociativeAndCommutative()
9942 case X86::VADDSSZrr: in isAssociativeAndCommutative()
9943 case X86::VMULPDrr: in isAssociativeAndCommutative()
9944 case X86::VMULPSrr: in isAssociativeAndCommutative()
9945 case X86::VMULPDYrr: in isAssociativeAndCommutative()
9946 case X86::VMULPSYrr: in isAssociativeAndCommutative()
9947 case X86::VMULPDZ128rr: in isAssociativeAndCommutative()
9948 case X86::VMULPSZ128rr: in isAssociativeAndCommutative()
9949 case X86::VMULPDZ256rr: in isAssociativeAndCommutative()
9950 case X86::VMULPSZ256rr: in isAssociativeAndCommutative()
9951 case X86::VMULPDZrr: in isAssociativeAndCommutative()
9952 case X86::VMULPSZrr: in isAssociativeAndCommutative()
9953 case X86::VMULSDrr: in isAssociativeAndCommutative()
9954 case X86::VMULSSrr: in isAssociativeAndCommutative()
9955 case X86::VMULSDZrr: in isAssociativeAndCommutative()
9956 case X86::VMULSSZrr: in isAssociativeAndCommutative()
9957 case X86::VADDPHZ128rr: in isAssociativeAndCommutative()
9958 case X86::VADDPHZ256rr: in isAssociativeAndCommutative()
9959 case X86::VADDPHZrr: in isAssociativeAndCommutative()
9960 case X86::VADDSHZrr: in isAssociativeAndCommutative()
9961 case X86::VMULPHZ128rr: in isAssociativeAndCommutative()
9962 case X86::VMULPHZ256rr: in isAssociativeAndCommutative()
9963 case X86::VMULPHZrr: in isAssociativeAndCommutative()
9964 case X86::VMULSHZrr: in isAssociativeAndCommutative()
10000 if (MI.getOpcode() == X86::MOV8rr || MI.getOpcode() == X86::MOV16rr || in describeMOVrrLoadedValue()
10004 assert(MI.getOpcode() == X86::MOV32rr && "Unexpected super-register case"); in describeMOVrrLoadedValue()
10016 case X86::LEA32r: in describeLoadedValue()
10017 case X86::LEA64r: in describeLoadedValue()
10018 case X86::LEA64_32r: { in describeLoadedValue()
10031 (Op2.getReg() == X86::NoRegister || Op2.getReg().isPhysical())); in describeLoadedValue()
10038 else if ((Op1.isReg() && Op1.getReg() != X86::NoRegister && in describeLoadedValue()
10040 (Op2.getReg() != X86::NoRegister && in describeLoadedValue()
10048 if ((Op1.isReg() && Op1.getReg() != X86::NoRegister)) { in describeLoadedValue()
10058 if (Op && Op2.getReg() != X86::NoRegister) { in describeLoadedValue()
10071 assert(Op2.getReg() != X86::NoRegister); in describeLoadedValue()
10076 assert(Op2.getReg() != X86::NoRegister); in describeLoadedValue()
10082 if (((Op1.isReg() && Op1.getReg() != X86::NoRegister) || Op1.isFI()) && in describeLoadedValue()
10083 Op2.getReg() != X86::NoRegister) { in describeLoadedValue()
10093 case X86::MOV8ri: in describeLoadedValue()
10094 case X86::MOV16ri: in describeLoadedValue()
10097 case X86::MOV32ri: in describeLoadedValue()
10098 case X86::MOV64ri: in describeLoadedValue()
10099 case X86::MOV64ri32: in describeLoadedValue()
10105 case X86::MOV8rr: in describeLoadedValue()
10106 case X86::MOV16rr: in describeLoadedValue()
10107 case X86::MOV32rr: in describeLoadedValue()
10108 case X86::MOV64rr: in describeLoadedValue()
10110 case X86::XOR32rr: { in describeLoadedValue()
10119 case X86::MOVSX64rr32: { in describeLoadedValue()
10139 assert(X86MCRegisterClasses[X86::GR32RegClassID].contains(Reg) && in describeLoadedValue()
10158 OldMI1.findRegisterDefOperand(X86::EFLAGS, /*TRI=*/nullptr); in setSpecialOperandAttr()
10160 OldMI2.findRegisterDefOperand(X86::EFLAGS, /*TRI=*/nullptr); in setSpecialOperandAttr()
10172 NewMI1.findRegisterDefOperand(X86::EFLAGS, /*TRI=*/nullptr); in setSpecialOperandAttr()
10174 NewMI2.findRegisterDefOperand(X86::EFLAGS, /*TRI=*/nullptr); in setSpecialOperandAttr()
10196 {MO_GOT_ABSOLUTE_ADDRESS, "x86-got-absolute-address"}, in getSerializableDirectMachineOperandTargetFlags()
10197 {MO_PIC_BASE_OFFSET, "x86-pic-base-offset"}, in getSerializableDirectMachineOperandTargetFlags()
10198 {MO_GOT, "x86-got"}, in getSerializableDirectMachineOperandTargetFlags()
10199 {MO_GOTOFF, "x86-gotoff"}, in getSerializableDirectMachineOperandTargetFlags()
10200 {MO_GOTPCREL, "x86-gotpcrel"}, in getSerializableDirectMachineOperandTargetFlags()
10201 {MO_GOTPCREL_NORELAX, "x86-gotpcrel-norelax"}, in getSerializableDirectMachineOperandTargetFlags()
10202 {MO_PLT, "x86-plt"}, in getSerializableDirectMachineOperandTargetFlags()
10203 {MO_TLSGD, "x86-tlsgd"}, in getSerializableDirectMachineOperandTargetFlags()
10204 {MO_TLSLD, "x86-tlsld"}, in getSerializableDirectMachineOperandTargetFlags()
10205 {MO_TLSLDM, "x86-tlsldm"}, in getSerializableDirectMachineOperandTargetFlags()
10206 {MO_GOTTPOFF, "x86-gottpoff"}, in getSerializableDirectMachineOperandTargetFlags()
10207 {MO_INDNTPOFF, "x86-indntpoff"}, in getSerializableDirectMachineOperandTargetFlags()
10208 {MO_TPOFF, "x86-tpoff"}, in getSerializableDirectMachineOperandTargetFlags()
10209 {MO_DTPOFF, "x86-dtpoff"}, in getSerializableDirectMachineOperandTargetFlags()
10210 {MO_NTPOFF, "x86-ntpoff"}, in getSerializableDirectMachineOperandTargetFlags()
10211 {MO_GOTNTPOFF, "x86-gotntpoff"}, in getSerializableDirectMachineOperandTargetFlags()
10212 {MO_DLLIMPORT, "x86-dllimport"}, in getSerializableDirectMachineOperandTargetFlags()
10213 {MO_DARWIN_NONLAZY, "x86-darwin-nonlazy"}, in getSerializableDirectMachineOperandTargetFlags()
10214 {MO_DARWIN_NONLAZY_PIC_BASE, "x86-darwin-nonlazy-pic-base"}, in getSerializableDirectMachineOperandTargetFlags()
10215 {MO_TLVP, "x86-tlvp"}, in getSerializableDirectMachineOperandTargetFlags()
10216 {MO_TLVP_PIC_BASE, "x86-tlvp-pic-base"}, in getSerializableDirectMachineOperandTargetFlags()
10217 {MO_SECREL, "x86-secrel"}, in getSerializableDirectMachineOperandTargetFlags()
10218 {MO_COFFSTUB, "x86-coffstub"}}; in getSerializableDirectMachineOperandTargetFlags()
10224 /// global base register for x86-32.
10254 PC = RegInfo.createVirtualRegister(&X86::GR32RegClass); in runOnMachineFunction()
10266 Register PBReg = RegInfo.createVirtualRegister(&X86::GR64RegClass); in runOnMachineFunction()
10267 Register GOTReg = RegInfo.createVirtualRegister(&X86::GR64RegClass); in runOnMachineFunction()
10268 BuildMI(FirstMBB, MBBI, DL, TII->get(X86::LEA64r), PBReg) in runOnMachineFunction()
10269 .addReg(X86::RIP) in runOnMachineFunction()
10275 BuildMI(FirstMBB, MBBI, DL, TII->get(X86::MOV64ri), GOTReg) in runOnMachineFunction()
10278 BuildMI(FirstMBB, MBBI, DL, TII->get(X86::ADD64rr), PC) in runOnMachineFunction()
10284 BuildMI(FirstMBB, MBBI, DL, TII->get(X86::LEA64r), PC) in runOnMachineFunction()
10285 .addReg(X86::RIP) in runOnMachineFunction()
10294 BuildMI(FirstMBB, MBBI, DL, TII->get(X86::MOVPC32r), PC).addImm(0); in runOnMachineFunction()
10301 BuildMI(FirstMBB, MBBI, DL, TII->get(X86::ADD32ri), GlobalBaseReg) in runOnMachineFunction()
10312 return "X86 PIC Global Base Reg Initialization"; in getPassName()
10358 case X86::TLS_base_addr32: in VisitNode()
10359 case X86::TLS_base_addr64: in VisitNode()
10391 TII->get(TargetOpcode::COPY), is64Bit ? X86::RAX : X86::EAX) in ReplaceTLSBaseAddrCall()
10411 is64Bit ? &X86::GR64RegClass : &X86::GR32RegClass); in SetRegister()
10417 .addReg(is64Bit ? X86::RAX : X86::EAX); in SetRegister()
10474 // FIXME: x86 doesn't implement getInstSizeInBytes, so in getOutliningCandidateInfo()
10566 if (MI.modifiesRegister(X86::RSP, &RI) || MI.readsRegister(X86::RSP, &RI) || in getOutliningTypeImpl()
10567 MI.getDesc().hasImplicitUseOfPhysReg(X86::RSP) || in getOutliningTypeImpl()
10568 MI.getDesc().hasImplicitDefOfPhysReg(X86::RSP)) in getOutliningTypeImpl()
10572 if (MI.readsRegister(X86::RIP, &RI) || in getOutliningTypeImpl()
10573 MI.getDesc().hasImplicitUseOfPhysReg(X86::RIP) || in getOutliningTypeImpl()
10574 MI.getDesc().hasImplicitDefOfPhysReg(X86::RIP)) in getOutliningTypeImpl()
10593 MachineInstr *retq = BuildMI(MF, DebugLoc(), get(X86::RET64)); in buildOutlinedFrame()
10603 It = MBB.insert(It, BuildMI(MF, DebugLoc(), get(X86::TAILJMPd64)) in insertOutlinedCall()
10607 It = MBB.insert(It, BuildMI(MF, DebugLoc(), get(X86::CALL64pcrel32)) in insertOutlinedCall()
10622 if (ST.hasMMX() && X86::VR64RegClass.contains(Reg)) in buildClearRegister()
10633 BuildMI(MBB, Iter, DL, get(X86::MOV32ri), Reg).addImm(0); in buildClearRegister()
10635 BuildMI(MBB, Iter, DL, get(X86::XOR32rr), Reg) in buildClearRegister()
10638 } else if (X86::VR128RegClass.contains(Reg)) { in buildClearRegister()
10644 BuildMI(MBB, Iter, DL, get(X86::PXORrr), Reg) in buildClearRegister()
10647 } else if (X86::VR256RegClass.contains(Reg)) { in buildClearRegister()
10653 BuildMI(MBB, Iter, DL, get(X86::VPXORrr), Reg) in buildClearRegister()
10656 } else if (X86::VR512RegClass.contains(Reg)) { in buildClearRegister()
10662 BuildMI(MBB, Iter, DL, get(X86::VPXORYrr), Reg) in buildClearRegister()
10665 } else if (X86::VK1RegClass.contains(Reg) || X86::VK2RegClass.contains(Reg) || in buildClearRegister()
10666 X86::VK4RegClass.contains(Reg) || X86::VK8RegClass.contains(Reg) || in buildClearRegister()
10667 X86::VK16RegClass.contains(Reg)) { in buildClearRegister()
10672 unsigned Op = ST.hasBWI() ? X86::KXORQrr : X86::KXORWrr; in buildClearRegister()
10684 case X86::VPDPWSSDrr: in getMachineCombinerPatterns()
10685 case X86::VPDPWSSDrm: in getMachineCombinerPatterns()
10686 case X86::VPDPWSSDYrr: in getMachineCombinerPatterns()
10687 case X86::VPDPWSSDYrm: { in getMachineCombinerPatterns()
10694 case X86::VPDPWSSDZ128r: in getMachineCombinerPatterns()
10695 case X86::VPDPWSSDZ128m: in getMachineCombinerPatterns()
10696 case X86::VPDPWSSDZ256r: in getMachineCombinerPatterns()
10697 case X86::VPDPWSSDZ256m: in getMachineCombinerPatterns()
10698 case X86::VPDPWSSDZr: in getMachineCombinerPatterns()
10699 case X86::VPDPWSSDZm: { in getMachineCombinerPatterns()
10730 case X86::VPDPWSSDrr: in genAlternativeDpCodeSequence()
10731 MaddOpc = X86::VPMADDWDrr; in genAlternativeDpCodeSequence()
10732 AddOpc = X86::VPADDDrr; in genAlternativeDpCodeSequence()
10734 case X86::VPDPWSSDrm: in genAlternativeDpCodeSequence()
10735 MaddOpc = X86::VPMADDWDrm; in genAlternativeDpCodeSequence()
10736 AddOpc = X86::VPADDDrr; in genAlternativeDpCodeSequence()
10738 case X86::VPDPWSSDZ128r: in genAlternativeDpCodeSequence()
10739 MaddOpc = X86::VPMADDWDZ128rr; in genAlternativeDpCodeSequence()
10740 AddOpc = X86::VPADDDZ128rr; in genAlternativeDpCodeSequence()
10742 case X86::VPDPWSSDZ128m: in genAlternativeDpCodeSequence()
10743 MaddOpc = X86::VPMADDWDZ128rm; in genAlternativeDpCodeSequence()
10744 AddOpc = X86::VPADDDZ128rr; in genAlternativeDpCodeSequence()
10750 case X86::VPDPWSSDYrr: in genAlternativeDpCodeSequence()
10751 MaddOpc = X86::VPMADDWDYrr; in genAlternativeDpCodeSequence()
10752 AddOpc = X86::VPADDDYrr; in genAlternativeDpCodeSequence()
10754 case X86::VPDPWSSDYrm: in genAlternativeDpCodeSequence()
10755 MaddOpc = X86::VPMADDWDYrm; in genAlternativeDpCodeSequence()
10756 AddOpc = X86::VPADDDYrr; in genAlternativeDpCodeSequence()
10758 case X86::VPDPWSSDZ256r: in genAlternativeDpCodeSequence()
10759 MaddOpc = X86::VPMADDWDZ256rr; in genAlternativeDpCodeSequence()
10760 AddOpc = X86::VPADDDZ256rr; in genAlternativeDpCodeSequence()
10762 case X86::VPDPWSSDZ256m: in genAlternativeDpCodeSequence()
10763 MaddOpc = X86::VPMADDWDZ256rm; in genAlternativeDpCodeSequence()
10764 AddOpc = X86::VPADDDZ256rr; in genAlternativeDpCodeSequence()
10770 case X86::VPDPWSSDZr: in genAlternativeDpCodeSequence()
10771 MaddOpc = X86::VPMADDWDZrr; in genAlternativeDpCodeSequence()
10772 AddOpc = X86::VPADDDZrr; in genAlternativeDpCodeSequence()
10774 case X86::VPDPWSSDZm: in genAlternativeDpCodeSequence()
10775 MaddOpc = X86::VPMADDWDZrm; in genAlternativeDpCodeSequence()
10776 AddOpc = X86::VPADDDZrr; in genAlternativeDpCodeSequence()