40#define DEBUG_TYPE "riscv-insert-vsetvli"
41#define RISCV_INSERT_VSETVLI_NAME "RISC-V Insert VSETVLI pass"
43STATISTIC(NumInsertedVSETVL,
"Number of VSETVL inst inserted");
44STATISTIC(NumCoalescedVSETVL,
"Number of VSETVL inst coalesced");
48 cl::desc(
"Insert vsetvlis before vmvNr.vs to ensure vtype is valid and "
64 return LI.getVNInfoBefore(
SI);
92 const RISCVSubtarget *ST;
93 const TargetInstrInfo *TII;
94 MachineRegisterInfo *MRI;
97 RISCVVSETVLIInfoAnalysis VIA;
99 std::vector<BlockData> BlockInfo;
100 std::queue<const MachineBasicBlock *> WorkList;
105 RISCVInsertVSETVLI() : MachineFunctionPass(ID) {}
106 bool runOnMachineFunction(MachineFunction &MF)
override;
108 void getAnalysisUsage(AnalysisUsage &AU)
const override {
123 bool needVSETVLI(
const DemandedFields &Used,
const VSETVLIInfo &Require,
124 const VSETVLIInfo &CurInfo)
const;
125 bool needVSETVLIPHI(
const VSETVLIInfo &Require,
126 const MachineBasicBlock &
MBB)
const;
127 void insertVSETVLI(MachineBasicBlock &
MBB,
129 const VSETVLIInfo &Info,
const VSETVLIInfo &PrevInfo);
131 void transferBefore(VSETVLIInfo &Info,
const MachineInstr &
MI)
const;
132 void transferAfter(VSETVLIInfo &Info,
const MachineInstr &
MI)
const;
133 bool computeVLVTYPEChanges(
const MachineBasicBlock &
MBB,
134 VSETVLIInfo &Info)
const;
135 void computeIncomingVLVTYPE(
const MachineBasicBlock &
MBB);
136 void emitVSETVLIs(MachineBasicBlock &
MBB);
137 void doPRE(MachineBasicBlock &
MBB);
138 void insertReadVL(MachineBasicBlock &
MBB);
140 bool canMutatePriorConfig(
const MachineInstr &PrevMI,
const MachineInstr &
MI,
141 const DemandedFields &Used,
142 MachineInstr *&AVLDefToMove)
const;
143 void coalesceVSETVLIs(MachineBasicBlock &
MBB)
const;
144 bool insertVSETMTK(MachineBasicBlock &
MBB, TKTMMode
Mode)
const;
149char RISCVInsertVSETVLI::ID = 0;
161 if (Info.getTWiden()) {
162 if (Info.hasAVLVLMAX()) {
163 Register DestReg = MRI->createVirtualRegister(&RISCV::GPRNoX0RegClass);
164 auto MI = BuildMI(MBB, InsertPt, DL, TII->get(RISCV::PseudoSF_VSETTNTX0))
165 .addReg(DestReg, RegState::Define | RegState::Dead)
166 .addReg(RISCV::X0, RegState::Kill)
167 .addImm(Info.encodeVTYPE());
169 LIS->InsertMachineInstrInMaps(*MI);
170 LIS->createAndComputeVirtRegInterval(DestReg);
173 auto MI = BuildMI(MBB, InsertPt, DL, TII->get(RISCV::PseudoSF_VSETTNT))
174 .addReg(RISCV::X0, RegState::Define | RegState::Dead)
175 .addReg(Info.getAVLReg())
176 .addImm(Info.encodeVTYPE());
178 LIS->InsertMachineInstrInMaps(*MI);
183 if (PrevInfo.isKnown()) {
186 if (Info.hasSameAVL(PrevInfo) && Info.hasSameVLMAX(PrevInfo)) {
187 auto MI = BuildMI(MBB, InsertPt, DL, TII->get(RISCV::PseudoVSETVLIX0X0))
188 .addReg(RISCV::X0, RegState::Define | RegState::Dead)
189 .addReg(RISCV::X0, RegState::Kill)
190 .addImm(Info.encodeVTYPE())
191 .addReg(RISCV::VL, RegState::Implicit);
193 LIS->InsertMachineInstrInMaps(*MI);
200 if (Info.hasSameVLMAX(PrevInfo) && Info.hasAVLReg()) {
201 if (const MachineInstr *DefMI = Info.getAVLDefMI(LIS);
202 DefMI && RISCVInstrInfo::isVectorConfigInstr(*DefMI)) {
203 VSETVLIInfo DefInfo = VIA.getInfoForVSETVLI(*DefMI);
204 if (DefInfo.hasSameAVL(PrevInfo) && DefInfo.hasSameVLMAX(PrevInfo)) {
206 BuildMI(MBB, InsertPt, DL, TII->get(RISCV::PseudoVSETVLIX0X0))
207 .addReg(RISCV::X0, RegState::Define | RegState::Dead)
208 .addReg(RISCV::X0, RegState::Kill)
209 .addImm(Info.encodeVTYPE())
210 .addReg(RISCV::VL, RegState::Implicit);
212 LIS->InsertMachineInstrInMaps(*MI);
219 if (Info.hasAVLImm()) {
220 auto MI = BuildMI(MBB, InsertPt, DL, TII->get(RISCV::PseudoVSETIVLI))
221 .addReg(RISCV::X0, RegState::Define | RegState::Dead)
222 .addImm(Info.getAVLImm())
223 .addImm(Info.encodeVTYPE());
225 LIS->InsertMachineInstrInMaps(*MI);
229 if (Info.hasAVLVLMAX()) {
230 Register DestReg = MRI->createVirtualRegister(&RISCV::GPRNoX0RegClass);
231 auto MI = BuildMI(MBB, InsertPt, DL, TII->get(RISCV::PseudoVSETVLIX0))
232 .addReg(DestReg, RegState::Define | RegState::Dead)
233 .addReg(RISCV::X0, RegState::Kill)
234 .addImm(Info.encodeVTYPE());
236 LIS->InsertMachineInstrInMaps(*MI);
237 LIS->createAndComputeVirtRegInterval(DestReg);
243 MRI->constrainRegClass(AVLReg, &RISCV::GPRNoX0RegClass);
247 .
addImm(Info.encodeVTYPE());
252 const VNInfo *CurVNI = Info.getAVLVNInfo();
260 MRI->createVirtualRegister(&RISCV::GPRNoX0RegClass);
264 II =
MBB->getFirstNonPHI();
273 MI->getOperand(1).setReg(AVLCopyReg);
305 Info.setVLMul(*NewVLMul);
315void RISCVInsertVSETVLI::transferBefore(VSETVLIInfo &Info,
316 const MachineInstr &
MI)
const {
319 (!
Info.isKnown() ||
Info.hasSEWLMULRatioOnly())) {
337 if (
Info.isValid() && !needVSETVLI(Demanded, NewInfo, Info))
340 const VSETVLIInfo PrevInfo =
Info;
344 const VSETVLIInfo IncomingInfo =
adjustIncoming(PrevInfo, NewInfo, Demanded);
356 Info.setAVL(IncomingInfo);
359 if (
Info.hasSEWLMULRatioOnly()) {
360 VSETVLIInfo RatiolessInfo = IncomingInfo;
361 RatiolessInfo.
setAVL(Info);
362 Info = RatiolessInfo;
373 (Demanded.
TailPolicy ? IncomingInfo : Info).getTailAgnostic() ||
375 (Demanded.
MaskPolicy ? IncomingInfo : Info).getMaskAgnostic() ||
378 (Demanded.
AltFmt ? IncomingInfo : Info).getAltFmt() && SEW < 32,
386void RISCVInsertVSETVLI::transferAfter(VSETVLIInfo &Info,
387 const MachineInstr &
MI)
const {
388 if (RISCVInstrInfo::isVectorConfigInstr(
MI)) {
393 if (RISCVInstrInfo::isFaultOnlyFirstLoad(
MI)) {
395 assert(
MI.getOperand(1).getReg().isVirtual());
401 Info.setAVLRegDef(VNI,
MI.getOperand(1).getReg());
403 Info.setAVLRegDef(
nullptr,
MI.getOperand(1).getReg());
409 if (
MI.isCall() ||
MI.isInlineAsm() ||
410 MI.modifiesRegister(RISCV::VL,
nullptr) ||
411 MI.modifiesRegister(RISCV::VTYPE,
nullptr))
415bool RISCVInsertVSETVLI::computeVLVTYPEChanges(
const MachineBasicBlock &
MBB,
416 VSETVLIInfo &Info)
const {
417 bool HadVectorOp =
false;
420 for (
const MachineInstr &
MI :
MBB) {
421 transferBefore(Info,
MI);
423 if (RISCVInstrInfo::isVectorConfigInstr(
MI) ||
426 RISCVInstrInfo::isXSfmmVectorConfigInstr(
MI))
429 transferAfter(Info,
MI);
435void RISCVInsertVSETVLI::computeIncomingVLVTYPE(
const MachineBasicBlock &
MBB) {
439 BBInfo.InQueue =
false;
443 VSETVLIInfo InInfo = BBInfo.
Pred;
449 InInfo = InInfo.
intersect(BlockInfo[
P->getNumber()].Exit);
457 if (InInfo == BBInfo.
Pred)
460 BBInfo.
Pred = InInfo;
462 <<
" changed to " << BBInfo.
Pred <<
"\n");
468 VSETVLIInfo TmpStatus;
469 computeVLVTYPEChanges(
MBB, TmpStatus);
473 if (BBInfo.
Exit == TmpStatus)
476 BBInfo.
Exit = TmpStatus;
478 <<
" changed to " << BBInfo.
Exit <<
"\n");
483 if (!BlockInfo[S->getNumber()].InQueue) {
484 BlockInfo[S->getNumber()].InQueue =
true;
492bool RISCVInsertVSETVLI::needVSETVLIPHI(
const VSETVLIInfo &Require,
493 const MachineBasicBlock &
MBB)
const {
508 const VSETVLIInfo &PBBExit = BlockInfo[PBB->getNumber()].Exit;
515 if (!
DefMI || !RISCVInstrInfo::isVectorConfigInstr(*
DefMI))
521 if (DefInfo != PBBExit)
536void RISCVInsertVSETVLI::emitVSETVLIs(MachineBasicBlock &
MBB) {
540 bool PrefixTransparent =
true;
541 for (MachineInstr &
MI :
MBB) {
542 const VSETVLIInfo PrevInfo = CurInfo;
543 transferBefore(CurInfo,
MI);
546 if (RISCVInstrInfo::isVectorConfigInstr(
MI)) {
548 assert(
MI.getOperand(3).getReg() == RISCV::VL &&
549 MI.getOperand(4).getReg() == RISCV::VTYPE &&
550 "Unexpected operands where VL and VTYPE should be");
551 MI.getOperand(3).setIsDead(
false);
552 MI.getOperand(4).setIsDead(
false);
553 PrefixTransparent =
false;
559 insertVSETVLI(
MBB,
MI,
MI.getDebugLoc(), CurInfo, PrevInfo);
560 PrefixTransparent =
false;
566 uint64_t TSFlags =
MI.getDesc().TSFlags;
576 if (!PrefixTransparent || needVSETVLIPHI(CurInfo,
MBB))
577 insertVSETVLI(
MBB,
MI,
MI.getDebugLoc(), CurInfo, PrevInfo);
578 PrefixTransparent =
false;
602 for (MachineInstr *DeadMI : DeadMIs) {
603 if (!
TII->isAddImmediate(*DeadMI,
Reg))
606 Register AddReg = DeadMI->getOperand(1).getReg();
607 DeadMI->eraseFromParent();
620 if (
MI.isInlineAsm()) {
627 if (
MI.isCall() ||
MI.isInlineAsm() ||
628 MI.modifiesRegister(RISCV::VL,
nullptr) ||
629 MI.modifiesRegister(RISCV::VTYPE,
nullptr))
630 PrefixTransparent =
false;
632 transferAfter(CurInfo,
MI);
636 if (CurInfo !=
Info.Exit) {
642 assert(CurInfo ==
Info.Exit &&
"InsertVSETVLI dataflow invariant violated");
650void RISCVInsertVSETVLI::doPRE(MachineBasicBlock &
MBB) {
654 MachineBasicBlock *UnavailablePred =
nullptr;
655 VSETVLIInfo AvailableInfo;
657 const VSETVLIInfo &PredInfo = BlockInfo[
P->getNumber()].Exit;
662 }
else if (!AvailableInfo.
isValid()) {
663 AvailableInfo = PredInfo;
664 }
else if (AvailableInfo != PredInfo) {
671 if (!UnavailablePred || !AvailableInfo.
isValid())
709 VSETVLIInfo CurInfo = AvailableInfo;
710 int TransitionsRemoved = 0;
711 for (
const MachineInstr &
MI :
MBB) {
712 const VSETVLIInfo LastInfo = CurInfo;
713 const VSETVLIInfo LastOldInfo = OldInfo;
714 transferBefore(CurInfo,
MI);
715 transferBefore(OldInfo,
MI);
716 if (CurInfo == LastInfo)
717 TransitionsRemoved++;
718 if (LastOldInfo == OldInfo)
719 TransitionsRemoved--;
720 transferAfter(CurInfo,
MI);
721 transferAfter(OldInfo,
MI);
722 if (CurInfo == OldInfo)
726 if (CurInfo != OldInfo || TransitionsRemoved <= 0)
733 auto OldExit = BlockInfo[UnavailablePred->
getNumber()].Exit;
735 << UnavailablePred->
getName() <<
" with state "
736 << AvailableInfo <<
"\n");
737 BlockInfo[UnavailablePred->
getNumber()].Exit = AvailableInfo;
743 insertVSETVLI(*UnavailablePred, InsertPt,
745 AvailableInfo, OldExit);
752bool RISCVInsertVSETVLI::canMutatePriorConfig(
753 const MachineInstr &PrevMI,
const MachineInstr &
MI,
754 const DemandedFields &Used, MachineInstr *&AVLDefToMove)
const {
755 AVLDefToMove =
nullptr;
759 if (!RISCVInstrInfo::isVLPreservingConfig(
MI)) {
763 if (
Used.VLZeroness) {
764 if (RISCVInstrInfo::isVLPreservingConfig(PrevMI))
771 auto &AVL =
MI.getOperand(1);
775 if (AVL.isReg() && AVL.getReg() != RISCV::X0) {
778 if (!VNI || !PrevVNI || VNI != PrevVNI) {
781 if (!AVL.getReg().isVirtual())
785 if (!
DefMI || !RISCVInstrInfo::isLoadImmediate(*
DefMI) ||
790 AVLDefToMove =
DefMI;
805 auto VType =
MI.getOperand(2).getImm();
809void RISCVInsertVSETVLI::coalesceVSETVLIs(MachineBasicBlock &
MBB)
const {
810 MachineInstr *NextMI =
nullptr;
818 auto dropAVLUse = [&](MachineOperand &MO) {
819 if (!MO.isReg() || !MO.getReg().isVirtual())
828 if (VLOpDef &&
TII->isAddImmediate(*VLOpDef, OldVLReg) &&
836 RISCVInstrInfo::isXSfmmVectorConfigInstr(
MI)) {
841 if (!RISCVInstrInfo::isVectorConfigInstr(
MI)) {
843 if (
MI.isCall() ||
MI.isInlineAsm() ||
844 MI.modifiesRegister(RISCV::VL,
nullptr) ||
845 MI.modifiesRegister(RISCV::VTYPE,
nullptr))
850 if (!
MI.getOperand(0).isDead())
854 if (!
Used.usedVL() && !
Used.usedVTYPE()) {
855 dropAVLUse(
MI.getOperand(1));
858 MI.eraseFromParent();
859 NumCoalescedVSETVL++;
864 MachineInstr *AVLDefToMove =
nullptr;
865 if (canMutatePriorConfig(
MI, *NextMI, Used, AVLDefToMove)) {
866 if (!RISCVInstrInfo::isVLPreservingConfig(*NextMI)) {
869 MI.getOperand(0).setReg(DefReg);
870 MI.getOperand(0).setIsDead(
false);
873 dropAVLUse(
MI.getOperand(1));
895 SlotIndex NextMISlot =
898 LiveInterval::Segment S(MISlot, NextMISlot, DefVNI);
900 DefVNI->
def = MISlot;
917 NumCoalescedVSETVL++;
927 for (
auto *
MI : ToDelete) {
928 assert(
MI->getOpcode() == RISCV::ADDI);
934 MI->eraseFromParent();
940void RISCVInsertVSETVLI::insertReadVL(MachineBasicBlock &
MBB) {
942 MachineInstr &
MI = *
I++;
943 if (RISCVInstrInfo::isFaultOnlyFirstLoad(
MI)) {
944 Register VLOutput =
MI.getOperand(1).getReg();
946 if (!
MI.getOperand(1).isDead()) {
948 TII->get(RISCV::PseudoReadVL), VLOutput);
957 DefVNI->
def = NewDefSI;
961 MI.getOperand(1).setReg(RISCV::X0);
967bool RISCVInsertVSETVLI::insertVSETMTK(MachineBasicBlock &
MBB,
968 TKTMMode
Mode)
const {
971 for (
auto &
MI :
MBB) {
972 uint64_t TSFlags =
MI.getDesc().TSFlags;
973 if (RISCVInstrInfo::isXSfmmVectorConfigTMTKInstr(
MI) ||
979 unsigned Opcode = 0, OpNum = 0;
985 Opcode = RISCV::PseudoSF_VSETTK;
991 Opcode = RISCV::PseudoSF_VSETTM;
995 assert(OpNum && Opcode &&
"Invalid OpNum or Opcode");
997 MachineOperand &
Op =
MI.getOperand(OpNum);
1000 .
addReg(RISCV::X0, RegState::Define | RegState::Dead)
1008 Op.setIsKill(
false);
1023bool RISCVInsertVSETVLI::runOnMachineFunction(MachineFunction &MF) {
1033 auto *LISWrapper = getAnalysisIfAvailable<LiveIntervalsWrapperPass>();
1034 LIS = LISWrapper ? &LISWrapper->getLIS() :
nullptr;
1035 VIA = RISCVVSETVLIInfoAnalysis(ST, LIS);
1037 assert(BlockInfo.empty() &&
"Expect empty block infos");
1040 bool HaveVectorOp =
false;
1043 for (
const MachineBasicBlock &
MBB : MF) {
1044 VSETVLIInfo TmpStatus;
1045 HaveVectorOp |= computeVLVTYPEChanges(
MBB, TmpStatus);
1048 BBInfo.
Exit = TmpStatus;
1050 <<
" is " << BBInfo.
Exit <<
"\n");
1055 if (!HaveVectorOp) {
1063 for (
const MachineBasicBlock &
MBB : MF) {
1064 WorkList.push(&
MBB);
1067 while (!WorkList.empty()) {
1068 const MachineBasicBlock &
MBB = *WorkList.front();
1070 computeIncomingVLVTYPE(
MBB);
1074 for (MachineBasicBlock &
MBB : MF)
1081 for (MachineBasicBlock &
MBB : MF)
1094 coalesceVSETVLIs(*
MBB);
1098 for (MachineBasicBlock &
MBB : MF)
1101 for (MachineBasicBlock &
MBB : MF) {
1102 insertVSETMTK(
MBB, VSETTM);
1103 insertVSETMTK(
MBB, VSETTK);
1107 return HaveVectorOp;
1112 return new RISCVInsertVSETVLI();
MachineInstrBuilder MachineInstrBuilder & DefMI
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
const HexagonInstrInfo * TII
Promote Memory to Register
uint64_t IntrinsicInst * II
#define INITIALIZE_PASS(passName, arg, name, cfg, analysis)
This file builds on the ADT/GraphTraits.h file to build a generic graph post order iterator.
static cl::opt< bool > EnsureWholeVectorRegisterMoveValidVTYPE(DEBUG_TYPE "-whole-vector-register-move-valid-vtype", cl::Hidden, cl::desc("Insert vsetvlis before vmvNr.vs to ensure vtype is valid and " "vill is cleared"), cl::init(true))
static VSETVLIInfo adjustIncoming(const VSETVLIInfo &PrevInfo, const VSETVLIInfo &NewInfo, DemandedFields &Demanded)
#define RISCV_INSERT_VSETVLI_NAME
static cl::opt< RegAllocEvictionAdvisorAnalysisLegacy::AdvisorMode > Mode("regalloc-enable-advisor", cl::Hidden, cl::init(RegAllocEvictionAdvisorAnalysisLegacy::AdvisorMode::Default), cl::desc("Enable regalloc advisor mode"), cl::values(clEnumValN(RegAllocEvictionAdvisorAnalysisLegacy::AdvisorMode::Default, "default", "Default"), clEnumValN(RegAllocEvictionAdvisorAnalysisLegacy::AdvisorMode::Release, "release", "precompiled"), clEnumValN(RegAllocEvictionAdvisorAnalysisLegacy::AdvisorMode::Development, "development", "for training")))
SI Optimize VGPR LiveRange
This file defines the 'Statistic' class, which is designed to be an easy way to expose various metric...
#define STATISTIC(VARNAME, DESC)
AnalysisUsage & addUsedIfAvailable()
Add the specified Pass class to the set of analyses used by this pass.
AnalysisUsage & addPreserved()
Add the specified Pass class to the set of analyses preserved by this pass.
LLVM_ABI void setPreservesCFG()
This function should be called by the pass, iff they do not:
FunctionPass class - This class is used to implement most global optimizations.
LiveInterval - This class represents the liveness of a register, or stack slot.
void setWeight(float Value)
MachineInstr * getInstructionFromIndex(SlotIndex index) const
Returns the instruction associated with the given index.
SlotIndex InsertMachineInstrInMaps(MachineInstr &MI)
LLVM_ABI void handleMove(MachineInstr &MI, bool UpdateFlags=false)
Call this method to notify LiveIntervals that instruction MI has been moved within a basic block.
SlotIndexes * getSlotIndexes() const
SlotIndex getInstructionIndex(const MachineInstr &Instr) const
Returns the base index of the given instruction.
void RemoveMachineInstrFromMaps(MachineInstr &MI)
SlotIndex getMBBEndIdx(const MachineBasicBlock *mbb) const
Return the last index in the given basic block.
LiveInterval & getInterval(Register Reg)
void removeInterval(Register Reg)
Interval removal.
LLVM_ABI bool shrinkToUses(LiveInterval *li, SmallVectorImpl< MachineInstr * > *dead=nullptr)
After removing some uses of a register, shrink its live range to just the remaining uses.
LLVM_ABI void extendToIndices(LiveRange &LR, ArrayRef< SlotIndex > Indices, ArrayRef< SlotIndex > Undefs)
Extend the live range LR to reach all points in Indices.
LLVM_ABI void splitSeparateComponents(LiveInterval &LI, SmallVectorImpl< LiveInterval * > &SplitLIs)
Split separate components in LiveInterval LI into separate intervals.
MachineBasicBlock * getMBBFromIndex(SlotIndex index) const
LiveInterval & createAndComputeVirtRegInterval(Register Reg)
LLVM_ABI iterator addSegment(Segment S)
Add the specified Segment to this range, merging segments as appropriate.
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
bool overlaps(const LiveRange &other) const
overlaps - Return true if the intersection of the two live ranges is not empty.
VNInfo * getVNInfoBefore(SlotIndex Idx) const
getVNInfoBefore - Return the VNInfo that is live up to but not necessarily including Idx,...
bool containsOneValue() 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.
int getNumber() const
MachineBasicBlocks are uniquely numbered at the function level, unless they're not in a MachineFuncti...
LLVM_ABI iterator getFirstTerminator()
Returns an iterator to the first terminator instruction of this basic block.
unsigned succ_size() const
LLVM_ABI DebugLoc findDebugLoc(instr_iterator MBBI)
Find the next valid DebugLoc starting at MBBI, skipping any debug instructions.
iterator_range< iterator > terminators()
iterator_range< succ_iterator > successors()
LLVM_ABI instr_iterator getFirstInstrTerminator()
Same getFirstTerminator but it ignores bundles and return an instr_iterator instead.
iterator_range< pred_iterator > predecessors()
MachineInstrBundleIterator< MachineInstr > iterator
LLVM_ABI StringRef getName() const
Return the name of the corresponding LLVM basic block, or an empty string.
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 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.
MachineRegisterInfo & getRegInfo()
getRegInfo - Return information about the registers currently in use.
unsigned getNumBlockIDs() const
getNumBlockIDs - Return the number of MBB ID's allocated.
const MachineInstrBuilder & addReg(Register RegNo, RegState Flags={}, unsigned SubReg=0) const
Add a new virtual register operand.
const MachineInstrBuilder & addImm(int64_t Val) const
Add a new immediate operand.
Representation of each machine instruction.
const MachineBasicBlock * getParent() const
const MCInstrDesc & getDesc() const
Returns the target instruction descriptor of this MachineInstr.
const MachineOperand & getOperand(unsigned i) const
LLVM_ABI MachineInstrBundleIterator< MachineInstr > eraseFromParent()
Unlink 'this' from the containing basic block and delete it.
LLVM_ABI void moveBefore(MachineInstr *MovePos)
Move the instruction before MovePos.
MachineOperand class - Representation of each machine instruction operand.
bool isReg() const
isReg - Tests if this is a MO_Register operand.
LLVM_ABI void setReg(Register Reg)
Change the register this operand corresponds to.
bool isImm() const
isImm - Tests if this is a MO_Immediate operand.
void setIsKill(bool Val=true)
Register getReg() const
getReg - Returns the register number.
static MachineOperand CreateReg(Register Reg, bool isDef, bool isImp=false, bool isKill=false, bool isDead=false, bool isUndef=false, bool isEarlyClobber=false, unsigned SubReg=0, bool isDebug=false, bool isInternalRead=false, bool isRenamable=false)
bool use_nodbg_empty(Register RegNo) const
use_nodbg_empty - Return true if there are no non-Debug instructions using the specified register.
const TargetRegisterInfo * getTargetRegisterInfo() const
LLVM_ABI MachineInstr * getUniqueVRegDef(Register Reg) const
getUniqueVRegDef - Return the unique machine instr that defines the specified virtual register or nul...
bool hasVInstructions() const
const RISCVRegisterInfo * getRegisterInfo() const override
const RISCVInstrInfo * getInstrInfo() const override
VSETVLIInfo getInfoForVSETVLI(const MachineInstr &MI) const
VSETVLIInfo computeInfoForInstr(const MachineInstr &MI) const
Defines the abstract state with which the forward dataflow models the values of the VL and VTYPE regi...
bool hasSameVTYPE(const VSETVLIInfo &Other) const
unsigned getTWiden() const
bool getMaskAgnostic() const
VSETVLIInfo intersect(const VSETVLIInfo &Other) const
void setAVLImm(unsigned Imm)
unsigned getSEWLMULRatio() const
void setVTYPE(unsigned VType)
Register getAVLReg() const
bool getTailAgnostic() const
bool hasSameVLMAX(const VSETVLIInfo &Other) const
bool isCompatible(const DemandedFields &Used, const VSETVLIInfo &Require, const LiveIntervals *LIS) const
const VNInfo * getAVLVNInfo() const
bool hasSEWLMULRatioOnly() const
bool hasEquallyZeroAVL(const VSETVLIInfo &Other, const LiveIntervals *LIS) const
static VSETVLIInfo getUnknown()
void setAVL(const VSETVLIInfo &Info)
Wrapper class representing virtual and physical registers.
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 getRegSlot(bool EC=false) const
Returns the register use/def slot in the current instruction for a normal or early-clobber def.
SlotIndex getInstructionIndex(const MachineInstr &MI, bool IgnoreBundle=false) const
Returns the base index for the given instruction.
void push_back(const T &Elt)
VNInfo - Value Number Information.
SlotIndex def
The index of the defining instruction.
bool isPHIDef() const
Returns true if this value is defined by a PHI instruction (or was, PHI instructions may have been el...
static unsigned getTMOpNum(const MCInstrDesc &Desc)
static bool hasTWidenOp(uint64_t TSFlags)
static unsigned getTKOpNum(const MCInstrDesc &Desc)
static unsigned getVLOpNum(const MCInstrDesc &Desc)
static bool hasTKOp(uint64_t TSFlags)
static bool hasVLOp(uint64_t TSFlags)
static bool hasTMOp(uint64_t TSFlags)
static bool hasSEWOp(uint64_t TSFlags)
LLVM_ABI std::optional< VLMUL > getSameRatioLMUL(unsigned Ratio, unsigned EEW)
static const MachineOperand & getVLOp(const MachineInstr &MI)
DemandedFields getDemanded(const MachineInstr &MI, const RISCVSubtarget *ST)
Return the fields and properties demanded by the provided instruction.
bool areCompatibleVTYPEs(uint64_t CurVType, uint64_t NewVType, const DemandedFields &Used)
Return true if moving from CurVType to NewVType is indistinguishable from the perspective of an instr...
static VNInfo * getVNInfoFromReg(Register Reg, const MachineInstr &MI, const LiveIntervals *LIS)
Given a virtual register Reg, return the corresponding VNInfo for it.
bool isVectorCopy(const TargetRegisterInfo *TRI, const MachineInstr &MI)
Return true if MI is a copy that will be lowered to one or more vmvNr.vs.
initializer< Ty > init(const Ty &Val)
This is an optimization pass for GlobalISel generic memory operations.
FunctionAddr VTableAddr Value
MachineInstrBuilder BuildMI(MachineFunction &MF, const MIMetadata &MIMD, const MCInstrDesc &MCID)
Builder interface. Specify how to create the initial instruction itself.
@ Define
Register definition.
iterator_range< early_inc_iterator_impl< detail::IterOfRange< RangeT > > > make_early_inc_range(RangeT &&Range)
Make a range that does early increment to allow mutation of the underlying range without disrupting i...
unsigned Log2_32(uint32_t Value)
Return the floor log base 2 of the specified value, -1 if the value is zero.
auto reverse(ContainerTy &&C)
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
FunctionPass * createRISCVInsertVSETVLIPass()
Returns an instance of the Insert VSETVLI pass.
class LLVM_GSL_OWNER SmallVector
Forward declaration of SmallVector so that calculateSmallVectorDefaultInlinedElements can reference s...
auto post_order(const T &G)
Post-order traversal of a graph.
DWARFExpression::Operation Op
char & RISCVInsertVSETVLIID
LLVM_ABI Printable printMBBReference(const MachineBasicBlock &MBB)
Prints a machine basic block reference.
Which subfields of VL or VTYPE have values we need to preserve?
static DemandedFields all()
enum llvm::RISCV::DemandedFields::@326061152055210015167034143142117063364004052074 SEW
enum llvm::RISCV::DemandedFields::@201276154261047021277240313173154105356124146047 LMUL