RegionTrack: A Trace-based Sound and Complete Checker to Debug Transactional Atomicity Violations and Non-Serializable Traces
Atomicity is a correctness criterion to reason about isolated code regions in a multithreaded program when they are executed concurrently. However, dynamic instances of these code regions, called transactions, may fail to behave atomically, resulting in transactional atomicity violations. Existing d...
Saved in:
Main Authors | , , , , , , |
---|---|
Format | Journal Article |
Language | English |
Published |
10.08.2020
|
Subjects | |
Online Access | Get full text |
Cover
Loading…
Summary: | Atomicity is a correctness criterion to reason about isolated code regions in
a multithreaded program when they are executed concurrently. However, dynamic
instances of these code regions, called transactions, may fail to behave
atomically, resulting in transactional atomicity violations. Existing dynamic
online atomicity checkers incur either false positives or false negatives in
detecting transactions experiencing transactional atomicity violations. This
paper proposes RegionTrack. RegionTrack tracks cross-thread dependences at the
event, dynamic subregion, and transaction levels. It maintains both dynamic
subregions within selected transactions and transactional happens-before
relations through its novel timestamp propagation approach. We prove that
RegionTrack is sound and complete in detecting both transactional atomicity
violations and non-serializable traces. To the best of our knowledge, it is the
first online technique that precisely captures the transitively closed set of
happens-before relations over all conflicting events with respect to every
running transaction for the above two kinds of issues. We have evaluated
RegionTrack on 19 subjects of the DaCapo and the Java Grande Forum benchmarks.
The empirical results confirm that RegionTrack precisely detected all those
transactions which experienced transactional atomicity violations and
identified all non-serializable traces. The overall results also show that
RegionTrack incurred 1.10x and 1.08x lower memory and runtime overheads than
Velodrome and 2.10x and 1.21x lower than Aerodrome, respectively. Moreover, it
incurred 2.89x lower memory overhead than DoubleChecker. On average, Velodrome
detected about 55% fewer violations than RegionTrack, which in turn reported
about 3%-70% fewer violations than DoubleChecker. |
---|---|
DOI: | 10.48550/arxiv.2008.04479 |