40#define GET_REGINFO_TARGET_DESC
41#include "X86GenRegisterInfo.inc"
45 cl::desc(
"Enable use of a base pointer for complex stack frames"));
50 cl::desc(
"Disable two address hints for register "
55 cl::desc(
"Basic block count threshold for emitting a warning about "
56 "callee-saved registers reserved due to setjmp"));
64 (TT.isX86_64() ?
X86::RIP :
X86::EIP)) {
68 Is64Bit = TT.isX86_64();
69 IsTarget64BitLP64 = Is64Bit && !TT.isX32();
70 IsWin64 = Is64Bit && TT.isOSWindows();
71 IsUEFI64 = Is64Bit && TT.isUEFI();
81 bool Use64BitReg = !TT.isX32();
82 StackPtr = Use64BitReg ? X86::RSP : X86::ESP;
83 FramePtr = Use64BitReg ? X86::RBP : X86::EBP;
84 BasePtr = Use64BitReg ? X86::RBX : X86::EBX;
98 if (!Is64Bit && Idx == X86::sub_8bit)
99 Idx = X86::sub_8bit_hi;
102 return X86GenRegisterInfo::getSubClassWithSubReg(RC, Idx);
108 unsigned SubIdx)
const {
110 if (!Is64Bit && SubIdx == X86::sub_8bit) {
111 A = X86GenRegisterInfo::getSubClassWithSubReg(
A, X86::sub_8bit_hi);
115 return X86GenRegisterInfo::getMatchingSuperRegClass(
A,
B, SubIdx);
129 if (RC == &X86::GR8_NOREXRegClass)
143 switch (Super->getID()) {
144 case X86::FR32RegClassID:
145 case X86::FR64RegClassID:
148 getRegSizeInBits(*Super) == getRegSizeInBits(*RC))
151 case X86::VR128RegClassID:
152 case X86::VR256RegClassID:
154 if (!Subtarget.hasVLX() &&
155 getRegSizeInBits(*Super) == getRegSizeInBits(*RC))
158 case X86::VR128XRegClassID:
159 case X86::VR256XRegClassID:
161 if (Subtarget.hasVLX() &&
162 getRegSizeInBits(*Super) == getRegSizeInBits(*RC))
165 case X86::FR32XRegClassID:
166 case X86::FR64XRegClassID:
169 getRegSizeInBits(*Super) == getRegSizeInBits(*RC))
172 case X86::GR8RegClassID:
173 case X86::GR16RegClassID:
174 case X86::GR32RegClassID:
175 case X86::GR64RegClassID:
176 case X86::GR8_NOREX2RegClassID:
177 case X86::GR16_NOREX2RegClassID:
178 case X86::GR32_NOREX2RegClassID:
179 case X86::GR64_NOREX2RegClassID:
180 case X86::RFP32RegClassID:
181 case X86::RFP64RegClassID:
182 case X86::RFP80RegClassID:
183 case X86::VR512_0_15RegClassID:
184 case X86::VR512RegClassID:
187 if (getRegSizeInBits(*Super) == getRegSizeInBits(*RC))
202 assert(Kind == 0 &&
"this should only be used for default cases");
203 if (IsTarget64BitLP64)
204 return &X86::GR64RegClass;
209 return Is64Bit ? &X86::LOW32_ADDR_ACCESSRegClass : &X86::GR32RegClass;
214 if (RC == &X86::CCRRegClass) {
216 return &X86::GR64RegClass;
218 return &X86::GR32RegClass;
228 unsigned FPDiff = TFI->
hasFP(MF) ? 1 : 0;
229 switch (RC->
getID()) {
232 case X86::GR32RegClassID:
234 case X86::GR64RegClassID:
236 case X86::VR128RegClassID:
237 return Is64Bit ? 10 : 4;
238 case X86::VR64RegClassID:
245 assert(MF &&
"MachineFunction required");
249 bool HasSSE = Subtarget.
hasSSE1();
250 bool HasAVX = Subtarget.
hasAVX();
252 bool HasEGPR = Subtarget.hasEGPR();
265 return CSR_NoRegs_SaveList;
270 return CSR_NoRegs_SaveList;
273 return CSR_64_AllRegs_AVX_SaveList;
274 return CSR_64_AllRegs_SaveList;
277 return HasEGPR ? CSR_Win64_APX_RT_MostRegs_SaveList
278 : CSR_Win64_RT_MostRegs_SaveList;
279 return CSR_64_RT_MostRegs_SaveList;
282 return CSR_64_RT_AllRegs_AVX_SaveList;
283 return CSR_64_RT_AllRegs_SaveList;
285 return CSR_64_NoneRegs_SaveList;
289 CSR_64_CXX_TLS_Darwin_PE_SaveList : CSR_64_TLS_Darwin_SaveList;
292 if (HasAVX512 && IsWin64)
293 return HasEGPR ? CSR_Win64_APX_Intel_OCL_BI_AVX512_SaveList
294 : CSR_Win64_Intel_OCL_BI_AVX512_SaveList;
295 if (HasAVX512 && Is64Bit)
296 return CSR_64_Intel_OCL_BI_AVX512_SaveList;
297 if (HasAVX && IsWin64)
298 return HasEGPR ? CSR_Win64_APX_Intel_OCL_BI_AVX_SaveList
299 : CSR_Win64_Intel_OCL_BI_AVX_SaveList;
300 if (HasAVX && Is64Bit)
301 return CSR_64_Intel_OCL_BI_AVX_SaveList;
302 if (!HasAVX && !IsWin64 && Is64Bit)
303 return CSR_64_Intel_OCL_BI_SaveList;
310 return HasEGPR ? CSR_Win64_APX_RegCall_SaveList
311 : CSR_Win64_RegCall_SaveList;
312 return CSR_Win64_RegCall_NoSSE_SaveList;
314 return HasSSE ? CSR_SysV64_RegCall_SaveList
315 : CSR_SysV64_RegCall_NoSSE_SaveList;
317 return HasSSE ? CSR_32_RegCall_SaveList : CSR_32_RegCall_NoSSE_SaveList;
319 assert(!Is64Bit &&
"CFGuard check mechanism only used on 32-bit X86");
320 return HasSSE ? CSR_Win32_CFGuard_Check_SaveList
321 : CSR_Win32_CFGuard_Check_NoSSE_SaveList;
324 return CSR_64_MostRegs_SaveList;
328 return HasEGPR ? CSR_Win64_APX_SaveList : CSR_Win64_SaveList;
329 return CSR_Win64_NoSSE_SaveList;
332 return CSR_32_SaveList;
334 return HasEGPR ? CSR_Win64_APX_SwiftTail_SaveList
335 : CSR_Win64_SwiftTail_SaveList;
336 return CSR_64_SwiftTail_SaveList;
339 return CSR_64EHRet_SaveList;
340 return CSR_64_SaveList;
344 return CSR_64_AllRegs_AVX512_SaveList;
346 return CSR_64_AllRegs_AVX_SaveList;
348 return CSR_64_AllRegs_SaveList;
349 return CSR_64_AllRegs_NoSSE_SaveList;
352 return CSR_32_AllRegs_AVX512_SaveList;
354 return CSR_32_AllRegs_AVX_SaveList;
356 return CSR_32_AllRegs_SSE_SaveList;
357 return CSR_32_AllRegs_SaveList;
364 F.getAttributes().hasAttrSomewhere(Attribute::SwiftError);
367 return HasEGPR ? CSR_Win64_APX_SwiftError_SaveList
368 : CSR_Win64_SwiftError_SaveList;
369 return CSR_64_SwiftError_SaveList;
372 if (IsWin64 || IsUEFI64) {
374 return HasEGPR ? CSR_Win64_APX_SaveList : CSR_Win64_SaveList;
375 return CSR_Win64_NoSSE_SaveList;
378 return CSR_64EHRet_SaveList;
379 return CSR_64_SaveList;
382 return CallsEHReturn ? CSR_32EHRet_SaveList : CSR_32_SaveList;
387 return Is64Bit ? CSR_IPRA_64_SaveList : CSR_IPRA_32_SaveList;
392 assert(MF &&
"Invalid MachineFunction pointer.");
395 return CSR_64_CXX_TLS_Darwin_ViaCopy_SaveList;
403 bool HasSSE = Subtarget.
hasSSE1();
404 bool HasAVX = Subtarget.
hasAVX();
406 bool HasEGPR = Subtarget.hasEGPR();
411 return CSR_NoRegs_RegMask;
414 return CSR_64_AllRegs_AVX_RegMask;
415 return CSR_64_AllRegs_RegMask;
418 return HasEGPR ? CSR_Win64_APX_RT_MostRegs_RegMask
419 : CSR_Win64_RT_MostRegs_RegMask;
420 return CSR_64_RT_MostRegs_RegMask;
423 return CSR_64_RT_AllRegs_AVX_RegMask;
424 return CSR_64_RT_AllRegs_RegMask;
426 return CSR_64_NoneRegs_RegMask;
429 return CSR_64_TLS_Darwin_RegMask;
432 if (HasAVX512 && IsWin64)
433 return HasEGPR ? CSR_Win64_APX_Intel_OCL_BI_AVX512_RegMask
434 : CSR_Win64_Intel_OCL_BI_AVX512_RegMask;
435 if (HasAVX512 && Is64Bit)
436 return CSR_64_Intel_OCL_BI_AVX512_RegMask;
437 if (HasAVX && IsWin64)
438 return HasEGPR ? CSR_Win64_APX_Intel_OCL_BI_AVX_RegMask
439 : CSR_Win64_Intel_OCL_BI_AVX_RegMask;
440 if (HasAVX && Is64Bit)
441 return CSR_64_Intel_OCL_BI_AVX_RegMask;
442 if (!HasAVX && !IsWin64 && Is64Bit)
443 return CSR_64_Intel_OCL_BI_RegMask;
450 return HasEGPR ? CSR_Win64_APX_RegCall_RegMask
451 : CSR_Win64_RegCall_RegMask;
452 return CSR_Win64_RegCall_NoSSE_RegMask;
454 return HasSSE ? CSR_SysV64_RegCall_RegMask
455 : CSR_SysV64_RegCall_NoSSE_RegMask;
457 return HasSSE ? CSR_32_RegCall_RegMask : CSR_32_RegCall_NoSSE_RegMask;
461 return HasEGPR ? CSR_Win64_APX_CFGuard_Check_RegMask
462 : CSR_Win64_CFGuard_Check_RegMask;
463 return CSR_Win64_CFGuard_Check_NoSSE_RegMask;
465 return HasSSE ? CSR_Win32_CFGuard_Check_RegMask
466 : CSR_Win32_CFGuard_Check_NoSSE_RegMask;
469 return CSR_64_MostRegs_RegMask;
472 return HasEGPR ? CSR_Win64_APX_RegMask : CSR_Win64_RegMask;
475 return CSR_32_RegMask;
477 return HasEGPR ? CSR_Win64_APX_SwiftTail_RegMask
478 : CSR_Win64_SwiftTail_RegMask;
479 return CSR_64_SwiftTail_RegMask;
481 return CSR_64_RegMask;
485 return CSR_64_AllRegs_AVX512_RegMask;
487 return CSR_64_AllRegs_AVX_RegMask;
489 return CSR_64_AllRegs_RegMask;
490 return CSR_64_AllRegs_NoSSE_RegMask;
493 return CSR_32_AllRegs_AVX512_RegMask;
495 return CSR_32_AllRegs_AVX_RegMask;
497 return CSR_32_AllRegs_SSE_RegMask;
498 return CSR_32_AllRegs_RegMask;
508 F.getAttributes().hasAttrSomewhere(Attribute::SwiftError);
511 return HasEGPR ? CSR_Win64_APX_SwiftError_RegMask
512 : CSR_Win64_SwiftError_RegMask;
513 return CSR_64_SwiftError_RegMask;
516 if (IsWin64 || IsUEFI64)
517 return HasEGPR ? CSR_Win64_APX_RegMask : CSR_Win64_RegMask;
518 return CSR_64_RegMask;
521 return CSR_32_RegMask;
526 return CSR_NoRegs_RegMask;
530 return CSR_64_TLS_Darwin_RegMask;
547 for (
const MCPhysReg &SubReg : subregs_inclusive(X86::RSP))
554 if (ST.hasUserReservedRegisters()) {
557 for (
unsigned Reg = X86::R8; Reg <= X86::R15; ++Reg)
558 if (ST.isRegisterReservedByUser(Reg))
559 for (
const MCPhysReg &SubReg : subregs_inclusive(Reg))
562 for (
unsigned Reg = X86::R16; Reg <= X86::R31; ++Reg)
563 if (ST.isRegisterReservedByUser(Reg))
564 for (
const MCPhysReg &SubReg : subregs_inclusive(Reg))
567 if (ST.isRegisterReservedByUser(X86::EDI))
568 for (
const MCPhysReg &SubReg : sub_and_superregs_inclusive(X86::EDI))
574 for (
const MCPhysReg &SubReg : subregs_inclusive(X86::RIP))
582 "Frame pointer clobbered by function invoke is not supported.");
584 for (
const MCPhysReg &SubReg : subregs_inclusive(X86::RBP))
592 "Stack realignment in presence of dynamic "
593 "allocas is not supported with "
594 "this calling convention.");
597 for (
const MCPhysReg &SubReg : subregs_inclusive(BasePtr))
610 for (
unsigned n = 0; n != 8; ++n)
626 for (
unsigned n = 0; n != 8; ++n) {
637 for (
unsigned n = 0; n != 16; ++n) {
646 Reserved.set(X86::R16, X86::R31WH + 1);
652 unsigned NumReservedCSRs = 0;
653 for (
unsigned Reg = X86::R16; Reg <= X86::R31; ++Reg)
654 if (isCalleeSavedPhysReg(Reg, MF)) {
656 for (
const MCPhysReg &SubReg : subregs_inclusive(Reg))
663 " callee-saved register(s) reserved due to setjmp in '" +
665 "'; this may impact performance in large functions");
677 {X86::SIL, X86::DIL, X86::BPL, X86::SPL,
678 X86::SIH, X86::DIH, X86::BPH, X86::SPH}));
694 static_assert((X86::R15WH + 1 == X86::YMM0) && (X86::YMM15 + 1 == X86::K0) &&
695 (X86::K6_K7 + 1 == X86::TMMCFG) &&
696 (X86::TMM7 + 1 == X86::R16) &&
697 (X86::R31WH + 1 == X86::NUM_TARGET_REGS),
698 "Register number may be incorrect");
702 return X86::NUM_TARGET_REGS;
704 return X86::TMM7 + 1;
706 return X86::K6_K7 + 1;
708 return X86::YMM15 + 1;
709 return X86::R15WH + 1;
717 return TRI.isSuperOrSubRegisterEq(RegA, RegB);
723 [&](
MCRegister &RegA) {
return IsSubReg(RegA, Reg); }) ||
724 (ST.hasMMX() && X86::VR64RegClass.contains(Reg));
733 [&](
MCRegister &RegA) {
return IsSubReg(RegA, Reg); }))
738 [&](
MCRegister &RegA) {
return IsSubReg(RegA, Reg); }))
743 X86::XMM3, X86::XMM4, X86::XMM5,
744 X86::XMM6, X86::XMM7},
745 [&](
MCRegister &RegA) { return IsSubReg(RegA, Reg); }))
748 return X86GenRegisterInfo::isArgumentRegister(MF, Reg);
757 if (
TRI.isSuperOrSubRegisterEq(X86::RSP, PhysReg))
762 if (TFI.
hasFP(MF) &&
TRI.isSuperOrSubRegisterEq(X86::RBP, PhysReg))
765 return X86GenRegisterInfo::isFixedRegister(MF, PhysReg);
769 return RC->
getID() == X86::TILERegClassID;
780 assert(!(Mask[X86::EFLAGS / 32] & (1U << (X86::EFLAGS % 32))) &&
781 "EFLAGS are not live-out from a patchpoint.");
784 for (
auto Reg : {X86::EFLAGS, X86::RIP, X86::EIP, X86::IP})
785 Mask[Reg / 32] &= ~(1U << (Reg % 32));
816 bool CantUseFP = hasStackRealignment(MF);
852 unsigned Opc =
II->getOpcode();
854 if ((
Opc != X86::LEA32r &&
Opc != X86::LEA64r &&
Opc != X86::LEA64_32r) ||
855 MI.getOperand(2).getImm() != 1 ||
856 MI.getOperand(3).getReg() != X86::NoRegister ||
857 MI.getOperand(4).getImm() != 0 ||
858 MI.getOperand(5).getReg() != X86::NoRegister)
864 if (
Opc == X86::LEA64_32r)
866 Register NewDestReg =
MI.getOperand(0).getReg();
868 MI.getParent()->getParent()->getSubtarget<
X86Subtarget>().getInstrInfo();
869 TII->copyPhysReg(*
MI.getParent(),
II,
MI.getDebugLoc(), NewDestReg, BasePtr,
870 MI.getOperand(1).isKill());
871 MI.eraseFromParent();
876 switch (
MI.getOpcode()) {
878 case X86::CLEANUPRET:
887 unsigned FIOperandNum,
889 int FIOffset)
const {
891 unsigned Opc =
MI.getOpcode();
892 if (
Opc == TargetOpcode::LOCAL_ESCAPE) {
898 MI.getOperand(FIOperandNum).ChangeToRegister(BaseReg,
false);
902 if (
Opc == TargetOpcode::STACKMAP ||
Opc == TargetOpcode::PATCHPOINT) {
903 assert(BasePtr == FramePtr &&
"Expected the FP as base register");
904 int64_t
Offset =
MI.getOperand(FIOperandNum + 1).getImm() + FIOffset;
905 MI.getOperand(FIOperandNum + 1).ChangeToImmediate(
Offset);
909 if (
MI.getOperand(FIOperandNum + 3).isImm()) {
911 int Imm = (int)(
MI.getOperand(FIOperandNum + 3).getImm());
912 int Offset = FIOffset + Imm;
914 "Requesting 64-bit offset in 32-bit immediate!");
916 MI.getOperand(FIOperandNum + 3).ChangeToImmediate(
Offset);
920 FIOffset + (
uint64_t)
MI.getOperand(FIOperandNum + 3).getOffset();
921 MI.getOperand(FIOperandNum + 3).setOffset(
Offset);
927 int SPAdj,
unsigned FIOperandNum,
936 int FrameIndex =
MI.getOperand(FIOperandNum).getIndex();
942 assert((!hasStackRealignment(MF) ||
944 "Return instruction can only reference SP relative frame objects");
947 }
else if (TFI->
Is64Bit && (
MBB.isEHFuncletEntry() || IsEHFuncletEpilogue)) {
958 unsigned Opc =
MI.getOpcode();
959 if (
Opc == TargetOpcode::LOCAL_ESCAPE) {
970 if (
Opc == X86::LEA64_32r && X86::GR32RegClass.
contains(BasePtr))
975 MI.getOperand(FIOperandNum).ChangeToRegister(MachineBasePtr,
false);
977 if (BasePtr == StackPtr)
982 if (
Opc == TargetOpcode::STACKMAP ||
Opc == TargetOpcode::PATCHPOINT) {
983 assert(BasePtr == FramePtr &&
"Expected the FP as base register");
984 int64_t
Offset =
MI.getOperand(FIOperandNum + 1).getImm() + FIOffset;
985 MI.getOperand(FIOperandNum + 1).ChangeToImmediate(
Offset);
989 if (
MI.getOperand(FIOperandNum+3).isImm()) {
992 int64_t Imm =
MI.getOperand(FIOperandNum + 3).getImm();
993 int64_t
Offset = FIOffset + Imm;
997 if (Is64Bit && !FitsIn32Bits) {
998 assert(RS &&
"RegisterScavenger was NULL");
1000 RS->enterBasicBlockEnd(
MBB);
1001 RS->backward(std::next(
II));
1003 Register ScratchReg = RS->scavengeRegisterBackwards(
1004 X86::GR64RegClass,
II,
false, 0,
1006 assert(ScratchReg != 0 &&
"scratch reg was 0");
1007 RS->setRegUsed(ScratchReg);
1011 MI.getOperand(FIOperandNum + 3).setImm(0);
1012 MI.getOperand(FIOperandNum + 2).setReg(ScratchReg);
1018 if (!Is64Bit && !FitsIn32Bits) {
1019 MI.emitGenericError(
"64-bit offset calculated but target is 32-bit");
1026 MI.getOperand(FIOperandNum + 3).ChangeToImmediate(
Offset);
1030 (
uint64_t)
MI.getOperand(FIOperandNum+3).getOffset();
1031 MI.getOperand(FIOperandNum + 3).setOffset(
Offset);
1046 switch (
MBBI->getOpcode()) {
1049 case TargetOpcode::PATCHABLE_RET:
1055 case X86::TCRETURNdi:
1056 case X86::TCRETURNri:
1057 case X86::TCRETURN_WIN64ri:
1058 case X86::TCRETURN_HIPE32ri:
1059 case X86::TCRETURNmi:
1060 case X86::TCRETURNdi64:
1061 case X86::TCRETURNri64:
1062 case X86::TCRETURNri64_ImpCall:
1063 case X86::TCRETURNmi64:
1064 case X86::TCRETURN_WINmi64:
1065 case X86::EH_RETURN:
1066 case X86::EH_RETURN64: {
1072 Is64Bit ? X86::GR64_NOSPRegClass : X86::GR32_NOSPRegClass;
1085 return TFI->
hasFP(MF) ? FramePtr : StackPtr;
1113 unsigned OpCode =
MI->getOpcode();
1119 Register SrcReg =
MI->getOperand(1).getReg();
1125 case X86::PTILELOADDV:
1126 case X86::PTILELOADDT1V:
1127 case X86::PTDPBSSDV:
1128 case X86::PTDPBSUDV:
1129 case X86::PTDPBUSDV:
1130 case X86::PTDPBUUDV:
1131 case X86::PTILEZEROV:
1132 case X86::PTDPBF16PSV:
1133 case X86::PTDPFP16PSV:
1134 case X86::PTCMMIMFP16PSV:
1135 case X86::PTCMMRLFP16PSV:
1136 case X86::PTILELOADDRSV:
1137 case X86::PTILELOADDRST1V:
1138 case X86::PTMMULTF32PSV:
1139 case X86::PTDPBF8PSV:
1140 case X86::PTDPBHF8PSV:
1141 case X86::PTDPHBF8PSV:
1142 case X86::PTDPHF8PSV: {
1145 ShapeT Shape(&MO1, &MO2, MRI);
1161 VirtReg, Order, Hints, MF, VRM,
Matrix);
1168 return BaseImplRetVal;
1170 if (
ID != X86::TILERegClassID) {
1172 !
TRI.isGeneralPurposeRegisterClass(&RC))
1173 return BaseImplRetVal;
1182 TwoAddrHints.
insert(PhysReg);
1191 unsigned OpIdx =
MI.getOperandNo(&MO);
1194 TryAddNDDHint(
MI.getOperand(1));
1195 if (
MI.isCommutable()) {
1197 TryAddNDDHint(
MI.getOperand(2));
1199 }
else if (
OpIdx == 1) {
1200 TryAddNDDHint(
MI.getOperand(0));
1201 }
else if (
MI.isCommutable() &&
OpIdx == 2) {
1202 TryAddNDDHint(
MI.getOperand(0));
1207 if (TwoAddrHints.
count(OrderReg))
1210 return BaseImplRetVal;
1221 if (PhysShape == VirtShape)
1227 for (
auto Hint : CopyHints) {
1237#define DEBUG_TYPE "tile-hint"
1239 dbgs() <<
"Hints for virtual register " <<
format_hex(VirtReg, 8) <<
"\n";
1240 for (
auto Hint : Hints) {
1241 dbgs() <<
"tmm" << Hint <<
",";
1252 switch (RC->
getID()) {
1255 case X86::GR8RegClassID:
1256 return &X86::GR8_NOREX2RegClass;
1257 case X86::GR16RegClassID:
1258 return &X86::GR16_NOREX2RegClass;
1259 case X86::GR32RegClassID:
1260 return &X86::GR32_NOREX2RegClass;
1261 case X86::GR64RegClassID:
1262 return &X86::GR64_NOREX2RegClass;
1263 case X86::GR32_NOSPRegClassID:
1264 return &X86::GR32_NOREX2_NOSPRegClass;
1265 case X86::GR64_NOSPRegClassID:
1266 return &X86::GR64_NOREX2_NOSPRegClass;
1271 switch (RC->
getID()) {
1274 case X86::GR8_NOREX2RegClassID:
1275 case X86::GR16_NOREX2RegClassID:
1276 case X86::GR32_NOREX2RegClassID:
1277 case X86::GR64_NOREX2RegClassID:
1278 case X86::GR32_NOREX2_NOSPRegClassID:
1279 case X86::GR64_NOREX2_NOSPRegClassID:
1280 case X86::GR64_with_sub_16bit_in_GR16_NOREX2RegClassID:
static const TargetRegisterClass * getRegClass(const MachineInstr &MI, Register Reg)
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
MachineBasicBlock MachineBasicBlock::iterator MBBI
This file implements the BitVector class.
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
const HexagonInstrInfo * TII
static cl::opt< bool > EnableBasePointer("m68k-use-base-pointer", cl::Hidden, cl::init(true), cl::desc("Enable use of a base pointer for complex stack frames"))
static bool CantUseSP(const MachineFrameInfo &MFI)
Register const TargetRegisterInfo * TRI
Promote Memory to Register
MachineInstr unsigned OpIdx
uint64_t IntrinsicInst * II
This file declares the machine register scavenger class.
static bool contains(SmallPtrSetImpl< ConstantExpr * > &Cache, ConstantExpr *Expr, Constant *C)
This file defines the SmallSet class.
cl::opt< bool > X86EnableAPXForRelocation
static cl::opt< unsigned > SetjmpCSRWarningThreshold("x86-setjmp-csr-warning-threshold", cl::Hidden, cl::init(50), cl::desc("Basic block count threshold for emitting a warning about " "callee-saved registers reserved due to setjmp"))
static cl::opt< bool > EnableBasePointer("x86-use-base-pointer", cl::Hidden, cl::init(true), cl::desc("Enable use of a base pointer for complex stack frames"))
static bool tryOptimizeLEAtoMOV(MachineBasicBlock::iterator II)
static cl::opt< bool > DisableRegAllocNDDHints("x86-disable-regalloc-hints-for-ndd", cl::Hidden, cl::init(false), cl::desc("Disable two address hints for register " "allocation"))
static ShapeT getTileShape(Register VirtReg, VirtRegMap *VRM, const MachineRegisterInfo *MRI)
Represent a constant reference to an array (0 or more elements consecutively in memory),...
CallingConv::ID getCallingConv() const
getCallingConv()/setCallingConv(CC) - These method get and set the calling convention of this functio...
bool hasFnAttribute(Attribute::AttrKind Kind) const
Return true if the function has the attribute.
A set of register units used to track register liveness.
bool available(MCRegister Reg) const
Returns true if no part of physical register Reg is live.
LLVM_ABI void stepBackward(const MachineInstr &MI)
Updates liveness when stepping backwards over the instruction MI.
LLVM_ABI void addLiveOuts(const MachineBasicBlock &MBB)
Adds registers living out of block MBB.
LLVM_ABI void reportWarning(SMLoc L, const Twine &Msg)
LLVM_ABI void reportError(SMLoc L, const Twine &Msg)
MCRegAliasIterator enumerates all registers aliasing Reg.
Wrapper class representing physical registers. Should be passed by value.
static constexpr unsigned NoRegister
MachineInstrBundleIterator< MachineInstr > iterator
The MachineFrameInfo class represents an abstract stack frame until prolog/epilog code is inserted.
bool hasVarSizedObjects() const
This method may be called any time after instruction selection is complete to determine if the stack ...
bool hasOpaqueSPAdjustment() const
Returns true if the function contains opaque dynamic stack adjustments.
bool isFixedObjectIndex(int ObjectIdx) const
Returns true if the specified index corresponds to a fixed stack object.
const TargetSubtargetInfo & getSubtarget() const
getSubtarget - Return the subtarget for which this machine code is being compiled.
StringRef getName() const
getName - Return the name of the corresponding LLVM function.
bool exposesReturnsTwice() const
exposesReturnsTwice - Returns true if the function calls setjmp or any other similar functions with a...
MachineFrameInfo & getFrameInfo()
getFrameInfo - Return the frame info object for the current function.
MCContext & getContext() const
bool callsEHReturn() const
MachineRegisterInfo & getRegInfo()
getRegInfo - Return information about the registers currently in use.
Function & getFunction()
Return the LLVM function that this machine code represents.
Ty * getInfo()
getInfo - Keep track of various per-function pieces of information for backends that would like to do...
const TargetMachine & getTarget() const
getTarget - Return the target machine this machine code is compiled with
const MachineInstrBuilder & addImm(int64_t Val) const
Add a new immediate operand.
Representation of each machine instruction.
MachineOperand class - Representation of each machine instruction operand.
LLVM_ABI void ChangeToImmediate(int64_t ImmVal, unsigned TargetFlags=0)
ChangeToImmediate - Replace this operand with a new immediate operand of the specified value.
MachineRegisterInfo - Keep track of information for virtual and physical registers,...
const TargetRegisterClass * getRegClass(Register Reg) const
Return the register class of the specified virtual register.
bool isReserved(MCRegister PhysReg) const
isReserved - Returns true when PhysReg is a reserved register.
def_iterator def_begin(Register RegNo) const
bool reservedRegsFrozen() const
reservedRegsFrozen - Returns true after freezeReservedRegs() was called to ensure the set of reserved...
bool canReserveReg(MCRegister PhysReg) const
canReserveReg - Returns true if PhysReg can be used as a reserved register.
iterator_range< reg_nodbg_iterator > reg_nodbg_operands(Register Reg) const
Wrapper class representing virtual and physical registers.
constexpr bool isPhysical() const
Return true if the specified register number is in the physical register namespace.
Represents a location in source code.
SmallSet - This maintains a set of unique values, optimizing for the case when the set is small (less...
size_type count(const T &V) const
count - Return 1 if the element is in the set, 0 otherwise.
std::pair< const_iterator, bool > insert(const T &V)
insert - Insert an element into the set if it isn't already there.
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
static StackOffset getFixed(int64_t Fixed)
bool hasFP(const MachineFunction &MF) const
hasFP - Return true if the specified function should have a dedicated frame pointer register.
LLVM_ABI bool FramePointerIsReserved(const MachineFunction &MF) const
FramePointerIsReserved - This returns true if the frame pointer must always either point to a new fra...
unsigned getID() const
Return the register class ID number.
bool contains(Register Reg) const
Return true if the specified register is included in this register class.
ArrayRef< unsigned > superclasses() const
Returns a list of super-classes.
TargetRegisterInfo base class - We assume that the target defines a static array of TargetRegisterDes...
virtual bool canRealignStack(const MachineFunction &MF) const
True if the stack can be realigned for the target.
virtual bool shouldRealignStack(const MachineFunction &MF) const
True if storage within the function requires the stack pointer to be aligned more than the normal cal...
virtual bool getRegAllocationHints(Register VirtReg, ArrayRef< MCPhysReg > Order, SmallVectorImpl< MCPhysReg > &Hints, const MachineFunction &MF, const VirtRegMap *VRM=nullptr, const LiveRegMatrix *Matrix=nullptr) const
Get a list of 'hint' registers that the register allocator should try first when allocating a physica...
Triple - Helper class for working with autoconf configuration names.
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
bool hasShape(Register virtReg) const
ShapeT getShape(Register virtReg) const
MCRegister getPhys(Register virtReg) const
returns the physical register mapped to the specified virtual register
void assignVirt2Shape(Register virtReg, ShapeT shape)
StackOffset getFrameIndexReferenceSP(const MachineFunction &MF, int FI, Register &SPReg, int Adjustment) const
StackOffset getFrameIndexReference(const MachineFunction &MF, int FI, Register &FrameReg) const override
getFrameIndexReference - This method should return the base register and offset used to reference a f...
bool Is64Bit
Is64Bit implies that x86_64 instructions are available.
int getWin64EHFrameIndexRef(const MachineFunction &MF, int FI, Register &SPReg) const
X86MachineFunctionInfo - This class is derived from MachineFunction and contains private X86 target-s...
bool getBPClobberedByInvoke() const
bool hasPreallocatedCall() const
MachineInstr * getStackPtrSaveMI() const
bool getFPClobberedByInvoke() const
bool hasBasePointer(const MachineFunction &MF) const
const TargetRegisterClass * getPointerRegClass(unsigned Kind=0) const override
getPointerRegClass - Returns a TargetRegisterClass used for pointer values.
const MCPhysReg * getCalleeSavedRegsViaCopy(const MachineFunction *MF) const
bool canRealignStack(const MachineFunction &MF) const override
BitVector getReservedRegs(const MachineFunction &MF) const override
getReservedRegs - Returns a bitset indexed by physical register number indicating if a register is a ...
Register getPtrSizedFrameRegister(const MachineFunction &MF) const
bool shouldRealignStack(const MachineFunction &MF) const override
unsigned getNumSupportedRegs(const MachineFunction &MF) const override
Return the number of registers for the function.
const MCPhysReg * getIPRACSRegs(const MachineFunction *MF) const override
getIPRACSRegs - This API can be removed when rbp is safe to optimized out when IPRA is on.
Register getFrameRegister(const MachineFunction &MF) const override
unsigned findDeadCallerSavedReg(MachineBasicBlock &MBB, MachineBasicBlock::iterator &MBBI) const
findDeadCallerSavedReg - Return a caller-saved register that isn't live when it reaches the "return" ...
const uint32_t * getDarwinTLSCallPreservedMask() const
bool isTileRegisterClass(const TargetRegisterClass *RC) const
Return true if it is tile register class.
bool isNonRex2RegClass(const TargetRegisterClass *RC) const
const uint32_t * getCallPreservedMask(const MachineFunction &MF, CallingConv::ID) const override
Register getPtrSizedStackRegister(const MachineFunction &MF) const
bool isArgumentRegister(const MachineFunction &MF, MCRegister Reg) const override
isArgumentReg - Returns true if Reg can be used as an argument to a function.
Register getStackRegister() const
const TargetRegisterClass * getLargestLegalSuperClass(const TargetRegisterClass *RC, const MachineFunction &MF) const override
const TargetRegisterClass * getMatchingSuperRegClass(const TargetRegisterClass *A, const TargetRegisterClass *B, unsigned Idx) const override
getMatchingSuperRegClass - Return a subclass of the specified register class A so that each register ...
unsigned getRegPressureLimit(const TargetRegisterClass *RC, MachineFunction &MF) const override
const TargetRegisterClass * getCrossCopyRegClass(const TargetRegisterClass *RC) const override
getCrossCopyRegClass - Returns a legal register class to copy a register in the specified class to or...
X86RegisterInfo(const Triple &TT)
const TargetRegisterClass * constrainRegClassToNonRex2(const TargetRegisterClass *RC) const
Register getBaseRegister() const
bool getRegAllocationHints(Register VirtReg, ArrayRef< MCPhysReg > Order, SmallVectorImpl< MCPhysReg > &Hints, const MachineFunction &MF, const VirtRegMap *VRM, const LiveRegMatrix *Matrix) const override
void eliminateFrameIndex(MachineBasicBlock::iterator II, unsigned FIOperandNum, Register BaseReg, int FIOffset) const
const uint32_t * getNoPreservedMask() const override
bool isFixedRegister(const MachineFunction &MF, MCRegister PhysReg) const override
Returns true if PhysReg is a fixed register.
const TargetRegisterClass * getSubClassWithSubReg(const TargetRegisterClass *RC, unsigned Idx) const override
const MCPhysReg * getCalleeSavedRegs(const MachineFunction *MF) const override
getCalleeSavedRegs - Return a null-terminated list of all of the callee-save registers on this target...
void adjustStackMapLiveOutMask(uint32_t *Mask) const override
const X86TargetLowering * getTargetLowering() const override
bool isTarget64BitILP32() const
Is this x86_64 with the ILP32 programming model (x32 ABI)?
bool supportSwiftError() const override
Return true if the target supports swifterror attribute.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
@ X86_64_SysV
The C convention as specified in the x86-64 supplement to the System V ABI, used on most non-Windows ...
@ HiPE
Used by the High-Performance Erlang Compiler (HiPE).
@ CFGuard_Check
Special calling convention on Windows for calling the Control Guard Check ICall funtion.
@ PreserveMost
Used for runtime calls that preserves most registers.
@ AnyReg
OBSOLETED - Used for stack based JavaScript calls.
@ CXX_FAST_TLS
Used for access functions.
@ X86_INTR
x86 hardware interrupt context.
@ GHC
Used by the Glasgow Haskell Compiler (GHC).
@ Cold
Attempts to make code in the caller as efficient as possible under the assumption that the call is no...
@ PreserveAll
Used for runtime calls that preserves (almost) all registers.
@ Intel_OCL_BI
Used for Intel OpenCL built-ins.
@ PreserveNone
Used for runtime calls that preserves none general registers.
@ Win64
The C convention as implemented on Windows/x86-64 and AArch64.
@ SwiftTail
This follows the Swift calling convention in how arguments are passed but guarantees tail calls will ...
@ GRAAL
Used by GraalVM. Two additional registers are reserved.
@ X86_RegCall
Register calling convention used for parameters transfer optimization.
void initLLVMToSEHAndCVRegMapping(MCRegisterInfo *MRI)
Define some predicates that are used for node matching.
unsigned getNonNDVariant(unsigned Opc)
initializer< Ty > init(const Ty &Val)
This is an optimization pass for GlobalISel generic memory operations.
MachineInstrBuilder BuildMI(MachineFunction &MF, const MIMetadata &MIMD, const MCInstrDesc &MCID)
Builder interface. Specify how to create the initial instruction itself.
constexpr bool isInt(int64_t x)
Checks if an integer fits into the given bit width.
MCRegister getX86SubSuperRegister(MCRegister Reg, unsigned Size, bool High=false)
constexpr from_range_t from_range
bool any_of(R &&range, UnaryPredicate P)
Provide wrappers to std::any_of which take ranges instead of having to pass begin/end explicitly.
static bool isFuncletReturnInstr(const MachineInstr &MI)
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
FormattedNumber format_hex(uint64_t N, unsigned Width, bool Upper=false)
format_hex - Output N as a fixed width hexadecimal.
uint16_t MCPhysReg
An unsigned integer type large enough to represent all physical registers, but not necessarily virtua...
bool is_contained(R &&Range, const E &Element)
Returns true if Element is found in Range.