Affiliation:
1. Microsoft, Redmond, WA
2. University of Central Florida, Orlando, FL, USA
Abstract
Nonblocking data structures allow scalable and thread-safe access to shared data. They provide individual operations that appear to execute atomically. However, it is often desirable to execute multiple operations atomically in a transactional manner. Previous solutions, such as Software Transactional Memory (STM) and transactional boosting, manage transaction synchronization separately from the underlying data structure’s thread synchronization. Although this reduces programming effort, it leads to overhead associated with additional synchronization and the need to rollback aborted transactions. In this work, we present a new methodology for transforming high-performance lock-free linked data structures into high-performance lock-free transactional linked data structures without revamping the data structures’ original synchronization design. Our approach leverages the semantic knowledge of the data structure to eliminate the overhead of false conflicts and rollbacks. We encapsulate all operations, operands, and transaction status in a transaction descriptor, which is shared among the nodes accessed by the same transaction. We coordinate threads to help finish the remaining operations of delayed transactions based on their transaction descriptors. When a transaction fails, we recover the correct abstract state by reversely interpreting the logical status of a node. We also present an obstruction-free version of our algorithm that can be applied to dynamic execution scenarios and an example of our approach applied to a hash map. In our experimental evaluation using transactions with randomly generated operations, our lock-free transactional data structures outperform the transactional boosted ones by 70% on average. They also outperform the alternative STM-based approaches by a factor of 2 to 13 across all scenarios. More importantly, we achieve 4,700 to 915,000 times fewer spurious aborts than the alternatives.
Funder
National Science Foundation
Publisher
Association for Computing Machinery (ACM)
Subject
Computational Theory and Mathematics,Computer Science Applications,Hardware and Architecture,Modelling and Simulation,Software
Cited by
9 articles.
订阅此论文施引文献
订阅此论文施引文献,注册后可以免费订阅5篇论文的施引文献,订阅后可以查看论文全部施引文献
1. Lock-Free Concurrent Smart Contracts;2024 IEEE International Conference on Blockchain and Cryptocurrency (ICBC);2024-05-27
2. C4: verified transactional objects;Proceedings of the ACM on Programming Languages;2022-04-29
3. Semantic Conflict Detection for Transactional Data Structure Libraries;Proceedings of the 33rd ACM Symposium on Parallelism in Algorithms and Architectures;2021-07-06
4. PETRA;ACM Transactions on Architecture and Code Optimization;2021-03
5. Multi-Gigabit CO-OFDM System over SMF and MMF Links for 5G URLLC Backhaul Network;Computers, Materials & Continua;2021