1 //===- ScopPass.cpp - The base class of Passes that operate on Polly IR ---===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // This file contains the definitions of the ScopPass members.
12 //===----------------------------------------------------------------------===//
14 #include "polly/ScopPass.h"
15 #include "polly/ScopInfo.h"
17 #include "llvm/Analysis/AssumptionCache.h"
18 #include "llvm/Analysis/BasicAliasAnalysis.h"
19 #include "llvm/Analysis/GlobalsModRef.h"
20 #include "llvm/Analysis/OptimizationRemarkEmitter.h"
21 #include "llvm/Analysis/ScalarEvolutionAliasAnalysis.h"
22 #include "llvm/Analysis/TargetTransformInfo.h"
25 using namespace polly
;
27 bool ScopPass::runOnRegion(Region
*R
, RGPassManager
&RGM
) {
33 if ((S
= getAnalysis
<ScopInfoRegionPass
>().getScop()))
39 void ScopPass::print(raw_ostream
&OS
, const Module
*M
) const {
44 void ScopPass::getAnalysisUsage(AnalysisUsage
&AU
) const {
45 AU
.addRequired
<ScopInfoRegionPass
>();
47 AU
.addPreserved
<AAResultsWrapperPass
>();
48 AU
.addPreserved
<BasicAAWrapperPass
>();
49 AU
.addPreserved
<LoopInfoWrapperPass
>();
50 AU
.addPreserved
<DominatorTreeWrapperPass
>();
51 AU
.addPreserved
<GlobalsAAWrapperPass
>();
52 AU
.addPreserved
<ScopDetectionWrapperPass
>();
53 AU
.addPreserved
<ScalarEvolutionWrapperPass
>();
54 AU
.addPreserved
<SCEVAAWrapperPass
>();
55 AU
.addPreserved
<OptimizationRemarkEmitterWrapperPass
>();
56 AU
.addPreserved
<RegionInfoPass
>();
57 AU
.addPreserved
<ScopInfoRegionPass
>();
58 AU
.addPreserved
<TargetTransformInfoWrapperPass
>();
62 template class OwningInnerAnalysisManagerProxy
<ScopAnalysisManager
, Function
>;
67 template class PassManager
<Scop
, ScopAnalysisManager
,
68 ScopStandardAnalysisResults
&, SPMUpdater
&>;
69 template class InnerAnalysisManagerProxy
<ScopAnalysisManager
, Function
>;
70 template class OuterAnalysisManagerProxy
<FunctionAnalysisManager
, Scop
,
71 ScopStandardAnalysisResults
&>;
75 PassManager
<Scop
, ScopAnalysisManager
, ScopStandardAnalysisResults
&,
76 SPMUpdater
&>::run(Scop
&S
, ScopAnalysisManager
&AM
,
77 ScopStandardAnalysisResults
&AR
, SPMUpdater
&U
) {
78 auto PA
= PreservedAnalyses::all();
79 for (auto &Pass
: Passes
) {
80 auto PassPA
= Pass
->run(S
, AM
, AR
, U
);
82 AM
.invalidate(S
, PassPA
);
83 PA
.intersect(std::move(PassPA
));
86 // All analyses for 'this' Scop have been invalidated above.
87 // If ScopPasses affect break other scops they have to propagate this
88 // information through the updater
89 PA
.preserveSet
<AllAnalysesOn
<Scop
>>();
93 bool ScopAnalysisManagerFunctionProxy::Result::invalidate(
94 Function
&F
, const PreservedAnalyses
&PA
,
95 FunctionAnalysisManager::Invalidator
&Inv
) {
97 // First, check whether our ScopInfo is about to be invalidated
98 auto PAC
= PA
.getChecker
<ScopAnalysisManagerFunctionProxy
>();
99 if (!(PAC
.preserved() || PAC
.preservedSet
<AllAnalysesOn
<Function
>>()) ||
100 Inv
.invalidate
<ScopInfoAnalysis
>(F
, PA
) ||
101 Inv
.invalidate
<ScalarEvolutionAnalysis
>(F
, PA
) ||
102 Inv
.invalidate
<LoopAnalysis
>(F
, PA
) ||
103 Inv
.invalidate
<DominatorTreeAnalysis
>(F
, PA
)) {
105 // As everything depends on ScopInfo, we must drop all existing results
107 if (auto *scop
= S
.second
.get())
109 InnerAM
->clear(*scop
, scop
->getName());
112 return true; // Invalidate the proxy result as well.
115 bool allPreserved
= PA
.allAnalysesInSetPreserved
<AllAnalysesOn
<Scop
>>();
117 // Invalidate all non-preserved analyses
118 // Even if all analyses were preserved, we still need to run deferred
120 for (auto &S
: *SI
) {
121 Optional
<PreservedAnalyses
> InnerPA
;
122 auto *scop
= S
.second
.get();
126 if (auto *OuterProxy
=
127 InnerAM
->getCachedResult
<FunctionAnalysisManagerScopProxy
>(*scop
)) {
128 for (const auto &InvPair
: OuterProxy
->getOuterInvalidations()) {
129 auto *OuterAnalysisID
= InvPair
.first
;
130 const auto &InnerAnalysisIDs
= InvPair
.second
;
132 if (Inv
.invalidate(OuterAnalysisID
, F
, PA
)) {
135 for (auto *InnerAnalysisID
: InnerAnalysisIDs
)
136 InnerPA
->abandon(InnerAnalysisID
);
141 InnerAM
->invalidate(*scop
, *InnerPA
);
147 InnerAM
->invalidate(*scop
, PA
);
150 return false; // This proxy is still valid
154 ScopAnalysisManagerFunctionProxy::Result
155 ScopAnalysisManagerFunctionProxy::run(Function
&F
,
156 FunctionAnalysisManager
&FAM
) {
157 return Result(*InnerAM
, FAM
.getResult
<ScopInfoAnalysis
>(F
));
163 OwningScopAnalysisManagerFunctionProxy::Result
164 OwningScopAnalysisManagerFunctionProxy::run(Function
&F
,
165 FunctionAnalysisManager
&FAM
) {
166 return Result(InnerAM
, FAM
.getResult
<ScopInfoAnalysis
>(F
));