LOPLSEDec 15, 2016

A Light-Weight Approach for Verifying Multi-Threaded Programs with CPAchecker

arXiv:1612.04983v113 citations
Originality Incremental advance
AI Analysis

This addresses the need for efficient verification tools for multi-threaded software, which is increasingly important due to multi-core processors, but it is an incremental extension of an existing framework.

The paper tackles the problem of verifying multi-threaded programs by introducing a new configurable program analysis integrated into CPAchecker, enhancing its applicability and enabling verification of properties like reachability and deadlock detection.

Verifying multi-threaded programs is becoming more and more important, because of the strong trend to increase the number of processing units per CPU socket. We introduce a new configurable program analysis for verifying multi-threaded programs with a bounded number of threads. We present a simple and yet efficient implementation as component of the existing program-verification framework CPAchecker. While CPAchecker is already competitive on a large benchmark set of sequential verification tasks, our extension enhances the overall applicability of the framework. Our implementation of handling multiple threads is orthogonal to the abstract domain of the data-flow analysis, and thus, can be combined with several existing analyses in CPAchecker, like value analysis, interval analysis, and BDD analysis. The new analysis is modular and can be used, for example, to verify reachability properties as well as to detect deadlocks in the program. This paper includes an evaluation of the benefit of some optimization steps (e.g., changing the iteration order of the reachability algorithm or applying partial-order reduction) as well as the comparison with other state-of-the-art tools for verifying multi-threaded programs.

Foundations

The foundational work for this paper's niche, ranked by how specifically the neighbourhood builds on it — not by global fame.

Your Notes