Abstract
We describe an abstract domain for representing useful invariants of heap-manipulating programs (in presence of recursive data structures and pointer arithmetic) written in languages like C or low-level code. This abstract domain allows representation of must and may equalities among pointer expressions. Pointer expressions contain existentially or universally quantified integer variables guarded by some base domain constraint. We allow quantification of a special form, namely Æ quantification, to balance expressiveness with efficient automated deduction. The existential quantification is over some dummy non-program variables, which are automatically made explicit by our analysis to express useful program invariants. The universal quantifier is used to express properties of collections of memory locations. Our abstract interpreter automatically computes invariants about programs over this abstract domain. We present initial experimental results demonstrating the effectiveness of this abstract domain on some common coding patterns. © Springer-Verlag Berlin Heidelberg 2007.
Cite
CITATION STYLE
Gulwani, S., & Tiwari, A. (2007). An abstract domain for analyzing heap-manipulating low-level software. In Lecture Notes in Computer Science (including subseries Lecture Notes in Artificial Intelligence and Lecture Notes in Bioinformatics) (Vol. 4590 LNCS, pp. 379–392). Springer Verlag. https://doi.org/10.1007/978-3-540-73368-3_42
Register to see more suggestions
Mendeley helps you to discover research relevant for your work.