aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/Analysis/LoopPassManager.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'llvm/lib/Analysis/LoopPassManager.cpp')
-rw-r--r--llvm/lib/Analysis/LoopPassManager.cpp31
1 files changed, 4 insertions, 27 deletions
diff --git a/llvm/lib/Analysis/LoopPassManager.cpp b/llvm/lib/Analysis/LoopPassManager.cpp
index 1d87e07..fd77b78 100644
--- a/llvm/lib/Analysis/LoopPassManager.cpp
+++ b/llvm/lib/Analysis/LoopPassManager.cpp
@@ -11,31 +11,8 @@
using namespace llvm;
-LoopAnalysisManagerFunctionProxy::Result
-LoopAnalysisManagerFunctionProxy::run(Function &F) {
- // TODO: In FunctionAnalysisManagerModuleProxy we assert that the
- // AnalysisManager is empty, but if we do that here we run afoul of the fact
- // that we still have results for previous functions alive. Should we be
- // clearing those when we finish a function?
- //assert(LAM->empty() && "Loop analyses ran prior to the function proxy!");
- return Result(*LAM);
-}
-
-LoopAnalysisManagerFunctionProxy::Result::~Result() {
- // Clear out the analysis manager if we're being destroyed -- it means we
- // didn't even see an invalidate call when we got invalidated.
- LAM->clear();
-}
-
-bool LoopAnalysisManagerFunctionProxy::Result::invalidate(
- Function &F, const PreservedAnalyses &PA) {
- // If this proxy isn't marked as preserved, then we can't even invalidate
- // individual loop analyses, there may be an invalid set of Loops in the cache
- // making it impossible to incrementally preserve them. Just clear the entire
- // manager.
- if (!PA.preserved(ID()))
- LAM->clear();
-
- // Return false to indicate that this result is still a valid proxy.
- return false;
+// Explicit instantiations for core typedef'ed templates.
+namespace llvm {
+template class InnerAnalysisManagerProxy<LoopAnalysisManager, Function>;
+template class OuterAnalysisManagerProxy<FunctionAnalysisManager, Loop>;
}