CURD: A Dynamic CUDA Race Detector

被引:0
|
作者
Peng, Yuanfeng [1 ]
Grover, Vinod [2 ]
Devietti, Joseph [1 ]
机构
[1] Univ Penn, Philadelphia, PA 19104 USA
[2] NVIDIA, Santa Clara, CA USA
关键词
data race detection; GPUs; Nvidia CUDA; GPU; VERIFICATION; ABSTRACTION; DESIGN;
D O I
暂无
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
As GPUs have become an integral part of nearly every processor, GPU programming has become increasingly popular. GPU programming requires a combination of extreme levels of parallelism and low-level programming, making it easy for concurrency bugs such as data races to arise. These concurrency bugs can be extremely subtle and difficult to debug due to the massive numbers of threads running concurrently on a modern GPU. While some tools exist to detect data races in GPU programs, they are often prohibitively slow or focused only on a small class of data races in shared memory. Compared to prior work, our race detector, CURD, can detect data races precisely on both shared and global memory, selects an appropriate race detection algorithm based on the synchronization used in a program, and utilizes efficient compiler instrumentation to reduce performance overheads. Across 53 benchmarks, we find that using CURD incurs an average slowdown of just 2.88x over native execution. CURD is 2.1x faster than Nvidia's CUDA-Racecheck race detector, despite detecting a much broader class of races. CURD finds 35 races across our benchmarks, including bugs in established benchmark suites and in sample programs from Nvidia.
引用
收藏
页码:390 / 403
页数:14
相关论文
共 50 条
  • [1] CURD: A Dynamic CUDA Race Detector
    Peng, Yuanfeng
    Grover, Vinod
    Devietti, Joseph
    [J]. PROCEEDINGS OF THE 39TH ACM SIGPLAN CONFERENCE ON PROGRAMMING LANGUAGE DESIGN AND IMPLEMENTATION, PLDI 2018, 2018, : 390 - 403
  • [2] CURD: A dynamic CUDA race detector
    Peng Y.
    Grover V.
    Devietti J.
    [J]. ACM SIGPLAN Notices, 2018, 53 (04): : 390 - 403
  • [3] Helgrind+: An Efficient Dynamic Race Detector
    Jannesari, Ali
    Bao, Kalbin
    Pankratius, Victor
    Tichy, Walter F.
    [J]. 2009 IEEE INTERNATIONAL SYMPOSIUM ON PARALLEL & DISTRIBUTED PROCESSING, VOLS 1-5, 2009, : 176 - 188
  • [4] Eraser: A dynamic data race detector for multithreaded programs
    Savage, S
    Burrows, M
    Nelson, G
    Sobalvarro, P
    Anderson, T
    [J]. ACM TRANSACTIONS ON COMPUTER SYSTEMS, 1997, 15 (04): : 391 - 411
  • [5] A dynamic predictive race detector for C/C++ programs
    Peng Luo
    Deqing Zou
    Hai Jin
    Yajuan Du
    Jinan Shen
    [J]. The Journal of Supercomputing, 2017, 73 : 3999 - 4019
  • [6] DYNAMIC RHEOLOGY OF RENNET CURD
    DEJMEK, P
    [J]. JOURNAL OF DAIRY SCIENCE, 1987, 70 (07) : 1325 - 1330
  • [7] A dynamic predictive race detector for C/C plus plus programs
    Luo, Peng
    Zou, Deqing
    Jin, Hai
    Du, Yajuan
    Shen, Jinan
    [J]. JOURNAL OF SUPERCOMPUTING, 2017, 73 (09): : 3999 - 4019
  • [8] VERIFIEDFT: A Verified, High-Performance Precise Dynamic Race Detector
    Wilcox, James R.
    Flanagan, Cormac
    Freund, Stephen N.
    [J]. ACM SIGPLAN NOTICES, 2018, 53 (01) : 354 - 367
  • [9] A one-dimensional dynamic model of curd syneresis based on viscoelastic properties of curd
    Castillo, M.
    Torrealba, S.
    Payne, F.
    [J]. JOURNAL OF ANIMAL SCIENCE, 2005, 83 : 15 - 16
  • [10] A one-dimensional dynamic model of curd syneresis based on viscoelastic properties of curd
    Castillo, M.
    Torrealba, S.
    Payne, F.
    [J]. JOURNAL OF DAIRY SCIENCE, 2005, 88 : 15 - 16