30 #define DEBUG_TYPE "machine-block-freq" 33 "view-machine-block-freq-propagation-dags",
cl::Hidden,
34 cl::desc(
"Pop up a window to show a dag displaying how machine block " 35 "frequencies propagate through the CFG."),
38 "display a graph using the " 39 "fractional block frequency representation."),
41 "display a graph using the raw " 42 "integer fractional block frequency representation."),
44 "profile count if available.")));
50 "Pop up a window to show a dag displaying MBP layout and associated " 51 "block frequencies of the CFG."),
54 "display a graph using the " 55 "fractional block frequency representation."),
57 "display a graph using the raw " 58 "integer fractional block frequency representation."),
60 "display a graph using the real " 61 "profile count if available.")));
73 cl::desc(
"Print the machine block frequency info."));
126 const MachineBlockFrequencyInfo *Graph) {
127 int layout_order = -1;
131 if (!CurFunc || F != CurFunc) {
133 LayoutOrderMap.
clear();
137 for (
auto MBI = F->
begin(); MBI != F->
end(); ++MBI, ++
O) {
138 LayoutOrderMap[&*MBI] =
O;
141 layout_order = LayoutOrderMap[Node];
148 const MachineBlockFrequencyInfo *Graph) {
154 const MachineBlockFrequencyInfo *MBFI) {
163 "Machine Block Frequency Analysis",
true,
true)
169 char MachineBlockFrequencyInfo::
ID = 0;
171 MachineBlockFrequencyInfo::MachineBlockFrequencyInfo()
190 MBFI->calculate(F, MBPI, MLI);
192 (ViewBlockFreqFuncName.empty() ||
205 getAnalysis<MachineBranchProbabilityInfo>();
217 ViewGraph(const_cast<MachineBlockFrequencyInfo *>(
this), Name, isSimple);
222 return MBFI ? MBFI->getBlockFreq(MBB) : 0;
227 const Function &
F = MBFI->getFunction()->getFunction();
228 return MBFI ? MBFI->getBlockProfileCount(F, MBB) :
None;
233 const Function &
F = MBFI->getFunction()->getFunction();
234 return MBFI ? MBFI->getProfileCountFromFreq(F, Freq) :
None;
239 assert(MBFI &&
"Expected analysis to be available");
240 return MBFI->isIrrLoopHeader(MBB);
244 return MBFI ? MBFI->getFunction() :
nullptr;
248 return MBFI ? &MBFI->getBPI() :
nullptr;
254 return MBFI ? MBFI->printBlockFreq(OS, Freq) : OS;
260 return MBFI ? MBFI->printBlockFreq(OS, MBB) : OS;
264 return MBFI ? MBFI->getEntryFreq() : 0;
static PassRegistry * getPassRegistry()
getPassRegistry - Access the global registry object, which is automatically initialized at applicatio...
std::string getNodeAttributes(const MachineBasicBlock *Node, const MachineBlockFrequencyInfo *Graph)
This class represents lattice values for constants.
cl::opt< unsigned > ViewHotFreqPercent
static ChildIteratorType child_end(const NodeRef N)
MachineBlockFrequencyInfo pass uses BlockFrequencyInfoImpl implementation to estimate machine basic b...
static GVDAGType getGVDT()
static ChildIteratorType child_begin(const NodeRef N)
*ViewGraph Emit a dot run run gv on the postscript *then cleanup For use from the debugger *void ViewGraph(const GraphType &G, const Twine &Name, bool ShortNames=false, const Twine &Title="", GraphProgram::Name Program=GraphProgram::DOT)
Machine Block Frequency Analysis
AnalysisUsage & addRequired()
INITIALIZE_PASS_BEGIN(MachineBlockFrequencyInfo, DEBUG_TYPE, "Machine Block Frequency Analysis", true, true) INITIALIZE_PASS_END(MachineBlockFrequencyInfo
#define INITIALIZE_PASS_DEPENDENCY(depName)
amdgpu Simplify well known AMD library false Value Value const Twine & Name
MachineFunctionPass - This class adapts the FunctionPass interface to allow convenient creation of pa...
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
void view(const Twine &Name, bool isSimple=true) const
Pop up a ghostview window with the current block frequency propagation rendered using dot...
std::string getNodeLabel(const MachineBasicBlock *Node, const MachineBlockFrequencyInfo *Graph)
std::string getNodeLabel(NodeRef Node, const BlockFrequencyInfoT *Graph, GVDAGType GType, int layout_order=-1)
cl::opt< GVDAGType > ViewBlockLayoutWithBFI("view-block-layout-with-bfi", cl::Hidden, cl::desc("Pop up a window to show a dag displaying MBP layout and associated " "block frequencies of the CFG."), cl::values(clEnumValN(GVDT_None, "none", "do not display graphs."), clEnumValN(GVDT_Fraction, "fraction", "display a graph using the " "fractional block frequency representation."), clEnumValN(GVDT_Integer, "integer", "display a graph using the raw " "integer fractional block frequency representation."), clEnumValN(GVDT_Count, "count", "display a graph using the real " "profile count if available.")))
static bool isSimple(Instruction *I)
Optional< uint64_t > getBlockProfileCount(const MachineBasicBlock *MBB) const
DOTGraphTraits(bool isSimple=false)
~MachineBlockFrequencyInfo() override
COFF::MachineTypes Machine
static cl::opt< bool > PrintMachineBlockFreq("print-machine-bfi", cl::init(false), cl::Hidden, cl::desc("Print the machine block frequency info."))
std::string getEdgeAttributes(const MachineBasicBlock *Node, EdgeIter EI, const MachineBlockFrequencyInfo *MBFI)
StringRef getName() const
getName - Return the name of the corresponding LLVM function.
static nodes_iterator nodes_begin(const MachineBlockFrequencyInfo *G)
static NodeRef getEntryNode(const MachineBlockFrequencyInfo *G)
initializer< Ty > init(const Ty &Val)
void getAnalysisUsage(AnalysisUsage &AU) const override
getAnalysisUsage - Subclasses that override getAnalysisUsage must call this.
cl::opt< std::string > PrintBlockFreqFuncName
ValuesClass values(OptsTy... Options)
Helper to build a ValuesClass by forwarding a variable number of arguments as an initializer list to ...
BlockFrequency getBlockFreq(const MachineBasicBlock *MBB) const
getblockFreq - Return block frequency.
raw_ostream & printBlockFreq(raw_ostream &OS, const BlockFrequency Freq) const
Represent the analysis usage information of a pass.
MachineBasicBlock::const_succ_iterator ChildIteratorType
std::vector< MachineBasicBlock * >::const_iterator const_succ_iterator
DenseMap< const MachineBasicBlock *, int > LayoutOrderMap
const MachineBranchProbabilityInfo * getMBPI() const
succ_iterator succ_begin()
const MachineBasicBlock & front() const
const MachineFunction * getFunction() const
std::string getEdgeAttributes(NodeRef Node, EdgeIter EI, const BlockFrequencyInfoT *BFI, const BranchProbabilityInfoT *BPI, unsigned HotPercentThreshold=0)
INITIALIZE_PASS_END(RegBankSelect, DEBUG_TYPE, "Assign register bank of generic virtual registers", false, false) RegBankSelect
void initializeMachineBlockFrequencyInfoPass(PassRegistry &)
DOTGraphTraits - Template class that can be specialized to customize how graphs are converted to 'dot...
std::string getNodeAttributes(NodeRef Node, const BlockFrequencyInfoT *Graph, unsigned HotPercentThreshold=0)
void getAnalysisUsage(AnalysisUsage &AU) const override
getAnalysisUsage - This function should be overriden by passes that need analysis information to do t...
raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
void setPreservesAll()
Set by analyses that do not transform their input at all.
void releaseMemory() override
releaseMemory() - This member can be implemented by a pass if it wants to be able to release its memo...
LLVM_NODISCARD LLVM_ATTRIBUTE_ALWAYS_INLINE bool equals(StringRef RHS) const
equals - Check for string equality, this is more efficient than compare() when the relative ordering ...
static cl::opt< GVDAGType > ViewMachineBlockFreqPropagationDAG("view-machine-block-freq-propagation-dags", cl::Hidden, cl::desc("Pop up a window to show a dag displaying how machine block " "frequencies propagate through the CFG."), cl::values(clEnumValN(GVDT_None, "none", "do not display graphs."), clEnumValN(GVDT_Fraction, "fraction", "display a graph using the " "fractional block frequency representation."), clEnumValN(GVDT_Integer, "integer", "display a graph using the raw " "integer fractional block frequency representation."), clEnumValN(GVDT_Count, "count", "display a graph using the real " "profile count if available.")))
#define clEnumValN(ENUMVAL, FLAGNAME, DESC)
const MachineFunction * getParent() const
Return the MachineFunction containing this basic block.
bool runOnMachineFunction(MachineFunction &F) override
runOnMachineFunction - This method must be overloaded to perform the desired machine code transformat...
typename GTraits::ChildIteratorType EdgeIter
static nodes_iterator nodes_end(const MachineBlockFrequencyInfo *G)
uint64_t getEntryFreq() const
assert(ImpDefSCC.getReg()==AMDGPU::SCC &&ImpDefSCC.isDef())
cl::opt< std::string > ViewBlockFreqFuncName
Optional< uint64_t > getProfileCountFromFreq(uint64_t Freq) const
bool isIrrLoopHeader(const MachineBasicBlock *MBB)
This class implements an extremely fast bulk output stream that can only output to a stream...
void calculate(const MachineFunction &F, const MachineBranchProbabilityInfo &MBPI, const MachineLoopInfo &MLI)
calculate - compute block frequency info for the given function.
Shared implementation for block frequency analysis.
Machine Block Frequency true