Added function IsLeafMethod to identify leaf methods.
This will use the CallGraph only if one is provided.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@950 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/include/llvm/Analysis/CallGraph.h b/include/llvm/Analysis/CallGraph.h
index 3c6f7cc..5f259d5 100644
--- a/include/llvm/Analysis/CallGraph.h
+++ b/include/llvm/Analysis/CallGraph.h
@@ -89,4 +89,18 @@
 
 }  // end namespace cfg
 
+
+//******************* Externally Visible Functions *************************/
+
+
+// Checks if a method contains any call instructions.
+// Note that this uses the call graph only if one is provided.
+// It does not build the call graph.
+// 
+bool	IsLeafMethod       (const Method* method,
+                            const cfg::CallGraph* callGraph = NULL);
+
+
+//**************************************************************************/
+
 #endif
diff --git a/lib/Analysis/IPA/CallGraph.cpp b/lib/Analysis/IPA/CallGraph.cpp
index 3f997a9..51072e7 100644
--- a/lib/Analysis/IPA/CallGraph.cpp
+++ b/lib/Analysis/IPA/CallGraph.cpp
@@ -70,3 +70,26 @@
   for (CallGraph::const_iterator I = CG.begin(), E = CG.end(); I != E; ++I)
     o << I->second;
 }
+
+
+
+// 
+// Checks if a method contains any call instructions.
+// Note that this uses the call graph only if one is provided.
+// It does not build the call graph.
+// 
+bool IsLeafMethod(const Method* M, const cfg::CallGraph* CG) {
+  if (CG) {
+    const cfg::CallGraphNode *cgn = (*CG)[M];
+    return (cgn->begin() == cgn->end());
+  }
+  else {
+    for (Method::inst_const_iterator I = M->inst_begin(), E = M->inst_end();
+         I != E; ++I)
+      if ((*I)->getOpcode() == Instruction::Call)
+        return false;
+    return true;
+  }
+}
+
+