OMPRacer: A Scalable and Precise Static Race Detector for OpenMP Programs

被引:11
|
作者
Swain, Bradley [1 ,3 ]
Li, Yanze [1 ]
Liu, Peiming [1 ]
Laguna, Ignacio [2 ]
Georgakoudis, Giorgis [2 ]
Huang, Jeff [1 ]
机构
[1] Texas A&M Univ, Comp Sci & Engn, College Stn, TX 77843 USA
[2] Lawrence Livermore Natl Lab, Ctr Appl Sci Comp, Livermore, CA 94550 USA
[3] Coderrect Inc, College Stn, TX USA
关键词
OpenMP; Data race detection; Static analysis; Rug detection; Nondeterminism; ALIAS ANALYSIS;
D O I
10.1109/SC41405.2020.00058
中图分类号
TP [自动化技术、计算机技术];
学科分类号
0812 ;
摘要
We present OMPRAcER, a static tool that uses flow-sensitive, interprocedural analysis to detect data races in OpenMP programs. OMPRAcER is fast, scalable, has high code coverage, and supports the most common OpenMP features by combining state-of-the-art pointer analysis, novel value-flow analysis, happens-before tracking, and generalized modelling of OpenMP APIs. Unlike dynamic tools that currently dominate data race detection, OMPRAcER achieves almost 100% code coverage using static analysis to detect a broader category of races without running the program or relying on specific input or runtime behaviour. OMPRAcER has competitive precision with dynamic tools like Archer and ROMP: passing 105/116 cases in DataRacellench with a total accuracy of 91%. OMPRAcER has been used to analyze several Exascale Computing Project proxy applications containing over 2 million lines of code in under 10 minutes. OMPRAcER has revealed previously unknown races in an ECP proxy app and a production simulation for COVID19.
引用
收藏
页数:14
相关论文
共 50 条
  • [1] MagicDetector: A Precise and Scalable Static Deadlock Detector for C/C++ Programs
    Huaxiong Cao
    Naijie Gu
    Yunkai Du
    [J]. Arabian Journal for Science and Engineering, 2016, 41 : 5149 - 5167
  • [2] Towards Incremental Static Race Detection in OpenMP Programs
    Swain, Bradley
    Huang, Jeff
    [J]. PROCEEDINGS OF CORRECTNESS 2018: 2ND IEEE/ACM INTERNATIONAL WORKSHOP ON SOFTWARE CORRECTNESS FOR HPC APPLICATIONS, 2018, : 33 - 41
  • [3] MagicDetector: A Precise and Scalable Static Deadlock Detector for C/C plus plus Programs
    Cao, Huaxiong
    Gu, Naijie
    Du, Yunkai
    [J]. ARABIAN JOURNAL FOR SCIENCE AND ENGINEERING, 2016, 41 (12) : 5149 - 5167
  • [4] LLOV: A Fast Static Data-Race Checker for OpenMP Programs
    Bora, Utpal
    Das, Santanu
    Kukreja, Pankaj
    Joshi, Saurabh
    Upadrasta, Ramakrishna
    Rajopadhye, Sanjay
    [J]. ACM TRANSACTIONS ON ARCHITECTURE AND CODE OPTIMIZATION, 2020, 17 (04)
  • [5] Static nonconcurrency analysis of OpenMP programs
    Lin, Yuan
    [J]. OPENMP SHARED MEMORY PARALLEL PROGRAMMING, PROCEEDINGS, 2008, 4315 : 36 - 50
  • [6] Dynamic Data Race Detection for OpenMP Programs
    Gu, Yizi
    Mellor-Crummey, John
    [J]. PROCEEDINGS OF THE INTERNATIONAL CONFERENCE FOR HIGH PERFORMANCE COMPUTING, NETWORKING, STORAGE, AND ANALYSIS (SC'18), 2018,
  • [7] Static detection of deadlocks in OpenMP Fortran programs
    School of Computer Science, National University of Defense Technology, Changsha 410073, China
    [J]. Jisuanji Yanjiu yu Fazhan, 2007, 3 (536-543):
  • [8] Efficient race verification for debugging programs with OpenMP directives
    Kim, Young-Joo
    Kang, Mun-Hye
    Ha, Ok-Kyoon
    Jun, Yong-Kee
    [J]. PARALLEL COMPUTING TECHNOLOGIES, PROCEEDINGS, 2007, 4671 : 230 - 239
  • [9] Empirical Comparison of Race Detection Tools for OpenMP Programs
    Ha, Ok-Kyoon
    Kim, Young-Joo
    Kang, Mun-Hye
    Jun, Yong-Kee
    [J]. GRID AND DISTRIBUTED COMPUTING, 2009, 63 : 108 - +
  • [10] Scalable thread visualization for debugging data races in OpenMP programs
    Kim, Young-Joc
    Lim, Jae-Seon
    Jun, Yong-Kee
    [J]. ADVANCES IN GRID AND PERVASIVE COMPUTING, PROCEEDINGS, 2007, 4459 : 310 - +