• DocumentCode
    596079
  • Title

    Efficient predictive analysis for detecting nondeterminism in multi-threaded programs

  • Author

    Sinha, Aloka ; Malik, S. ; Gupta, Arpan

  • Author_Institution
    Princeton Univ., Princeton, NJ, USA
  • fYear
    2012
  • fDate
    22-25 Oct. 2012
  • Firstpage
    6
  • Lastpage
    15
  • Abstract
    Determinism is often a desired property in multithreaded programs. A multi-threaded program is said to be deterministic if for a given input, different thread interleavings result in the same system state in the execution of the program. This, in turn, requires that different interleavings preserve the values read by each read operation. A related, but less strict condition is for the program to be race-free. A deterministic program is race-free but the converse may not be true. There is much work done in the static analysis of programs to detect races and nondeterminism. However, this can be expensive and may not complete for large programs in reasonable time. In contrast to static analysis, predictive analysis techniques take a given program trace and explore other possible interleavings that may violate a given property - in this case the property of interest is determinism. Predictive analysis can be sound, but is not complete as it is limited to a specific set of program runs. Nonetheless, it is of interest as it offers greater scalability than static analysis. This work presents a predictive analysis method for detecting nondeterminism in multi-threaded programs. Potential cases of nondeterminism are checked by constructing a causality graph from the thread events and confirming that it is acyclic. On average, the number of graphs analyzed per benchamrk is one per potential case of nondeterminism, thereby ensuring that it is efficient. We demonstrate its application on some benchmark Java and C/C++ programs.
  • Keywords
    C++ language; Java; causality; graph theory; multi-threading; program diagnostics; C/C++ program; Java program; causality graph; deterministic program; multithreaded program; nondeterminism detection; predictive analysis; program execution; program trace; race detection; read operation; static analysis; thread event; thread interleavings; Abstracts; Benchmark testing; Context; Design automation; Image edge detection; Instruction sets; Synchronization;
  • fLanguage
    English
  • Publisher
    ieee
  • Conference_Titel
    Formal Methods in Computer-Aided Design (FMCAD), 2012
  • Conference_Location
    Cambridge
  • Print_ISBN
    978-1-4673-4832-4
  • Type

    conf

  • Filename
    6462550