29#define DEBUG_TYPE "opt-phis"
31STATISTIC(NumPHICycles,
"Number of PHI cycles replaced");
32STATISTIC(NumDeadPHICycles,
"Number of dead PHI cycles");
48 InstrSet &PHIsInCycle);
56 OptimizePHIsLegacy() : MachineFunctionPass(ID) {}
58 bool runOnMachineFunction(MachineFunction &MF)
override {
65 void getAnalysisUsage(AnalysisUsage &AU)
const override {
72char OptimizePHIsLegacy::ID = 0;
77 "Optimize machine instruction PHIs",
false,
false)
98 for (MachineBasicBlock &
MBB : Fn)
109bool OptimizePHIs::IsSingleValuePHICycle(MachineInstr *
MI,
111 InstrSet &PHIsInCycle) {
112 assert(
MI->isPHI() &&
"IsSingleValuePHICycle expects a PHI instruction");
116 if (!PHIsInCycle.insert(
MI).second)
120 if (PHIsInCycle.size() == 16)
124 for (
unsigned i = 1; i !=
MI->getNumOperands(); i += 2) {
126 if (SrcReg == DstReg)
128 MachineInstr *SrcMI =
MRI->getVRegDef(SrcReg);
135 SrcMI =
MRI->getVRegDef(SrcReg);
140 if (SrcMI->
isPHI()) {
141 if (!IsSingleValuePHICycle(SrcMI, SingleValReg, PHIsInCycle))
145 if (SingleValReg && SingleValReg != SrcReg)
147 SingleValReg = SrcReg;
155bool OptimizePHIs::IsDeadPHICycle(MachineInstr *
MI, InstrSet &PHIsInCycle) {
156 assert(
MI->isPHI() &&
"IsDeadPHICycle expects a PHI instruction");
158 assert(DstReg.
isVirtual() &&
"PHI destination is not a virtual register");
161 if (!PHIsInCycle.insert(
MI).second)
165 if (PHIsInCycle.size() == 16)
168 for (MachineInstr &
UseMI :
MRI->use_nodbg_instructions(DstReg)) {
169 if (!
UseMI.isPHI() || !IsDeadPHICycle(&
UseMI, PHIsInCycle))
178bool OptimizePHIs::OptimizeBB(MachineBasicBlock &
MBB) {
182 MachineInstr *
MI = &*MII++;
188 InstrSet PHIsInCycle;
189 if (IsSingleValuePHICycle(
MI, SingleValReg, PHIsInCycle) && SingleValReg) {
191 if (!
MRI->constrainRegClass(SingleValReg,
MRI->getRegClass(OldReg)))
194 MRI->replaceRegWith(OldReg, SingleValReg);
195 MI->eraseFromParent();
198 MRI->clearKillFlags(SingleValReg);
207 if (IsDeadPHICycle(
MI, PHIsInCycle)) {
208 for (MachineInstr *PhiMI : PHIsInCycle) {
211 PhiMI->eraseFromParent();
unsigned const MachineRegisterInfo * MRI
MachineInstrBuilder & UseMI
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
const HexagonInstrInfo * TII
Promote Memory to Register
#define INITIALIZE_PASS(passName, arg, name, cfg, analysis)
This file defines the SmallPtrSet class.
This file defines the 'Statistic' class, which is designed to be an easy way to expose various metric...
#define STATISTIC(VARNAME, DESC)
LLVM_ABI void setPreservesCFG()
This function should be called by the pass, iff they do not:
Represents analyses that only rely on functions' control flow.
MachineInstrBundleIterator< MachineInstr > iterator
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.
MachineRegisterInfo & getRegInfo()
getRegInfo - Return information about the registers currently in use.
Function & getFunction()
Return the LLVM function that this machine code represents.
Representation of each machine instruction.
const MachineOperand & getOperand(unsigned i) const
unsigned getSubReg() const
Register getReg() const
getReg - Returns the register number.
MachineRegisterInfo - Keep track of information for virtual and physical registers,...
A set of analyses that are preserved following a run of a transformation pass.
static PreservedAnalyses all()
Construct a special preserved set that preserves all passes.
Wrapper class representing virtual and physical registers.
constexpr bool isVirtual() const
Return true if the specified register number is in the virtual register namespace.
SmallPtrSetIterator - This implements a const_iterator for SmallPtrSet.
SmallPtrSet - This class implements a set which is optimized for holding SmallSize or less elements.
TargetInstrInfo - Interface to description of machine instruction set.
virtual const TargetInstrInfo * getInstrInfo() const
This is an optimization pass for GlobalISel generic memory operations.
AnalysisManager< MachineFunction > MachineFunctionAnalysisManager
LLVM_ABI PreservedAnalyses getMachineFunctionPassPreservedAnalyses()
Returns the minimum set of Analyses that all machine function passes must preserve.
LLVM_ABI char & OptimizePHIsLegacyID
OptimizePHIs - This pass optimizes machine instruction PHIs to take advantage of opportunities create...