A data-centric framework for debugging highly parallel applications

Minh Ngoc Dinh, David Andrew Abramson, Chao Jin, Andrew Gontarek, Robert Moench, Luiz DeRose

    Research output: Contribution to journalArticleResearchpeer-review

    Abstract

    Contemporary parallel debuggers allow users to control more than one processing thread while supporting the same examination and visualisation operations of that of sequential debuggers. This approach restricts the use of parallel debuggers when it comes to large scale scientific applications run across hundreds of thousands compute cores. First, manually observing the runtime data to detect error becomes impractical because the data is too big. Second, performing expensive but useful debugging operations becomes infeasible as the computational codes become more complex, involving larger data structures, and as the machines become larger. This study explores the idea of a data-centric debugging approach, which could be used to make parallel debuggers more powerful. It discusses the use of ad hoc debug-time assertions that allow a user to reason about the state of a parallel computation. These assertions support the verification and validation of program state at runtime as a whole rather than focusing on that of only a single process state. Furthermore, the debugger s performance can be improved by exploiting the underlying parallel platform because the available compute cores can execute parallel debugging functions, while a program is idling at a breakpoint. We demonstrate the system with several case studies and evaluate the performance of the tool on a 20 000 cores Cray XE6.
    Original languageEnglish
    Pages (from-to)501 - 526
    Number of pages26
    JournalSoftware-Practice & Experience
    Volume45
    Issue number4
    DOIs
    Publication statusPublished - 2015

    Cite this