Rethinking Incremental and Parallel Pointer Analysis Academic Article uri icon

abstract

  • Pointer analysis is at the heart of most interprocedural program analyses. However, scaling pointer analysis to large programs is extremely challenging. In this article, we study incremental pointer analysis and present a new algorithm for computing the points-to information incrementally (i.e., upon code insertion, deletion, and modification). Underpinned by new observations of incremental pointer analysis, our algorithm significantly advances the state of the art in that it avoids redundant computations and the expensive graph reachability analysis, and preserves precision as the corresponding whole program exhaustive analysis. Moreover, it is parallel within each iteration of fixed-point computation. We have implemented our algorithm, IPA, for Java based on the WALA framework and evaluated its performance extensively on real-world large, complex applications. Experimental results show that IPA achieves more than 200X speedups over existing incremental algorithms, two to five orders of magnitude faster than whole program pointer analysis, and also improves the performance of an incremental data race detector by orders of magnitude. Our IPA implementation is open source and has been adopted by WALA.

published proceedings

  • ACM TRANSACTIONS ON PROGRAMMING LANGUAGES AND SYSTEMS

author list (cited authors)

  • Liu, B., Huang, J., & Rauchwerger, L.

citation count

  • 13

complete list of authors

  • Liu, Bozhen||Huang, Jeff||Rauchwerger, Lawrence

publication date

  • March 2019