31#include "llvm/Config/llvm-config.h"
43#define DEBUG_TYPE "codegen"
47 cl::desc(
"When printing machine IR, annotate instructions and blocks with "
48 "SlotIndexes when available"),
52 : BB(
B),
Number(-1), xParent(&MF) {
55 IrrLoopHeaderWeight =
B->getIrrLoopHeaderWeight();
58MachineBasicBlock::~MachineBasicBlock() =
default;
62 if (!CachedMCSymbol) {
79 Suffix = (Suffix +
Twine(
".__part.") +
Twine(SectionID.Number)).str();
81 CachedMCSymbol = Ctx.getOrCreateSymbol(MF->
getName() + Suffix);
85 CachedMCSymbol = Ctx.createBlockSymbol(
90 return CachedMCSymbol;
94 if (!CachedEHContMCSymbol) {
101 return CachedEHContMCSymbol;
105 if (!CachedEndMCSymbol) {
112 return CachedEndMCSymbol;
145 N->getParent()->removeFromMBBNumbering(
N->Number);
147 N->AnalysisNumber = -1;
153 assert(!
N->getParent() &&
"machine instruction already in a basic block");
154 N->setParent(Parent);
160 MF->handleInsertion(*
N);
166 assert(
N->getParent() &&
"machine instruction not in a basic block");
170 MF->handleRemoval(*
N);
171 N->removeRegOperandsFromUseLists(MF->
getRegInfo());
174 N->setParent(
nullptr);
180 instr_iterator
First,
181 instr_iterator
Last) {
182 assert(Parent->getParent() == FromList.Parent->getParent() &&
183 "cannot transfer MachineInstrs between MachineFunctions");
186 if (
this == &FromList)
189 assert(Parent != FromList.Parent &&
"Two lists have the same parent?");
194 First->setParent(Parent);
198 assert(!
MI->getParent() &&
"MI is still in a block!");
199 Parent->getParent()->deleteMachineInstr(
MI);
204 while (
I != E &&
I->isPHI())
206 assert((
I == E || !
I->isInsideBundle()) &&
207 "First non-phi MI cannot be inside a bundle!");
216 while (
I != E && (
I->isPHI() ||
I->isPosition() ||
217 TII->isBasicBlockPrologue(*
I)))
221 assert((
I == E || !
I->isInsideBundle()) &&
222 "First non-phi / non-label instruction is inside a bundle!");
232 while (
I != E && (
I->isPHI() ||
I->isPosition() ||
I->isDebugInstr() ||
233 (SkipPseudoOp &&
I->isPseudoProbe()) ||
234 TII->isBasicBlockPrologue(*
I, Reg)))
238 assert((
I == E || !
I->isInsideBundle()) &&
239 "First non-phi / non-label / non-debug "
240 "instruction is inside a bundle!");
246 while (
I !=
B && ((--
I)->isTerminator() ||
I->isDebugInstr()))
248 while (
I != E && !
I->isTerminator())
255 while (
I !=
B && ((--
I)->isTerminator() ||
I->isDebugInstr()))
257 while (
I != E && !
I->isTerminator())
279 if (
I->isDebugInstr() ||
I->isInsideBundle())
281 if (SkipPseudoOp &&
I->isPseudoProbe())
290 for (
const MachineBasicBlock *Succ :
successors())
300#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
307 for (
const MachineBasicBlock *Succ :
successors()) {
308 if (Succ->isInlineAsmBrIndirectTarget())
322 return LBB->hasName();
328 return LBB->getName();
346 bool IsStandalone)
const {
349 OS <<
"Can't print out MachineBasicBlock because parent MachineFunction"
354 const Module *M =
F.getParent();
357 print(OS, MST, Indexes, IsStandalone);
362 bool IsStandalone)
const {
365 OS <<
"Can't print out MachineBasicBlock because parent MachineFunction"
379 bool HasLineAttributes =
false;
383 if (Indexes) OS <<
'\t';
385 OS <<
"; predecessors: ";
390 HasLineAttributes =
true;
394 if (Indexes) OS <<
'\t';
396 OS.
indent(2) <<
"successors: ";
405 if (!Probs.empty() && IsStandalone) {
421 HasLineAttributes =
true;
425 if (Indexes) OS <<
'\t';
426 OS.
indent(2) <<
"liveins: ";
429 for (
const auto &LI :
liveins()) {
431 if (!LI.LaneMask.all())
434 HasLineAttributes =
true;
437 if (HasLineAttributes)
440 bool IsInBundle =
false;
448 if (IsInBundle && !
MI.isInsideBundle()) {
453 OS.
indent(IsInBundle ? 4 : 2);
454 MI.print(OS, MST, IsStandalone,
false,
false,
467 if (IrrLoopHeaderWeight && IsStandalone) {
468 if (Indexes) OS <<
'\t';
469 OS.
indent(2) <<
"; Irreducible loop header weight: " << *IrrLoopHeaderWeight
493 bool hasAttributes =
false;
502 if (moduleSlotTracker) {
504 }
else if (bb->getParent()) {
511 os <<
"<ir-block badref>";
520 os <<
'.' << bb->getName();
522 hasAttributes =
true;
531 os << (hasAttributes ?
", " :
" (");
532 os <<
"machine-block-address-taken";
533 hasAttributes =
true;
536 os << (hasAttributes ?
", " :
" (");
537 os <<
"ir-block-address-taken ";
539 hasAttributes =
true;
542 os << (hasAttributes ?
", " :
" (");
544 hasAttributes =
true;
547 os << (hasAttributes ?
", " :
" (");
548 os <<
"inlineasm-br-indirect-target";
549 hasAttributes =
true;
552 os << (hasAttributes ?
", " :
" (");
553 os <<
"ehfunclet-entry";
554 hasAttributes =
true;
557 os << (hasAttributes ?
", " :
" (");
558 os <<
"ehscope-entry";
559 hasAttributes =
true;
562 os << (hasAttributes ?
", " :
" (");
564 hasAttributes =
true;
567 os << (hasAttributes ?
", " :
" (");
579 hasAttributes =
true;
582 os << (hasAttributes ?
", " :
" (");
583 os <<
"bb_id " <<
getBBID()->BaseID;
585 os <<
" " <<
getBBID()->CloneID;
586 hasAttributes =
true;
588 if (CallFrameSize != 0) {
589 os << (hasAttributes ?
", " :
" (");
590 os <<
"call-frame-size " << CallFrameSize;
591 hasAttributes =
true;
609 if (
I == LiveIns.end())
612 I->LaneMask &= ~LaneMask;
613 if (
I->LaneMask.none())
627 if (Reg == SRI.getSubReg()) {
628 unsigned SubRegIndex = SRI.getSubRegIndex();
629 LaneBitmask SubRegLaneMask =
TRI->getSubRegIndexLaneMask(SubRegIndex);
640 LiveInVector::iterator LI = LiveIns.begin() + (
I - LiveIns.begin());
641 return LiveIns.erase(LI);
648 return I !=
livein_end() && (
I->LaneMask & LaneMask).any();
657 LiveInVector::const_iterator
I = LiveIns.begin();
658 LiveInVector::const_iterator J;
659 LiveInVector::iterator Out = LiveIns.begin();
660 for (;
I != LiveIns.end(); ++Out,
I = J) {
663 for (J = std::next(
I); J != LiveIns.end() && J->PhysReg == PhysReg; ++J)
664 LaneMask |= J->LaneMask;
665 Out->PhysReg = PhysReg;
666 Out->LaneMask = LaneMask;
668 LiveIns.erase(Out, LiveIns.end());
675 assert(RC &&
"Register class is required");
677 "Only the entry block and landing pads can have physreg live ins");
686 for (;
I != E &&
I->isCopy(); ++
I)
687 if (
I->getOperand(1).getReg() == PhysReg) {
688 Register VirtReg =
I->getOperand(0).getReg();
713 if (TerminatorI ==
MBB.end())
717 return TII->getJumpTableIndex(Terminator);
721 MachineBasicBlock *PreviousLayoutSuccessor) {
730 MachineBasicBlock *
TBB =
nullptr, *FBB =
nullptr;
733 bool B =
TII->analyzeBranch(*
this,
TBB, FBB,
Cond);
735 assert(!
B &&
"UpdateTerminators requires analyzable predecessors!");
741 TII->removeBranch(*
this);
750 if (!PreviousLayoutSuccessor || !
isSuccessor(PreviousLayoutSuccessor) ||
751 PreviousLayoutSuccessor->
isEHPad())
757 TII->insertBranch(*
this, PreviousLayoutSuccessor,
nullptr,
Cond,
DL);
767 if (
TII->reverseBranchCondition(
Cond))
769 TII->removeBranch(*
this);
770 TII->insertBranch(*
this, FBB,
nullptr,
Cond,
DL);
772 TII->removeBranch(*
this);
779 assert(PreviousLayoutSuccessor);
783 if (PreviousLayoutSuccessor ==
TBB) {
787 TII->removeBranch(*
this);
797 if (
TII->reverseBranchCondition(
Cond)) {
800 TII->insertBranch(*
this, PreviousLayoutSuccessor,
nullptr,
Cond,
DL);
803 TII->removeBranch(*
this);
804 TII->insertBranch(*
this, PreviousLayoutSuccessor,
nullptr,
Cond,
DL);
806 TII->removeBranch(*
this);
807 TII->insertBranch(*
this,
TBB, PreviousLayoutSuccessor,
Cond,
DL);
814 for (
auto Prob : Probs)
815 Sum += Prob.getNumerator();
821 "The sum of successors's probabilities exceeds one.");
829 if (!(Probs.empty() && !Successors.empty()))
830 Probs.push_back(Prob);
831 Successors.push_back(Succ);
832 Succ->addPredecessor(
this);
840 Successors.push_back(Succ);
841 Succ->addPredecessor(
this);
845 MachineBasicBlock *New,
846 bool NormalizeSuccProbs) {
848 assert(OldI !=
succ_end() &&
"Old is not a successor of this block!");
850 "New is already a successor of this block!");
858 : *getProbabilityIterator(OldI));
859 if (NormalizeSuccProbs)
864 bool NormalizeSuccProbs) {
871 assert(
I != Successors.end() &&
"Not a current successor!");
875 if (!Probs.empty()) {
876 probability_iterator WI = getProbabilityIterator(
I);
878 if (NormalizeSuccProbs)
882 (*I)->removePredecessor(
this);
883 return Successors.erase(
I);
887 MachineBasicBlock *New) {
906 assert(OldI != E &&
"Old is not a successor of this block");
910 Old->removePredecessor(
this);
911 New->addPredecessor(
this);
918 if (!Probs.empty()) {
919 auto ProbIter = getProbabilityIterator(NewI);
920 if (!ProbIter->isUnknown())
921 *ProbIter += *getProbabilityIterator(OldI);
928 if (!Orig->Probs.empty())
940 assert(
I != Predecessors.
end() &&
"Pred is not a predecessor of this block!");
949 MachineBasicBlock *Succ = *FromMBB->
succ_begin();
953 if (!FromMBB->Probs.empty()) {
954 auto Prob = *FromMBB->Probs.begin();
969 MachineBasicBlock *Succ = *FromMBB->
succ_begin();
970 if (!FromMBB->Probs.empty()) {
971 auto Prob = *FromMBB->Probs.begin();
997 return Successors.
size() == 1 ? Successors[0] :
nullptr;
1001 return Predecessors.
size() == 1 ? Predecessors[0] :
nullptr;
1016 MachineBasicBlock *
TBB =
nullptr, *FBB =
nullptr;
1019 if (
TII->analyzeBranch(*
this,
TBB, FBB,
Cond)) {
1031 if (!
TBB)
return &*Fallthrough;
1037 return &*Fallthrough;
1041 if (
Cond.empty())
return nullptr;
1045 return (FBB ==
nullptr) ? &*Fallthrough :
nullptr;
1058 if (SplitPoint ==
end()) {
1066 if (UpdateLiveIns) {
1097 int JumpTableIndex) {
1098 assert(JumpTableIndex >= 0 &&
"need valid index");
1115 if (Pred == &IgnoreMBB)
1120 if (!
TII.analyzeBranch(*Pred, DummyT, DummyF,
Cond,
1127 if (PredJTI == JumpTableIndex)
1145 : MF(MF), Indexes(Indexes) {
1146 MF.setDelegate(
this);
1150 MF.resetDelegate(
this);
1151 for (
auto MI : Insertions)
1152 Indexes->insertMachineInstrInMaps(*
MI);
1158 Insertions.insert(&
MI);
1162 if (Indexes && !Insertions.remove(&
MI))
1163 Indexes->removeMachineInstrFromMaps(
MI);
1170#define GET_RESULT(RESULT, GETTER, INFIX) \
1173 auto *Wrapper = P->getAnalysisIfAvailable<RESULT##INFIX##WrapperPass>(); \
1174 return Wrapper ? &Wrapper->GETTER() : nullptr; \
1176 return MFAM->getCachedResult<RESULT##Analysis>(*MF); \
1179 assert((
P || MFAM) &&
"Need a way to get analysis results!");
1196 MachineBasicBlock *PrevFallthrough =
getNextNode();
1202 bool ChangedIndirectJump =
false;
1207 ChangedIndirectJump =
true;
1214 auto *LIS = Analyses.
LIS;
1217 else if (Analyses.
SI)
1223 auto *LV = Analyses.
LV;
1230 if (MO.getReg() == 0 || !MO.isKill() || MO.isUndef())
1233 if (Reg.isPhysical() || LV->getVarInfo(Reg).removeKill(
MI)) {
1236 MO.setIsKill(
false);
1246 if (!MO.isReg() || MO.getReg() == 0)
1260 if (Succ == PrevFallthrough)
1261 PrevFallthrough = NMBB;
1262 auto *Indexes = Analyses.
SI;
1263 if (!ChangedIndirectJump) {
1283 TII->insertBranch(*NMBB, Succ,
nullptr,
Cond,
DL);
1290 for (
const auto &LI : Succ->
liveins())
1297 while (!KilledRegs.
empty()) {
1300 if (!(--
I)->addRegisterKilled(Reg,
TRI,
false))
1302 if (Reg.isVirtual())
1303 LV->getVarInfo(Reg).Kills.push_back(&*
I);
1309 if (LiveInSets !=
nullptr)
1310 LV->addNewBlock(NMBB,
this, Succ, *LiveInSets);
1312 LV->addNewBlock(NMBB,
this, Succ);
1326 SlotIndex StartIndex = Indexes->getMBBEndIdx(
this);
1328 SlotIndex EndIndex = Indexes->getMBBEndIdx(NMBB);
1334 I != E &&
I->isPHI(); ++
I) {
1335 for (
unsigned ni = 1, ne =
I->getNumOperands(); ni != ne; ni += 2) {
1336 if (
I->getOperand(ni+1).getMBB() == NMBB) {
1346 "PHI sources should be live out of their predecessors.");
1357 if (PHISrcRegs.
count(Reg) || !LIS->hasInterval(Reg))
1361 if (!LI.
liveAt(PrevIndex))
1367 assert(VNI &&
"LiveInterval should have VNInfo where it is live.");
1371 VNInfo *VNI = SR.getVNInfoAt(PrevIndex);
1378 SR.removeSegment(StartIndex, EndIndex);
1394 if (
MachineLoop *DestLoop = MLI->getLoopFor(Succ)) {
1395 if (TIL == DestLoop) {
1397 DestLoop->addBasicBlockToLoop(NMBB, *MLI);
1398 }
else if (TIL->contains(DestLoop)) {
1400 TIL->addBasicBlockToLoop(NMBB, *MLI);
1401 }
else if (DestLoop->contains(TIL)) {
1403 DestLoop->addBasicBlockToLoop(NMBB, *MLI);
1409 assert(DestLoop->getHeader() == Succ &&
1410 "Should not create irreducible loops!");
1412 P->addBasicBlockToLoop(NMBB, *MLI);
1443 if (!L || L->getHeader() != Succ)
1455 MachineBasicBlock *
TBB =
nullptr, *FBB =
nullptr;
1458 if (
TII->analyzeBranch(*
const_cast<MachineBasicBlock *
>(
this),
TBB, FBB,
Cond,
1467 LLVM_DEBUG(
dbgs() <<
"Won't split critical edge after degenerate "
1478 if (
MI->isBundledWithSucc() && !
MI->isBundledWithPred())
1479 MI->unbundleFromSucc();
1481 if (
MI->isBundledWithPred() && !
MI->isBundledWithSucc())
1482 MI->unbundleFromPred();
1490 return Insts.erase(
I);
1497 return Insts.remove(
MI);
1502 assert(!
MI->isBundledWithPred() && !
MI->isBundledWithSucc() &&
1503 "Cannot insert instruction with bundle flags");
1509 return Insts.insert(
I,
MI);
1529 MachineBasicBlock *New) {
1530 assert(Old != New &&
"Cannot replace self with self!");
1535 if (!
I->isTerminator())
break;
1540 if (MO.isMBB() && MO.getMBB() == Old)
1549 MachineBasicBlock *New) {
1551 for (
unsigned i = 2, e =
MI.getNumOperands() + 1; i != e; i += 2) {
1565 return MBBI->getDebugLoc();
1574 if (!
MBBI->isDebugInstr())
1575 return MBBI->getDebugLoc();
1586 if (!
MBBI->isDebugInstr())
1587 return MBBI->getDebugLoc();
1597 return MBBI->getDebugLoc();
1607 while (TI !=
end() && !TI->isBranch())
1611 DL = TI->getDebugLoc();
1612 for (++TI ; TI !=
end() ; ++TI)
1625 const auto &Prob = *getProbabilityIterator(Succ);
1626 if (!Prob.isUnknown())
1630 unsigned KnownProbNum = 0;
1632 for (
const auto &
P : Probs) {
1633 if (!
P.isUnknown()) {
1638 return Sum.getCompl() / (Probs.size() - KnownProbNum);
1664 *getProbabilityIterator(
I) = Prob;
1668MachineBasicBlock::const_probability_iterator
1669MachineBasicBlock::getProbabilityIterator(
1671 assert(Probs.size() == Successors.size() &&
"Async probability list!");
1672 const size_t index = std::distance(Successors.begin(),
I);
1673 assert(index < Probs.size() &&
"Not a current successor!");
1674 return Probs.begin() + index;
1678MachineBasicBlock::probability_iterator
1680 assert(Probs.size() == Successors.size() &&
"Async probability list!");
1681 const size_t index = std::distance(Successors.begin(),
I);
1682 assert(index < Probs.size() &&
"Not a current successor!");
1683 return Probs.begin() + index;
1695 unsigned Neighborhood)
const {
1696 assert(Reg.isPhysical());
1697 unsigned N = Neighborhood;
1701 for (;
I !=
end() &&
N > 0; ++
I) {
1702 if (
I->isDebugOrPseudoInstr())
1713 if (Info.FullyDefined || Info.Clobbered)
1722 if (
TRI->regsOverlap(LI.PhysReg, Reg))
1740 if (
I->isDebugOrPseudoInstr())
1754 if (!Info.PartialDeadDef)
1763 if (Info.Killed || Info.Clobbered)
1769 }
while (
I !=
begin() &&
N > 0);
1774 while (
I !=
begin() && std::prev(
I)->isDebugOrPseudoInstr())
1781 if (
TRI->regsOverlap(LI.PhysReg, Reg))
1810 std::vector<RegisterMaskPair> &OldLiveIns) {
1811 assert(OldLiveIns.empty() &&
"Vector must be empty");
1817 "Liveness information is accurate");
1818 return LiveIns.begin();
1824 MCRegister ExceptionPointer, ExceptionSelector;
1831 return liveout_iterator(*
this, ExceptionPointer, ExceptionSelector,
false);
1837 for (
auto I = R.begin(), E = R.end();
I != E; ++
I) {
1845 const MachineBasicBlock &PredMBB) {
1847 Phi.removePHIIncomingValueFor(PredMBB);
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
MachineBasicBlock MachineBasicBlock::iterator MBBI
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.
const HexagonInstrInfo * TII
This file implements the LivePhysRegs utility for tracking liveness of physical registers.
#define GET_RESULT(RESULT, GETTER, INFIX)
static bool jumpTableHasOtherUses(const MachineFunction &MF, const MachineBasicBlock &IgnoreMBB, int JumpTableIndex)
static void unbundleSingleMI(MachineInstr *MI)
Prepare MI to be removed from its bundle.
static int findJumpTableIndex(const MachineBasicBlock &MBB)
static cl::opt< bool > PrintSlotIndexes("print-slotindexes", cl::desc("When printing machine IR, annotate instructions and blocks with " "SlotIndexes when available"), cl::init(true), cl::Hidden)
Register const TargetRegisterInfo * TRI
uint64_t IntrinsicInst * II
const SmallVectorImpl< MachineOperand > MachineBasicBlock * TBB
const SmallVectorImpl< MachineOperand > & Cond
static bool isLiveOut(const MachineBasicBlock &MBB, unsigned Reg)
This file describes how to lower LLVM code to machine code.
SlotIndexUpdateDelegate(MachineFunction &MF, SlotIndexes *Indexes)
void MF_HandleRemoval(MachineInstr &MI) override
Callback before a removal. This should not modify the MI directly.
void MF_HandleInsertion(MachineInstr &MI) override
Callback after an insertion. This should not modify the MI directly.
~SlotIndexUpdateDelegate() override
LLVM Basic Block Representation.
static uint32_t getDenominator()
static BranchProbability getUnknown()
uint32_t getNumerator() const
static BranchProbability getZero()
static void normalizeProbabilities(ProbabilityIter Begin, ProbabilityIter End)
LLVM_ABI unsigned getLine() const
static LLVM_ABI DebugLoc getMergedLocation(DebugLoc LocA, DebugLoc LocB)
When two instructions are combined into a single instruction we also need to combine the original loc...
LLVM_ABI unsigned getCol() const
bool hasPersonalityFn() const
Check whether this function has a personality function.
Constant * getPersonalityFn() const
Get the personality function associated with this function.
void splitCriticalEdge(BasicBlockT *FromBB, BasicBlockT *ToBB, BasicBlockT *NewBB)
Apply updates that the critical edge (FromBB, ToBB) has been split with NewBB.
A helper class to return the specified delimiter string after the first invocation of operator String...
LiveInterval - This class represents the liveness of a register, or stack slot.
iterator_range< subrange_iterator > subranges()
void insertMBBInMaps(MachineBasicBlock *MBB)
A set of physical registers with utility functions to track liveness when walking backward/forward th...
LLVM_ABI iterator addSegment(Segment S)
Add the specified Segment to this range, merging segments as appropriate.
bool liveAt(SlotIndex index) const
LLVM_ABI void removeSegment(SlotIndex Start, SlotIndex End, bool RemoveDeadValNo=false)
Remove the specified interval from this live range.
VNInfo * getVNInfoAt(SlotIndex Idx) const
getVNInfoAt - Return the VNInfo that is live at Idx, or NULL.
LoopT * getLoopFor(const BlockT *BB) const
Return the inner most loop that BB lives in.
Context object for machine code objects.
LLVM_ABI MCSymbol * createBlockSymbol(const Twine &Name, bool AlwaysEmit=false)
Get or create a symbol for a basic block.
LLVM_ABI MCSymbol * getOrCreateSymbol(const Twine &Name)
Lookup the symbol inside with the specified Name.
Wrapper class representing physical registers. Should be passed by value.
constexpr bool isPhysical() const
Return true if the specified register number is in the physical register namespace.
Iterator that enumerates the sub-registers of a Reg and the associated sub-register indices.
bool isValid() const
Returns true if this iterator is not yet at the end.
MCSymbol - Instances of this class represent a symbol name in the MC file, and MCSymbols are created ...
bool isInlineAsmBrIndirectTarget() const
Returns true if this is the indirect dest of an INLINEASM_BR.
LLVM_ABI DebugLoc rfindPrevDebugLoc(reverse_instr_iterator MBBI)
Has exact same behavior as findPrevDebugLoc (it also searches towards the beginning of this MBB) exce...
LLVM_ABI void transferSuccessorsAndUpdatePHIs(MachineBasicBlock *FromMBB)
Transfers all the successors, as in transferSuccessors, and update PHI operands in the successor bloc...
LLVM_ABI bool hasEHPadSuccessor() const
void normalizeSuccProbs()
Normalize probabilities of all successors so that the sum of them becomes one.
livein_iterator livein_end() const
LLVM_ABI iterator getFirstTerminatorForward()
Finds the first terminator in a block by scanning forward.
bool isEHPad() const
Returns true if the block is a landing pad.
LLVM_ABI void replacePhiUsesWith(MachineBasicBlock *Old, MachineBasicBlock *New)
Update all phi nodes in this basic block to refer to basic block New instead of basic block Old.
LLVM_ABI MachineInstr * remove_instr(MachineInstr *I)
Remove the possibly bundled instruction from the instruction list without deleting it.
instr_iterator instr_begin()
MachineInstrBundleIterator< const MachineInstr > const_iterator
LLVM_ABI MCSymbol * getSymbol() const
Return the MCSymbol for this basic block.
LLVM_ABI void moveBefore(MachineBasicBlock *NewAfter)
Move 'this' block before or after the specified block.
LLVM_ABI void replaceSuccessor(MachineBasicBlock *Old, MachineBasicBlock *New)
Replace successor OLD with NEW and update probability info.
LLVM_ABI MachineBasicBlock * getFallThrough(bool JumpToFallThrough=true)
Return the fallthrough block if the block can implicitly transfer control to the block after it by fa...
LLVM_ABI void transferSuccessors(MachineBasicBlock *FromMBB)
Transfers all the successors from MBB to this machine basic block (i.e., copies all the successors Fr...
MachineBasicBlock * SplitCriticalEdge(MachineBasicBlock *Succ, Pass &P, std::vector< SparseBitVector<> > *LiveInSets=nullptr, MachineDomTreeUpdater *MDTU=nullptr)
bool hasLabelMustBeEmitted() const
Test whether this block must have its label emitted.
LLVM_ABI instr_iterator insert(instr_iterator I, MachineInstr *M)
Insert MI into the instruction list before I, possibly inside a bundle.
LLVM_ABI BranchProbability getSuccProbability(const_succ_iterator Succ) const
Return probability of the edge from this block to MBB.
iterator_range< livein_iterator > liveins() const
iterator_range< iterator > phis()
Returns a range that iterates over the phis in the basic block.
reverse_instr_iterator instr_rbegin()
int getNumber() const
MachineBasicBlocks are uniquely numbered at the function level, unless they're not in a MachineFuncti...
LLVM_ABI iterator SkipPHIsAndLabels(iterator I)
Return the first instruction in MBB after I that is not a PHI or a label.
LLVM_ABI void addSuccessorWithoutProb(MachineBasicBlock *Succ)
Add Succ as a successor of this MachineBasicBlock.
SmallVectorImpl< MachineBasicBlock * >::const_iterator const_succ_iterator
LLVM_ABI bool hasName() const
Check if there is a name of corresponding LLVM basic block.
void setCallFrameSize(unsigned N)
Set the call frame size on entry to this basic block.
std::optional< UniqueBBID > getBBID() const
const BasicBlock * getBasicBlock() const
Return the LLVM basic block that this instance corresponded to originally.
LLVM_ABI MCSymbol * getEHContSymbol() const
Return the Windows EH Continuation Symbol for this basic block.
LLVM_ABI void splitSuccessor(MachineBasicBlock *Old, MachineBasicBlock *New, bool NormalizeSuccProbs=false)
Split the old successor into old plus new and updates the probability info.
@ PrintNameIr
Add IR name where available.
@ PrintNameAttributes
Print attributes.
LLVM_ABI void updateTerminator(MachineBasicBlock *PreviousLayoutSuccessor)
Update the terminator instructions in block to account for changes to block layout which may have bee...
LLVM_ABI const MachineBasicBlock * getSinglePredecessor() const
Return the predecessor of this block if it has a single predecessor.
LLVM_ABI iterator SkipPHIsLabelsAndDebug(iterator I, Register Reg=Register(), bool SkipPseudoOp=true)
Return the first instruction in MBB after I that is not a PHI, label or debug.
LLVM_ABI bool canFallThrough()
Return true if the block can implicitly transfer control to the block after it by falling off the end...
LLVM_ABI void setSuccProbability(succ_iterator I, BranchProbability Prob)
Set successor probability of a given iterator.
LLVM_ABI iterator getFirstNonDebugInstr(bool SkipPseudoOp=true)
Returns an iterator to the first non-debug instruction in the basic block, or end().
succ_iterator succ_begin()
bool livein_empty() const
LLVM_ABI void removeLiveIn(MCRegister Reg, LaneBitmask LaneMask=LaneBitmask::getAll())
Remove the specified register from the live in set.
LLVM_ABI void printAsOperand(raw_ostream &OS, bool PrintType=true) const
LLVM_ABI void validateSuccProbs() const
Validate successors' probabilities and check if the sum of them is approximate one.
bool isIRBlockAddressTaken() const
Test whether this block is the target of an IR BlockAddress.
LiveInVector::const_iterator livein_iterator
LLVM_ABI MCSymbol * getEndSymbol() const
Returns the MCSymbol marking the end of this basic block.
LLVM_ABI void clearLiveIns()
Clear live in list.
bool isEHFuncletEntry() const
Returns true if this is the entry block of an EH funclet.
LLVM_ABI LivenessQueryResult computeRegisterLiveness(const TargetRegisterInfo *TRI, MCRegister Reg, const_iterator Before, unsigned Neighborhood=10) const
Return whether (physical) register Reg has been defined and not killed as of just before Before.
LLVM_ABI iterator getFirstTerminator()
Returns an iterator to the first terminator instruction of this basic block.
LLVM_ABI livein_iterator livein_begin() const
unsigned succ_size() const
bool isReturnBlock() const
Convenience function that returns true if the block ends in a return instruction.
LLVM_ABI const uint32_t * getBeginClobberMask(const TargetRegisterInfo *TRI) const
Get the clobber mask for the start of this basic block.
LLVM_ABI void removePHIsIncomingValuesForPredecessor(const MachineBasicBlock &PredMBB)
Iterate over block PHI instructions and remove all incoming values for PredMBB.
MBBSectionID getSectionID() const
Returns the section ID of this basic block.
LLVM_ABI void dump() const
bool isEHScopeEntry() const
Returns true if this is the entry block of an EH scope, i.e., the block that used to have a catchpad ...
LLVM_ABI bool isEntryBlock() const
Returns true if this is the entry block of the function.
LLVM_ABI void addSuccessor(MachineBasicBlock *Succ, BranchProbability Prob=BranchProbability::getUnknown())
Add Succ as a successor of this MachineBasicBlock.
LLVM_ABI void copySuccessor(const MachineBasicBlock *Orig, succ_iterator I)
Copy a successor (and any probability info) from original block to this block's.
SmallVectorImpl< MachineBasicBlock * >::iterator succ_iterator
BasicBlock * getAddressTakenIRBlock() const
Retrieves the BasicBlock which corresponds to this MachineBasicBlock.
LLVM_ABI void sortUniqueLiveIns()
Sorts and uniques the LiveIns vector.
LLVM_ABI const MachineBasicBlock * getSingleSuccessor() const
Return the successor of this block if it has a single successor.
LLVM_ABI liveout_iterator liveout_begin() const
Iterator scanning successor basic blocks' liveins to determine the registers potentially live at the ...
LLVM_ABI void removeSuccessor(MachineBasicBlock *Succ, bool NormalizeSuccProbs=false)
Remove successor from the successors list of this MachineBasicBlock.
LLVM_ABI iterator getFirstNonPHI()
Returns a pointer to the first instruction in this block that is not a PHINode instruction.
LLVM_ABI bool isPredecessor(const MachineBasicBlock *MBB) const
Return true if the specified MBB is a predecessor of this block.
bool hasSuccessorProbabilities() const
Return true if any of the successors have probabilities attached to them.
LLVM_ABI DebugLoc rfindDebugLoc(reverse_instr_iterator MBBI)
Has exact same behavior as findDebugLoc (it also searches towards the end of this MBB) except that th...
LLVM_ABI void print(raw_ostream &OS, const SlotIndexes *=nullptr, bool IsStandalone=true) const
reverse_instr_iterator instr_rend()
LLVM_ABI DebugLoc findDebugLoc(instr_iterator MBBI)
Find the next valid DebugLoc starting at MBBI, skipping any debug instructions.
Instructions::iterator instr_iterator
LLVM_ABI iterator getLastNonDebugInstr(bool SkipPseudoOp=true)
Returns an iterator to the last non-debug instruction in the basic block, or end().
LLVM_ABI void ReplaceUsesOfBlockWith(MachineBasicBlock *Old, MachineBasicBlock *New)
Given a machine basic block that branched to 'Old', change the code and CFG so that it branches to 'N...
LLVM_ABI bool isLayoutSuccessor(const MachineBasicBlock *MBB) const
Return true if the specified MBB will be emitted immediately after this block, such that if this bloc...
LLVM_ABI DebugLoc findPrevDebugLoc(instr_iterator MBBI)
Find the previous valid DebugLoc preceding MBBI, skipping any debug instructions.
LLVM_ABI MachineBasicBlock * splitAt(MachineInstr &SplitInst, bool UpdateLiveIns=true, LiveIntervals *LIS=nullptr)
Split a basic block into 2 pieces at SplitPoint.
LLVM_ABI bool canSplitCriticalEdge(const MachineBasicBlock *Succ, const MachineLoopInfo *MLI=nullptr) const
Check if the edge between this block and the given successor Succ, can be split.
LLVM_ABI void eraseFromParent()
This method unlinks 'this' from the containing function and deletes it.
friend class MachineFunction
LLVM_ABI void removeLiveInOverlappedWith(MCRegister Reg)
Remove the specified register from any overlapped live in.
instr_iterator instr_end()
void addLiveIn(MCRegister PhysReg, LaneBitmask LaneMask=LaneBitmask::getAll())
Adds the specified register as a live in.
const MachineFunction * getParent() const
Return the MachineFunction containing this basic block.
LLVM_ABI instr_iterator erase(instr_iterator I)
Remove an instruction from the instruction list and delete it.
LLVM_ABI std::string getFullName() const
Return a formatted string to identify this block and its parent function.
bool isBeginSection() const
Returns true if this block begins any section.
unsigned getCallFrameSize() const
Return the call frame size on entry to this basic block.
LLVM_ABI DebugLoc findBranchDebugLoc()
Find and return the merged DebugLoc of the branch instructions of the block.
iterator_range< succ_iterator > successors()
LLVM_ABI instr_iterator getFirstInstrTerminator()
Same getFirstTerminator but it ignores bundles and return an instr_iterator instead.
reverse_iterator rbegin()
bool isMachineBlockAddressTaken() const
Test whether this block is used as something other than the target of a terminator,...
LLVM_ABI void printName(raw_ostream &os, unsigned printNameFlags=PrintNameIr, ModuleSlotTracker *moduleSlotTracker=nullptr) const
Print the basic block's name as:
LLVM_ABI bool isSuccessor(const MachineBasicBlock *MBB) const
Return true if the specified MBB is a successor of this block.
iterator_range< pred_iterator > predecessors()
void splice(iterator Where, MachineBasicBlock *Other, iterator From)
Take an instruction from MBB 'Other' at the position From, and insert it into this MBB right before '...
Align getAlignment() const
Return alignment of the basic block.
MachineInstrBundleIterator< MachineInstr > iterator
LLVM_ABI bool isLegalToHoistInto() const
Returns true if it is legal to hoist instructions into this block.
LLVM_ABI bool canPredictBranchProbabilities() const
LLVM_ABI StringRef getName() const
Return the name of the corresponding LLVM basic block, or an empty string.
LLVM_ABI bool mayHaveInlineAsmBr() const
Returns true if this block may have an INLINEASM_BR (overestimate, by checking if any of the successo...
LivenessQueryResult
Possible outcome of a register liveness query to computeRegisterLiveness()
@ LQR_Dead
Register is known to be fully dead.
@ LQR_Live
Register is known to be (at least partially) live.
@ LQR_Unknown
Register liveness not decidable from local neighborhood.
LLVM_ABI void moveAfter(MachineBasicBlock *NewBefore)
LLVM_ABI const uint32_t * getEndClobberMask(const TargetRegisterInfo *TRI) const
Get the clobber mask for the end of the basic block.
LLVM_ABI bool sizeWithoutDebugLargerThan(unsigned Limit) const
LLVM_ABI bool isLiveIn(MCRegister Reg, LaneBitmask LaneMask=LaneBitmask::getAll()) const
Return true if the specified register is in the live in set.
LLVM_ABI MachineBasicBlock * removeFromParent()
This method unlinks 'this' from the containing function, and returns it, but does not delete it.
Instructions::reverse_iterator reverse_instr_iterator
unsigned addToMBBNumbering(MachineBasicBlock *MBB)
Adds the MBB to the internal numbering.
unsigned getFunctionNumber() const
getFunctionNumber - Return a unique ID for the current function.
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 hasBBSections() const
Returns true if this function has basic block sections enabled.
MCContext & getContext() const
MachineRegisterInfo & getRegInfo()
getRegInfo - Return information about the registers currently in use.
Function & getFunction()
Return the LLVM function that this machine code represents.
BasicBlockListType::iterator iterator
void remove(iterator MBBI)
unsigned assignAnalysisNumber()
const MachineJumpTableInfo * getJumpTableInfo() const
getJumpTableInfo - Return the jump table info object for the current function.
void splice(iterator InsertPt, iterator MBBI)
MachineBasicBlock * CreateMachineBasicBlock(const BasicBlock *BB=nullptr, std::optional< UniqueBBID > BBID=std::nullopt)
CreateMachineInstr - Allocate a new MachineInstr.
void erase(iterator MBBI)
void insert(iterator MBBI, MachineBasicBlock *MBB)
const TargetMachine & getTarget() const
getTarget - Return the target machine this machine code is compiled with
BasicBlockListType::const_iterator const_iterator
const MachineInstrBuilder & addReg(Register RegNo, RegState Flags={}, unsigned SubReg=0) const
Add a new virtual register operand.
reverse_iterator getReverse() const
Get a reverse iterator to the same node.
Representation of each machine instruction.
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...
const std::vector< MachineJumpTableEntry > & getJumpTables() const
MachineOperand class - Representation of each machine instruction operand.
MachineBasicBlock * getMBB() const
void setMBB(MachineBasicBlock *MBB)
Register getReg() const
getReg - Returns the register number.
MachineRegisterInfo - Keep track of information for virtual and physical registers,...
bool tracksLiveness() const
tracksLiveness - Returns true when tracking register liveness accurately.
LLVM_ABI Register createVirtualRegister(const TargetRegisterClass *RegClass, StringRef Name="")
createVirtualRegister - Create and return a new virtual register in the function with the specified r...
LLVM_ABI const TargetRegisterClass * constrainRegClass(Register Reg, const TargetRegisterClass *RC, unsigned MinNumRegs=0)
constrainRegClass - Constrain the register class of the specified virtual register to be a common sub...
unsigned getNumVirtRegs() const
getNumVirtRegs - Return the number of virtual registers created.
Manage lifetime of a slot tracker for printing IR.
int getLocalSlot(const Value *V)
Return the slot number of the specified local value.
void incorporateFunction(const Function &F)
Incorporate the given function.
A Module instance is used to store all the information related to an LLVM module.
Pass interface - Implemented by all 'passes'.
Simple wrapper around std::function<void(raw_ostream&)>.
Wrapper class representing virtual and physical registers.
static Register index2VirtReg(unsigned Index)
Convert a 0-based index to a virtual register number.
SlotIndex - An opaque wrapper around machine indexes.
SlotIndex getPrevSlot() const
Returns the previous slot in the index list.
void insertMBBInMaps(MachineBasicBlock *mbb)
Add the given MachineBasicBlock into the maps.
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.
bool hasIndex(const MachineInstr &instr) const
Returns true if the given machine instr is mapped to an index, otherwise returns false.
A SetVector that performs no allocations if smaller than a certain size.
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.
SmallString - A SmallString is just a SmallVector with methods and accessors that make it work better...
iterator erase(const_iterator CI)
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
StringRef - Represent a constant reference to a string, i.e.
TargetInstrInfo - Interface to description of machine instruction set.
virtual Register getExceptionPointerRegister(const Constant *PersonalityFn) const
If a physical register, this returns the register that receives the exception address on entry to an ...
virtual Register getExceptionSelectorRegister(const Constant *PersonalityFn) const
If a physical register, this returns the register that receives the exception typeid on entry to a la...
This class defines information used to lower LLVM code to legal SelectionDAG operators that the targe...
bool requiresStructuredCFG() const
TargetRegisterInfo base class - We assume that the target defines a static array of TargetRegisterDes...
virtual const TargetInstrInfo * getInstrInfo() const
virtual const TargetRegisterInfo * getRegisterInfo() const =0
Return the target's register information.
virtual const TargetLowering * getTargetLowering() const
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.
VNInfo - Value Number Information.
LLVM_ABI StringRef getName() const
Return a constant reference to the value's name.
self_iterator getIterator()
MachineBasicBlock * getNextNode()
This class implements an extremely fast bulk output stream that can only output to a stream.
raw_ostream & indent(unsigned NumSpaces)
indent - Insert 'NumSpaces' spaces.
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.
initializer< Ty > init(const Ty &Val)
This is an optimization pass for GlobalISel generic memory operations.
IterT next_nodbg(IterT It, IterT End, bool SkipPseudoOp=true)
Increment It, then continue incrementing it while it points to a debug instruction.
auto find(R &&Range, const T &Val)
Provide wrappers to std::find which take ranges instead of having to pass begin/end explicitly.
MachineInstrBuilder BuildMI(MachineFunction &MF, const MIMetadata &MIMD, const MCInstrDesc &MCID)
Builder interface. Specify how to create the initial instruction itself.
@ Kill
The last use of a register.
iterator_range< T > make_range(T x, T y)
Convenience function for iterating over sub-ranges.
LLVM_ABI PhysRegInfo AnalyzePhysRegInBundle(const MachineInstr &MI, Register Reg, const TargetRegisterInfo *TRI)
AnalyzePhysRegInBundle - Analyze how the current instruction or bundle uses a physical register.
Printable PrintLaneMask(LaneBitmask LaneMask)
Create Printable object to print LaneBitmasks on a raw_ostream.
AnalysisManager< MachineFunction > MachineFunctionAnalysisManager
IterT skipDebugInstructionsForward(IterT It, IterT End, bool SkipPseudoOp=true)
Increment It until it points to a non-debug instruction or to End and return the resulting iterator.
void sort(IteratorTy Start, IteratorTy End)
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
auto instructionsWithoutDebug(IterT It, IterT End, bool SkipPseudoOp=true)
Construct a range iterator which begins at It and moves forwards until End is reached,...
IterT skipDebugInstructionsBackward(IterT It, IterT Begin, bool SkipPseudoOp=true)
Decrement It until it points to a non-debug instruction or to Begin and return the resulting iterator...
format_object< Ts... > format(const char *Fmt, const Ts &... Vals)
These are helper functions used to produce formatted output.
@ First
Helpers to iterate all locations in the MemoryEffectsBase class.
uint16_t MCPhysReg
An unsigned integer type large enough to represent all physical registers, but not necessarily virtua...
PredIterator< BasicBlock, Value::user_iterator > pred_iterator
raw_ostream & operator<<(raw_ostream &OS, const APFixedPoint &FX)
auto find_if(R &&Range, UnaryPredicate P)
Provide wrappers to std::find_if which take ranges instead of having to pass begin/end explicitly.
bool is_contained(R &&Range, const E &Element)
Returns true if Element is found in Range.
bool equal(L &&LRange, R &&RRange)
Wrapper function around std::equal to detect if pair-wise elements between two ranges are the same.
IterT prev_nodbg(IterT It, IterT Begin, bool SkipPseudoOp=true)
Decrement It, then continue decrementing it while it points to a debug instruction.
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.
void addLiveIns(MachineBasicBlock &MBB, const LivePhysRegs &LiveRegs)
Adds registers contained in LiveRegs to the block live-in list of MBB.
void swap(llvm::BitVector &LHS, llvm::BitVector &RHS)
Implement std::swap in terms of BitVector swap.
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.
This represents a simple continuous liveness interval for a value.
LLVM_ABI static const MBBSectionID ExceptionSectionID
LLVM_ABI static const MBBSectionID ColdSectionID
Pair of physical register and lane mask.
Split the critical edge from this block to the given successor block, and return the newly created bl...
MachineJumpTableEntry - One jump table in the jump table info.
std::vector< MachineBasicBlock * > MBBs
MBBs - The vector of basic blocks from which to create the jump table.
Information about how a physical register Reg is used by a set of operands.
static void deleteNode(NodeTy *V)
void removeNodeFromList(NodeTy *)
void addNodeToList(NodeTy *)
When an MBB is added to an MF, we need to update the parent pointer of the MBB, the MBB numbering,...
void transferNodesFromList(ilist_callback_traits &OldList, Iterator, Iterator)
Callback before transferring nodes to this list.
Template traits for intrusive list.