mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-08 12:21:04 +00:00
77a10244b2
Summary: First step in adding MemorySSA as dependency for loop pass manager. Adding the dependency under a flag. New pass manager: MSSA pointer in LoopStandardAnalysisResults can be null. Legacy and new pass manager: Use cl::opt EnableMSSALoopDependency. Disabled by default. Reviewers: sanjoy, davide, gberry Subscribers: mehdi_amini, Prazek, llvm-commits Differential Revision: https://reviews.llvm.org/D40274 llvm-svn: 318772
161 lines
6.0 KiB
C++
161 lines
6.0 KiB
C++
//===- LoopAnalysisManager.h - Loop analysis management ---------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
/// \file
|
|
///
|
|
/// This header provides classes for managing per-loop analyses. These are
|
|
/// typically used as part of a loop pass pipeline over the loop nests of
|
|
/// a function.
|
|
///
|
|
/// Loop analyses are allowed to make some simplifying assumptions:
|
|
/// 1) Loops are, where possible, in simplified form.
|
|
/// 2) Loops are *always* in LCSSA form.
|
|
/// 3) A collection of analysis results are available:
|
|
/// - LoopInfo
|
|
/// - DominatorTree
|
|
/// - ScalarEvolution
|
|
/// - AAManager
|
|
///
|
|
/// The primary mechanism to provide these invariants is the loop pass manager,
|
|
/// but they can also be manually provided in order to reason about a loop from
|
|
/// outside of a dedicated pass manager.
|
|
///
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_ANALYSIS_LOOPANALYSISMANAGER_H
|
|
#define LLVM_ANALYSIS_LOOPANALYSISMANAGER_H
|
|
|
|
#include "llvm/ADT/PostOrderIterator.h"
|
|
#include "llvm/ADT/PriorityWorklist.h"
|
|
#include "llvm/ADT/STLExtras.h"
|
|
#include "llvm/Analysis/AliasAnalysis.h"
|
|
#include "llvm/Analysis/BasicAliasAnalysis.h"
|
|
#include "llvm/Analysis/GlobalsModRef.h"
|
|
#include "llvm/Analysis/LoopInfo.h"
|
|
#include "llvm/Analysis/MemorySSA.h"
|
|
#include "llvm/Analysis/ScalarEvolution.h"
|
|
#include "llvm/Analysis/ScalarEvolutionAliasAnalysis.h"
|
|
#include "llvm/Analysis/TargetLibraryInfo.h"
|
|
#include "llvm/Analysis/TargetTransformInfo.h"
|
|
#include "llvm/IR/Dominators.h"
|
|
#include "llvm/IR/PassManager.h"
|
|
|
|
namespace llvm {
|
|
|
|
/// The adaptor from a function pass to a loop pass computes these analyses and
|
|
/// makes them available to the loop passes "for free". Each loop pass is
|
|
/// expected expected to update these analyses if necessary to ensure they're
|
|
/// valid after it runs.
|
|
struct LoopStandardAnalysisResults {
|
|
AAResults &AA;
|
|
AssumptionCache ∾
|
|
DominatorTree &DT;
|
|
LoopInfo &LI;
|
|
ScalarEvolution &SE;
|
|
TargetLibraryInfo &TLI;
|
|
TargetTransformInfo &TTI;
|
|
MemorySSA *MSSA;
|
|
};
|
|
|
|
/// Enables memory ssa as a dependency for loop passes.
|
|
extern cl::opt<bool> EnableMSSALoopDependency;
|
|
|
|
/// Extern template declaration for the analysis set for this IR unit.
|
|
extern template class AllAnalysesOn<Loop>;
|
|
|
|
extern template class AnalysisManager<Loop, LoopStandardAnalysisResults &>;
|
|
/// \brief The loop analysis manager.
|
|
///
|
|
/// See the documentation for the AnalysisManager template for detail
|
|
/// documentation. This typedef serves as a convenient way to refer to this
|
|
/// construct in the adaptors and proxies used to integrate this into the larger
|
|
/// pass manager infrastructure.
|
|
typedef AnalysisManager<Loop, LoopStandardAnalysisResults &>
|
|
LoopAnalysisManager;
|
|
|
|
/// A proxy from a \c LoopAnalysisManager to a \c Function.
|
|
typedef InnerAnalysisManagerProxy<LoopAnalysisManager, Function>
|
|
LoopAnalysisManagerFunctionProxy;
|
|
|
|
/// A specialized result for the \c LoopAnalysisManagerFunctionProxy which
|
|
/// retains a \c LoopInfo reference.
|
|
///
|
|
/// This allows it to collect loop objects for which analysis results may be
|
|
/// cached in the \c LoopAnalysisManager.
|
|
template <> class LoopAnalysisManagerFunctionProxy::Result {
|
|
public:
|
|
explicit Result(LoopAnalysisManager &InnerAM, LoopInfo &LI)
|
|
: InnerAM(&InnerAM), LI(&LI) {}
|
|
Result(Result &&Arg) : InnerAM(std::move(Arg.InnerAM)), LI(Arg.LI) {
|
|
// We have to null out the analysis manager in the moved-from state
|
|
// because we are taking ownership of the responsibilty to clear the
|
|
// analysis state.
|
|
Arg.InnerAM = nullptr;
|
|
}
|
|
Result &operator=(Result &&RHS) {
|
|
InnerAM = RHS.InnerAM;
|
|
LI = RHS.LI;
|
|
// We have to null out the analysis manager in the moved-from state
|
|
// because we are taking ownership of the responsibilty to clear the
|
|
// analysis state.
|
|
RHS.InnerAM = nullptr;
|
|
return *this;
|
|
}
|
|
~Result() {
|
|
// InnerAM is cleared in a moved from state where there is nothing to do.
|
|
if (!InnerAM)
|
|
return;
|
|
|
|
// Clear out the analysis manager if we're being destroyed -- it means we
|
|
// didn't even see an invalidate call when we got invalidated.
|
|
InnerAM->clear();
|
|
}
|
|
|
|
/// Accessor for the analysis manager.
|
|
LoopAnalysisManager &getManager() { return *InnerAM; }
|
|
|
|
/// Handler for invalidation of the proxy for a particular function.
|
|
///
|
|
/// If the proxy, \c LoopInfo, and associated analyses are preserved, this
|
|
/// will merely forward the invalidation event to any cached loop analysis
|
|
/// results for loops within this function.
|
|
///
|
|
/// If the necessary loop infrastructure is not preserved, this will forcibly
|
|
/// clear all of the cached analysis results that are keyed on the \c
|
|
/// LoopInfo for this function.
|
|
bool invalidate(Function &F, const PreservedAnalyses &PA,
|
|
FunctionAnalysisManager::Invalidator &Inv);
|
|
|
|
private:
|
|
LoopAnalysisManager *InnerAM;
|
|
LoopInfo *LI;
|
|
};
|
|
|
|
/// Provide a specialized run method for the \c LoopAnalysisManagerFunctionProxy
|
|
/// so it can pass the \c LoopInfo to the result.
|
|
template <>
|
|
LoopAnalysisManagerFunctionProxy::Result
|
|
LoopAnalysisManagerFunctionProxy::run(Function &F, FunctionAnalysisManager &AM);
|
|
|
|
// Ensure the \c LoopAnalysisManagerFunctionProxy is provided as an extern
|
|
// template.
|
|
extern template class InnerAnalysisManagerProxy<LoopAnalysisManager, Function>;
|
|
|
|
extern template class OuterAnalysisManagerProxy<FunctionAnalysisManager, Loop,
|
|
LoopStandardAnalysisResults &>;
|
|
/// A proxy from a \c FunctionAnalysisManager to a \c Loop.
|
|
typedef OuterAnalysisManagerProxy<FunctionAnalysisManager, Loop,
|
|
LoopStandardAnalysisResults &>
|
|
FunctionAnalysisManagerLoopProxy;
|
|
|
|
/// Returns the minimum set of Analyses that all loop passes must preserve.
|
|
PreservedAnalyses getLoopPassPreservedAnalyses();
|
|
}
|
|
|
|
#endif // LLVM_ANALYSIS_LOOPANALYSISMANAGER_H
|