We present a technique for automatic verification of pointer programs based on a decision procedure for the monadic second-order logic on finite strings. We are concerned with a while-fragment of Pascal, which includes recursively-defined pointer structures but excludes pointer arithmetic. We define a logic of stores with interesting basic predicates such as pointer equality, tests for nil pointers, and garbage cells, as well as reachability along pointers. We present a complete decision procedure for Hoare triples based on this logic over loop-free code. Combined with explicit loop invariants, the decision procedure allows us to answer surprisingly detailed questions about small but non-trivial programs. If a program fails to satisfy a certain property, then we can automatically supply an initial store that provides a counterexample. Our technique has been fully and efficiently implemented for linear linked lists, and it extends in principle to tree structures. The resulting system can be used to verify extensive properties of smaller pointer programs and could be particularly useful in a teaching environment.
CITATION STYLE
Jensen, J. L., Jørgensen, M. E., Klarlund, N., & Schwartzbach, M. I. (1997). Automatic Verification of Pointer Programs using Monadic Second-Order Logic. SIGPLAN Notices (ACM Special Interest Group on Programming Languages), 32(5), 226–234. https://doi.org/10.1145/258916.258936
Mendeley helps you to discover research relevant for your work.