[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