Title
A Sound and Complete Proof Technique for Linearizability of Concurrent Data Structures
Abstract
Efficient implementations of data structures such as queues, stacks or hash-tables allow for concurrent access by many processes at the same time. To increase concurrency, these algorithms often completely dispose with locking, or only lock small parts of the structure. Linearizability is the standard correctness criterion for such a scenario—where a concurrent object is linearizable if all of its operations appear to take effect instantaneously some time between their invocation and return. The potential concurrent access to the shared data structure tremendously increases the complexity of the verification problem, and thus current proof techniques for showing linearizability are all tailored to specific types of data structures. In previous work, we have shown how simulation-based proof conditions for linearizability can be used to verify a number of subtle concurrent algorithms. In this article, we now show that conditions based on backward simulation can be used to show linearizability of every linearizable algorithm, that is, we show that our proof technique is both sound and complete. We exemplify our approach by a linearizability proof of a concurrent queue, introduced in Herlihy and Wing's landmark paper on linearizability. Except for their manual proof, none of the numerous other approaches have successfully treated this queue. Our approach is supported by a full mechanisation: both the linearizability proofs for case studies like the queue, and the proofs of soundness and completeness have been carried out with an interactive prover, which is KIV.
Year
DOI
Venue
2014
10.1145/2629496
ACM Trans. Comput. Log.
Keywords
Field
DocType
algorithms,kiv,verification,software/program verification,concurrent access,theorem proving,nonatomic refinement,refinement,linearizability,z
Linearizability,Discrete mathematics,Data structure,Concurrency,Queue,Correctness,Mathematical proof,Concurrent data structure,Gas meter prover,Mathematics
Journal
Volume
Issue
ISSN
15
4
1529-3785
Citations 
PageRank 
References 
23
0.82
47
Authors
3
Name
Order
Citations
PageRank
Gerhard Schellhorn176956.43
John Derrick217016.67
Heike Wehrheim31013104.85