Call Graph Construction
A call graph shows the method calling relationship of a program. It is a directed graph, whose nodes represent different methods, and edges represent caller -> callee relationship.
SootUp contains several call graph construction algorithms. Below, we show how you can use each of these.
Creating the Type Hierarchy
All the call graph construction algorithms require the view to access the type hierarchy for resolving method calls based of sub typing relationship. Below, we show how to create a type hierarchy:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |  | 
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |  | 
Defining an Entry Method
All the call graph construction algorithms require an entry method to start with. In java application, you usually define the main method. However, it is possible to define arbitrary entry methods depending on your needs. Below, we show how to define such an entry method:
| 1 2 3 4 5 6 7 8 9 |  | 
| 1 |  | 
Class Hierarchy Analysis
Class Hierarchy Analysis (CHA) algorithm is the most sound call graph construction algorithm available in SootUp. It soundly includes all implementers of an interface, when resolving a method call on an interface. You can construct a call graph with CHA as follows:
| 1 2 3 4 5 6 7 |  | 
| 1 2 3 4 5 6 7 8 |  | 
Rapid Type Analysis
Rapid Type Analysis (RTA) algorithm constructs a rather precise version of the call graph that the CHA constructs. It refines CHA by considering only the instantiated implementers of an interface, when resolving a method call on an interface. You can construct a call graph with RTA as follows:
| 1 2 3 4 5 6 7 |  | 
| 1 2 3 4 5 6 7 8 9 10 11 12 13 |  | 
Variable Type Analysis
Variable Type Analysis (VTA) algorithm further refines the call graph that the RTA constructs. It refines RTA by considering only the assigned instantiations of the implementers of an interface, when resolving a method call on an interface. When considering assignments, we usually need to consider pointer (points-to) relationship.
Info
VTA algorithm was implemented using the Spark pointer analysis framework. A reimplementation of Spark in SootUp is currently under development.
Spark requires an initial call graph to begin with. You can use one of the call graphs that we have constructed above. You can construct a call graph with VTA as follows:
| 1 2 3 |  | 
| 1 2 3 4 5 6 7 8 9 10 11 12 13 |  |