43#include "llvm/Config/llvm-config.h"
83#define DEBUG_TYPE "codegen"
86 "align-all-functions",
87 cl::desc(
"Force the alignment of all functions in log2 format (e.g. 4 "
88 "means align on 16B boundaries)."),
96 case P::FailedISel:
return "FailedISel";
97 case P::IsSSA:
return "IsSSA";
98 case P::Legalized:
return "Legalized";
99 case P::NoPHIs:
return "NoPHIs";
100 case P::NoVRegs:
return "NoVRegs";
101 case P::RegBankSelected:
return "RegBankSelected";
102 case P::Selected:
return "Selected";
103 case P::TracksLiveness:
return "TracksLiveness";
104 case P::TiedOpsRewritten:
return "TiedOpsRewritten";
105 case P::FailsVerification:
return "FailsVerification";
106 case P::FailedRegAlloc:
return "FailedRegAlloc";
107 case P::TracksDebugUserValues:
return "TracksDebugUserValues";
114 if (!
F.hasFnAttribute(Attribute::SafeStack))
120 if (!Existing || Existing->getNumOperands() != 2)
123 auto *MetadataName =
"unsafe-stack-size";
124 if (
auto &
N = Existing->getOperand(0)) {
125 if (
N.equalsStr(MetadataName)) {
126 if (
auto &
Op = Existing->getOperand(1)) {
128 FrameInfo.setUnsafeStackSize(Val);
135void MachineFunction::Delegate::anchor() {}
138 const char *Separator =
"";
142 OS << Separator << getPropertyName(static_cast<Property>(
I));
155 MBB->getParent()->deleteMachineBasicBlock(
MBB);
160 if (
auto MA =
F.getFnStackAlign())
166 Attribute FPAttr =
F.getFnAttribute(
"frame-pointer");
182 unsigned FunctionNum)
183 : F(F), Target(Target), STI(STI), Ctx(Ctx) {
184 FunctionNumber = FunctionNum;
201 TheDelegate->MF_HandleChangeDesc(
MI, TID);
204void MachineFunction::init() {
206 Properties.setIsSSA();
207 Properties.setTracksLiveness();
215 !
F.hasFnAttribute(
"no-realign-stack");
216 bool ForceRealignSP =
F.hasFnAttribute(Attribute::StackAlignment) ||
217 F.hasFnAttribute(
"stackrealign");
220 ForceRealignSP && CanRealignSP);
225 if (
F.hasFnAttribute(Attribute::StackAlignment))
226 FrameInfo->ensureMaxAlignment(*
F.getFnStackAlign());
235 if (
F.hasMetadata(LLVMContext::MD_func_sanitize) ||
236 F.getMetadata(LLVMContext::MD_kcfi_type))
237 Alignment = std::max(Alignment,
Align(4));
242 JumpTableInfo =
nullptr;
245 F.hasPersonalityFn() ?
F.getPersonalityFn() :
nullptr))) {
251 formatv(
"Can't create a MachineFunction using a Module with a "
252 "Target-incompatible DataLayout attached\n Target "
253 "DataLayout: {0}\n Module DataLayout: {1}\n",
254 Target.createDataLayout().getStringRepresentation(),
258 PSVManager = std::make_unique<PseudoSourceValueManager>(
getTarget());
263 assert(!MFInfo &&
"MachineFunctionInfo already set");
264 MFInfo = Target.createMachineFunctionInfo(Allocator, F, &STI);
270 assert(!MFInfo &&
"new function already has MachineFunctionInfo");
275 OrigMF.MFInfo->
clone(Allocator, *
this, Src2DstMBB);
279 RegInfo->copyPendingVirtRegMapEntriesFrom(OrigMF.
getRegInfo());
287void MachineFunction::clear() {
293 JumpTableInfo->~MachineJumpTableInfo();
294 Allocator.Deallocate(JumpTableInfo);
295 JumpTableInfo =
nullptr;
303 I->Insts.clearAndLeakNodesUnsafely();
304 MBBNumbering.clear();
309 CodeViewAnnotations.clear();
312 RegInfo->~MachineRegisterInfo();
316 MFInfo->~MachineFunctionInfo();
317 Allocator.Deallocate(MFInfo);
320 FrameInfo->~MachineFrameInfo();
321 Allocator.Deallocate(FrameInfo);
323 ConstantPool->~MachineConstantPool();
324 Allocator.Deallocate(ConstantPool);
327 WinEHInfo->~WinEHFuncInfo();
328 Allocator.Deallocate(WinEHInfo);
333 return F.getDataLayout();
340 if (JumpTableInfo)
return JumpTableInfo;
342 JumpTableInfo =
new (Allocator)
344 return JumpTableInfo;
348 return F.getDenormalMode(FPType);
361 else if (!F.hasOptSize())
362 PrefAlignment = STI.getTargetLowering()->getPrefFunctionAlignment();
364 PrefAlignment =
Align(1);
369[[nodiscard]]
unsigned
371 FrameInstructions.push_back(Inst);
372 return FrameInstructions.size() - 1;
382 Inst.replaceRegister(DwarfFromReg, DwarfToReg);
390 if (
empty()) { MBBNumbering.clear();
return; }
398 unsigned BlockNo = 0;
400 BlockNo = std::prev(
MBBI)->getNumber() + 1;
402 for (;
MBBI != E; ++
MBBI, ++BlockNo) {
403 if (
MBBI->getNumber() != (
int)BlockNo) {
405 if (
MBBI->getNumber() != -1) {
407 "MBB number mismatch!");
408 MBBNumbering[
MBBI->getNumber()] =
nullptr;
412 if (MBBNumbering[BlockNo])
413 MBBNumbering[BlockNo]->setNumber(-1);
415 MBBNumbering[BlockNo] = &*
MBBI;
416 MBBI->setNumber(BlockNo);
422 assert(BlockNo <= MBBNumbering.size() &&
"Mismatch!");
423 MBBNumbering.resize(BlockNo);
435 const Align Alignment =
MBBI->getAlignment();
443 if (Alignment <= FunctionAlignment) {
449 FunctionAlignment.
value();
464 if (
MBBI->getSectionID() == CurrentSectionID)
466 MBBI->setIsBeginSection();
467 std::prev(
MBBI)->setIsEndSection();
468 CurrentSectionID =
MBBI->getSectionID();
477 return new (InstructionRecycler.Allocate<
MachineInstr>(Allocator))
484MachineFunction::CloneMachineInstr(
const MachineInstr *Orig) {
492 MachineInstr *FirstClone =
nullptr;
495 MachineInstr *Cloned = CloneMachineInstr(&*
I);
497 if (FirstClone ==
nullptr) {
503 if (!
I->isBundledWithSucc())
524 assert((!
MI->isCandidateForAdditionalCallInfo() ||
525 !CallSitesInfo.contains(
MI)) &&
526 "Call site info was not updated!");
528 assert((!
MI->isCandidateForAdditionalCallInfo() ||
529 !CalledGlobalsInfo.contains(
MI)) &&
530 "Called globals info was not updated!");
538 InstructionRecycler.Deallocate(Allocator,
MI);
545 std::optional<UniqueBBID> BBID) {
551 if (Target.Options.BBAddrMap ||
553 MBB->setBBID(BBID.has_value() ? *BBID :
UniqueBBID{NextBBID++, 0});
559 assert(
MBB->getParent() ==
this &&
"MBB parent mismatch!");
562 JumpTableInfo->RemoveMBBFromJumpTables(
MBB);
563 MBB->~MachineBasicBlock();
564 BasicBlockRecycler.Deallocate(Allocator,
MBB);
573 Size.getValue().getKnownMinValue() != ~UINT64_C(0)) &&
574 "Unexpected an unknown size to be represented using "
575 "LocationSize::beforeOrAfter()");
576 return new (Allocator)
578 Ordering, FailureOrdering);
586 return new (Allocator)
588 Ordering, FailureOrdering);
596 Size.getValue().getKnownMinValue() != ~UINT64_C(0)) &&
597 "Unexpected an unknown size to be represented using "
598 "LocationSize::beforeOrAfter()");
599 return new (Allocator)
607 return new (Allocator)
658 return MachineInstr::ExtraInfo::create(Allocator, MMOs, PreInstrSymbol,
659 PostInstrSymbol, HeapAllocMarker,
660 PCSections, CFIType, MMRAs, DS);
664 char *Dest = Allocator.Allocate<
char>(Name.size() + 1);
666 Dest[Name.size()] = 0;
674 memset(Mask, 0,
Size *
sizeof(Mask[0]));
679 int* AllocMask = Allocator.Allocate<
int>(Mask.size());
680 copy(Mask, AllocMask);
681 return {AllocMask, Mask.size()};
684#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
695 OS <<
"# Machine code for function " <<
getName() <<
": ";
700 FrameInfo->print(*
this, OS);
704 JumpTableInfo->print(OS);
707 ConstantPool->print(OS);
711 if (RegInfo && !RegInfo->livein_empty()) {
712 OS <<
"Function Live Ins: ";
714 I = RegInfo->livein_begin(), E = RegInfo->livein_end();
I != E; ++
I) {
718 if (std::next(
I) != E)
726 for (
const auto &BB : *
this) {
729 BB.print(OS, MST, Indexes,
true);
732 OS <<
"\n# End machine code for function " <<
getName() <<
".\n\n";
743 F.needsUnwindTableEntry() ||
744 !F.getParent()->debug_compile_units().empty();
766 ConstantInt::get(Int64Ty, TypeIdVal,
false));
776 return (
"CFG for '" +
F->getName() +
"' function").str();
788 OSS <<
": " << BB->getName();
793 if (OutStr[0] ==
'\n')
794 OutStr.erase(OutStr.begin());
797 for (
unsigned i = 0; i != OutStr.length(); ++i)
798 if (OutStr[i] ==
'\n') {
800 OutStr.insert(OutStr.begin() + i + 1,
'l');
811 errs() <<
"MachineFunction::viewCFG is only available in debug builds on "
812 <<
"systems with Graphviz or gv!\n";
821 errs() <<
"MachineFunction::viewCFGOnly is only available in debug builds on "
822 <<
"systems with Graphviz or gv!\n";
842 "Register class mismatch!");
854 bool isLinkerPrivate)
const {
856 assert(JumpTableInfo &&
"No jump tables");
857 assert(JTI < JumpTableInfo->getJumpTables().
size() &&
"Invalid JTI!");
859 StringRef Prefix = isLinkerPrivate ?
DL.getLinkerPrivateGlobalPrefix()
860 :
DL.getInternalSymbolPrefix();
864 return Ctx.getOrCreateSymbol(Name);
870 return Ctx.getOrCreateSymbol(
Twine(
DL.getInternalSymbolPrefix()) +
879 unsigned N = LandingPads.size();
880 for (
unsigned i = 0; i <
N; ++i) {
887 return LandingPads[
N];
898 MCSymbol *LandingPadLabel = Ctx.createTempSymbol();
907 if (LPI->isCleanup() && LPI->getNumClauses() != 0)
913 for (
unsigned I = LPI->getNumClauses();
I != 0; --
I) {
914 Value *Val = LPI->getClause(
I - 1);
915 if (LPI->isCatch(
I - 1)) {
922 for (
const Use &U : CVal->operands())
931 for (
unsigned I = CPI->arg_size();
I != 0; --
I) {
941 return LandingPadLabel;
946 LPadToCallSiteMap[Sym].append(Sites.
begin(), Sites.
end());
950 for (
unsigned i = 0,
N = TypeInfos.size(); i !=
N; ++i)
951 if (TypeInfos[i] == TI)
return i + 1;
953 TypeInfos.push_back(TI);
954 return TypeInfos.size();
961 for (
unsigned i : FilterEnds) {
962 unsigned j = TyIds.
size();
965 if (FilterIds[--i] != TyIds[--j])
976 int FilterID = -(1 + FilterIds.size());
977 FilterIds.reserve(FilterIds.size() + TyIds.
size() + 1);
979 FilterEnds.push_back(FilterIds.size());
980 FilterIds.push_back(0);
986 assert(
MI->isCandidateForAdditionalCallInfo() &&
987 "Call site info refers only to call (MI) candidates");
989 if (!
Target.Options.EmitCallSiteInfo && !
Target.Options.EmitCallGraphSection)
990 return CallSitesInfo.
end();
991 return CallSitesInfo.
find(
MI);
1001 if (BMI.isCandidateForAdditionalCallInfo())
1008 assert(
MI->shouldUpdateAdditionalCallInfo() &&
1009 "Call info refers only to call (MI) candidates or "
1010 "candidates inside bundles");
1015 if (CSIt != CallSitesInfo.end())
1016 CallSitesInfo.erase(CSIt);
1018 CalledGlobalsInfo.erase(CallMI);
1024 "Call info refers only to call (MI) candidates or "
1025 "candidates inside bundles");
1027 if (!New->isCandidateForAdditionalCallInfo())
1032 if (CSIt != CallSitesInfo.end()) {
1034 CallSitesInfo[New] = std::move(CSInfo);
1038 if (CGIt != CalledGlobalsInfo.end()) {
1040 CalledGlobalsInfo[New] = std::move(CGInfo);
1047 "Call info refers only to call (MI) candidates or "
1048 "candidates inside bundles");
1050 if (!New->isCandidateForAdditionalCallInfo())
1055 if (CSIt != CallSitesInfo.end()) {
1057 CallSitesInfo.erase(CSIt);
1058 CallSitesInfo[New] = std::move(CSInfo);
1062 if (CGIt != CalledGlobalsInfo.end()) {
1064 CalledGlobalsInfo.erase(CGIt);
1065 CalledGlobalsInfo[New] = std::move(CGInfo);
1086 unsigned MaxOperand) {
1098 for (
unsigned int I = 0;
I < MaxOperand; ++
I) {
1100 auto &NewMO = New.getOperand(
I);
1103 if (!OldMO.isReg() || !OldMO.isDef())
1107 unsigned NewInstrNum = New.getDebugInstrNum();
1109 std::make_pair(NewInstrNum,
I));
1121 if (
auto CopyDstSrc =
TII.isCopyLikeInstr(
MI)) {
1122 Dest = CopyDstSrc->Destination->getReg();
1125 Dest =
MI.getOperand(0).getReg();
1128 auto CacheIt = DbgPHICache.find(Dest);
1129 if (CacheIt != DbgPHICache.end())
1130 return CacheIt->second;
1134 DbgPHICache.insert({Dest, OperandPair});
1160 auto GetRegAndSubreg =
1161 [&](
const MachineInstr &Cpy) -> std::pair<Register, unsigned> {
1165 OldReg = Cpy.getOperand(0).getReg();
1166 NewReg = Cpy.getOperand(1).getReg();
1167 SubReg = Cpy.getOperand(1).getSubReg();
1168 }
else if (Cpy.isSubregToReg()) {
1169 OldReg = Cpy.getOperand(0).getReg();
1170 NewReg = Cpy.getOperand(1).getReg();
1171 SubReg = Cpy.getOperand(2).getImm();
1173 auto CopyDetails = *
TII.isCopyInstr(Cpy);
1177 NewReg = Src.getReg();
1178 SubReg = Src.getSubReg();
1181 return {NewReg, SubReg};
1188 auto State = GetRegAndSubreg(
MI);
1189 auto CurInst =
MI.getIterator();
1193 if (!State.first.isVirtual())
1207 State = GetRegAndSubreg(Inst);
1214 auto ApplySubregisters =
1216 for (
unsigned Subreg :
reverse(SubregsSeen)) {
1224 P = {NewInstrNumber, 0};
1231 if (State.first.isVirtual()) {
1234 for (
auto &MO : Inst->
all_defs()) {
1235 if (MO.getReg() != State.first)
1245 assert(CurInst->isCopyLike() ||
TII.isCopyInstr(*CurInst));
1246 State = GetRegAndSubreg(*CurInst);
1249 auto RMII = CurInst->getReverseIterator();
1250 auto PrevInstrs =
make_range(RMII, CurInst->getParent()->instr_rend());
1251 for (
auto &ToExamine : PrevInstrs) {
1252 for (
auto &MO : ToExamine.all_defs()) {
1254 if (!
TRI.regsOverlap(RegToSeek, MO.getReg()))
1257 return ApplySubregisters(
1258 {ToExamine.getDebugInstrNum(), MO.getOperandNo()});
1275 TII.get(TargetOpcode::DBG_PHI));
1276 Builder.addReg(State.first);
1278 Builder.addImm(NewNum);
1279 return ApplySubregisters({NewNum, 0u});
1286 const MCInstrDesc &RefII =
TII->get(TargetOpcode::DBG_VALUE_LIST);
1288 MI.setDebugValueUndef();
1292 for (
auto &
MBB : *
this) {
1293 for (
auto &
MI :
MBB) {
1294 if (!
MI.isDebugRef())
1297 bool IsValidRef =
true;
1308 if (Reg == 0 || !RegInfo->hasOneDef(Reg)) {
1321 MO.ChangeToDbgInstrRef(Result.first, Result.second);
1324 unsigned OperandIdx = 0;
1325 for (
const auto &DefMO :
DefMI.operands()) {
1326 if (DefMO.isReg() && DefMO.isDef() && DefMO.getReg() == Reg)
1333 unsigned ID =
DefMI.getDebugInstrNum();
1334 MO.ChangeToDbgInstrRef(
ID, OperandIdx);
1339 MakeUndefDbgValue(
MI);
1353 if (F.hasFnAttribute(Attribute::OptimizeNone))
1380 const std::vector<MachineBasicBlock *> &
MBBs)
1426 const std::vector<MachineBasicBlock*> &DestBBs) {
1427 assert(!DestBBs.empty() &&
"Cannot create an empty jump table!");
1429 return JumpTables.size()-1;
1434 assert(JTI < JumpTables.size() &&
"Invalid JTI!");
1436 if (Hotness <= JumpTables[JTI].Hotness)
1439 JumpTables[JTI].Hotness = Hotness;
1447 assert(Old != New &&
"Not making a change?");
1448 bool MadeChange =
false;
1449 for (
size_t i = 0, e = JumpTables.size(); i != e; ++i)
1456 bool MadeChange =
false;
1458 auto removeBeginItr = std::remove(JTE.MBBs.begin(), JTE.MBBs.end(),
MBB);
1459 MadeChange |= (removeBeginItr != JTE.MBBs.end());
1460 JTE.MBBs.erase(removeBeginItr, JTE.MBBs.end());
1470 assert(Old != New &&
"Not making a change?");
1471 bool MadeChange =
false;
1482 if (JumpTables.empty())
return;
1484 OS <<
"Jump Tables:\n";
1486 for (
unsigned i = 0, e = JumpTables.size(); i != e; ++i) {
1496#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
1508void MachineConstantPoolValue::anchor() {}
1511 return DL.getTypeAllocSize(Ty);
1516 return Val.MachineCPVal->getSizeInBytes(
DL);
1517 return DL.getTypeAllocSize(
Val.ConstVal->getType());
1523 return Val.ConstVal->needsDynamicRelocation();
1549 if (
C.isMachineConstantPoolEntry()) {
1550 Deleted.insert(
C.Val.MachineCPVal);
1551 delete C.Val.MachineCPVal;
1564 if (
A ==
B)
return true;
1568 if (
A->getType() ==
B->getType())
return false;
1576 uint64_t StoreSize =
DL.getTypeStoreSize(
A->getType());
1577 if (StoreSize !=
DL.getTypeStoreSize(
B->getType()) || StoreSize > 128)
1580 bool ContainsUndefOrPoisonA =
A->containsUndefOrPoisonElement();
1591 else if (
A->getType() != IntTy)
1597 else if (
B->getType() != IntTy)
1608 return !ContainsUndefOrPoisonA;
1615 if (Alignment > PoolAlignment) PoolAlignment = Alignment;
1620 for (
unsigned i = 0, e = Constants.size(); i != e; ++i)
1621 if (!Constants[i].isMachineConstantPoolEntry() &&
1623 if (Constants[i].
getAlign() < Alignment)
1624 Constants[i].Alignment = Alignment;
1629 return Constants.size()-1;
1634 if (Alignment > PoolAlignment) PoolAlignment = Alignment;
1639 int Idx = V->getExistingMachineCPValue(
this, Alignment);
1641 MachineCPVsSharingEntries.insert(V);
1642 return (
unsigned)Idx;
1646 return Constants.size()-1;
1650 if (Constants.empty())
return;
1652 OS <<
"Constant Pool:\n";
1653 for (
unsigned i = 0, e = Constants.size(); i != e; ++i) {
1654 OS <<
" cp#" << i <<
": ";
1655 if (Constants[i].isMachineConstantPoolEntry())
1656 Constants[i].Val.MachineCPVal->print(OS);
1658 Constants[i].Val.ConstVal->printAsOperand(OS,
false);
1659 OS <<
", align=" << Constants[i].getAlign().value();
1669std::optional<Function::ProfileCount>
1670ProfileSummaryInfo::getEntryCount<llvm::MachineFunction>(
1672 return F->getFunction().getEntryCount();
1675#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
MachineInstrBuilder MachineInstrBuilder & DefMI
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
MachineBasicBlock MachineBasicBlock::iterator MBBI
This file contains the simple types necessary to represent the attributes associated with functions a...
static const Function * getParent(const Value *V)
This file implements the BitVector class.
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
#define LLVM_DUMP_METHOD
Mark debug helper function definitions like dump() that should not be stripped from debug builds.
This file defines the DenseMap class.
This file defines the DenseSet and SmallDenseSet classes.
const HexagonInstrInfo * TII
static MaybeAlign getAlign(Value *Ptr)
Module.h This file contains the declarations for the Module class.
This file declares the MachineConstantPool class which is an abstract constant pool to keep track of ...
static FramePointerKind getFramePointerPolicy(const Function &F)
static cl::opt< unsigned > AlignAllFunctions("align-all-functions", cl::desc("Force the alignment of all functions in log2 format (e.g. 4 " "means align on 16B boundaries)."), cl::init(0), cl::Hidden)
static const MachineInstr * getCallInstr(const MachineInstr *MI)
Return the call machine instruction or find a call within bundle.
static Align getFnStackAlignment(const TargetSubtargetInfo &STI, const Function &F)
static bool CanShareConstantPoolEntry(const Constant *A, const Constant *B, const DataLayout &DL)
Test whether the given two constants can be allocated the same constant pool entry referenced by.
void setUnsafeStackSize(const Function &F, MachineFrameInfo &FrameInfo)
static const char * getPropertyName(MachineFunctionProperties::Property Prop)
Register const TargetRegisterInfo * TRI
static bool isSimple(Instruction *I)
This file defines the SmallString class.
This file defines the SmallVector class.
This file implements the StringSwitch template, which mimics a switch() statement whose cases are str...
static const int BlockSize
This file describes how to lower LLVM code to machine code.
void print(OutputBuffer &OB) const
void clear(AllocatorType &Allocator)
Release all the tracked allocations to the allocator.
Represent a constant reference to an array (0 or more elements consecutively in memory),...
size_t size() const
Get the array size.
Functions, function parameters, and return types can have attributes to indicate how they should be t...
LLVM_ABI StringRef getValueAsString() const
Return the attribute's value as a string.
bool isValid() const
Return true if the attribute is any kind of attribute.
LLVM Basic Block Representation.
LLVM_ABI InstListType::const_iterator getFirstNonPHIIt() const
Returns an iterator to the first instruction in this block that is not a PHINode instruction.
InstListType::const_iterator const_iterator
Base class for all callable instructions (InvokeInst and CallInst) Holds everything related to callin...
LLVM_ABI bool isIndirectCall() const
Return true if the callsite is an indirect call.
This is an important base class in LLVM.
A parsed version of the target data layout string in and methods for querying it.
Align getABIIntegerTypeAlignment(unsigned BitWidth) const
Returns the minimum ABI-required alignment for an integer type of the specified bitwidth.
LLVM_ABI unsigned getPointerSize(unsigned AS=0) const
The pointer representation size in bytes, rounded up to a whole number of bytes.
LLVM_ABI Align getPointerABIAlignment(unsigned AS) const
Layout pointer alignment.
iterator find(const_arg_type_t< KeyT > Val)
DenseMapIterator< KeyT, ValueT, KeyInfoT, BucketT > iterator
Implements a dense probed hash-table based set.
bool hasFnAttribute(Attribute::AttrKind Kind) const
Return true if the function has the attribute.
MDNode * getMetadata(unsigned KindID) const
Get the metadata of given kind attached to this Instruction.
Class to represent integer types.
static LLVM_ABI IntegerType * get(LLVMContext &C, unsigned NumBits)
This static method is the primary way of constructing an IntegerType.
Context object for machine code objects.
Describe properties that are true of each instruction in the target description file.
MCRegisterInfo base class - We assume that the target defines a static array of MCRegisterDesc object...
virtual int64_t getDwarfRegNum(MCRegister Reg, bool isEH) const
Map a target register to an equivalent dwarf register number.
unsigned getNumRegs() const
Return the number of registers this target has (useful for sizing arrays holding per register informa...
Wrapper class representing physical registers. Should be passed by value.
MCSymbol - Instances of this class represent a symbol name in the MC file, and MCSymbols are created ...
const MDOperand & getOperand(unsigned I) const
ArrayRef< MDOperand > operands() const
Tracking metadata reference owned by Metadata.
LLVM_ABI StringRef getString() const
void setIsEndSection(bool V=true)
LLVM_ABI instr_iterator insert(instr_iterator I, MachineInstr *M)
Insert MI into the instruction list before I, possibly inside a bundle.
const BasicBlock * getBasicBlock() const
Return the LLVM basic block that this instance corresponded to originally.
MBBSectionID getSectionID() const
Returns the section ID of this basic block.
LLVM_ABI iterator getFirstNonPHI()
Returns a pointer to the first instruction in this block that is not a PHINode instruction.
Instructions::const_iterator const_instr_iterator
const MachineFunction * getParent() const
Return the MachineFunction containing this basic block.
MachineInstrBundleIterator< MachineInstr > iterator
void setIsBeginSection(bool V=true)
This class is a data container for one entry in a MachineConstantPool.
union llvm::MachineConstantPoolEntry::@004270020304201266316354007027341142157160323045 Val
The constant itself.
LLVM_ABI bool needsRelocation() const
This method classifies the entry according to whether or not it may generate a relocation entry.
bool isMachineConstantPoolEntry() const
isMachineConstantPoolEntry - Return true if the MachineConstantPoolEntry is indeed a target specific ...
LLVM_ABI unsigned getSizeInBytes(const DataLayout &DL) const
LLVM_ABI SectionKind getSectionKind(const DataLayout *DL) const
Abstract base class for all machine specific constantpool value subclasses.
virtual unsigned getSizeInBytes(const DataLayout &DL) const
The MachineConstantPool class keeps track of constants referenced by a function which must be spilled...
LLVM_ABI void dump() const
dump - Call print(cerr) to be called from the debugger.
LLVM_ABI void print(raw_ostream &OS) const
print - Used by the MachineFunction printer to print information about constant pool objects.
LLVM_ABI ~MachineConstantPool()
LLVM_ABI unsigned getConstantPoolIndex(const Constant *C, Align Alignment)
getConstantPoolIndex - Create a new entry in the constant pool or return an existing one.
The MachineFrameInfo class represents an abstract stack frame until prolog/epilog code is inserted.
void setFramePointerPolicy(FramePointerKind Kind)
LLVM_ABI void print(raw_ostream &OS) const
Print the MachineFunctionProperties in human-readable form.
MachineFunctionProperties & reset(Property P)
virtual void MF_HandleRemoval(MachineInstr &MI)=0
Callback before a removal. This should not modify the MI directly.
virtual void MF_HandleInsertion(MachineInstr &MI)=0
Callback after an insertion. This should not modify the MI directly.
int getFilterIDFor(ArrayRef< unsigned > TyIds)
Return the id of the filter encoded by TyIds. This is function wide.
bool UseDebugInstrRef
Flag for whether this function contains DBG_VALUEs (false) or DBG_INSTR_REF (true).
void moveAdditionalCallInfo(const MachineInstr *Old, const MachineInstr *New)
Move the call site info from Old to \New call site info.
std::pair< unsigned, unsigned > DebugInstrOperandPair
Pair of instruction number and operand number.
unsigned addFrameInst(const MCCFIInstruction &Inst)
bool useDebugInstrRef() const
Returns true if the function's variable locations are tracked with instruction referencing.
SmallVector< DebugSubstitution, 8 > DebugValueSubstitutions
Debug value substitutions: a collection of DebugSubstitution objects, recording changes in where a va...
unsigned getFunctionNumber() const
getFunctionNumber - Return a unique ID for the current function.
MCSymbol * getPICBaseSymbol() const
getPICBaseSymbol - Return a function-local symbol to represent the PIC base.
void viewCFGOnly() const
viewCFGOnly - This function is meant for use from the debugger.
ArrayRef< int > allocateShuffleMask(ArrayRef< int > Mask)
void substituteDebugValuesForInst(const MachineInstr &Old, MachineInstr &New, unsigned MaxOperand=UINT_MAX)
Create substitutions for any tracked values in Old, to point at New.
const TargetSubtargetInfo & getSubtarget() const
getSubtarget - Return the subtarget for which this machine code is being compiled.
MachineJumpTableInfo * getOrCreateJumpTableInfo(unsigned JTEntryKind)
getOrCreateJumpTableInfo - Get the JumpTableInfo for this function, if it does already exist,...
StringRef getName() const
getName - Return the name of the corresponding LLVM function.
unsigned getNewDebugInstrNum()
void dump() const
dump - Print the current MachineFunction to cerr, useful for debugger use.
void makeDebugValueSubstitution(DebugInstrOperandPair, DebugInstrOperandPair, unsigned SubReg=0)
Create a substitution between one <instr,operand> value to a different, new value.
MachineMemOperand * getMachineMemOperand(MachinePointerInfo PtrInfo, MachineMemOperand::Flags f, LLT MemTy, Align base_alignment, const AAMDNodes &AAInfo=AAMDNodes(), const MDNode *Ranges=nullptr, SyncScope::ID SSID=SyncScope::System, AtomicOrdering Ordering=AtomicOrdering::NotAtomic, AtomicOrdering FailureOrdering=AtomicOrdering::NotAtomic)
getMachineMemOperand - Allocate a new MachineMemOperand.
MachineFunction(Function &F, const TargetMachine &Target, const TargetSubtargetInfo &STI, MCContext &Ctx, unsigned FunctionNum)
bool needsFrameMoves() const
True if this function needs frame moves for debug or exceptions.
MachineInstr::ExtraInfo * createMIExtraInfo(ArrayRef< MachineMemOperand * > MMOs, MCSymbol *PreInstrSymbol=nullptr, MCSymbol *PostInstrSymbol=nullptr, MDNode *HeapAllocMarker=nullptr, MDNode *PCSections=nullptr, uint32_t CFIType=0, MDNode *MMRAs=nullptr, Value *DS=nullptr)
Allocate and construct an extra info structure for a MachineInstr.
unsigned getTypeIDFor(const GlobalValue *TI)
Return the type id for the specified typeinfo. This is function wide.
void finalizeDebugInstrRefs()
Finalise any partially emitted debug instructions.
void deallocateOperandArray(OperandCapacity Cap, MachineOperand *Array)
Dellocate an array of MachineOperands and recycle the memory.
DenormalMode getDenormalMode(const fltSemantics &FPType) const
Returns the denormal handling type for the default rounding mode of the function.
void initTargetMachineFunctionInfo(const TargetSubtargetInfo &STI)
Initialize the target specific MachineFunctionInfo.
void replaceFrameInstRegister(MCRegister From, MCRegister To)
Replace all references to register.
const char * createExternalSymbolName(StringRef Name)
Allocate a string and populate it with the given external symbol name.
uint32_t * allocateRegMask()
Allocate and initialize a register mask with NumRegister bits.
MCSymbol * getJTISymbol(unsigned JTI, MCContext &Ctx, bool isLinkerPrivate=false) const
getJTISymbol - Return the MCSymbol for the specified non-empty jump table.
void setCallSiteLandingPad(MCSymbol *Sym, ArrayRef< unsigned > Sites)
Map the landing pad's EH symbol to the call site indexes.
void setUseDebugInstrRef(bool UseInstrRef)
Set whether this function will use instruction referencing or not.
LandingPadInfo & getOrCreateLandingPadInfo(MachineBasicBlock *LandingPad)
Find or create an LandingPadInfo for the specified MachineBasicBlock.
MachineRegisterInfo & getRegInfo()
getRegInfo - Return information about the registers currently in use.
const DataLayout & getDataLayout() const
Return the DataLayout attached to the Module associated to this MF.
MCSymbol * addLandingPad(MachineBasicBlock *LandingPad)
Add a new panding pad, and extract the exception handling information from the landingpad instruction...
unsigned DebugInstrNumberingCount
A count of how many instructions in the function have had numbers assigned to them.
void deleteMachineBasicBlock(MachineBasicBlock *MBB)
DeleteMachineBasicBlock - Delete the given MachineBasicBlock.
Align getAlignment() const
getAlignment - Return the alignment of the function.
void handleChangeDesc(MachineInstr &MI, const MCInstrDesc &TID)
static const unsigned int DebugOperandMemNumber
A reserved operand number representing the instructions memory operand, for instructions that have a ...
Function & getFunction()
Return the LLVM function that this machine code represents.
Align getPreferredAlignment() const
Returns the preferred alignment which comes from the function attributes (optsize,...
MachineFunctionInfo * cloneInfoFrom(const MachineFunction &OrigMF, const DenseMap< MachineBasicBlock *, MachineBasicBlock * > &Src2DstMBB)
DebugInstrOperandPair salvageCopySSAImpl(MachineInstr &MI)
const MachineBasicBlock & back() const
BasicBlockListType::iterator iterator
void setDebugInstrNumberingCount(unsigned Num)
Set value of DebugInstrNumberingCount field.
bool shouldSplitStack() const
Should we be emitting segmented stack stuff for the function.
void viewCFG() const
viewCFG - This function is meant for use from the debugger.
bool shouldUseDebugInstrRef() const
Determine whether, in the current machine configuration, we should use instruction referencing or not...
const MachineFunctionProperties & getProperties() const
Get the function properties.
void eraseAdditionalCallInfo(const MachineInstr *MI)
Following functions update call site info.
void RenumberBlocks(MachineBasicBlock *MBBFrom=nullptr)
RenumberBlocks - This discards all of the MachineBasicBlock numbers and recomputes them.
const MachineBasicBlock & front() const
Register addLiveIn(MCRegister PReg, const TargetRegisterClass *RC)
addLiveIn - Add the specified physical register as a live-in value and create a corresponding virtual...
int64_t estimateFunctionSizeInBytes()
Return an estimate of the function's code size, taking into account block and function alignment.
void print(raw_ostream &OS, const SlotIndexes *=nullptr) const
print - Print out the MachineFunction in a format suitable for debugging to the specified stream.
void addInvoke(MachineBasicBlock *LandingPad, MCSymbol *BeginLabel, MCSymbol *EndLabel)
Provide the begin and end labels of an invoke style call and associate it with a try landing pad bloc...
MachineBasicBlock * CreateMachineBasicBlock(const BasicBlock *BB=nullptr, std::optional< UniqueBBID > BBID=std::nullopt)
CreateMachineInstr - Allocate a new MachineInstr.
void copyAdditionalCallInfo(const MachineInstr *Old, const MachineInstr *New)
Copy the call site info from Old to \ New.
VariableDbgInfoMapTy VariableDbgInfos
void assignBeginEndSections()
Assign IsBeginSection IsEndSection fields for basic blocks in this function.
const TargetMachine & getTarget() const
getTarget - Return the target machine this machine code is compiled with
DebugInstrOperandPair salvageCopySSA(MachineInstr &MI, DenseMap< Register, DebugInstrOperandPair > &DbgPHICache)
Find the underlying defining instruction / operand for a COPY instruction while in SSA form.
Representation of each machine instruction.
LLVM_ABI void bundleWithPred()
Bundle this instruction with its predecessor.
bool isCopyLike() const
Return true if the instruction behaves like a copy.
filtered_mop_range all_defs()
Returns an iterator range over all operands that are (explicit or implicit) register defs.
unsigned getNumOperands() const
Retuns the total number of operands.
unsigned peekDebugInstrNum() const
Examine the instruction number of this MachineInstr.
LLVM_ABI unsigned getDebugInstrNum()
Fetch the instruction number of this MachineInstr.
const MachineOperand & getOperand(unsigned i) const
LLVM_ABI bool shouldUpdateAdditionalCallInfo() const
Return true if copying, moving, or erasing this instruction requires updating additional call info (s...
LLVM_ABI bool RemoveMBBFromJumpTables(MachineBasicBlock *MBB)
RemoveMBBFromJumpTables - If MBB is present in any jump tables, remove it.
LLVM_ABI bool ReplaceMBBInJumpTables(MachineBasicBlock *Old, MachineBasicBlock *New)
ReplaceMBBInJumpTables - If Old is the target of any jump tables, update the jump tables to branch to...
LLVM_ABI void print(raw_ostream &OS) const
print - Used by the MachineFunction printer to print information about jump tables.
LLVM_ABI unsigned getEntrySize(const DataLayout &TD) const
getEntrySize - Return the size of each entry in the jump table.
LLVM_ABI unsigned createJumpTableIndex(const std::vector< MachineBasicBlock * > &DestBBs)
createJumpTableIndex - Create a new jump table.
LLVM_ABI void dump() const
dump - Call to stderr.
LLVM_ABI bool ReplaceMBBInJumpTable(unsigned Idx, MachineBasicBlock *Old, MachineBasicBlock *New)
ReplaceMBBInJumpTable - If Old is a target of the jump tables, update the jump table to branch to New...
LLVM_ABI bool updateJumpTableEntryHotness(size_t JTI, MachineFunctionDataHotness Hotness)
JTEntryKind
JTEntryKind - This enum indicates how each entry of the jump table is represented and emitted.
@ EK_GPRel32BlockAddress
EK_GPRel32BlockAddress - Each entry is an address of block, encoded with a relocation as gp-relative,...
@ EK_Inline
EK_Inline - Jump table entries are emitted inline at their point of use.
@ EK_LabelDifference32
EK_LabelDifference32 - Each entry is the address of the block minus the address of the jump table.
@ EK_Custom32
EK_Custom32 - Each entry is a 32-bit value that is custom lowered by the TargetLowering::LowerCustomJ...
@ EK_LabelDifference64
EK_LabelDifference64 - Each entry is the address of the block minus the address of the jump table.
@ EK_BlockAddress
EK_BlockAddress - Each entry is a plain address of block, e.g.: .word LBB123.
@ EK_GPRel64BlockAddress
EK_GPRel64BlockAddress - Each entry is an address of block, encoded with a relocation as gp-relative,...
LLVM_ABI unsigned getEntryAlignment(const DataLayout &TD) const
getEntryAlignment - Return the alignment of each entry in the jump table.
JTEntryKind getEntryKind() const
A description of a memory reference used in the backend.
LocationSize getSize() const
Return the size in bytes of the memory reference.
AtomicOrdering getFailureOrdering() const
For cmpxchg atomic operations, return the atomic ordering requirements when store does not occur.
const PseudoSourceValue * getPseudoValue() const
const MDNode * getRanges() const
Return the range tag for the memory reference.
SyncScope::ID getSyncScopeID() const
Returns the synchronization scope ID for this memory operation.
Flags
Flags values. These may be or'd together.
AtomicOrdering getSuccessOrdering() const
Return the atomic ordering requirements for this memory operation.
const MachinePointerInfo & getPointerInfo() const
Flags getFlags() const
Return the raw flags of the source value,.
AAMDNodes getAAInfo() const
Return the AA tags for the memory reference.
const Value * getValue() const
Return the base address of the memory access.
Align getBaseAlign() const
Return the minimum known alignment in bytes of the base address, without the offset.
int64_t getOffset() const
For normal values, this is a byte offset added to the base address.
MachineOperand class - Representation of each machine instruction operand.
MachineInstr * getParent()
getParent - Return the instruction that this operand belongs to.
static unsigned getRegMaskSize(unsigned NumRegs)
Returns number of elements needed for a regmask array.
Register getReg() const
getReg - Returns the register number.
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.
def_iterator def_begin(Register RegNo) const
LLVM_ABI Register createVirtualRegister(const TargetRegisterClass *RegClass, StringRef Name="")
createVirtualRegister - Create and return a new virtual register in the function with the specified r...
std::vector< std::pair< MCRegister, Register > >::const_iterator livein_iterator
bool hasOneDef(Register RegNo) const
Return true if there is exactly one operand defining the specified register.
LLVM_ABI Register getLiveInVirtReg(MCRegister PReg) const
getLiveInVirtReg - If PReg is a live-in physical register, return the corresponding live-in virtual r...
const TargetRegisterInfo * getTargetRegisterInfo() const
void addLiveIn(MCRegister Reg, Register vreg=Register())
addLiveIn - Add the specified register as a live-in.
Manage lifetime of a slot tracker for printing IR.
void incorporateFunction(const Function &F)
Incorporate the given function.
bool isNull() const
Test if the pointer held in the union is null, regardless of which type it is.
Simple wrapper around std::function<void(raw_ostream&)>.
Wrapper class representing virtual and physical registers.
SectionKind - This is a simple POD value that classifies the properties of a section.
static SectionKind getMergeableConst4()
static SectionKind getReadOnlyWithRel()
static SectionKind getMergeableConst8()
static SectionKind getMergeableConst16()
static SectionKind getReadOnly()
static SectionKind getMergeableConst32()
SmallString - A SmallString is just a SmallVector with methods and accessors that make it work better...
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
Represent a constant reference to a string, i.e.
A switch()-like statement whose cases are string literals.
StringSwitch & Case(StringLiteral S, T Value)
bool isStackRealignable() const
isStackRealignable - This method returns whether the stack can be realigned.
Align getStackAlign() const
getStackAlignment - This method returns the number of bytes to which the stack pointer must be aligne...
TargetInstrInfo - Interface to description of machine instruction set.
Align getMinFunctionAlignment() const
Return the minimum function alignment.
Primary interface to the complete machine description for the target machine.
unsigned ForceDwarfFrameSection
Emit DWARF debug frame section.
bool contains(Register Reg) const
Return true if the specified register is included in this register class.
bool hasSubClassEq(const TargetRegisterClass *RC) const
Returns true if RC is a sub-class of or equal to this class.
TargetRegisterInfo base class - We assume that the target defines a static array of TargetRegisterDes...
TargetSubtargetInfo - Generic base class for all target subtargets.
virtual const TargetFrameLowering * getFrameLowering() const
virtual const TargetInstrInfo * getInstrInfo() const
virtual const TargetRegisterInfo * getRegisterInfo() const =0
Return the target's register information.
virtual const TargetLowering * getTargetLowering() const
Target - Wrapper for Target specific information.
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
The instances of the Type class are immutable: once they are created, they are never changed.
static LLVM_ABI IntegerType * getInt64Ty(LLVMContext &C)
A Use represents the edge between a Value definition and its users.
LLVM Value Representation.
LLVMContext & getContext() const
All values hold a context through their type.
LLVM_ABI const Value * stripPointerCasts() const
Strip off pointer casts, all-zero GEPs and address space casts.
LLVM_ABI StringRef getName() const
Return a constant reference to the value's name.
self_iterator getIterator()
iterator erase(iterator where)
This class implements an extremely fast bulk output stream that can only output to a stream.
A raw_ostream that writes to an std::string.
A raw_ostream that writes to an SmallVector or SmallString.
#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.
@ C
The default llvm calling convention, compatible with C.
initializer< Ty > init(const Ty &Val)
std::enable_if_t< detail::IsValidPointer< X, Y >::value, X * > extract(Y &&MD)
Extract a Value from Metadata.
uint64_t MD5Hash(const FunctionId &Obj)
This is an optimization pass for GlobalISel generic memory operations.
MachineBasicBlock::instr_iterator getBundleStart(MachineBasicBlock::instr_iterator I)
Returns an iterator to the first instruction in the bundle containing I.
MachineInstrBuilder BuildMI(MachineFunction &MF, const MIMetadata &MIMD, const MCInstrDesc &MCID)
Builder interface. Specify how to create the initial instruction itself.
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
iterator_range< T > make_range(T x, T y)
Convenience function for iterating over sub-ranges.
void append_range(Container &C, Range &&R)
Wrapper function to append range R to container C.
LLVM_ABI Printable printJumpTableEntryReference(unsigned Idx)
Prints a jump table entry reference.
MachineFunctionDataHotness
auto dyn_cast_or_null(const Y &Val)
auto formatv(bool Validate, const char *Fmt, Ts &&...Vals)
auto reverse(ContainerTy &&C)
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
LLVM_ABI void report_fatal_error(Error Err, bool gen_crash_diag=true)
MachineBasicBlock::instr_iterator getBundleEnd(MachineBasicBlock::instr_iterator I)
Returns an iterator pointing beyond the bundle containing I.
constexpr uint64_t alignTo(uint64_t Size, Align A)
Returns a multiple of A needed to store Size bytes.
LLVM_ABI Constant * ConstantFoldCastOperand(unsigned Opcode, Constant *C, Type *DestTy, const DataLayout &DL)
Attempt to constant fold a cast with the specified operand.
LLVM_ABI EHPersonality classifyEHPersonality(const Value *Pers)
See if the given exception handling personality function is one that we understand.
bool isa(const From &Val)
isa<X> - Return true if the parameter to the template is an instance of one of the template type argu...
LLVM_ABI raw_fd_ostream & errs()
This returns a reference to a raw_ostream for standard error.
AtomicOrdering
Atomic ordering for LLVM's memory model.
bool isFuncletEHPersonality(EHPersonality Pers)
Returns true if this is a personality function that invokes handler funclets (which must return to it...
DWARFExpression::Operation Op
void ViewGraph(const GraphType &G, const Twine &Name, bool ShortNames=false, const Twine &Title="", GraphProgram::Name Program=GraphProgram::DOT)
ViewGraph - Emit a dot graph, run 'dot', run gv on the postscript file, then cleanup.
OutputIt copy(R &&Range, OutputIt Out)
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
Align commonAlignment(Align A, uint64_t Offset)
Returns the alignment that satisfies both alignments.
LLVM_ABI Printable printReg(Register Reg, const TargetRegisterInfo *TRI=nullptr, unsigned SubIdx=0, const MachineRegisterInfo *MRI=nullptr)
Prints virtual and physical registers with or without a TRI instance.
LLVM_ABI Printable printMBBReference(const MachineBasicBlock &MBB)
Prints a machine basic block reference.
bool debuginfoShouldUseDebugInstrRef(const Triple &T)
A collection of metadata nodes that might be associated with a memory access used by the alias-analys...
This struct is a compact representation of a valid (non-zero power of two) alignment.
constexpr uint64_t value() const
This is a hole in the type system and should not be abused.
std::string getNodeLabel(const MachineBasicBlock *Node, const MachineFunction *Graph)
DOTGraphTraits(bool isSimple=false)
static std::string getGraphName(const MachineFunction *F)
DOTGraphTraits - Template class that can be specialized to customize how graphs are converted to 'dot...
DefaultDOTGraphTraits(bool simple=false)
Represent subnormal handling kind for floating point instruction inputs and outputs.
This structure is used to retain landing pad info for the current function.
SmallVector< MCSymbol *, 1 > EndLabels
MCSymbol * LandingPadLabel
MachineBasicBlock * LandingPadBlock
SmallVector< MCSymbol *, 1 > BeginLabels
std::vector< int > TypeIds
MachineFunctionInfo - This class can be derived from and used by targets to hold private target-speci...
virtual ~MachineFunctionInfo()
virtual MachineFunctionInfo * clone(BumpPtrAllocator &Allocator, MachineFunction &DestMF, const DenseMap< MachineBasicBlock *, MachineBasicBlock * > &Src2DstMBB) const
Make a functionally equivalent copy of this MachineFunctionInfo in MF.
SmallVector< ConstantInt *, 4 > CalleeTypeIds
Callee type ids.
MDNode * CallTarget
'call_target' metadata for the DISubprogram.
MachineJumpTableEntry - One jump table in the jump table info.
LLVM_ABI MachineJumpTableEntry(const std::vector< MachineBasicBlock * > &M)
std::vector< MachineBasicBlock * > MBBs
MBBs - The vector of basic blocks from which to create the jump table.
MachineFunctionDataHotness Hotness
The hotness of MJTE is inferred from the hotness of the source basic block(s) that reference it.
This class contains a discriminated union of information about pointers in memory operands,...
PointerUnion< const Value *, const PseudoSourceValue * > V
This is the IR pointer value for the access, or it is null if unknown.
MachinePointerInfo getWithOffset(int64_t O) const
This struct is a compact representation of a valid (power of two) or undefined (0) alignment.
static void deleteNode(NodeTy *V)