* Add support for Invoke instructions
authorChris Lattner <sabre@nondot.org>
Sat, 13 Oct 2001 06:33:19 +0000 (06:33 +0000)
committerChris Lattner <sabre@nondot.org>
Sat, 13 Oct 2001 06:33:19 +0000 (06:33 +0000)
* Add support for indirect calls

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@752 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Analysis/IPA/CallGraph.cpp

index 87dbf2b4255d3698ed181de63b58ba421621bc1e..3f997a9dd40c3c8815b495d4cbfea3e317cb6e13 100644 (file)
@@ -4,6 +4,10 @@
 // eventually implement call graph serialization and deserialization for
 // annotation support.
 //
+// This call graph represents a dynamic method invocation as a null method node.
+// A call graph may only have up to one null method node that represents all of
+// the dynamic method invocations.
+//
 //===----------------------------------------------------------------------===//
 
 #include "llvm/Analysis/CallGraph.h"
@@ -12,6 +16,7 @@
 #include "llvm/Module.h"
 #include "llvm/Method.h"
 #include "llvm/iOther.h"
+#include "llvm/iTerminators.h"
 #include <algorithm>
 
 using namespace cfg;
@@ -36,10 +41,13 @@ CallGraphNode *CallGraph::getNodeFor(Method *M) {
 void CallGraph::addToCallGraph(Method *M) {
   CallGraphNode *Node = getNodeFor(M);
 
-  for (Method::inst_iterator II = M->inst_begin(), IE = M->inst_end();
-       II != IE; ++II) {
-    if (CallInst *CI = dyn_cast<CallInst>(*II))
+  for (Method::inst_iterator I = M->inst_begin(), E = M->inst_end();
+       I != E; ++I) {
+    // Dynamic calls will cause Null nodes to be created
+    if (CallInst *CI = dyn_cast<CallInst>(*I))
       Node->addCalledMethod(getNodeFor(CI->getCalledMethod()));
+    else if (InvokeInst *II = dyn_cast<InvokeInst>(*I))
+      Node->addCalledMethod(getNodeFor(II->getCalledMethod()));
   }
 }