PLSESep 28, 2017

Thread-Modular Static Analysis for Relaxed Memory Models

arXiv:1709.10077v118 citations
Originality Incremental advance
AI Analysis

This work addresses the challenge of accurate static analysis for concurrent programs on modern processors, representing an incremental advance in domain-specific verification techniques.

The paper tackles the problem of analyzing concurrent software on weak memory models by proposing a static analysis method that reduces false alarms and unsound proofs, achieving significant accuracy improvements with moderate runtime overhead.

We propose a memory-model-aware static program analysis method for accurately analyzing the behavior of concurrent software running on processors with weak consistency models such as x86-TSO, SPARC-PSO, and SPARC-RMO. At the center of our method is a unified framework for deciding the feasibility of inter-thread interferences to avoid propagating spurious data flows during static analysis and thus boost the performance of the static analyzer. We formulate the checking of interference feasibility as a set of Datalog rules which are both efficiently solvable and general enough to capture a range of hardware-level memory models. Compared to existing techniques, our method can significantly reduce the number of bogus alarms as well as unsound proofs. We implemented the method and evaluated it on a large set of multithreaded C programs. Our experiments showthe method significantly outperforms state-of-the-art techniques in terms of accuracy with only moderate run-time overhead.

Foundations

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

Your Notes