PRECISE Seminar: Modular Reasoning about Heap Paths via Effectively Propositional Formulas

PRECISE Seminar: Modular Reasoning about Heap Paths via Effectively Propositional Formulas
Mon, January 27, 2014 @ 1:00pm EST
Levine Hall - Room 307
3330 Walnut Street
Philadelphia, PA 19104
Speaker
Shachar Itzhaky
Tel Aviv University
Abstract

First order logic with transitive closure, and separation logic enable elegant interactive verification of heap-manipulating programs. However, undecidabilty results and high asymptotic complexity of checking validity preclude complete automatic verification of such programs, even when loop invariants and procedure contracts are specified as formulas in these logics. This work tackles the problem of procedure-modular verification of reachability properties of heap-manipulating programs using efficient decision procedures that are complete: that is, a SAT solver must generate a counterexample whenever a program does not satisfy its specification. By (a) requiring each procedure modifies a fixed set of heap partitions and creates a bounded amount of heap sharing, and (b) restricting program contracts and loop invariants to use only deterministic paths in the heap, we show that heap reachability updates can be described in a simple manner. The restrictions force program specifications and verification conditions to lie within a fragment of first-order logic with transitive closure that is reducible to effectively propositional logic, and hence facilitate sound, complete and efficient verification. We implemented a tool atop Z3 and report on preliminary experiments that establish the correctness of several programs that manipulate linked data structures.

Speaker Bio

Shachar took his undergraduate studies in computer science at the Open University, and then entered a Master program at Tel Aviv University under the supervision of Prof. Mooly Sagiv. His Master thesis was a simple method for inductive synthesis of short code fragments with applications to finite differencing. After obtaining a Master's degree he continued as a graduate student under the supervision of Prof. Sagiv, in the area of automated software verification.