2LS: Heap Analysis and Memory Safety (Competition Contribution)

Viktor Malik,Martin Hruska,Peter Schrammel,Tomas Vojnar
DOI: https://doi.org/10.48550/arXiv.1903.00712
2020-01-03
Abstract:2LS is a framework for analysis of sequential C programs that can verify and refute program assertions and termination. The 2LS framework is built upon the CPROVER infrastructure and implements template-based synthesis techniques, e.g. to find invariants and ranking functions, and incremental loop unwinding techniques to find counterexamples and k-induction proofs. The main improvements in this year's version are the ability of 2LS to analyse programs requiring combined reasoning about shape and content of dynamic data structures, and an instrumentation for memory safety properties.
Software Engineering,Logic in Computer Science
What problem does this paper attempt to address?