Opportunities and Pitfalls of Multi-Core Scaling Using Hardware Transaction Memory

Zhaoguo Wang,Hao Qian,Haibo Chen,Jinyang Li
DOI: https://doi.org/10.1145/2500727.2500745
2013-01-01
Abstract:Hardware transactional memory, which holds the promise to simplify and scale up multicore synchronization, has recently become available in main stream processors in the form of Intel's restricted transactional memory (RTM). Will RTM be a panacea for multi-core scaling? This paper tries to shed some light on this question by studying the performance scalability of a concurrent skip list using competing synchronization techniques, including fine-grained locking, lock-free and RTM (using both Intel's RTM emulator and a real RTM machine). Our experience suggests that RTM indeed simplifies the implementation, however, a lot of care must be taken to get good performance. Specifically, to avoid excessive aborts due to RTM capacity miss or conflicts, programmers should move memory allocation/deallocation out of RTM region, tuning fallback functions, and use compiler optimization.
What problem does this paper attempt to address?