Semi-sparse flow-sensitive pointer analysis
Ben Hardekopf and Calvin Lin

Abstract:

Pointer analysis is a prerequisite for many program analyses, and the effectiveness of these analyses depends on the precision of the pointer information they receive. Two major axes of pointer analysis precision are flow-sensitivity and context-sensitivity, and while there has been significant recent progress regarding scalable context-sensitive pointer analysis, relatively little progress has been made in improving the scalability of flow-sensitive pointer analysis.

This paper presents a new interprocedural, flow-sensitive pointer analysis algorithm that combines two ideas-semi-sparse analysis and a novel use of BDDs-that arise from a careful understanding of the unique challenges that face flow-sensitive pointer analysis. We evaluate our algorithm on 12 C benchmarks ranging from 11K to 474K lines of code. Our fastest algorithm is on average 197x faster and uses 4.6x less memory than the state of the art, and it can analyze programs that are an order of magnitude larger than the previous state of the art.

Published:

"Semi-sparse flow-sensitive pointer analysis"
Ben Hardekopf and Calvin Lin.
Proceedings of the 2009 36th annual ACM SIGPLAN-SIGACT symposium on Principles of programming languages (POPL'09) , Savannah, GA, January 2009.

Download:

Paper:

BibTeX Entry:

@inproceedings{1480911,
 author = {Hardekopf, Ben and Lin, Calvin},
 title = {Semi-sparse flow-sensitive pointer analysis},
 booktitle = {POPL '09: Proceedings of the 36th annual ACM SIGPLAN-SIGACT symposium on Principles of programming languages},
 year = {2009},
 isbn = {978-1-60558-379-2},
 pages = {226--238},
 location = {Savannah, GA, USA},
 doi = {http://doi.acm.org/10.1145/1480881.1480911},
 publisher = {ACM},
 address = {New York, NY, USA},
 }

Valid CSS! Valid HTML 4.01!