30#include "llvm/Config/llvm-config.h"
53 assert((PrevMask & ~NewMask).
none() &&
"Must not remove bits");
54 if (PrevMask.
any() || NewMask.
none())
59 for (; PSetI.
isValid(); ++PSetI)
60 CurrSetPressure[*PSetI] += Weight;
68 assert((NewMask & ~PrevMask).
none() &&
"Must not add bits");
69 if (NewMask.
any() || PrevMask.
none())
74 for (; PSetI.
isValid(); ++PSetI) {
75 assert(CurrSetPressure[*PSetI] >= Weight &&
"register pressure underflow");
76 CurrSetPressure[*PSetI] -= Weight;
80#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
84 for (
unsigned i = 0, e = SetPressure.
size(); i < e; ++i) {
85 if (SetPressure[i] != 0) {
86 dbgs() <<
TRI->getRegPressureSetName(i) <<
"=" << SetPressure[i] <<
' ';
94 dbgs() <<
"Max Pressure: ";
96 dbgs() <<
"Live In: ";
99 if (!
P.LaneMask.all())
104 dbgs() <<
"Live Out: ";
107 if (!
P.LaneMask.all())
117 dbgs() <<
"Curr Pressure: ";
125 const char *sep =
"";
142 dbgs() <<
"[Excess=";
144 dbgs() <<
", CriticalMax=";
146 dbgs() <<
", CurrentMax=";
156 if (PreviousMask.
any() || NewMask.
none())
161 for (; PSetI.
isValid(); ++PSetI) {
162 CurrSetPressure[*PSetI] += Weight;
163 P.MaxSetPressure[*PSetI] =
164 std::max(P.MaxSetPressure[*PSetI], CurrSetPressure[*PSetI]);
225 unsigned NumRegUnits =
TRI.getNumRegs();
226 unsigned NumVirtRegs =
MRI.getNumVirtRegs();
227 Regs.setUniverse(NumRegUnits + NumVirtRegs);
228 this->NumRegUnits = NumRegUnits;
246 CurrSetPressure.
clear();
247 LiveThruPressure.clear();
248 P.MaxSetPressure.clear();
250 if (RequireIntervals)
267 bool TrackLaneMasks,
bool TrackUntiedDefs) {
273 MRI = &MF->getRegInfo();
275 this->TrackUntiedDefs = TrackUntiedDefs;
276 this->TrackLaneMasks = TrackLaneMasks;
278 if (RequireIntervals) {
279 assert(lis &&
"IntervalPressure requires LiveIntervals");
284 CurrSetPressure.assign(TRI->getNumRegPressureSets(), 0);
286 P.MaxSetPressure = CurrSetPressure;
290 UntiedDefs.setUniverse(MRI->getNumVirtRegs());
295 if (RequireIntervals)
303 if (RequireIntervals)
312 if (IdxPos == MBB->end())
313 return LIS->getMBBEndIdx(MBB);
314 return LIS->getInstructionIndex(*IdxPos).getRegSlot();
319 if (RequireIntervals)
324 assert(P.LiveInRegs.empty() &&
"inconsistent max pressure result");
325 P.LiveInRegs.reserve(LiveRegs.size());
326 LiveRegs.appendTo(P.LiveInRegs);
331 if (RequireIntervals)
336 assert(P.LiveOutRegs.empty() &&
"inconsistent max pressure result");
337 P.LiveOutRegs.reserve(LiveRegs.size());
338 LiveRegs.appendTo(P.LiveOutRegs);
344 assert(LiveRegs.size() == 0 &&
"no region boundary");
359 LiveThruPressure.assign(TRI->getNumRegPressureSets(), 0);
373 return Other.VRegOrUnit == VRegOrUnit;
375 if (
I == RegUnits.
end())
385 return Other.VRegOrUnit == VRegOrUnit;
387 if (
I == RegUnits.
end()) {
397 return Other.VRegOrUnit == VRegOrUnit;
399 if (
I == RegUnits.
end()) {
411 return Other.VRegOrUnit == VRegOrUnit;
413 if (
I != RegUnits.
end()) {
414 I->LaneMask &= ~Pair.LaneMask;
415 if (
I->LaneMask.none())
430 if (Property(SR, Pos))
431 Result |= SR.LaneMask;
433 }
else if (Property(LI, Pos)) {
434 Result = TrackLaneMasks
465class RegisterOperandsCollector {
466 friend class llvm::RegisterOperands;
468 RegisterOperands &RegOpers;
469 const TargetRegisterInfo &
TRI;
470 const MachineRegisterInfo &
MRI;
473 RegisterOperandsCollector(RegisterOperands &RegOpers,
474 const TargetRegisterInfo &
TRI,
475 const MachineRegisterInfo &
MRI,
bool IgnoreDead)
476 : RegOpers(RegOpers),
TRI(
TRI),
MRI(
MRI), IgnoreDead(IgnoreDead) {}
478 void collectInstr(
const MachineInstr &
MI)
const {
479 for (ConstMIBundleOperands OperI(
MI); OperI.isValid(); ++OperI)
480 collectOperand(*OperI);
483 for (
const VRegMaskOrUnit &
P : RegOpers.
Defs)
487 void collectInstrLanes(
const MachineInstr &
MI)
const {
488 for (ConstMIBundleOperands OperI(
MI); OperI.isValid(); ++OperI)
489 collectOperandLanes(*OperI);
492 for (
const VRegMaskOrUnit &
P : RegOpers.
Defs)
497 void collectOperand(
const MachineOperand &MO)
const {
518 void pushReg(
Register Reg, SmallVectorImpl<VRegMaskOrUnit> &RegUnits)
const {
522 }
else if (
MRI.isAllocatable(
Reg)) {
529 void collectOperandLanes(
const MachineOperand &MO)
const {
536 pushRegLanes(
Reg, SubRegIdx, RegOpers.
Uses);
547 pushRegLanes(
Reg, SubRegIdx, RegOpers.
Defs);
551 void pushRegLanes(
Register Reg,
unsigned SubRegIdx,
552 SmallVectorImpl<VRegMaskOrUnit> &RegUnits)
const {
554 LaneBitmask LaneMask = SubRegIdx != 0
555 ?
TRI.getSubRegIndexLaneMask(SubRegIdx)
556 :
MRI.getMaxLaneMaskForVReg(
Reg);
557 addRegLanes(RegUnits, VRegMaskOrUnit(VirtRegOrUnit(
Reg), LaneMask));
558 }
else if (
MRI.isAllocatable(
Reg)) {
571 bool TrackLaneMasks,
bool IgnoreDead) {
582 for (
auto *RI =
Defs.begin(); RI !=
Defs.end(); ) {
602 for (
auto *
I =
Defs.begin();
I !=
Defs.end();) {
608 if (VRegOrUnit.
isVirtualReg() && AddFlagsMI !=
nullptr &&
609 (LiveAfter & ~
I->LaneMask).none())
613 if (ActualDef.
none()) {
616 I->LaneMask = ActualDef;
622 for (
auto &[VRegOrUnit, LaneMask] :
Uses)
625 if (AddFlagsMI !=
nullptr) {
632 if (LiveAfter.
none())
667 for (; PSetI.
isValid(); ++PSetI) {
669 PressureDiff::iterator
I = nonconst_begin(), E = nonconst_end();
670 for (;
I != E &&
I->isValid(); ++
I) {
671 if (
I->getPSet() >= *PSetI)
678 if (!
I->isValid() ||
I->getPSet() != *PSetI) {
680 for (PressureDiff::iterator J =
I; J != E && PTmp.
isValid(); ++J)
684 unsigned NewUnitInc =
I->getUnitInc() + Weight;
685 if (NewUnitInc != 0) {
686 I->setUnitInc(NewUnitInc);
689 PressureDiff::iterator J;
690 for (J = std::next(
I); J != E && J->
isValid(); ++J, ++
I)
712 return Other.VRegOrUnit == VRegOrUnit;
716 if (
I == LiveInOrOut.
end()) {
721 PrevMask =
I->LaneMask;
723 I->LaneMask = NewMask;
738 LaneBitmask LiveMask = LiveRegs.contains(P.VRegOrUnit);
743 LaneBitmask LiveMask = LiveRegs.contains(P.VRegOrUnit);
756 assert(!CurrPos->isDebugOrPseudoInstr());
767 LaneBitmask NewMask = PreviousMask & ~Def.LaneMask;
769 LaneBitmask LiveOut = Def.LaneMask & ~PreviousMask;
775 PreviousMask = LiveOut;
778 if (NewMask.
none()) {
781 if (TrackLaneMasks && LiveUses !=
nullptr)
789 if (RequireIntervals)
790 SlotIdx = LIS->getInstructionIndex(*CurrPos).
getRegSlot();
798 if (NewMask == PreviousMask)
802 if (PreviousMask.
none()) {
803 if (LiveUses !=
nullptr) {
804 if (!TrackLaneMasks) {
808 return Other.VRegOrUnit == VRegOrUnit;
810 bool IsRedef =
I != LiveUses->
end();
822 if (RequireIntervals) {
831 if (TrackUntiedDefs) {
835 (LiveRegs.contains(VRegOrUnit) & Def.LaneMask).none())
842 assert(CurrPos != MBB->begin());
854 if (RequireIntervals && !CurrPos->isDebugOrPseudoInstr())
855 SlotIdx = LIS->getInstructionIndex(*CurrPos).
getRegSlot();
864 if (CurrPos->isDebugOrPseudoInstr()) {
867 assert(CurrPos == MBB->begin());
873 RegOpers.
collect(
MI, *TRI, *MRI, TrackLaneMasks,
false);
874 if (TrackLaneMasks) {
877 }
else if (RequireIntervals) {
881 recede(RegOpers, LiveUses);
886 assert(!TrackUntiedDefs &&
"unsupported mode");
887 assert(CurrPos != MBB->end());
892 if (RequireIntervals)
897 if (RequireIntervals)
905 LaneBitmask LiveMask = LiveRegs.contains(VRegOrUnit);
913 if (RequireIntervals) {
915 if (LastUseMask.
any()) {
939 RegOpers.
collect(
MI, *TRI, *MRI, TrackLaneMasks,
false);
940 if (TrackLaneMasks) {
954 for (
unsigned i = 0, e = OldPressureVec.
size(); i < e; ++i) {
955 unsigned POld = OldPressureVec[i];
956 unsigned PNew = NewPressureVec[i];
957 int PDiff = (int)PNew - (
int)POld;
962 if (!LiveThruPressureVec.
empty())
963 Limit += LiveThruPressureVec[i];
969 PDiff = PNew - Limit;
970 }
else if (Limit > PNew)
971 PDiff = Limit - POld;
995 unsigned CritIdx = 0, CritEnd = CriticalPSets.
size();
996 for (
unsigned i = 0, e = OldMaxPressureVec.
size(); i < e; ++i) {
997 unsigned POld = OldMaxPressureVec[i];
998 unsigned PNew = NewMaxPressureVec[i];
1003 while (CritIdx != CritEnd && CriticalPSets[CritIdx].getPSet() < i)
1006 if (CritIdx != CritEnd && CriticalPSets[CritIdx].getPSet() == i) {
1007 int PDiff = (int)PNew - CriticalPSets[CritIdx].getUnitInc();
1032 assert(!
MI->isDebugOrPseudoInstr() &&
"Expect a nondebug instruction.");
1035 if (RequireIntervals)
1036 SlotIdx = LIS->getInstructionIndex(*MI).
getRegSlot();
1040 RegOpers.
collect(*
MI, *TRI, *MRI, TrackLaneMasks,
true);
1044 else if (RequireIntervals)
1053 LaneBitmask LiveAfter = LiveRegs.contains(P.VRegOrUnit);
1056 LaneBitmask LiveBefore = (LiveAfter & ~DefLanes) | UseLanes;
1064 LaneBitmask LiveAfter = LiveRegs.contains(P.VRegOrUnit);
1091 std::vector<unsigned> SavedPressure = CurrSetPressure;
1092 std::vector<unsigned> SavedMaxPressure = P.MaxSetPressure;
1099 MaxPressureLimit, Delta);
1104 P.MaxSetPressure.swap(SavedMaxPressure);
1105 CurrSetPressure.swap(SavedPressure);
1114 if (Delta != Delta2) {
1115 dbgs() <<
"PDiff: ";
1117 dbgs() <<
"DELTA: " << *
MI;
1156 unsigned CritIdx = 0, CritEnd = CriticalPSets.
size();
1158 PDiffI = PDiff.
begin(), PDiffE = PDiff.
end();
1159 PDiffI != PDiffE && PDiffI->
isValid(); ++PDiffI) {
1161 unsigned PSetID = PDiffI->getPSet();
1162 unsigned Limit = RCI->getRegPressureSetLimit(PSetID);
1163 if (!LiveThruPressure.empty())
1164 Limit += LiveThruPressure[PSetID];
1166 unsigned POld = CurrSetPressure[PSetID];
1167 unsigned MOld = P.MaxSetPressure[PSetID];
1168 unsigned MNew = MOld;
1170 unsigned PNew = POld + PDiffI->getUnitInc();
1171 assert((PDiffI->getUnitInc() >= 0) == (PNew >= POld)
1172 &&
"PSet overflow/underflow");
1177 unsigned ExcessInc = 0;
1179 ExcessInc = POld > Limit ? PNew - POld : PNew - Limit;
1180 else if (POld > Limit)
1181 ExcessInc = Limit - POld;
1191 while (CritIdx != CritEnd && CriticalPSets[CritIdx].getPSet() < PSetID)
1194 if (CritIdx != CritEnd && CriticalPSets[CritIdx].getPSet() == PSetID) {
1195 int CritInc = (int)MNew - CriticalPSets[CritIdx].getUnitInc();
1196 if (CritInc > 0 && CritInc <= std::numeric_limits<int16_t>::max()) {
1229 if (InstSlot >= PriorUseIdx && InstSlot < NextUseIdx) {
1232 LastUseMask &= ~UseMask;
1233 if (LastUseMask.
none())
1242 assert(RequireIntervals);
1250 assert(RequireIntervals);
1252 *LIS, *MRI, TrackLaneMasks, VRegOrUnit, Pos.
getBaseIndex(),
1254 const LiveRange::Segment *S = LR.getSegmentContaining(Pos);
1255 return S != nullptr && S->end == Pos.getRegSlot();
1261 assert(RequireIntervals);
1278 assert(!
MI->isDebugOrPseudoInstr() &&
"Expect a nondebug instruction.");
1281 if (RequireIntervals)
1282 SlotIdx = LIS->getInstructionIndex(*MI).
getRegSlot();
1286 RegOpers.
collect(*
MI, *TRI, *MRI, TrackLaneMasks,
false);
1290 if (RequireIntervals) {
1294 if (LastUseMask.
none())
1303 findUseBetween(VRegOrUnit, LastUseMask, CurrIdx, SlotIdx, *MRI, LIS);
1304 if (LastUseMask.
none())
1307 LaneBitmask LiveMask = LiveRegs.contains(VRegOrUnit);
1315 LaneBitmask LiveMask = LiveRegs.contains(Def.VRegOrUnit);
1340 std::vector<unsigned> SavedPressure = CurrSetPressure;
1341 std::vector<unsigned> SavedMaxPressure = P.MaxSetPressure;
1348 MaxPressureLimit, Delta);
1353 P.MaxSetPressure.swap(SavedMaxPressure);
1354 CurrSetPressure.swap(SavedPressure);
1360 std::vector<unsigned> &PressureResult,
1361 std::vector<unsigned> &MaxPressureResult) {
1363 PressureResult = CurrSetPressure;
1364 MaxPressureResult = P.MaxSetPressure;
1369 P.MaxSetPressure.swap(MaxPressureResult);
1370 CurrSetPressure.swap(PressureResult);
1376 std::vector<unsigned> &PressureResult,
1377 std::vector<unsigned> &MaxPressureResult) {
1379 PressureResult = CurrSetPressure;
1380 MaxPressureResult = P.MaxSetPressure;
1385 P.MaxSetPressure.swap(MaxPressureResult);
1386 CurrSetPressure.swap(PressureResult);
unsigned const MachineRegisterInfo * MRI
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
#define LLVM_DUMP_METHOD
Mark debug helper function definitions like dump() that should not be stripped from debug builds.
A common definition of LaneBitmask for use in TableGen and CodeGen.
Register const TargetRegisterInfo * TRI
Promote Memory to Register
Register Usage Information Collector
static void computeExcessPressureDelta(ArrayRef< unsigned > OldPressureVec, ArrayRef< unsigned > NewPressureVec, RegPressureDelta &Delta, const RegisterClassInfo *RCI, ArrayRef< unsigned > LiveThruPressureVec)
Find the max change in excess pressure across all sets.
static LaneBitmask getLiveLanesAt(const LiveIntervals &LIS, const MachineRegisterInfo &MRI, bool TrackLaneMasks, VirtRegOrUnit VRegOrUnit, SlotIndex Pos)
static void increaseSetPressure(std::vector< unsigned > &CurrSetPressure, const MachineRegisterInfo &MRI, VirtRegOrUnit VRegOrUnit, LaneBitmask PrevMask, LaneBitmask NewMask)
Increase pressure for each pressure set provided by TargetRegisterInfo.
static LaneBitmask getRegLanes(ArrayRef< VRegMaskOrUnit > RegUnits, VirtRegOrUnit VRegOrUnit)
static void removeRegLanes(SmallVectorImpl< VRegMaskOrUnit > &RegUnits, VRegMaskOrUnit Pair)
static void computeMaxPressureDelta(ArrayRef< unsigned > OldMaxPressureVec, ArrayRef< unsigned > NewMaxPressureVec, ArrayRef< PressureChange > CriticalPSets, ArrayRef< unsigned > MaxPressureLimit, RegPressureDelta &Delta)
Find the max change in max pressure that either surpasses a critical PSet limit or exceeds the curren...
static LaneBitmask getLanesWithProperty(const LiveIntervals &LIS, const MachineRegisterInfo &MRI, bool TrackLaneMasks, VirtRegOrUnit VRegOrUnit, SlotIndex Pos, LaneBitmask SafeDefault, bool(*Property)(const LiveRange &LR, SlotIndex Pos))
static void setRegZero(SmallVectorImpl< VRegMaskOrUnit > &RegUnits, VirtRegOrUnit VRegOrUnit)
static LaneBitmask findUseBetween(VirtRegOrUnit VRegOrUnit, LaneBitmask LastUseMask, SlotIndex PriorUseIdx, SlotIndex NextUseIdx, const MachineRegisterInfo &MRI, const LiveIntervals *LIS)
Helper to find a vreg use between two indices [PriorUseIdx, NextUseIdx).
static const LiveRange * getLiveRange(const LiveIntervals &LIS, VirtRegOrUnit VRegOrUnit)
static void addRegLanes(SmallVectorImpl< VRegMaskOrUnit > &RegUnits, VRegMaskOrUnit Pair)
static void decreaseSetPressure(std::vector< unsigned > &CurrSetPressure, const MachineRegisterInfo &MRI, VirtRegOrUnit VRegOrUnit, LaneBitmask PrevMask, LaneBitmask NewMask)
Decrease pressure for each pressure set provided by TargetRegisterInfo.
This file defines the SmallVector class.
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
size_t size() const
size - Get the array size.
bool empty() const
empty - Check if the array is empty.
A live range for subregisters.
LiveInterval - This class represents the liveness of a register, or stack slot.
bool hasSubRanges() const
Returns true if subregister liveness information is available.
iterator_range< subrange_iterator > subranges()
SlotIndex getInstructionIndex(const MachineInstr &Instr) const
Returns the base index of the given instruction.
LiveInterval & getInterval(Register Reg)
LiveRange * getCachedRegUnit(MCRegUnit Unit)
Return the live range for register unit Unit if it has already been computed, or nullptr if it hasn't...
Result of a LiveRange query.
bool isDeadDef() const
Return true if this instruction has a dead def.
This class represents the liveness of a register, stack slot, etc.
const Segment * getSegmentContaining(SlotIndex Idx) const
Return the segment that contains the specified index, or null if there is none.
bool liveAt(SlotIndex index) const
LiveQueryResult Query(SlotIndex Idx) const
Query Liveness at Idx.
LLVM_ABI void init(const MachineRegisterInfo &MRI)
MachineInstrBundleIterator< const MachineInstr > const_iterator
const TargetSubtargetInfo & getSubtarget() const
getSubtarget - Return the subtarget for which this machine code is being compiled.
Representation of each machine instruction.
LLVM_ABI void setRegisterDefReadUndef(Register Reg, bool IsUndef=true)
Mark all subregister defs of register Reg with the undef flag.
MachineOperand class - Representation of each machine instruction operand.
unsigned getSubReg() const
bool readsReg() const
readsReg - Returns true if this operand reads the previous value of its register.
bool isReg() const
isReg - Tests if this is a MO_Register operand.
MachineInstr * getParent()
getParent - Return the instruction that this operand belongs to.
Register getReg() const
getReg - Returns the register number.
bool isInternalRead() const
MachineRegisterInfo - Keep track of information for virtual and physical registers,...
Iterate over the pressure sets affected by the given physical or virtual register.
unsigned getWeight() const
Capture a change in pressure for a single pressure set.
unsigned getPSetOrMax() const
LLVM_ABI void dump() const
List of PressureChanges in order of increasing, unique PSetID.
const PressureChange * const_iterator
LLVM_ABI void dump(const TargetRegisterInfo &TRI) const
const_iterator end() const
LLVM_ABI void addPressureChange(VirtRegOrUnit VRegOrUnit, bool IsDec, const MachineRegisterInfo *MRI)
Add a change in pressure to the pressure diff of a given instruction.
const_iterator begin() const
LLVM_ABI void addInstruction(unsigned Idx, const RegisterOperands &RegOpers, const MachineRegisterInfo &MRI)
Record pressure difference induced by the given operand list to node with index Idx.
LLVM_ABI void init(unsigned N)
Initialize an array of N PressureDiffs.
LLVM_ABI void closeRegion()
Finalize the region boundaries and recored live ins and live outs.
LLVM_ABI void discoverLiveIn(VRegMaskOrUnit Pair)
Add Reg to the live in set and increase max pressure.
LLVM_ABI void closeBottom()
Set the boundary for the bottom of the region and summarize live outs.
LLVM_ABI void recede(SmallVectorImpl< VRegMaskOrUnit > *LiveUses=nullptr)
Recede across the previous instruction.
LLVM_ABI void bumpDownwardPressure(const MachineInstr *MI)
Record the downward impact of a single instruction on current register pressure.
LLVM_ABI void addLiveRegs(ArrayRef< VRegMaskOrUnit > Regs)
Force liveness of virtual registers or physical register units.
LLVM_ABI void recedeSkipDebugValues()
Recede until we find an instruction which is not a DebugValue.
LLVM_ABI void getMaxUpwardPressureDelta(const MachineInstr *MI, PressureDiff *PDiff, RegPressureDelta &Delta, ArrayRef< PressureChange > CriticalPSets, ArrayRef< unsigned > MaxPressureLimit)
Consider the pressure increase caused by traversing this instruction bottom-up.
LLVM_ABI void initLiveThru(const RegPressureTracker &RPTracker)
Initialize the LiveThru pressure set based on the untied defs found in RPTracker.
LLVM_ABI void bumpDeadDefs(ArrayRef< VRegMaskOrUnit > DeadDefs)
RegPressureTracker(IntervalPressure &rp)
LLVM_ABI void dump() const
LLVM_ABI void init(const MachineFunction *mf, const RegisterClassInfo *rci, const LiveIntervals *lis, const MachineBasicBlock *mbb, MachineBasicBlock::const_iterator pos, bool TrackLaneMasks, bool TrackUntiedDefs)
Setup the RegPressureTracker.
LLVM_ABI void discoverLiveInOrOut(VRegMaskOrUnit Pair, SmallVectorImpl< VRegMaskOrUnit > &LiveInOrOut)
LLVM_ABI LaneBitmask getLiveThroughAt(VirtRegOrUnit VRegOrUnit, SlotIndex Pos) const
LLVM_ABI bool isBottomClosed() const
Does this pressure result have a valid bottom position and live outs.
LLVM_ABI LaneBitmask getLiveLanesAt(VirtRegOrUnit VRegOrUnit, SlotIndex Pos) const
bool hasUntiedDef(Register VirtReg) const
LLVM_ABI void closeTop()
Set the boundary for the top of the region and summarize live ins.
LLVM_ABI void getMaxDownwardPressureDelta(const MachineInstr *MI, RegPressureDelta &Delta, ArrayRef< PressureChange > CriticalPSets, ArrayRef< unsigned > MaxPressureLimit)
Consider the pressure increase caused by traversing this instruction top-down.
LLVM_ABI void advance()
Advance across the current instruction.
LLVM_ABI bool isTopClosed() const
Does this pressure result have a valid top position and live ins.
LLVM_ABI void bumpUpwardPressure(const MachineInstr *MI)
Record the upward impact of a single instruction on current register pressure.
LLVM_ABI LaneBitmask getLastUsedLanes(VirtRegOrUnit VRegOrUnit, SlotIndex Pos) const
LLVM_ABI void increaseRegPressure(VirtRegOrUnit VRegOrUnit, LaneBitmask PreviousMask, LaneBitmask NewMask)
LLVM_ABI void getDownwardPressure(const MachineInstr *MI, std::vector< unsigned > &PressureResult, std::vector< unsigned > &MaxPressureResult)
Get the pressure of each PSet after traversing this instruction top-down.
LLVM_ABI SlotIndex getCurrSlot() const
Get the SlotIndex for the first nondebug instruction including or after the current position.
LLVM_ABI void decreaseRegPressure(VirtRegOrUnit VRegOrUnit, LaneBitmask PreviousMask, LaneBitmask NewMask)
LLVM_ABI void getUpwardPressure(const MachineInstr *MI, std::vector< unsigned > &PressureResult, std::vector< unsigned > &MaxPressureResult)
Get the pressure of each PSet after traversing this instruction bottom-up.
LLVM_ABI void discoverLiveOut(VRegMaskOrUnit Pair)
Add Reg to the live out set and increase max pressure.
LLVM_ABI void getUpwardPressureDelta(const MachineInstr *MI, PressureDiff &PDiff, RegPressureDelta &Delta, ArrayRef< PressureChange > CriticalPSets, ArrayRef< unsigned > MaxPressureLimit) const
This is the fast version of querying register pressure that does not directly depend on current liven...
unsigned getRegPressureSetLimit(unsigned Idx) const
Get the register unit limit for the given pressure set index.
List of registers defined and used by a machine instruction.
SmallVector< VRegMaskOrUnit, 8 > Defs
List of virtual registers and register units defined by the instruction which are not dead.
LLVM_ABI void collect(const MachineInstr &MI, const TargetRegisterInfo &TRI, const MachineRegisterInfo &MRI, bool TrackLaneMasks, bool IgnoreDead)
Analyze the given instruction MI and fill in the Uses, Defs and DeadDefs list based on the MachineOpe...
SmallVector< VRegMaskOrUnit, 8 > DeadDefs
List of virtual registers and register units defined by the instruction but dead.
LLVM_ABI void adjustLaneLiveness(const LiveIntervals &LIS, const MachineRegisterInfo &MRI, SlotIndex Pos, MachineInstr *AddFlagsMI=nullptr)
Use liveness information to find out which uses/defs are partially undefined/dead and adjust the VReg...
LLVM_ABI void detectDeadDefs(const MachineInstr &MI, const LiveIntervals &LIS)
Use liveness information to find dead defs not marked with a dead flag and move them to the DeadDefs ...
SmallVector< VRegMaskOrUnit, 8 > Uses
List of virtual registers and register units read by the instruction.
Wrapper class representing virtual and physical registers.
MCRegister asMCReg() const
Utility to check-convert this value to a MCRegister.
constexpr bool isVirtual() const
Return true if the specified register number is in the virtual register namespace.
SlotIndex - An opaque wrapper around machine indexes.
SlotIndex getDeadSlot() const
Returns the dead def kill slot for the current instruction.
SlotIndex getBaseIndex() const
Returns the base index for associated with this index.
SlotIndex getRegSlot(bool EC=false) const
Returns the register use/def slot in the current instruction for a normal or early-clobber def.
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
reference emplace_back(ArgTypes &&... Args)
iterator erase(const_iterator CI)
void push_back(const T &Elt)
TargetRegisterInfo base class - We assume that the target defines a static array of TargetRegisterDes...
virtual const TargetRegisterInfo * getRegisterInfo() const =0
Return the target's register information.
A Use represents the edge between a Value definition and its users.
Wrapper class representing a virtual register or register unit.
constexpr bool isVirtualReg() const
constexpr MCRegUnit asMCRegUnit() const
constexpr Register asVirtualReg() const
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
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.
Printable PrintLaneMask(LaneBitmask LaneMask)
Create Printable object to print LaneBitmasks on a raw_ostream.
LLVM_ATTRIBUTE_RETURNS_NONNULL void * safe_calloc(size_t Count, size_t Sz)
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.
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
auto find_if(R &&Range, UnaryPredicate P)
Provide wrappers to std::find_if which take ranges instead of having to pass begin/end explicitly.
LLVM_ABI void dumpRegSetPressure(ArrayRef< unsigned > SetPressure, const TargetRegisterInfo *TRI)
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 printVRegOrUnit(VirtRegOrUnit VRegOrUnit, const TargetRegisterInfo *TRI)
Create Printable object to print virtual registers and physical registers on a raw_ostream.
void swap(llvm::BitVector &LHS, llvm::BitVector &RHS)
Implement std::swap in terms of BitVector swap.
RegisterPressure computed within a region of instructions delimited by TopIdx and BottomIdx.
LLVM_ABI void reset()
Clear the result so it can be used for another round of pressure tracking.
LLVM_ABI void openBottom(SlotIndex PrevBottom)
If the current bottom is not greater than the previous index, open it.
SlotIndex TopIdx
Record the boundary of the region being tracked.
LLVM_ABI void openTop(SlotIndex NextTop)
If the current top is not less than or equal to the next index, open it.
static constexpr LaneBitmask getAll()
constexpr bool none() const
constexpr bool any() const
static constexpr LaneBitmask getNone()
This represents a simple continuous liveness interval for a value.
Store the effects of a change in pressure on things that MI scheduler cares about.
PressureChange CriticalMax
PressureChange CurrentMax
LLVM_ABI void dump() const
RegisterPressure computed within a region of instructions delimited by TopPos and BottomPos.
MachineBasicBlock::const_iterator TopPos
Record the boundary of the region being tracked.
MachineBasicBlock::const_iterator BottomPos
LLVM_ABI void openTop(MachineBasicBlock::const_iterator PrevTop)
If the current top is the previous instruction (before receding), open it.
LLVM_ABI void reset()
Clear the result so it can be used for another round of pressure tracking.
LLVM_ABI void openBottom(MachineBasicBlock::const_iterator PrevBottom)
If the current bottom is the previous instr (before advancing), open it.
SmallVector< VRegMaskOrUnit, 8 > LiveOutRegs
SmallVector< VRegMaskOrUnit, 8 > LiveInRegs
List of live in virtual registers or physical register units.
LLVM_ABI void dump(const TargetRegisterInfo *TRI) const
std::vector< unsigned > MaxSetPressure
Map of max reg pressure indexed by pressure set ID, not class ID.