Automatic Verification of Pointer Programs using Monadic Second-Order Logic

9Citations
Citations of this article
14Readers
Mendeley users who have this article in their library.

Abstract

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.

Cite

CITATION STYLE

APA

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

Register to see more suggestions

Mendeley helps you to discover research relevant for your work.

Already have an account?

Save time finding and organizing research with Mendeley

Sign up for free