TxRace: Efficient Data Race Detection Using Commodity Hardware Transactional Memory

被引:20
|
作者
Zhang, Tong [1 ]
Lee, Dongyoon [1 ]
Jung, Changhee [1 ]
机构
[1] Virginia Tech, Blacksburg, VA 24061 USA
关键词
data race; concurrency bug detection; hardware transactional memory; dynamic program analysis;
D O I
10.1145/2954679.2872384
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
Detecting data races is important for debugging shared-memory multithreaded programs, but the high runtime overhead prevents the wide use of dynamic data race detectors. This paper presents TxRace, a new software data race detector that leverages commodity hardware transactional memory (HTM) to speed up data race detection. TxRace instruments a multithreaded program to transform synchronization-free regions into transactions, and exploits the conflict detection mechanism of HTM for lightweight data race detection at runtime. However, the limitations of the current best-effort commodity HTMs expose several challenges in using them for data race detection: (1) lack of ability to pinpoint racy instructions, (2) false positives caused by cache line granularity of conflict detection, and (3) transactional aborts for non-conflict reasons (e.g., capacity or unknown). To overcome these challenges, TxRace performs lightweight HTM-based data race detection at first, and occasionally switches to slow yet precise data race detection only for the small fraction of execution intervals in which potential races are reported by HTM. According to the experimental results, TxRace reduces the average runtime overhead of dynamic data race detection from 11.68x to 4.65x with only a small number of false negatives.
引用
收藏
页码:159 / 173
页数:15
相关论文
共 50 条
  • [31] The Scalability of Disjoint Data Structures on a New Hardware Transactional Memory System
    Gong Su
    Stephen Heisig
    [J]. International Journal of Parallel Programming, 2015, 43 : 1192 - 1217
  • [32] Experiences with Disjoint Data Structures in a New Hardware Transactional Memory System
    Su, Gong
    Heisig, Stephen
    [J]. 2013 25TH INTERNATIONAL SYMPOSIUM ON COMPUTER ARCHITECTURE AND HIGH PERFORMANCE COMPUTING (SBAC-PAD), 2013, : 9 - 16
  • [33] ZEBRA: Data-Centric Contention Management in Hardware Transactional Memory
    Titos-Gil, Ruben
    Negi, Anurag
    Acacio, Manuel E.
    Garcia, Jose M.
    Stenstrom, Per
    [J]. IEEE TRANSACTIONS ON PARALLEL AND DISTRIBUTED SYSTEMS, 2014, 25 (05) : 1359 - 1369
  • [34] Clock Gate on Abort: Towards Energy-Efficient Hardware Transactional Memory
    Sanyal, Sutirtha
    Roy, Sourav
    Cristal, Adrian
    Unsal, Osman S.
    Valero, Mateo
    [J]. 2009 IEEE INTERNATIONAL SYMPOSIUM ON PARALLEL & DISTRIBUTED PROCESSING, VOLS 1-5, 2009, : 1920 - +
  • [35] Data Race Detection with Minimal Hardware Support
    Gonzalez-Alberquilla, Rekai
    Emmanuel Frati, Fernando
    Pinuel, Luis
    Strauss, Karin
    Ceze, Luis
    [J]. COMPUTER JOURNAL, 2014, 57 (05): : 675 - 692
  • [36] Trade: Precise dynamic race detection for scalable transactional memory systems
    Kestor, Gokcen
    Unsal, Osman S.
    Cristal, Adrian
    Tasiran, Serdar
    [J]. ACM Transactions on Parallel Computing, 2015, 2 (02)
  • [37] Mitigating the Mismatch between the Coherence Protocol and Conflict Detection in Hardware Transactional Memory
    Zhao, Lihang
    Chen, Lizhong
    Draper, Jeffrey
    [J]. 2014 IEEE 28TH INTERNATIONAL PARALLEL AND DISTRIBUTED PROCESSING SYMPOSIUM, 2014,
  • [38] Protecting Private Keys against Memory Disclosure Attacks using Hardware Transactional Memory
    Guan, Le
    Lin, Jingqiang
    Luo, Bo
    Jing, Jiwu
    Wang, Jing
    [J]. 2015 IEEE SYMPOSIUM ON SECURITY AND PRIVACY SP 2015, 2015, : 3 - 19
  • [39] Transactional Memory with Strong Atomicity Using Off-the-Shelf Memory Protection Hardware
    Abadi, Martin
    Harris, Tim
    Mehrara, Mojtaba
    [J]. ACM SIGPLAN NOTICES, 2009, 44 (04) : 185 - 195
  • [40] Accelerating Data Race Detection with Minimal Hardware Support
    Gonzalez-Alberquilla, Rodrigo
    Strauss, Karin
    Ceze, Luis
    Pinuel, Luis
    [J]. EURO-PAR 2011 PARALLEL PROCESSING, PT 1, 2011, 6852 : 27 - 38