FastTrack: Efficient and Precise Dynamic Race Detection

被引:97
|
作者
Flanagan, Cormac [1 ]
Freund, Stephen N. [2 ]
机构
[1] Univ Calif Santa Cruz, Dept Comp Sci, Santa Cruz, CA 95064 USA
[2] Williams Coll, Dept Comp Sci, Williamstown, MA 01267 USA
关键词
Languages; Algorithms; Verification; Race conditions; concurrency; dynamic analysis;
D O I
10.1145/1543135.1542490
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
Multithreaded programs are notoriously prone to race conditions. Prior work on dynamic race detectors includes fast but imprecise race detectors that report false alarms, as well as slow but precise race detectors that never report false alarms. The latter typically use expensive vector clock operations that require time linear in the number of program threads. This paper exploits the insight that the full generality of vector clocks is unnecessary in most cases. That is, we can replace heavyweight vector clocks with an adaptive lightweight representation that, for almost all operations of the target program, requires only constant space and supports constant-time operations. This representation change significantly improves time and space performance, with no loss in precision. Experimental results on Java benchmarks including the Eclipse development environment show that our FASTTRACK race detector is an order of magnitude faster than a traditional vector-clock race detector, and roughly twice as fast as the high-performance DJIT(+) algorithm. FASTTRACK is even comparable in speed to ERASER on our Java benchmarks, while never reporting false alarms.
引用
收藏
页码:121 / 133
页数:13
相关论文
共 50 条
  • [31] Precise Dynamic Data Race Prediction for Interrupt-Driven Embedded Software
    Yu, Tingting
    Jia, Chunpeng
    Chen, Rui
    Li, Chao
    Wang, Boxiang
    Jiang, Yunsong
    [J]. 2023 IEEE 34TH INTERNATIONAL SYMPOSIUM ON SOFTWARE RELIABILITY ENGINEERING WORKSHOPS, ISSREW, 2023, : 69 - 74
  • [32] Parallel loop transformation technique for efficient race detection
    Kim, JS
    Han, DS
    Yu, CS
    [J]. PROCEEDINGS OF THE EIGHTH INTERNATIONAL CONFERENCE ON PARALLEL AND DISTRIBUTED SYSTEMS, 2001, : 265 - 272
  • [33] Detection of redundant expressions: A precise, efficient, and pragmatic algorithm in SSA
    Pai, Rekha R.
    [J]. COMPUTER LANGUAGES SYSTEMS & STRUCTURES, 2016, 46 : 167 - 181
  • [34] SafeSpace MFNet: Precise and Efficient MultiFeature Drone Detection Network
    Khan, Misha Urooj
    Dil, Mahnoor
    Alam, Muhammad Zeshan
    Orakazi, Farooq Alam
    Almasoud, Abdullah M.
    Kaleem, Zeeshan
    Yuen, Chau
    [J]. IEEE TRANSACTIONS ON VEHICULAR TECHNOLOGY, 2024, 73 (03) : 3106 - 3118
  • [35] Dynamic detection and prevention of race conditions in file accesses
    Tsyrklevich, E
    Yee, B
    [J]. USENIX ASSOCIATION PROCEEDINGS OF THE 12TH USENIX SECURITY SYMPOSIUM, 2003, : 243 - 255
  • [36] Dynamic Determinacy Race Detection for Task Parallelism with Futures
    Surendran, Rishi
    Sarkar, Vivek
    [J]. RUNTIME VERIFICATION, (RV 2016), 2016, 10012 : 368 - 385
  • [37] BIGFOOT: Static Check Placement for Dynamic Race Detection
    Rhodes, Dustin
    Flanagan, Cormac
    Freund, Stephen N.
    [J]. ACM SIGPLAN NOTICES, 2017, 52 (06) : 141 - 156
  • [38] Precise facial landmark detection by Dynamic Semantic Aggregation Transformer
    Wan, Jun
    Liu, He
    Wu, Yujia
    Lai, Zhihui
    Min, Wenwen
    Liu, Jun
    [J]. PATTERN RECOGNITION, 2024, 156
  • [39] Deterministic Dynamic Race Detection Across Program Versions
    Poluri, Varun
    Ramanathan, Murali Krishna
    [J]. 2015 31ST INTERNATIONAL CONFERENCE ON SOFTWARE MAINTENANCE AND EVOLUTION (ICSME) PROCEEDINGS, 2015, : 181 - 190
  • [40] User-Guided Dynamic Data Race Detection
    Metzger, Markus
    Tian, Xinmin
    Tedeschi, Walfred
    [J]. INTERNATIONAL JOURNAL OF PARALLEL PROGRAMMING, 2015, 43 (02) : 159 - 179