Generating precise and concise procedure summaries

G Yorsh, E Yahav, S Chandra - Proceedings of the 35th annual ACM …, 2008 - dl.acm.org
Proceedings of the 35th annual ACM SIGPLAN-SIGACT symposium on Principles of …, 2008dl.acm.org
We present a framework for generating procedure summaries that are (a) precise-applying
the summary in a given context yields the same result as re-analyzing the procedure in that
context, and (b) concise-the summary exploits the commonalitiesin the ways the procedure
manipulates abstract values, and does not contain superfluous context information. The use
of a precise and concise procedure summary inmodular analyses provides a way to capture
infinitely many possible contexts in a finite way; in interprocedural analyses, it provides a …
We present a framework for generating procedure summaries that are (a) precise - applying the summary in a given context yields the same result as re-analyzing the procedure in that context, and(b) concise - the summary exploits the commonalitiesin the ways the procedure manipulates abstract values, and does not contain superfluous context information.
The use of a precise and concise procedure summary inmodular analyses provides a way to capture infinitely many possible contexts in a finite way; in interprocedural analyses, it provides a compact representation of an explicit input-output summary table without loss of precision.
We define a class of abstract domains and transformers for which precise and concise summaries can be efficiently generated using our framework. Our framework is rich enough to encode a wide range of problems, including all IFDS and IDE problems. In addition, we show how the framework is instantiated to provide novel solutions to two hard problems: modular linear constant propagation and modular typestate verification, both in the presence of aliasing. We implemented a prototype of our framework that computes summaries for the typestate domain, and report on preliminary experimental results.
ACM Digital Library