[PM] Introduce an analysis set used to preserve all analyses over
a function's CFG when that CFG is unchanged. This allows transformation passes to simply claim they preserve the CFG and analysis passes to check for the CFG being preserved to remove the fanout of all analyses being listed in all passes. I've gone through and removed or cleaned up as many of the comments reminding us to do this as I could. Differential Revision: https://reviews.llvm.org/D28627 llvm-svn: 292054
This commit is contained in:
@@ -31,6 +31,15 @@ char PostDominatorTreeWrapperPass::ID = 0;
|
||||
INITIALIZE_PASS(PostDominatorTreeWrapperPass, "postdomtree",
|
||||
"Post-Dominator Tree Construction", true, true)
|
||||
|
||||
bool PostDominatorTree::invalidate(Function &F, const PreservedAnalyses &PA,
|
||||
FunctionAnalysisManager::Invalidator &) {
|
||||
// Check whether the analysis, all analyses on functions, or the function's
|
||||
// CFG have been preserved.
|
||||
auto PAC = PA.getChecker<PostDominatorTreeAnalysis>();
|
||||
return !(PAC.preserved() || PAC.preservedSet<AllAnalysesOn<Function>>() ||
|
||||
PAC.preservedSet<CFGAnalyses>());
|
||||
}
|
||||
|
||||
bool PostDominatorTreeWrapperPass::runOnFunction(Function &F) {
|
||||
DT.recalculate(F);
|
||||
return false;
|
||||
|
||||
Reference in New Issue
Block a user