LLVM 19.0.0git
LazyMachineBlockFrequencyInfo.cpp
Go to the documentation of this file.
1///===- LazyMachineBlockFrequencyInfo.cpp - Lazy Machine Block Frequency --===//
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/// \file
9/// This is an alternative analysis pass to MachineBlockFrequencyInfo. The
10/// difference is that with this pass the block frequencies are not computed
11/// when the analysis pass is executed but rather when the BFI result is
12/// explicitly requested by the analysis client.
13///
14///===---------------------------------------------------------------------===//
15
19
20using namespace llvm;
21
22#define DEBUG_TYPE "lazy-machine-block-freq"
23
25 "Lazy Machine Block Frequency Analysis", true, true)
29 "Lazy Machine Block Frequency Analysis", true, true)
30
32
37}
38
40 AnalysisUsage &AU) const {
42 AU.setPreservesAll();
44}
45
47 OwnedMBFI.reset();
48 OwnedMLI.reset();
49 OwnedMDT.reset();
50}
51
53LazyMachineBlockFrequencyInfoPass::calculateIfNotAvailable() const {
54 auto *MBFIWrapper =
55 getAnalysisIfAvailable<MachineBlockFrequencyInfoWrapperPass>();
56 if (MBFIWrapper) {
57 LLVM_DEBUG(dbgs() << "MachineBlockFrequencyInfo is available\n");
58 return MBFIWrapper->getMBFI();
59 }
60
61 auto &MBPI = getAnalysis<MachineBranchProbabilityInfoWrapperPass>().getMBPI();
62 auto *MLIWrapper = getAnalysisIfAvailable<MachineLoopInfoWrapperPass>();
63 auto *MLI = MLIWrapper ? &MLIWrapper->getLI() : nullptr;
64 auto *MDTWrapper = getAnalysisIfAvailable<MachineDominatorTreeWrapperPass>();
65 auto *MDT = MDTWrapper ? &MDTWrapper->getDomTree() : nullptr;
66 LLVM_DEBUG(dbgs() << "Building MachineBlockFrequencyInfo on the fly\n");
67 LLVM_DEBUG(if (MLI) dbgs() << "LoopInfo is available\n");
68
69 if (!MLI) {
70 LLVM_DEBUG(dbgs() << "Building LoopInfo on the fly\n");
71 // First create a dominator tree.
72 LLVM_DEBUG(if (MDT) dbgs() << "DominatorTree is available\n");
73
74 if (!MDT) {
75 LLVM_DEBUG(dbgs() << "Building DominatorTree on the fly\n");
76 OwnedMDT = std::make_unique<MachineDominatorTree>();
77 OwnedMDT->getBase().recalculate(*MF);
78 MDT = OwnedMDT.get();
79 }
80
81 // Generate LoopInfo from it.
82 OwnedMLI = std::make_unique<MachineLoopInfo>();
83 OwnedMLI->analyze(MDT->getBase());
84 MLI = OwnedMLI.get();
85 }
86
87 OwnedMBFI = std::make_unique<MachineBlockFrequencyInfo>();
88 OwnedMBFI->calculate(*MF, MBPI, *MLI);
89 return *OwnedMBFI;
90}
91
94 MF = &F;
95 return false;
96}
COFF::MachineTypes Machine
Definition: COFFYAML.cpp:371
#define LLVM_DEBUG(X)
Definition: Debug.h:101
Lazy Machine Block Frequency true
Lazy Machine Block Frequency Analysis
===- LazyMachineBlockFrequencyInfo.h - Lazy Block Frequency -*- C++ -*–===//
#define F(x, y, z)
Definition: MD5.cpp:55
#define INITIALIZE_PASS_DEPENDENCY(depName)
Definition: PassSupport.h:55
#define INITIALIZE_PASS_END(passName, arg, name, cfg, analysis)
Definition: PassSupport.h:59
#define INITIALIZE_PASS_BEGIN(passName, arg, name, cfg, analysis)
Definition: PassSupport.h:52
Represent the analysis usage information of a pass.
AnalysisUsage & addRequired()
void setPreservesAll()
Set by analyses that do not transform their input at all.
This is an alternative analysis pass to MachineBlockFrequencyInfo.
void getAnalysisUsage(AnalysisUsage &AU) const override
getAnalysisUsage - This function should be overriden by passes that need analysis information to do t...
void releaseMemory() override
releaseMemory() - This member can be implemented by a pass if it wants to be able to release its memo...
bool runOnMachineFunction(MachineFunction &F) override
runOnMachineFunction - This method must be overloaded to perform the desired machine code transformat...
const MachineBlockFrequencyInfo & getMBFI() const
Definition: MBFIWrapper.h:37
MachineBlockFrequencyInfo pass uses BlockFrequencyInfoImpl implementation to estimate machine basic b...
const MachineBranchProbabilityInfo * getMBPI() const
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.
static PassRegistry * getPassRegistry()
getPassRegistry - Access the global registry object, which is automatically initialized at applicatio...
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
Definition: Debug.cpp:163
void initializeLazyMachineBlockFrequencyInfoPassPass(PassRegistry &)