1. Precise Call Graphs for C Programs with Function Pointers
- Author
-
Ana Milanova, Atanas Rountev, and Barbara G. Ryder
- Subjects
Tagged pointer ,Pointer aliasing ,Computer science ,Programming language ,Opaque pointer ,Smart pointer ,Call graph ,computer.software_genre ,Function pointer ,Pointer swizzling ,Dangling pointer ,Pointer (computer programming) ,Escape analysis ,Pointer analysis ,computer ,Software - Abstract
The use of pointers presents serious problems for software productivity tools for software understanding, restructuring, and testing. Pointers enable indirect memory accesses through pointer dereferences, as well as indirect procedure calls (e.g., through function pointers in C). Such indirect accesses and calls can be disambiguated with pointer analysis. In this paper we evaluate the precision of one specific pointer analysis (the FA pointer analysis by Zhang et al.) for the purposes of call graph construction for C programs with function pointers. The analysis is incorporated in a production-strength code-browsing tool from Siemens Corporate Research in which the program call graph is used as a primary tool for code understanding. The FA pointer analysis uses an inexpensive, almost-linear, flow- and context-insensitive algorithm. To measure analysis precision, we compare the call graph constructed by this analysis with the most precise call graph obtainable by a large category of existing pointer analyses. Surprisingly, for all our data programs the FA analysis achieves the best possible precision. This result indicates that for the purposes of call graph construction, inexpensive pointer analyses may provide precision comparable to the precision of expensive pointer analyses.
- Published
- 2004
- Full Text
- View/download PDF