PAPI software-defined events for in-depth performance analysis
Autor: | Jack Dongarra, Anthony Danalis, Heike Jagode, Hartwig Anzt |
---|---|
Rok vydání: | 2019 |
Předmět: |
Profiling (computer programming)
020203 distributed computing Standardization Application programming interface business.industry Computer science 02 engineering and technology Theoretical Computer Science Software Hardware and Architecture 0202 electrical engineering electronic engineering information engineering Software engineering business |
Zdroj: | The International Journal of High Performance Computing Applications. 33:1113-1127 |
ISSN: | 1741-2846 1094-3420 |
DOI: | 10.1177/1094342019846287 |
Popis: | The methodology and standardization layer provided by the Performance Application Programming Interface (PAPI) has played a vital role in application profiling for almost two decades. It has enabled sophisticated performance analysis tool designers and performance-conscious scientists to gain insights into their applications by simply instrumenting their code using a handful of PAPI functions that “just work” across different hardware components. In the past, PAPI development had focused primarily on hardware-specific performance metrics. However, the rapidly increasing complexity of software infrastructure poses new measurement and analysis challenges for the developers of large-scale applications. In particular, acquiring information regarding the behavior of libraries and runtimes—used by scientific applications—requires low-level binary instrumentation, or APIs specific to each library and runtime. No uniform API for monitoring events that originate from inside the software stack has emerged. In this article, we present our efforts to extend PAPI’s role so that it becomes the de facto standard for exposing performance-critical events, which we refer to as software-defined events (SDEs), from different software layers. Upgrading PAPI with SDEs enables monitoring of both types of performance events—hardware- and software-related events—in a uniform way, through the same consistent PAPI. The goal of this article is threefold. First, we motivate the need for SDEs and describe our design decisions regarding the functionality we offer through PAPI’s new SDE interface. Second, we illustrate how SDEs can be utilized by different software packages, specifically, by showcasing their use in the numerical linear algebra library MAGMA-Sparse, the tensor algebra library TAMM that is part of the NWChem suite, and the compiler-based performance analysis tool Byfl. Third, we provide a performance analysis of the overhead that results from monitoring SDEs and discuss the trade-offs between overhead and functionality. |
Databáze: | OpenAIRE |
Externí odkaz: |