SEMar 7, 2014

Automatically finding atomic regions for fixing bugs in Concurrent programs

arXiv:1403.1749v15 citations
Originality Incremental advance
AI Analysis

This addresses the challenge of debugging concurrent software for developers, though it is incremental as it builds on existing verification techniques.

The paper tackles the problem of automatically fixing bugs in concurrent programs by inferring minimal atomic blocks that ensure correctness, achieving a 1.7x speed improvement over prior methods.

This paper presents a technique for automatically constructing a fix for buggy concurrent programs: given a concurrent program that does not satisfy user-provided assertions, we infer atomic blocks that fix the program. An atomic block protects a piece of code and ensures that it runs without interruption from other threads. Our technique uses a verification tool as a subroutine to find the smallest atomic regions that remove all bugs in a given program. Keeping the atomic regions small allows for maximum concurrency. We have implemented our approach in a tool called AtomicInf. A user of AtomicInf can choose between strong and weak atomicity semantics for the inferred fix. While the former is simpler to find, the latter provides more information about the bugs that got fixed. We ran AtomicInf on several benchmarks and came up with the smallest and the most precise atomic regions in all of them. We implemented an earlier technique to our setting and observed that AtomicInf is 1.7 times faster on an average as compared to an earlier approach.

Foundations

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

Your Notes