LLVM 23.0.0git
MachineFunctionPass.cpp
Go to the documentation of this file.
1//===-- MachineFunctionPass.cpp -------------------------------------------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This file contains the definitions of the MachineFunctionPass members.
10//
11//===----------------------------------------------------------------------===//
12
31#include "llvm/CodeGen/Passes.h"
32#include "llvm/IR/Dominators.h"
33#include "llvm/IR/Function.h"
34#include "llvm/IR/Module.h"
35
36using namespace llvm;
37using namespace ore;
38
40 "dropped-variable-stats-mir", cl::Hidden,
41 cl::desc("Dump dropped debug variables stats for MIR passes"),
42 cl::init(false));
43
44Pass *MachineFunctionPass::createPrinterPass(raw_ostream &O,
45 const std::string &Banner) const {
46 return createMachineFunctionPrinterPass(O, Banner);
47}
48
49bool MachineFunctionPass::runOnFunction(Function &F) {
50 // Do not codegen any 'available_externally' functions at all, they have
51 // definitions outside the translation unit.
52 if (F.hasAvailableExternallyLinkage())
53 return false;
54
55 MachineModuleInfo &MMI = getAnalysis<MachineModuleInfoWrapperPass>().getMMI();
56 MachineFunction &MF = MMI.getOrCreateMachineFunction(F);
57
58 MachineFunctionProperties &MFProps = MF.getProperties();
59
60#ifndef NDEBUG
61 if (!MFProps.verifyRequiredProperties(RequiredProperties)) {
62 errs() << "MachineFunctionProperties required by " << getPassName()
63 << " pass are not met by function " << F.getName() << ".\n"
64 << "Required properties: ";
65 RequiredProperties.print(errs());
66 errs() << "\nCurrent properties: ";
67 MFProps.print(errs());
68 errs() << "\n";
69 llvm_unreachable("MachineFunctionProperties check failed");
70 }
71#endif
72 // Collect the MI count of the function before the pass.
73 unsigned CountBefore, CountAfter;
74
75 // Check if the user asked for size remarks.
76 bool ShouldEmitSizeRemarks =
77 F.getParent()->shouldEmitInstrCountChangedRemark();
78
79 // If we want size remarks, collect the number of MachineInstrs in our
80 // MachineFunction before the pass runs.
81 if (ShouldEmitSizeRemarks)
82 CountBefore = MF.getInstructionCount();
83
84 MFProps.reset(ClearedProperties);
85
86 bool RV;
88 DroppedVariableStatsMIR DroppedVarStatsMF;
89 auto PassName = getPassName();
90 DroppedVarStatsMF.runBeforePass(PassName, &MF);
91 RV = runOnMachineFunction(MF);
92 DroppedVarStatsMF.runAfterPass(PassName, &MF);
93 } else {
94 RV = runOnMachineFunction(MF);
95 }
96
97 if (ShouldEmitSizeRemarks) {
98 // We wanted size remarks. Check if there was a change to the number of
99 // MachineInstrs in the module. Emit a remark if there was a change.
100 CountAfter = MF.getInstructionCount();
101 if (CountBefore != CountAfter) {
102 MachineOptimizationRemarkEmitter MORE(MF, nullptr);
103 MORE.emit([&]() {
104 int64_t Delta = static_cast<int64_t>(CountAfter) -
105 static_cast<int64_t>(CountBefore);
106 MachineOptimizationRemarkAnalysis R("size-info", "FunctionMISizeChange",
108 &MF.front());
109 R << NV("Pass", getPassName())
110 << ": Function: " << NV("Function", F.getName()) << ": "
111 << "MI Instruction count changed from "
112 << NV("MIInstrsBefore", CountBefore) << " to "
113 << NV("MIInstrsAfter", CountAfter)
114 << "; Delta: " << NV("Delta", Delta);
115 return R;
116 });
117 }
118 }
119
120 MFProps.set(SetProperties);
121
122 return RV;
123}
124
125bool MachineFunctionPass::printIRUnit(raw_ostream &OS, Function &F) {
126 // available_externally functions are not codegen'd (see runOnFunction).
127 if (F.hasAvailableExternallyLinkage())
128 return false;
129 MachineModuleInfo &MMI = getAnalysis<MachineModuleInfoWrapperPass>().getMMI();
131 return true;
132}
133
137
138 // MachineFunctionPass preserves all LLVM IR passes, but there's no
139 // high-level way to express this. Instead, just list a bunch of
140 // passes explicitly. This does not include setPreservesCFG,
141 // because CodeGen overloads that to mean preserving the MachineBasicBlock
142 // CFG in addition to the LLVM IR CFG.
157
159}
This is the interface for LLVM's primary stateless and local alias analysis.
===- DroppedVariableStatsMIR.h - Opt Diagnostics -*- C++ -*----------—===//
This is the interface for a simple mod/ref and alias analysis over globals.
Module.h This file contains the declarations for the Module class.
#define F(x, y, z)
Definition MD5.cpp:54
static cl::opt< bool > DroppedVarStatsMIR("dropped-variable-stats-mir", cl::Hidden, cl::desc("Dump dropped debug variables stats for MIR passes"), cl::init(false))
===- MachineOptimizationRemarkEmitter.h - Opt Diagnostics -*- C++ -*-—===//
This is the interface for a SCEV-based alias analysis.
static const char PassName[]
A wrapper pass to provide the legacy pass manager access to a suitably prepared AAResults object.
Represent the analysis usage information of a pass.
AnalysisUsage & addRequired()
AnalysisUsage & addPreserved()
Add the specified Pass class to the set of analyses preserved by this pass.
Legacy wrapper pass to provide the BasicAAResult object.
Legacy analysis pass which computes BranchProbabilityInfo.
Legacy analysis pass which computes a DominatorTree.
Definition Dominators.h:306
void runBeforePass(StringRef PassID, MachineFunction *MF)
void runAfterPass(StringRef PassID, MachineFunction *MF)
DISubprogram * getSubprogram() const
Get the attached subprogram.
Legacy wrapper pass to provide the GlobalsAAResult object.
This is an alternative analysis pass to BlockFrequencyInfoWrapperPass.
This is an alternative analysis pass to BranchProbabilityInfoWrapperPass.
The legacy pass manager's analysis pass to compute loop information.
Definition LoopInfo.h:612
void getAnalysisUsage(AnalysisUsage &AU) const override
getAnalysisUsage - Subclasses that override getAnalysisUsage must call this.
virtual bool runOnMachineFunction(MachineFunction &MF)=0
runOnMachineFunction - This method must be overloaded to perform the desired machine code transformat...
LLVM_ABI void print(raw_ostream &OS) const
Print the MachineFunctionProperties in human-readable form.
bool verifyRequiredProperties(const MachineFunctionProperties &V) const
MachineFunctionProperties & set(Property P)
MachineFunctionProperties & reset(Property P)
unsigned getInstructionCount() const
Return the number of MachineInstrs in this MachineFunction.
Function & getFunction()
Return the LLVM function that this machine code represents.
const MachineFunctionProperties & getProperties() const
Get the function properties.
const MachineBasicBlock & front() const
void print(raw_ostream &OS, const SlotIndexes *=nullptr) const
print - Print out the MachineFunction in a format suitable for debugging to the specified stream.
LLVM_ABI MachineFunction & getOrCreateMachineFunction(Function &F)
Returns the MachineFunction constructed for the IR function F.
A wrapper analysis pass for the legacy pass manager that exposes a MemoryDepnedenceResults instance.
Pass interface - Implemented by all 'passes'.
Definition Pass.h:99
AnalysisType & getAnalysis() const
getAnalysis<AnalysisType>() - This function is used by subclasses to get to the analysis information ...
virtual void getAnalysisUsage(AnalysisUsage &) const
getAnalysisUsage - This function should be overriden by passes that need analysis information to do t...
Definition Pass.cpp:112
virtual StringRef getPassName() const
getPassName - Return a nice clean name for a pass.
Definition Pass.cpp:85
Legacy wrapper pass to provide the SCEVAAResult object.
This class implements an extremely fast bulk output stream that can only output to a stream.
Definition raw_ostream.h:53
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
initializer< Ty > init(const Ty &Val)
Add a small namespace to avoid name clashes with the classes used in the streaming interface.
DiagnosticInfoOptimizationBase::Argument NV
This is an optimization pass for GlobalISel generic memory operations.
LLVM_ABI MachineFunctionPass * createMachineFunctionPrinterPass(raw_ostream &OS, const std::string &Banner="")
MachineFunctionPrinter pass - This pass prints out the machine function to the given stream as a debu...
LLVM_ABI raw_fd_ostream & errs()
This returns a reference to a raw_ostream for standard error.
#define MORE()
Definition regcomp.c:246