LLVM 22.0.0git
MachineDominators.cpp
Go to the documentation of this file.
1//===- MachineDominators.cpp - Machine Dominator Calculation --------------===//
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 implements simple dominator construction algorithms for finding
10// forward dominators on machine functions.
11//
12//===----------------------------------------------------------------------===//
13
15#include "llvm/CodeGen/Passes.h"
17#include "llvm/Pass.h"
18#include "llvm/PassRegistry.h"
22
23using namespace llvm;
24
25namespace llvm {
26// Always verify dominfo if expensive checking is enabled.
27#ifdef EXPENSIVE_CHECKS
28bool VerifyMachineDomInfo = true;
29#else
31#endif
32} // namespace llvm
33
35 "verify-machine-dom-info", cl::location(VerifyMachineDomInfo), cl::Hidden,
36 cl::desc("Verify machine dominator info (time consuming)"));
37
38namespace llvm {
40template class LLVM_EXPORT_TEMPLATE
42
43namespace DomTreeBuilder {
44template LLVM_EXPORT_TEMPLATE void Calculate<MBBDomTree>(MBBDomTree &DT);
45template LLVM_EXPORT_TEMPLATE void
46CalculateWithUpdates<MBBDomTree>(MBBDomTree &DT, MBBUpdates U);
47
48template LLVM_EXPORT_TEMPLATE void
49InsertEdge<MBBDomTree>(MBBDomTree &DT, MachineBasicBlock *From,
51
52template LLVM_EXPORT_TEMPLATE void
53DeleteEdge<MBBDomTree>(MBBDomTree &DT, MachineBasicBlock *From,
55
56template LLVM_EXPORT_TEMPLATE void
57ApplyUpdates<MBBDomTree>(MBBDomTree &DT, MBBDomTreeGraphDiff &,
58 MBBDomTreeGraphDiff *);
59
60template LLVM_EXPORT_TEMPLATE bool
61Verify<MBBDomTree>(const MBBDomTree &DT, MBBDomTree::VerificationLevel VL);
62} // namespace DomTreeBuilder
63}
64
68 // Check whether the analysis, all analyses on machine functions, or the
69 // machine function's CFG have been preserved.
71 return !PAC.preserved() &&
72 !PAC.preservedSet<AllAnalysesOn<MachineFunction>>() &&
73 !PAC.preservedSet<CFGAnalyses>();
74}
75
76AnalysisKey MachineDominatorTreeAnalysis::Key;
77
81 return MachineDominatorTree(MF);
82}
83
87 OS << "MachineDominatorTree for machine function: " << MF.getName() << '\n';
90}
91
93
95 "MachineDominator Tree Construction", true, true)
96
101}
102
104
107 return false;
108}
109
111
113 if (VerifyMachineDomInfo && DT)
115 report_fatal_error("MachineDominatorTree verification failed!");
116}
117
119 const Module *) const {
120 if (DT)
121 DT->print(OS);
122}
BlockVerifier::State From
#define LLVM_EXPORT_TEMPLATE
Definition: Compiler.h:215
Generic dominator tree construction - this file provides routines to construct immediate dominator in...
#define F(x, y, z)
Definition: MD5.cpp:55
static cl::opt< bool, true > VerifyMachineDomInfoX("verify-machine-dom-info", cl::location(VerifyMachineDomInfo), cl::Hidden, cl::desc("Verify machine dominator info (time consuming)"))
#define INITIALIZE_PASS(passName, arg, name, cfg, analysis)
Definition: PassSupport.h:56
raw_pwrite_stream & OS
This templated class represents "all analyses that operate over <a particular IR unit>" (e....
Definition: Analysis.h:50
API to communicate dependencies between analyses during invalidation.
Definition: PassManager.h:294
A container for analyses that lazily runs them and caches their results.
Definition: PassManager.h:255
PassT::Result & getResult(IRUnitT &IR, ExtraArgTs... ExtraArgs)
Get the result of an analysis pass for a given IR unit.
Definition: PassManager.h:412
Represents analyses that only rely on functions' control flow.
Definition: Analysis.h:73
Base class for the actual dominator tree node.
Core dominator tree base class.
Analysis pass which computes a MachineDominatorTree.
LLVM_ABI Result run(MachineFunction &MF, MachineFunctionAnalysisManager &)
LLVM_ABI PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
Analysis pass which computes a MachineDominatorTree.
void verifyAnalysis() const override
verifyAnalysis() - This member can be implemented by a analysis pass to check state of analysis infor...
void print(raw_ostream &OS, const Module *M=nullptr) const override
print - Print out the internal state of the pass.
bool runOnMachineFunction(MachineFunction &MF) override
runOnMachineFunction - This method must be overloaded to perform the desired machine code transformat...
void releaseMemory() override
releaseMemory() - This member can be implemented by a pass if it wants to be able to release its memo...
DominatorTree Class - Concrete subclass of DominatorTreeBase that is used to compute a normal dominat...
LLVM_ABI bool invalidate(MachineFunction &, const PreservedAnalyses &PA, MachineFunctionAnalysisManager::Invalidator &)
Handle invalidation explicitly.
MachineFunctionPass - This class adapts the FunctionPass interface to allow convenient creation of pa...
StringRef getName() const
getName - Return the name of the corresponding LLVM function.
A Module instance is used to store all the information related to an LLVM module.
Definition: Module.h:67
static LLVM_ABI PassRegistry * getPassRegistry()
getPassRegistry - Access the global registry object, which is automatically initialized at applicatio...
A set of analyses that are preserved following a run of a transformation pass.
Definition: Analysis.h:112
static PreservedAnalyses all()
Construct a special preserved set that preserves all passes.
Definition: Analysis.h:118
PreservedAnalysisChecker getChecker() const
Build a checker for this PreservedAnalyses and the specified analysis type.
Definition: Analysis.h:275
This class implements an extremely fast bulk output stream that can only output to a stream.
Definition: raw_ostream.h:53
LocationClass< Ty > location(Ty &L)
Definition: CommandLine.h:464
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
Printable print(const GCNRegPressure &RP, const GCNSubtarget *ST=nullptr, unsigned DynamicVGPRBlockSize=0)
LLVM_ABI char & MachineDominatorsID
MachineDominators - This pass is a machine dominators analysis pass.
LLVM_ABI void report_fatal_error(Error Err, bool gen_crash_diag=true)
Definition: Error.cpp:167
bool VerifyMachineDomInfo
LLVM_ABI void initializeMachineDominatorTreeWrapperPassPass(PassRegistry &)
A special type used by analysis passes to provide an address that identifies that particular analysis...
Definition: Analysis.h:29