Adaptive and efficient abortable mutual exclusion

Scott and Scherer recently pointed out that existing locking algorithms do not meet a need that arises in practical systems. Specifically, database systems and real time systems need mutual exclusion locks that support the abort capability, which makes it possible for a process that waits "too long" to abort its attempt to acquire the lock. Further, to ensure high performance in cache coherent and NUMA multiprocessors, the locking algorithm should generate as few remote references as possible.To help meet this need, Scott and Scherer in 2001 and Scott in 2002 proposed some local-spin abortable mutual exclusion algorithms, but these algorithms have Shortcomings. Specifically, the algorithm by Scott and Scherer allows an aborting process to be blocked by other processes, which is unacceptable. The subsequent algorithms by Scott overcome this shortcoming, but these have unbounded worst-case time and space complexity.In this paper, we present art efficient local-spin algorithm with the following complexity: in each acquisition and release/abort of the lock, a process makes O(min(k, log n)) remote memory references, where k is the point contention and n is the total number of processes for which the lock is designed. Thus, not only is the algorithm adaptive, but also its worst-case time complexity has a small logarithmic bound. The algorithm has O(n) space complexity. To our knowledge, this is the first abortable mutual exclusion algorithm that has bounded time complexity and requires only a bounded number of memory words.

[1]  Hagit Attiya,et al.  Adaptive and efficient mutual exclusion , 2002, PODC '00.

[2]  Michael L. Scott,et al.  Scalable reader-writer synchronization for shared-memory multiprocessors , 1991, PPOPP '91.

[3]  Mark Moir,et al.  A simple local-spin group mutual exclusion algorithm , 1999, PODC '99.

[4]  Michael L. Scott,et al.  Non-blocking timeout in scalable queue-based spin locks , 2002, PODC '02.

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

[6]  Thomas E. Anderson,et al.  The Performance of Spin Lock Alternatives for Shared-Memory Multiprocessors , 1990, IEEE Trans. Parallel Distributed Syst..

[7]  Hagit Attiya,et al.  Adaptive and efficient mutual exclusion (extended abstract) , 2000, PODC.

[8]  Robert Sims,et al.  Alpha architecture reference manual , 1992 .

[9]  Richard L. Sites,et al.  Alpha Architecture Reference Manual , 1995 .

[10]  Manhoi Choy,et al.  Adaptive solutions to the mutual exclusion problem , 1993, PODC '93.

[11]  Travis S. Craig Queuing spin lock algorithms to support timing predictability , 1993, 1993 Proceedings Real-Time Systems Symposium.

[12]  Michael L. Scott,et al.  Algorithms for scalable synchronization on shared-memory multiprocessors , 1991, TOCS.

[13]  David L Weaver,et al.  The SPARC architecture manual : version 9 , 1994 .

[14]  G. S. Graham A New Solution of Dijkstra ' s Concurrent Programming Problem , 2022 .

[15]  William N. Scherer,et al.  Scalable queue-based spin locks with timeout , 2001, PPoPP '01.

[16]  Edsger W. Dijkstra,et al.  Solution of a problem in concurrent programming control , 1965, CACM.

[17]  Michel Raynal,et al.  Algorithms for mutual exclusion , 1986 .

[18]  Anoop Gupta,et al.  Parallel computer architecture - a hardware / software approach , 1998 .

[19]  Yehuda Afek,et al.  Long-lived adaptive collect with applications , 1999, 40th Annual Symposium on Foundations of Computer Science (Cat. No.99CB37039).

[20]  James H. Anderson,et al.  Fast and Scalable Mutual Exclusion , 1999, DISC.

[21]  Prasad Jayanti f-arrays: implementation and applications , 2002, PODC '02.