44#include "llvm/Config/llvm-config.h"
66#define DEBUG_TYPE "stack-coloring"
81 cl::desc(
"Do not optimize lifetime zones that "
91 cl::desc(
"Treat stack lifetimes as starting on first use, not on START marker."));
94STATISTIC(NumMarkerSeen,
"Number of lifetime markers found.");
95STATISTIC(StackSpaceSaved,
"Number of bytes saved due to merging slots.");
96STATISTIC(StackSlotMerged,
"Number of stack slot merged.");
97STATISTIC(EscapedAllocas,
"Number of allocas that escaped the lifetime region");
387 struct BlockLifetimeInfo {
402 using LivenessMap = DenseMap<const MachineBasicBlock *, BlockLifetimeInfo>;
403 LivenessMap BlockLiveness;
406 DenseMap<const MachineBasicBlock *, int> BasicBlocks;
422 SlotIndexes *Indexes =
nullptr;
426 SmallVector<MachineInstr*, 8> Markers;
430 BitVector InterestingSlots;
434 BitVector ConservativeSlots;
437 unsigned NumIterations;
440 StackColoring(SlotIndexes *Indexes) : Indexes(Indexes) {}
441 bool run(MachineFunction &Func,
bool OnlyRemoveMarkers =
false);
445 using BlockBitVecMap = DenseMap<const MachineBasicBlock *, BitVector>;
449 void dumpIntervals()
const;
450 void dumpBB(MachineBasicBlock *
MBB)
const;
451 void dumpBV(
const char *tag,
const BitVector &BV)
const;
455 bool removeAllMarkers();
460 unsigned collectMarkers(
unsigned NumSlot);
466 void calculateLocalLiveness();
470 bool applyFirstUse(
int Slot) {
473 if (ConservativeSlots.test(Slot))
483 bool isLifetimeStartOrEnd(
const MachineInstr &
MI,
484 SmallVector<int, 4> &
slots,
488 void calculateLiveIntervals(
unsigned NumSlots);
492 void remapInstructions(DenseMap<int, int> &SlotRemap);
500 void removeInvalidSlotRanges();
504 void expungeSlotMap(DenseMap<int, int> &SlotRemap,
unsigned NumSlots);
511 StackColoringLegacy() : MachineFunctionPass(ID) {}
513 void getAnalysisUsage(AnalysisUsage &AU)
const override;
514 bool runOnMachineFunction(MachineFunction &Func)
override;
519char StackColoringLegacy::ID = 0;
524 "Merge disjoint stack slots",
false,
false)
529void StackColoringLegacy::getAnalysisUsage(
AnalysisUsage &AU)
const {
534#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
537 dbgs() << tag <<
" : { ";
538 for (
unsigned I = 0,
E = BV.
size();
I !=
E; ++
I)
544 LivenessMap::const_iterator BI = BlockLiveness.find(
MBB);
545 assert(BI != BlockLiveness.end() &&
"Block not found");
546 const BlockLifetimeInfo &BlockInfo = BI->second;
548 dumpBV(
"BEGIN", BlockInfo.Begin);
549 dumpBV(
"END", BlockInfo.End);
550 dumpBV(
"LIVE_IN", BlockInfo.LiveIn);
551 dumpBV(
"LIVE_OUT", BlockInfo.LiveOut);
563 for (
unsigned I = 0,
E = Intervals.
size();
I !=
E; ++
I) {
564 dbgs() <<
"Interval[" <<
I <<
"]:\n";
565 Intervals[
I]->dump();
572 assert((
MI.getOpcode() == TargetOpcode::LIFETIME_START ||
573 MI.getOpcode() == TargetOpcode::LIFETIME_END) &&
574 "Expected LIFETIME_START or LIFETIME_END op");
586bool StackColoring::isLifetimeStartOrEnd(
const MachineInstr &
MI,
587 SmallVector<int, 4> &
slots,
589 if (
MI.getOpcode() == TargetOpcode::LIFETIME_START ||
590 MI.getOpcode() == TargetOpcode::LIFETIME_END) {
594 if (!InterestingSlots.
test(Slot))
596 slots.push_back(Slot);
597 if (
MI.getOpcode() == TargetOpcode::LIFETIME_END) {
601 if (!applyFirstUse(Slot)) {
606 if (!
MI.isDebugInstr()) {
608 for (
const MachineOperand &MO :
MI.operands()) {
611 int Slot = MO.getIndex();
614 if (InterestingSlots.
test(Slot) && applyFirstUse(Slot)) {
615 slots.push_back(Slot);
628unsigned StackColoring::collectMarkers(
unsigned NumSlot) {
629 unsigned MarkersFound = 0;
630 BlockBitVecMap SeenStartMap;
631 InterestingSlots.
clear();
632 InterestingSlots.
resize(NumSlot);
633 ConservativeSlots.
clear();
634 ConservativeSlots.
resize(NumSlot);
637 SmallVector<int, 8> NumStartLifetimes(NumSlot, 0);
638 SmallVector<int, 8> NumEndLifetimes(NumSlot, 0);
646 BitVector BetweenStartEnd;
647 BetweenStartEnd.
resize(NumSlot);
649 BlockBitVecMap::const_iterator
I = SeenStartMap.find(Pred);
650 if (
I != SeenStartMap.end()) {
651 BetweenStartEnd |=
I->second;
656 for (MachineInstr &
MI : *
MBB) {
657 if (
MI.isDebugInstr())
659 if (
MI.getOpcode() == TargetOpcode::LIFETIME_START ||
660 MI.getOpcode() == TargetOpcode::LIFETIME_END) {
664 InterestingSlots.
set(Slot);
665 if (
MI.getOpcode() == TargetOpcode::LIFETIME_START) {
666 BetweenStartEnd.
set(Slot);
667 NumStartLifetimes[
Slot] += 1;
669 BetweenStartEnd.
reset(Slot);
670 NumEndLifetimes[
Slot] += 1;
680 <<
" with allocation: " << Allocation->
getName() <<
"\n");
685 for (
const MachineOperand &MO :
MI.operands()) {
688 int Slot = MO.getIndex();
691 if (! BetweenStartEnd.
test(Slot)) {
692 ConservativeSlots.
set(Slot);
697 BitVector &SeenStart = SeenStartMap[
MBB];
698 SeenStart |= BetweenStartEnd;
706 for (
unsigned slot = 0; slot < NumSlot; ++slot) {
707 if (NumStartLifetimes[slot] > 1 || NumEndLifetimes[slot] > 1)
708 ConservativeSlots.
set(slot);
716 for (WinEHTryBlockMapEntry &TBME : EHInfo->TryBlockMap)
718 if (
H.CatchObj.FrameIndex != std::numeric_limits<int>::max() &&
719 H.CatchObj.FrameIndex >= 0)
720 ConservativeSlots.
set(
H.CatchObj.FrameIndex);
725 ConservativeSlots.
set();
727 LLVM_DEBUG(dumpBV(
"Conservative slots", ConservativeSlots));
735 BasicBlocks[
MBB] = BasicBlockNumbering.
size();
739 BlockLifetimeInfo &BlockInfo = BlockLiveness[
MBB];
741 BlockInfo.Begin.resize(NumSlot);
742 BlockInfo.End.resize(NumSlot);
744 SmallVector<int, 4>
slots;
745 for (MachineInstr &
MI : *
MBB) {
746 bool isStart =
false;
748 if (isLifetimeStartOrEnd(
MI,
slots, isStart)) {
750 assert(
slots.size() == 1 &&
"unexpected: MI ends multiple slots");
752 if (BlockInfo.Begin.test(Slot)) {
753 BlockInfo.Begin.reset(Slot);
755 BlockInfo.End.set(Slot);
757 for (
auto Slot :
slots) {
765 <<
" with allocation: " << Allocation->
getName());
768 if (BlockInfo.End.test(Slot)) {
769 BlockInfo.End.reset(Slot);
771 BlockInfo.Begin.set(Slot);
779 NumMarkerSeen += MarkersFound;
783void StackColoring::calculateLocalLiveness() {
784 unsigned NumIters = 0;
788 BitVector LocalLiveIn;
789 BitVector LocalLiveOut;
794 for (
const MachineBasicBlock *BB : BasicBlockNumbering) {
796 LivenessMap::iterator BI = BlockLiveness.find(BB);
797 assert(BI != BlockLiveness.end() &&
"Block not found");
798 BlockLifetimeInfo &BlockInfo = BI->second;
802 for (MachineBasicBlock *Pred : BB->predecessors()) {
803 LivenessMap::const_iterator
I = BlockLiveness.find(Pred);
807 if (
I != BlockLiveness.end())
808 LocalLiveIn |=
I->second.LiveOut;
818 LocalLiveOut = LocalLiveIn;
819 LocalLiveOut.
reset(BlockInfo.End);
820 LocalLiveOut |= BlockInfo.Begin;
823 if (!LocalLiveIn.
subsetOf(BlockInfo.LiveIn)) {
825 BlockInfo.LiveIn |= LocalLiveIn;
829 if (!LocalLiveOut.
subsetOf(BlockInfo.LiveOut)) {
831 BlockInfo.LiveOut |= LocalLiveOut;
836 NumIterations = NumIters;
839void StackColoring::calculateLiveIntervals(
unsigned NumSlots) {
845 for (
const MachineBasicBlock &
MBB : *MF) {
848 DefinitelyInUse.
clear();
849 DefinitelyInUse.
resize(NumSlots);
852 BlockLifetimeInfo &MBBLiveness = BlockLiveness[&
MBB];
853 for (
int pos = MBBLiveness.LiveIn.find_first(); pos != -1;
854 pos = MBBLiveness.LiveIn.find_next(pos)) {
859 for (
const MachineInstr &
MI :
MBB) {
860 SmallVector<int, 4>
slots;
861 bool IsStart =
false;
862 if (!isLifetimeStartOrEnd(
MI,
slots, IsStart))
865 for (
auto Slot :
slots) {
870 if (!DefinitelyInUse[Slot]) {
872 DefinitelyInUse[
Slot] =
true;
875 Starts[
Slot] = ThisIndex;
878 VNInfo *VNI = Intervals[
Slot]->getValNumInfo(0);
879 Intervals[
Slot]->addSegment(
880 LiveInterval::Segment(Starts[Slot], ThisIndex, VNI));
881 Starts[
Slot] = SlotIndex();
882 DefinitelyInUse[
Slot] =
false;
889 for (
unsigned i = 0; i < NumSlots; ++i) {
894 VNInfo *VNI = Intervals[i]->getValNumInfo(0);
895 Intervals[i]->addSegment(LiveInterval::Segment(Starts[i], EndIdx, VNI));
900bool StackColoring::removeAllMarkers() {
903 MI->eraseFromParent();
912void StackColoring::remapInstructions(DenseMap<int, int> &SlotRemap) {
913 unsigned FixedInstr = 0;
914 unsigned FixedMemOp = 0;
915 unsigned FixedDbg = 0;
918 for (
auto &VI : MF->getVariableDbgInfo()) {
919 if (!
VI.Var || !
VI.inStackSlot())
921 int Slot =
VI.getStackSlot();
922 if (
auto It = SlotRemap.
find(Slot); It != SlotRemap.
end()) {
925 VI.updateStackSlot(It->second);
931 DenseMap<const AllocaInst*, const AllocaInst*> Allocas;
934 SmallPtrSet<const AllocaInst*, 32> MergedAllocas;
936 for (
const std::pair<int, int> &SI : SlotRemap) {
939 assert(To && From &&
"Invalid allocation object");
945 const_cast<AllocaInst *
>(To)->moveBefore(
946 const_cast<AllocaInst *
>(From)->getIterator());
956 BitCastInst *Cast =
new BitCastInst(Inst, From->
getType());
962 MergedAllocas.
insert(From);
979 AllocaInst *FromAI =
const_cast<AllocaInst *
>(From);
982 for (
auto &Use : FromAI->
uses()) {
984 if (BCI->isUsedByMetadata())
995 std::vector<std::vector<MachineMemOperand *>> SSRefs(
997 for (MachineBasicBlock &BB : *MF)
998 for (MachineInstr &
I : BB) {
1000 if (
I.getOpcode() == TargetOpcode::LIFETIME_START ||
1001 I.getOpcode() == TargetOpcode::LIFETIME_END)
1005 for (MachineMemOperand *MMO :
I.memoperands()) {
1012 auto It = Allocas.
find(AI);
1013 if (It == Allocas.
end())
1016 MMO->setValue(It->second);
1021 for (MachineOperand &MO :
I.operands()) {
1024 int FromSlot = MO.getIndex();
1031 if (!SlotRemap.count(FromSlot))
1042 bool TouchesMemory =
I.mayLoadOrStore();
1047 const LiveInterval *
Interval = &*Intervals[FromSlot];
1049 "Found instruction usage outside of live range.");
1054 int ToSlot = SlotRemap[FromSlot];
1055 MO.setIndex(ToSlot);
1061 bool ReplaceMemOps =
false;
1062 for (MachineMemOperand *MMO :
I.memoperands()) {
1066 MMO->getPseudoValue())) {
1067 int FI = FSV->getFrameIndex();
1068 auto To = SlotRemap.find(FI);
1069 if (To != SlotRemap.end())
1070 SSRefs[FI].push_back(MMO);
1075 bool MayHaveConflictingAAMD =
false;
1076 if (MMO->getAAInfo()) {
1077 if (
const Value *MMOV = MMO->getValue()) {
1078 SmallVector<Value *, 4> Objs;
1082 MayHaveConflictingAAMD =
true;
1084 for (
Value *V : Objs) {
1089 if (AI && MergedAllocas.
count(AI)) {
1090 MayHaveConflictingAAMD =
true;
1096 if (MayHaveConflictingAAMD) {
1097 NewMMOs.
push_back(MF->getMachineMemOperand(MMO, AAMDNodes()));
1098 ReplaceMemOps =
true;
1107 I.setMemRefs(*MF, NewMMOs);
1112 if (!
E.value().empty()) {
1113 const PseudoSourceValue *NewSV =
1114 MF->getPSVManager().getFixedStack(SlotRemap.find(
E.index())->second);
1115 for (MachineMemOperand *
Ref :
E.value())
1116 Ref->setValue(NewSV);
1120 if (WinEHFuncInfo *EHInfo = MF->getWinEHFuncInfo())
1121 for (WinEHTryBlockMapEntry &TBME : EHInfo->TryBlockMap)
1123 if (
H.CatchObj.FrameIndex != std::numeric_limits<int>::max())
1124 if (
auto It = SlotRemap.find(
H.CatchObj.FrameIndex);
1125 It != SlotRemap.end())
1126 H.CatchObj.FrameIndex = It->second;
1128 LLVM_DEBUG(
dbgs() <<
"Fixed " << FixedMemOp <<
" machine memory operands.\n");
1129 LLVM_DEBUG(
dbgs() <<
"Fixed " << FixedDbg <<
" debug locations.\n");
1130 LLVM_DEBUG(
dbgs() <<
"Fixed " << FixedInstr <<
" machine instructions.\n");
1136void StackColoring::removeInvalidSlotRanges() {
1137 for (MachineBasicBlock &BB : *MF)
1138 for (MachineInstr &
I : BB) {
1139 if (
I.getOpcode() == TargetOpcode::LIFETIME_START ||
1140 I.getOpcode() == TargetOpcode::LIFETIME_END ||
I.isDebugInstr())
1149 if (!
I.mayLoad() && !
I.mayStore())
1153 for (
const MachineOperand &MO :
I.operands()) {
1157 int Slot = MO.getIndex();
1162 if (Intervals[Slot]->
empty())
1178void StackColoring::expungeSlotMap(DenseMap<int, int> &SlotRemap,
1179 unsigned NumSlots) {
1181 for (
unsigned i=0; i < NumSlots; ++i) {
1183 if (
auto It = SlotRemap.
find(i); It != SlotRemap.
end()) {
1187 auto It = SlotRemap.
find(Target);
1188 if (It == SlotRemap.
end())
1197bool StackColoringLegacy::runOnMachineFunction(MachineFunction &MF) {
1198 StackColoring SC(&getAnalysis<SlotIndexesWrapperPass>().getSI());
1199 return SC.run(MF, skipFunction(MF.
getFunction()));
1210bool StackColoring::run(
MachineFunction &Func,
bool OnlyRemoveMarkers) {
1212 <<
"********** Function: " << Func.getName() <<
'\n');
1215 BlockLiveness.clear();
1216 BasicBlocks.
clear();
1217 BasicBlockNumbering.clear();
1221 VNInfoAllocator.Reset();
1230 SortedSlots.
reserve(NumSlots);
1232 LiveStarts.
resize(NumSlots);
1234 unsigned NumMarkers = collectMarkers(NumSlots);
1236 unsigned TotalSize = 0;
1237 LLVM_DEBUG(
dbgs() <<
"Found " << NumMarkers <<
" markers and " << NumSlots
1247 LLVM_DEBUG(
dbgs() <<
"Total Stack size: " << TotalSize <<
" bytes\n\n");
1253 OnlyRemoveMarkers) {
1255 return removeAllMarkers();
1258 for (
unsigned i=0; i < NumSlots; ++i) {
1259 std::unique_ptr<LiveInterval> LI(
new LiveInterval(i, 0));
1260 LI->getNextValue(Indexes->
getZeroIndex(), VNInfoAllocator);
1266 calculateLocalLiveness();
1267 LLVM_DEBUG(
dbgs() <<
"Dataflow iterations: " << NumIterations <<
"\n");
1271 calculateLiveIntervals(NumSlots);
1277 removeInvalidSlotRanges();
1280 DenseMap<int, int> SlotRemap;
1281 unsigned RemovedSlots = 0;
1282 unsigned ReducedSize = 0;
1285 for (
unsigned I = 0;
I < NumSlots; ++
I) {
1286 if (Intervals[SortedSlots[
I]]->
empty())
1287 SortedSlots[
I] = -1;
1308 for (
auto &s : LiveStarts)
1314 for (
unsigned I = 0;
I < NumSlots; ++
I) {
1315 if (SortedSlots[
I] == -1)
1318 for (
unsigned J=
I+1; J < NumSlots; ++J) {
1319 if (SortedSlots[J] == -1)
1322 int FirstSlot = SortedSlots[
I];
1323 int SecondSlot = SortedSlots[J];
1329 LiveInterval *
First = &*Intervals[FirstSlot];
1330 LiveInterval *Second = &*Intervals[SecondSlot];
1331 auto &FirstS = LiveStarts[FirstSlot];
1332 auto &SecondS = LiveStarts[SecondSlot];
1337 if (!
First->isLiveAtIndexes(SecondS) &&
1340 First->MergeSegmentsInAsValue(*Second,
First->getValNumInfo(0));
1342 int OldSize = FirstS.size();
1343 FirstS.append(SecondS.begin(), SecondS.end());
1344 auto Mid = FirstS.begin() + OldSize;
1345 std::inplace_merge(FirstS.begin(), Mid, FirstS.end());
1347 SlotRemap[SecondSlot] = FirstSlot;
1348 SortedSlots[J] = -1;
1350 << SecondSlot <<
" together.\n");
1356 "Merging a small object into a larger one");
1368 StackSpaceSaved += ReducedSize;
1369 StackSlotMerged += RemovedSlots;
1370 LLVM_DEBUG(
dbgs() <<
"Merge " << RemovedSlots <<
" slots. Saved "
1371 << ReducedSize <<
" bytes\n");
1375 if (!SlotRemap.
empty()) {
1376 expungeSlotMap(SlotRemap, NumSlots);
1377 remapInstructions(SlotRemap);
1380 return removeAllMarkers();
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file implements the BitVector class.
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
#define LLVM_DUMP_METHOD
Mark debug helper function definitions like dump() that should not be stripped from debug builds.
This file contains the declarations for the subclasses of Constant, which represent the different fla...
This file defines the DenseMap class.
This file builds on the ADT/GraphTraits.h file to build generic depth first graph iterator.
This defines the Use class.
std::pair< uint64_t, uint64_t > Interval
#define INITIALIZE_PASS_DEPENDENCY(depName)
#define INITIALIZE_PASS_END(passName, arg, name, cfg, analysis)
#define INITIALIZE_PASS_BEGIN(passName, arg, name, cfg, analysis)
static bool isValid(const char C)
Returns true if C is a valid mangled character: <0-9a-zA-Z_>.
This file defines the SmallPtrSet class.
This file defines the SmallVector class.
static int getStartOrEndSlot(const MachineInstr &MI)
static cl::opt< bool > DisableColoring("no-stack-coloring", cl::init(false), cl::Hidden, cl::desc("Disable stack coloring"))
static cl::opt< bool > ProtectFromEscapedAllocas("protect-from-escaped-allocas", cl::init(false), cl::Hidden, cl::desc("Do not optimize lifetime zones that " "are broken"))
The user may write code that uses allocas outside of the declared lifetime zone.
static cl::opt< bool > LifetimeStartOnFirstUse("stackcoloring-lifetime-start-on-first-use", cl::init(true), cl::Hidden, cl::desc("Treat stack lifetimes as starting on first use, not on START marker."))
Enable enhanced dataflow scheme for lifetime analysis (treat first use of stack slot as start of slot...
Merge disjoint stack slots
This file defines the 'Statistic' class, which is designed to be an easy way to expose various metric...
#define STATISTIC(VARNAME, DESC)
PointerType * getType() const
Overload to return most specific pointer type.
PassT::Result & getResult(IRUnitT &IR, ExtraArgTs... ExtraArgs)
Get the result of an analysis pass for a given IR unit.
Represent the analysis usage information of a pass.
bool test(unsigned Idx) const
Returns true if bit Idx is set.
BitVector & reset()
Reset all bits in the bitvector.
void resize(unsigned N, bool t=false)
Grow or shrink the bitvector.
void clear()
Removes all bits from the bitvector.
BitVector & set()
Set all bits in the bitvector.
size_type size() const
Returns the number of bits in this bitvector.
bool subsetOf(const BitVector &RHS) const
Check if This is a subset of RHS.
iterator find(const_arg_type_t< KeyT > Val)
LLVM_ABI bool comesBefore(const Instruction *Other) const
Given an instruction Other in the same basic block as this instruction, return true if this instructi...
LLVM_ABI void insertAfter(Instruction *InsertPos)
Insert an unlinked instruction into a basic block immediately after the specified instruction.
LLVM_ABI bool isLiveAtIndexes(ArrayRef< SlotIndex > Slots) const
int getNumber() const
MachineBasicBlocks are uniquely numbered at the function level, unless they're not in a MachineFuncti...
iterator_range< pred_iterator > predecessors()
LLVM_ABI StringRef getName() const
Return the name of the corresponding LLVM basic block, or an empty string.
The MachineFrameInfo class represents an abstract stack frame until prolog/epilog code is inserted.
SSPLayoutKind getObjectSSPLayout(int ObjectIdx) const
const AllocaInst * getObjectAllocation(int ObjectIdx) const
Return the underlying Alloca of the specified stack object if it exists.
SSPLayoutKind
Stack Smashing Protection (SSP) rules require that vulnerable stack allocations are located close the...
@ SSPLK_LargeArray
Array or nested array >= SSP-buffer-size.
@ SSPLK_AddrOf
The address of this allocation is exposed and triggered protection.
@ SSPLK_None
Did not trigger a stack protector.
void setObjectSSPLayout(int ObjectIdx, SSPLayoutKind Kind)
Align getObjectAlign(int ObjectIdx) const
Return the alignment of the specified stack object.
int64_t getObjectSize(int ObjectIdx) const
Return the size of the specified object.
void RemoveStackObject(int ObjectIdx)
Remove or mark dead a statically sized stack object.
int getObjectIndexEnd() const
Return one past the maximum frame object index.
uint8_t getStackID(int ObjectIdx) const
void setObjectAlignment(int ObjectIdx, Align Alignment)
setObjectAlignment - Change the alignment of the specified stack object.
MachineFunctionPass - This class adapts the FunctionPass interface to allow convenient creation of pa...
void getAnalysisUsage(AnalysisUsage &AU) const override
getAnalysisUsage - Subclasses that override getAnalysisUsage must call this.
const WinEHFuncInfo * getWinEHFuncInfo() const
getWinEHFuncInfo - Return information about how the current function uses Windows exception handling.
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.
Function & getFunction()
Return the LLVM function that this machine code represents.
Representation of each machine instruction.
MachineOperand class - Representation of each machine instruction operand.
static LLVM_ABI PoisonValue * get(Type *T)
Static factory methods - Return an 'poison' object of the specified type.
A set of analyses that are preserved following a run of a transformation pass.
static PreservedAnalyses all()
Construct a special preserved set that preserves all passes.
LLVM_ABI void print(raw_ostream &os) const
Print this index to the given raw_ostream.
SlotIndex getMBBEndIdx(unsigned Num) const
Returns the index past the last valid index in the given basic block.
SlotIndex getInstructionIndex(const MachineInstr &MI, bool IgnoreBundle=false) const
Returns the base index for the given instruction.
SlotIndex getMBBStartIdx(unsigned Num) const
Returns the first index in the given basic block number.
SlotIndex getZeroIndex()
Returns the zero index for this analysis.
size_type count(ConstPtrType Ptr) const
count - Return 1 if the specified pointer is in the set, 0 otherwise.
std::pair< iterator, bool > insert(PtrType Ptr)
Inserts Ptr if and only if there is no element in the container equal to Ptr.
void reserve(size_type N)
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
BumpPtrAllocator Allocator
LLVM_ABI void replaceAllUsesWith(Value *V)
Change all uses of this to point to a new Value.
bool isUsedByMetadata() const
Return true if there is metadata referencing this value.
iterator_range< use_iterator > uses()
LLVM_ABI StringRef getName() const
Return a constant reference to the value's name.
self_iterator getIterator()
constexpr char Align[]
Key for Kernel::Arg::Metadata::mAlign.
initializer< Ty > init(const Ty &Val)
DXILDebugInfoMap run(Module &M)
NodeAddr< UseNode * > Use
friend class Instruction
Iterator for Instructions in a `BasicBlock.
constexpr size_t MaxAlignment
This is an optimization pass for GlobalISel generic memory operations.
void dump(const SparseBitVector< ElementSize > &LHS, raw_ostream &out)
FunctionAddr VTableAddr Value
void stable_sort(R &&Range)
auto enumerate(FirstRange &&First, RestRanges &&...Rest)
Given two or more input ranges, returns a new range whose values are tuples (A, B,...
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
LLVM_ABI bool getUnderlyingObjectsForCodeGen(const Value *V, SmallVectorImpl< Value * > &Objects)
This is a wrapper around getUnderlyingObjects and adds support for basic ptrtoint+arithmetic+inttoptr...
AnalysisManager< MachineFunction > MachineFunctionAnalysisManager
LLVM_ABI PreservedAnalyses getMachineFunctionPassPreservedAnalyses()
Returns the minimum set of Analyses that all machine function passes must preserve.
auto dyn_cast_or_null(const Y &Val)
void sort(IteratorTy Start, IteratorTy End)
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
FunctionAddr VTableAddr Count
class LLVM_GSL_OWNER SmallVector
Forward declaration of SmallVector so that calculateSmallVectorDefaultInlinedElements can reference s...
@ Ref
The access may reference the value stored in memory.
@ First
Helpers to iterate all locations in the MemoryEffectsBase class.
LLVM_ABI char & StackColoringLegacyID
StackSlotColoring - This pass performs stack coloring and merging.
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
iterator_range< df_iterator< T > > depth_first(const T &G)
LLVM_ABI Printable printMBBReference(const MachineBasicBlock &MBB)
Prints a machine basic block reference.
SmallVector< WinEHHandlerType, 1 > HandlerArray