[PATCH] D72816: [CallGraph] Add invalidate method.
Alina Sbirlea via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Wed Jan 15 17:20:12 PST 2020
asbirlea created this revision.
asbirlea added reviewers: Eugene.Zelenko, chandlerc.
Herald added subscribers: sanjoy.google, hiraditya.
Herald added a project: LLVM.
Add invalidate method in CallGraph.
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D72816
Files:
llvm/include/llvm/Analysis/CallGraph.h
llvm/lib/Analysis/CallGraph.cpp
Index: llvm/lib/Analysis/CallGraph.cpp
===================================================================
--- llvm/lib/Analysis/CallGraph.cpp
+++ llvm/lib/Analysis/CallGraph.cpp
@@ -57,6 +57,13 @@
#endif
}
+bool CallGraph::invalidate(Module &M, const PreservedAnalyses &PA,
+ ModuleAnalysisManager::Invalidator &) {
+ auto PAC = PA.getChecker<CallGraphAnalysis>();
+ return !(PAC.preserved() || PAC.preservedSet<AllAnalysesOn<Module>>() ||
+ PAC.preservedSet<CFGAnalyses>());
+}
+
void CallGraph::addToCallGraph(Function *F) {
CallGraphNode *Node = getOrInsertFunction(F);
Index: llvm/include/llvm/Analysis/CallGraph.h
===================================================================
--- llvm/include/llvm/Analysis/CallGraph.h
+++ llvm/include/llvm/Analysis/CallGraph.h
@@ -112,6 +112,9 @@
/// Returns the module the call graph corresponds to.
Module &getModule() const { return M; }
+ bool invalidate(Module &M, const PreservedAnalyses &PA,
+ ModuleAnalysisManager::Invalidator &);
+
inline iterator begin() { return FunctionMap.begin(); }
inline iterator end() { return FunctionMap.end(); }
inline const_iterator begin() const { return FunctionMap.begin(); }
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D72816.238398.patch
Type: text/x-patch
Size: 1248 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20200116/bf366265/attachment.bin>
More information about the llvm-commits
mailing list