25#define DEBUG_TYPE "processimpdefs"
45class ProcessImplicitDefs {
60char ProcessImplicitDefsLegacy::ID = 0;
64 "Process Implicit Definitions",
false,
false)
66void ProcessImplicitDefsLegacy::getAnalysisUsage(
AnalysisUsage &AU)
const {
72bool ProcessImplicitDefs::canTurnIntoImplicitDef(
MachineInstr *
MI) {
73 if (!
MI->isCopyLike() &&
74 !
MI->isInsertSubreg() &&
75 !
MI->isRegSequence() &&
78 for (
const MachineOperand &MO :
MI->all_uses())
84void ProcessImplicitDefs::processImplicitDef(MachineInstr *
MI) {
93 MachineInstr *UserMI = MO.getParent();
94 if (!canTurnIntoImplicitDef(UserMI))
97 UserMI->
setDesc(
TII->get(TargetOpcode::IMPLICIT_DEF));
98 WorkList.insert(UserMI);
100 MI->eraseFromParent();
106 for (
unsigned i =
MI->getNumOperands() - 1; i; --i)
107 MI->removeOperand(i);
113 bool ImplicitDefIsDead =
false;
114 bool SearchedWholeBlock =
true;
115 constexpr unsigned SearchLimit = 35;
117 for (++SearchMI; SearchMI != SearchE; ++SearchMI) {
118 if (SearchMI->isDebugInstr())
120 if (++
Count > SearchLimit) {
121 SearchedWholeBlock =
false;
124 for (MachineOperand &MO : SearchMI->operands()) {
132 if (
TRI->isSubRegisterEq(
Reg, SearchReg)) {
140 if (
TRI->isSubRegisterEq(SearchReg,
Reg)) {
141 ImplicitDefIsDead =
true;
149 if (ImplicitDefIsDead) {
157 if (ImplicitDefIsDead ||
158 (SearchedWholeBlock &&
MI->getParent()->succ_empty())) {
159 MI->eraseFromParent();
164bool ProcessImplicitDefsLegacy::runOnMachineFunction(MachineFunction &MF) {
165 return ProcessImplicitDefs().run(MF);
171 if (!ProcessImplicitDefs().
run(MF))
176 .preserve<AAManager>();
183 LLVM_DEBUG(
dbgs() <<
"********** PROCESS IMPLICIT DEFS **********\n"
184 <<
"********** Function: " << MF.
getName() <<
'\n');
191 assert(WorkList.empty() &&
"Inconsistent worklist state");
196 if (
MI.isImplicitDef())
197 WorkList.insert(&
MI);
199 if (WorkList.empty())
203 <<
" implicit defs.\n");
207 do processImplicitDef(WorkList.pop_back_val());
208 while (!WorkList.empty());
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
const HexagonInstrInfo * TII
Register const TargetRegisterInfo * TRI
Promote Memory to Register
#define INITIALIZE_PASS(passName, arg, name, cfg, analysis)
This file implements a set that has insertion order iteration characteristics.
A wrapper pass to provide the legacy pass manager access to a suitably prepared AAResults object.
Represent the analysis usage information of a pass.
Represents analyses that only rely on functions' control flow.
Instructions::iterator instr_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.
Properties which a MachineFunction may have at a given point in time.
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.
Representation of each machine instruction.
LLVM_ABI void setDesc(const MCInstrDesc &TID)
Replace the instruction descriptor (thus opcode) of the current instruction with a new one.
MachineRegisterInfo - Keep track of information for virtual and physical registers,...
iterator_range< use_nodbg_iterator > use_nodbg_operands(Register Reg) const
static PreservedAnalyses all()
Construct a special preserved set that preserves all passes.
PreservedAnalyses & preserveSet()
Mark an analysis set as preserved.
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
constexpr bool isVirtual() const
Return true if the specified register number is in the virtual register namespace.
constexpr bool isPhysical() const
Return true if the specified register number is in the physical register namespace.
A SetVector that performs no allocations if smaller than a certain size.
TargetInstrInfo - Interface to description of machine instruction set.
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.
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
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 raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
FunctionAddr VTableAddr Count
LLVM_ABI char & ProcessImplicitDefsID
ProcessImpicitDefs pass - This pass removes IMPLICIT_DEFs.
LLVM_ABI Printable printMBBReference(const MachineBasicBlock &MBB)
Prints a machine basic block reference.