A Lock-Based STM Protocol That Satisfies Opacity and Progressiveness

The aim of a software transactional memory (STM) system is to facilitate the delicate problem of low-level concurrency management, i.e. the design of programs made up of processes/threads that concurrently access shared objects. To that end, a STM system allows a programmer to write transactions accessing shared objects, without having to take care of the fact that these objects are concurrently accessed: the programmer is discharged from the delicate problem of concurrency management. Given a transaction, the STM system commits or aborts it. Ideally, it has to be efficient (this is measured by the number of transactions committed per time unit), while ensuring that as few transactions as possible are aborted. From a safety point of view (the one addressed in this paper), a STM system has to ensure that, whatever its fate (commit or abort), each transaction always operates on a consistent state. STM systems have recently received a lot of attention. Among the proposed solutions, lock-based systems and clock-based systems have been particularly investigated. Their design is mainly efficiency-oriented, the properties they satisfy are not always clearly stated, and few of them are formally proved. This paper presents a lock-based STM system designed from simple basic principles. Its main features are the following: it (1) uses visible reads, (2) does not require the shared memory to manage several versions of each object, (3) uses neither timestamps, nor version numbers, (4) satisfies the opacity safety property, (5) aborts a transaction only when it conflicts with some other live transaction (progressiveness property), (6) never aborts a write only transaction, (7) employs only bounded control variables, (8) has no centralized contention point, and (9) is formally proved correct.

[1]  Michael F. Spear,et al.  Conflict Detection and Validation Strategies for Software Transactional Memory , 2006, DISC.

[2]  William N. Scherer,et al.  Advanced contention management for dynamic software transactional memory , 2005, PODC '05.

[3]  Torvald Riegel,et al.  A Lazy Snapshot Algorithm with Eager Validation , 2006, DISC.

[4]  Nir Shavit,et al.  Transactional Locking II , 2006, DISC.

[5]  Torvald Riegel,et al.  Time-based transactional memory with scalable time bases , 2007, SPAA '07.

[6]  Maurice Herlihy,et al.  Linearizability: a correctness condition for concurrent objects , 1990, TOPL.

[7]  Rachid Guerraoui,et al.  Partial snapshot objects , 2008, SPAA '08.

[8]  Prasad Jayanti,et al.  Efficient and practical constructions of LL/SC variables , 2003, PODC '03.

[9]  Michael Mitzenmacher,et al.  Compressed bloom filters , 2002, TNET.

[10]  Rachid Guerraoui,et al.  Toward a theory of transactional contention managers , 2005, PODC '05.

[11]  Nir Shavit,et al.  Maintaining Consistent Transactional States without a Global Clock , 2008, SIROCCO.

[12]  Hagit Attiya,et al.  Atomic Snapshots in O(n log n) Operations , 1998, SIAM J. Comput..

[13]  Michel Raynal,et al.  A Lock-based Protocol for Software Transactional Memory , 2008 .

[14]  Burton H. Bloom,et al.  Space/time trade-offs in hash coding with allowable errors , 1970, CACM.

[15]  Michael L. Scott Sequential Specification of Transactional Memory Semantics , 2006 .

[16]  Mark Moir Practical implementations of non-blocking synchronization primitives , 1997, PODC '97.

[17]  David Hutchison,et al.  Scalable Bloom Filters , 2007, Inf. Process. Lett..

[18]  Nir Shavit,et al.  Software transactional memory , 1995, PODC '95.

[19]  Rachid Guerraoui,et al.  On the correctness of transactional memory , 2008, PPoPP.

[20]  Christos H. Papadimitriou,et al.  The serializability of concurrent database updates , 1979, JACM.

[21]  João P. Cachopo,et al.  Versioned boxes as the basis for memory transactions , 2006, Sci. Comput. Program..

[22]  Rachid Guerraoui,et al.  Transactions are back---but are they the same? , 2008, SIGA.

[23]  Hagit Attiya Needed: foundations for transactional memory , 2008, SIGA.