English

SMT-based Model Checking for Recursive Programs

Logic in Computer Science 2014-05-27 v2

Abstract

We present an SMT-based symbolic model checking algorithm for safety verification of recursive programs. The algorithm is modular and analyzes procedures individually. Unlike other SMT-based approaches, it maintains both "over-" and "under-approximations" of procedure summaries. Under-approximations are used to analyze procedure calls without inlining. Over-approximations are used to block infeasible counterexamples and detect convergence to a proof. We show that for programs and properties over a decidable theory, the algorithm is guaranteed to find a counterexample, if one exists. However, efficiency depends on an oracle for quantifier elimination (QE). For Boolean Programs, the algorithm is a polynomial decision procedure, matching the worst-case bounds of the best BDD-based algorithms. For Linear Arithmetic (integers and rationals), we give an efficient instantiation of the algorithm by applying QE "lazily". We use existing interpolation techniques to over-approximate QE and introduce "Model Based Projection" to under-approximate QE. Empirical evaluation on SV-COMP benchmarks shows that our algorithm improves significantly on the state-of-the-art.

Keywords

Cite

@article{arxiv.1405.4028,
  title  = {SMT-based Model Checking for Recursive Programs},
  author = {Anvesh Komuravelli and Arie Gurfinkel and Sagar Chaki},
  journal= {arXiv preprint arXiv:1405.4028},
  year   = {2014}
}

Comments

originally published as part of the proceedings of CAV 2014; fixed typos, better wording at some places

R2 v1 2026-06-22T04:15:33.046Z